[
    {
        "tags": [
            "arrays",
            "json",
            "string",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1603992134,
                "creation_date": 1603992134,
                "answer_id": 64596179,
                "question_id": 64596104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not familiar with `jq`, but if you just replace every `&quot;,&quot;` with `,`, it does the trick. It&#39;s a hack, so it could break if the input data changes format.\r\n\r\n```\r\n$ cat temp.txt \r\ndrop_reasons=[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n\r\n$ perl -pe &#39;s/&quot;,&quot;/,/g&#39; temp.txt\r\ndrop_reasons=[&quot;a,b,c&quot;]\r\n\r\n```",
                "title": "Transform array to string using jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1603992982,
                "last_edit_date": 1603992982,
                "creation_date": 1603992215,
                "answer_id": 64596209,
                "question_id": 64596104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a pared-down sample JSON object with just the relevant key:\r\n\r\n```sh\r\n$ cat test.json\r\n{\r\n    &quot;drop_reasons&quot;: [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n}\r\n$ jq &#39;.drop_reasons |= join(&quot;,&quot;)&#39; test.json\r\n{\r\n  &quot;drop_reasons&quot;: &quot;a,b,c&quot;\r\n}\r\n```\r\n\r\nYour sample with an empty array would change to an empty string.\r\n\r\n---\r\n\r\n`x |= y` is essentially shorthand for `x = (x | y)`. The parens are what you were missing in your attempt; they&#39;re needed because of `jq` precedence rules.",
                "title": "Transform array to string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1603992982,
        "creation_date": 1603991767,
        "last_edit_date": 1603992600,
        "question_id": 64596104,
        "body_markdown": "I have a json with a reasons array in the format `[]` or `[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]`. Basically i want to replace \r\n`drop_reasons=[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]` in json to `drop_reasons=&quot;a,b,c&quot;` . I know we can use `join(&quot;,&quot;)` for this with jq .However , don&#39;t know how to modify it in the json . \r\n\r\nI have tried this - ` cat test.json | jq &#39; .drop_reasons = .drop_reasons | join(&quot;,&quot;) &#39; | sponge test.json`\r\n, but doesn&#39;t see, to work , it tries to join the entire json rather than just drop_reasons. How do i tackle it ? Any help will be appreciated. Thanks\r\n\r\nSample json is :\r\n\r\n    {&quot;id&quot;:11828997,&quot;user&quot;:&quot;8ddbceef-c374-44be-82f6-996b9d3f9cbd&quot;,&quot;timestamp&quot;:&quot;2020-08-12T05:50:00+05:30&quot;,&quot;claim_timestamp&quot;:&quot;2020-08-12T20:30:58+05:30&quot;,&quot;unique_key&quot;:&quot;d56af2a7-10b8-4a98-b12c-a8aeab9fc56e&quot;,&quot;platform&quot;:&quot;android&quot;,&quot;location_type&quot;:&quot;indoor&quot;,&quot;activity_type&quot;:&quot;unknown&quot;,&quot;activity_confidence&quot;:0,&quot;total_day_steps&quot;:151744,&quot;gf_total_steps&quot;:0,&quot;step_count&quot;:122,&quot;session_id&quot;:&quot;1792b79c-1490-4b13-83e2-3c50ebce28f4&quot;,&quot;label&quot;:&quot;indoor&quot;,&quot;is_claimed&quot;:false,&quot;is_dropped&quot;:false,&quot;drop_reasons&quot;:[],&quot;is_valid&quot;:false,&quot;invalid_reason&quot;:[&quot;steps&gt;allowed_freq&quot;],&quot;conversion&quot;:null,&quot;createdAt&quot;:&quot;2020-08-12T20:30:58.385285+05:30&quot;,&quot;updatedAt&quot;:&quot;2020-08-12T20:30:58.385285+05:30&quot;,&quot;location_uuid&quot;:null,&quot;location_latitude&quot;:28.6673,&quot;location_longitude&quot;:77.3915,&quot;location_accuracy&quot;:1000,&quot;location_speed&quot;:0,&quot;location_timestamp&quot;:&quot;2020-08-12T05:46:40+05:30&quot;,&quot;location_altitude&quot;:0,&quot;location_ios_distance_filler&quot;:null,&quot;location_ios_desired_accuracy&quot;:null,&quot;location_distance_filter&quot;:0,&quot;location_desired_accuracy&quot;:0,&quot;location_course&quot;:0,&quot;location_floor&quot;:null,&quot;meta_data_geo_string&quot;:&quot;28.6672867,77.3914746&quot;,&quot;meta_data_timezone&quot;:&quot;Asia/Kolkata&quot;,&quot;meta_data_device_model&quot;:&quot;Redmi Note 8 Pro&quot;,&quot;meta_data_device_brand&quot;:&quot;redmi&quot;,&quot;meta_data_device_manufacturer&quot;:&quot;xiaomi&quot;,&quot;meta_data_app_version&quot;:&quot;0.9.31&quot;,&quot;meta_data_bundle_id&quot;:&quot;com.pepkit.ssg&quot;,&quot;meta_data_build_no&quot;:&quot;213&quot;,&quot;meta_data_plan_id&quot;:&quot;a562ad72-54a9-4aea-941c-7f075e2a8b18&quot;}\r\n",
        "link": "https://stackoverflow.com/questions/64596104/transform-array-to-string-using-jq",
        "title": "Transform array to string using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "formatting",
            "jq",
            "quotation-marks"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3014400,
                    "reputation": 180,
                    "user_id": 2557000,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OU6Lu.jpg?s=256",
                    "display_name": "paq",
                    "link": "https://stackoverflow.com/users/2557000/paq"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1604043624,
                "post_id": 64601031,
                "comment_id": 114231989,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1604037494,
                "last_edit_date": 1604037494,
                "creation_date": 1604021038,
                "answer_id": 64601499,
                "question_id": 64601031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are four alternatives that should work with a bash or bash-like shell. They can be adapted for other shells as well.\r\n```\r\njq -n $&#39;[{&quot;command&quot;: [&quot;printf \\&#39;this is a text\\&#39;&quot;]}]&#39;\r\n```\r\n```\r\ncat &lt;&lt; EOF | jq .\r\n[{&quot;command&quot;: [&quot;printf &#39;this is a text&#39;&quot;]}]\r\nEOF\r\n```\r\n```\r\njq --arg cmd &quot;printf &#39;this is a text&#39;&quot; -n &#39;[{command: [ $cmd ]}]&#39;\r\n```\r\n```\r\nVAR=&quot;[{\\&quot;command\\&quot;: [\\&quot;printf &#39;this is a text&#39;\\&quot;]}]&quot;\r\njq -n --argjson var &quot;$VAR&quot; &#39;$var&#39;\r\n```\r\n\r\nSee also https://stackoverflow.com/questions/1250079/how-to-escape-single-quotes-within-single-quoted-strings",
                "title": "how to escape single quote in `jq`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1604043457,
        "creation_date": 1604017084,
        "last_edit_date": 1604043457,
        "question_id": 64601031,
        "body_markdown": "I am trying to format a json string using `jq` with expected output like this:\r\n```\r\n[\r\n  {\r\n    &quot;command&quot;: [\r\n      &quot;printf &#39;this is a text&#39;&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nHowever, I cannot get it to work for the single quotes (&#39;), e.g. `$  jq -n &#39;[{&quot;command&quot;: [&quot;printf &#39;this is a text&#39;&quot;]}]&#39;` gives me a compile error.\r\n\r\nI also thought about escaping all double quotes e.g. `jq -n &quot;[{\\&quot;command\\&quot;: [\\&quot;printf &#39;this is a text&#39;\\&quot;]}]&quot;`, this is fine however the json string is passed in from a function, I can replace all double quotes with `\\&quot;` first and then run the jq command but it&#39;s not very elegant.\r\n\r\nIs there a better way to handle the single quotes inside a json string?",
        "link": "https://stackoverflow.com/questions/64601031/how-to-escape-single-quote-in-jq",
        "title": "how to escape single quote in `jq`"
    },
    {
        "tags": [
            "python",
            "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": 0,
                "creation_date": 1604019216,
                "post_id": 64601197,
                "comment_id": 114227113,
                "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": 1604021886,
                "post_id": 64601197,
                "comment_id": 114227579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604033590,
                "last_edit_date": 1604033590,
                "creation_date": 1604021762,
                "answer_id": 64601584,
                "question_id": 64601197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s start with the lines of text in the problem description:\r\n```\r\n192.168.1.2\r\n192.168.1.3\r\n192.168.1.5\r\n192.168.1.6\r\n192.168.1.7\r\n```\r\n\r\nIf count=0, then if you pipe these lines into this variant of your jq program:\r\n\r\n    jq -nR --arg stat fails --arg count $count  &#39;\r\n      [{$stat,$count},\r\n       {liststat: &quot;topips&quot;,\r\n        items: [inputs]}]&#39;\r\n\r\nyou would get the output shown below.  You should be able to modify this example in accordance with your requirements. Chances are you could achieve the desired output efficiently using jq alone (i.e., without any of the intermediate steps shown in the Q). \r\n\r\n## Output\r\n```\r\n[\r\n  {\r\n    &quot;stat&quot;: &quot;fails&quot;,\r\n    &quot;count&quot;: &quot;0&quot;\r\n  },\r\n  {\r\n    &quot;liststat&quot;: &quot;topips&quot;,\r\n    &quot;items&quot;: [\r\n      &quot;192.168.1.2&quot;,\r\n      &quot;192.168.1.3&quot;,\r\n      &quot;192.168.1.5&quot;,\r\n      &quot;192.168.1.6&quot;,\r\n      &quot;192.168.1.7&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n",
                "title": "How can I transform lines of values for jq to JSON output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604033590,
        "creation_date": 1604018342,
        "question_id": 64601197,
        "body_markdown": "I have this getting the top IPs from my webserver. Trying to return a JSON object seen at the bottom of this. Is there an easy conversion to lines to the format jq needs to create a string array? \r\n\r\n\r\n```\r\nips=$(cat /var/log/nginx/access.log | cut -d&#39; &#39; -f1 | sort | uniq -c | sort -nr | head -n 5 | cut -d&#39; &#39; -f8)\r\n```\r\n\r\nResults in:\r\n```\r\n192.168.1.2\r\n192.168.1.3\r\n192.168.1.5\r\n192.168.1.6\r\n192.168.1.7\r\n```\r\n\r\n\r\nMy expected output is:\r\n\r\n```\r\n&quot;192.168.1.2&quot; &quot;192.168.1.3&quot; &quot;192.168.1.5&quot; &quot;192.168.1.6&quot; &quot;192.168.1.7&quot;\r\n```\r\n\r\nI may be going about this in a long way. What I have is this output going into a jq for a json file with some other values. \r\n\r\n\r\nThe single values work fine but parsing the list of topipsis where I am having trouble.\r\n```\r\njq -n --arg stat fails --arg count $count  &#39;[{&quot;stat&quot;:$stat,&quot;count&quot;: $count},{&quot;liststat&quot;: &quot;topips&quot;,items: $ARGS.positional }]&#39; --args ${ips[@]}\r\n```\r\n\r\n\r\n\r\nExpected result something like this:\r\n\r\n```\r\n{\r\n&quot;topip&quot;: [&quot;10.10.20.9&quot;,&quot;10.10.10.24&quot;,&quot;10.10.10.26&quot;,&quot;10.10.10.28&quot;,&quot;10.10.10.121&quot;,&quot;192.168.1.152&quot;,&quot;172.169.10.21&quot;,&quot;112.10.10.2&quot;,&quot;10.10.10.21&quot;,&quot;10.10.10.21&quot;],\r\n&quot;logins&quot;:66,\r\n&quot;visits&quot;:75,\r\n&quot;errors&quot;:1759\r\n}\r\n```\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64601197/how-can-i-transform-lines-of-values-for-jq-to-json-output",
        "title": "How can I transform lines of values for jq to JSON output?"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1604051236,
                "creation_date": 1604051236,
                "answer_id": 64605999,
                "question_id": 64605920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add objects together to combine their contents. If a key exists in both the left and right objects the value from the right object will remain.\r\n```\r\necho &#39;{&quot;a&quot;: {&quot;a1&quot;:1, &quot;a2&quot;: 2}, &quot;b&quot;: 3}&#39; | jq &#39;.a+{b}&#39;\r\n{\r\n  &quot;a1&quot;: 1,\r\n  &quot;a2&quot;: 2,\r\n  &quot;b&quot;: 3\r\n}\r\n```",
                "title": "How can I spread an object&#39;s properties in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604065958,
                "last_edit_date": 1604065958,
                "creation_date": 1604062096,
                "answer_id": 64608669,
                "question_id": 64605920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want a completely generic solution:\r\n```\r\n[..|objects|with_entries(select(.value|type!=&quot;object&quot;))]|add\r\n```\r\n\r\nOr if you want a depth-first approach, replace `add` by `reverse|add`.\r\n\r\nThe above of course comes with the understanding that `add` resolves conflicts in a lossy way. If you don’t want any lossiness, choose a different method for combining objects, or maybe don’t combine them at all.",
                "title": "How can I spread an object&#39;s properties in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604090751,
                "last_edit_date": 1604090751,
                "creation_date": 1604089116,
                "answer_id": 64615234,
                "question_id": 64605920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that only examines the top-level values, without referring to any key by name:\r\n```\r\nwith_entries(if .value|type==&quot;object&quot; then .value|to_entries[] else . end)\r\n```\r\nFor the example, this produces:\r\n```\r\n{\r\n  &quot;a1&quot;: 1,\r\n  &quot;a2&quot;: 2,\r\n  &quot;b&quot;: 3\r\n}\r\n```\r\n\r\nNote that even though this solution doesn&#39;t use `add` explicitly, it comes with a similar caveat about key collisions.",
                "title": "How can I spread an object&#39;s properties in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1604090751,
        "creation_date": 1604050920,
        "last_edit_date": 1604062340,
        "question_id": 64605920,
        "body_markdown": "If I need to access the properties of an object, I&#39;m currently accessing each property manually:\r\n\r\n```\r\necho &#39;{&quot;a&quot;: {&quot;a1&quot;:1, &quot;a2&quot;: 2}, &quot;b&quot;: 3}&#39; | jq &#39;{a1:.a.a1, a2: .a.a2,b}&#39;\r\n{\r\n  &quot;a1&quot;: 1,\r\n  &quot;a2&quot;: 2,\r\n  &quot;b&quot;: 3\r\n}\r\n```\r\n\r\nI&#39;d like to avoid specifying every property. Is there an equivalent to the Object spread operator in JS, something like `jq &#39;{...a, b}&#39;`?\r\n",
        "link": "https://stackoverflow.com/questions/64605920/how-can-i-spread-an-objects-properties-in-jq",
        "title": "How can I spread an object&#39;s properties in jq?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604100602,
                "post_id": 64614241,
                "comment_id": 114254058,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604085036,
                "last_edit_date": 1604085036,
                "creation_date": 1604084485,
                "answer_id": 64614295,
                "question_id": 64614241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You almost got it right, but need the object value iterator construct, `.[]` to get the value corresponding to the key\r\n\r\n    .facts | keys_unsorted[] as $k | .[$k].stuff\r\n\r\nThis assumes that, inside `facts` you have one object containing the IP address as the key and you want to extract `.stuff` from it.\r\n\r\nOptionally, to guard against objects that don&#39;t contain `stuff` inside, you could add `?` as `.[$k].stuff?`. And also you could optionally validate keys against a valid IP regex condition and filter values only for those keys.",
                "title": "JSON: using jq with variable keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604158949,
        "creation_date": 1604084191,
        "last_edit_date": 1604158949,
        "question_id": 64614241,
        "body_markdown": "I have input JSON data in a bunch of files, with an IP address as one of the keys. I need to iterate over a the files, and I need to get &quot;stuff&quot; out of them. The IP address is different for each file, but I&#39;d like to use a single jq command to get the data. I have tried a bunch of things, the closest I&#39;ve come is this:\r\n\r\n```\r\njq &#39;.facts | keys | keys as $ip | .[0]&#39; a_file\r\n```\r\n\r\nOn my input in _a_file_ of:\r\n\r\n```\r\n{\r\n    &quot;facts&quot;: {\r\n       &quot;1.1.1.1&quot;: {\r\n            &quot;stuff&quot;:&quot;value&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nit returns the IP address, i.e. `1.1.1.1`, but then how do I to go back do something like this (which is obviously wrong, but I hope you get the idea):\r\n```\r\njq &#39;.facts.$ip[0].stuff&#39; a_file\r\n```\r\nIn my mind I&#39;m trying to populate a variable, and then use the value of that variable to rewind the input and scan it again.\r\n\r\n=== EDIT ===\r\nNote that my input was actually more like this:\r\n\r\n```\r\n{\r\n    &quot;facts&quot;: {\r\n       &quot;1.1.1.1&quot;: {\r\n            &quot;stuff&quot;: {\r\n                &quot;thing1&quot;:&quot;value1&quot;\r\n            }\r\n        },\r\n        &quot;outer_thing&quot;: &quot;outer_value&quot;\r\n    }\r\n}\r\n```\r\n\r\nSo I got an error:\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:9): Cannot index string with string &quot;stuff&quot;\r\n```\r\n\r\nThis fixed it- the question mark after `.stuff`:\r\n```\r\n.facts | keys_unsorted[] as $k | .[$k].stuff?\r\n```",
        "link": "https://stackoverflow.com/questions/64614241/json-using-jq-with-variable-keys",
        "title": "JSON: using jq with variable keys"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604135151,
                "creation_date": 1604135151,
                "answer_id": 64620070,
                "question_id": 64618513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the jq FAQ:\r\n\r\n&gt; The encoding of the file might not be valid for JSON text, which is defined as a sequence of Unicode code points. jq currently requires the text be encoded as UTF-8 (and therefore allows ASCII). Note that the default encoding used in PowerShell when redirecting terminal output to a file is UTF-16. If you need to convert from one encoding to another, consider using iconv, or if you are using Windows, try pasting your JSON into Notepad and saving the file as a UTF-8 file.",
                "title": "Parsing Maxmind JSON with jq (or python3)?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604136119,
                "last_edit_date": 1604136119,
                "creation_date": 1604135542,
                "answer_id": 64620127,
                "question_id": 64618513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Once you’ve sorted out the encoding issues, you might want to consider:\r\n\r\n    .. | .iso_code? // empty\r\n\r\nor if you just want the distinct answers:\r\n\r\n    [.. | .iso_code? // empty] | unique[]\r\n\r\nSee also https://jqplay.org/s/mv9aO0DTqd",
                "title": "Parsing Maxmind JSON with jq (or python3)?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1604136119,
        "creation_date": 1604119636,
        "question_id": 64618513,
        "body_markdown": "I have been experimenting with jq but cannot parse out the iso_code value in the output from the Maxmind beta application [mmdbinspect][1] which is JSON output.\r\n\r\nI get a &#39;Cannot index array with string&#39; error message no matter what I tried. ie. jq -r .&#39;Database&#39;\r\n\r\n\r\n    {\r\n          &quot;Database&quot;: &quot;/usr/local/var/GeoIP/GeoLite2-City.mmdb&quot;,\r\n          &quot;Records&quot;: [\r\n            {\r\n              &quot;Network&quot;: &quot;8.8.8.8/17&quot;,\r\n              &quot;Record&quot;: {\r\n                &quot;continent&quot;: {\r\n                  &quot;code&quot;: &quot;NA&quot;,\r\n                  &quot;geoname_id&quot;: 6255149,\r\n                  &quot;names&quot;: {\r\n                    &quot;de&quot;: &quot;Nordamerika&quot;,\r\n                    &quot;en&quot;: &quot;North America&quot;,\r\n                    &quot;es&quot;: &quot;Norteam&#233;rica&quot;,\r\n                    &quot;fr&quot;: &quot;Am&#233;rique du Nord&quot;,\r\n                    &quot;ja&quot;: &quot;北アメリカ&quot;,\r\n                    &quot;pt-BR&quot;: &quot;Am&#233;rica do Norte&quot;,\r\n                    &quot;ru&quot;: &quot;Северная Америка&quot;,\r\n                    &quot;zh-CN&quot;: &quot;北美洲&quot;\r\n                  }\r\n                },\r\n                &quot;country&quot;: {\r\n                  &quot;geoname_id&quot;: 6252001,\r\n                  &quot;iso_code&quot;: &quot;US&quot;,\r\n                  &quot;names&quot;: {\r\n                    &quot;de&quot;: &quot;USA&quot;,\r\n                    &quot;en&quot;: &quot;United States&quot;,\r\n                    &quot;es&quot;: &quot;Estados Unidos&quot;,\r\n                    &quot;fr&quot;: &quot;&#201;tats-Unis&quot;,\r\n                    &quot;ja&quot;: &quot;アメリカ合衆国&quot;,\r\n                    &quot;pt-BR&quot;: &quot;Estados Unidos&quot;,\r\n                    &quot;ru&quot;: &quot;США&quot;,\r\n                    &quot;zh-CN&quot;: &quot;美国&quot;\r\n                  }\r\n                },\r\n                &quot;location&quot;: {\r\n                  &quot;accuracy_radius&quot;: 1000,\r\n                  &quot;latitude&quot;: 37.751,\r\n                  &quot;longitude&quot;: -97.822,\r\n                  &quot;time_zone&quot;: &quot;America/Chicago&quot;\r\n                },\r\n                &quot;registered_country&quot;: {\r\n                  &quot;geoname_id&quot;: 6252001,\r\n                  &quot;iso_code&quot;: &quot;US&quot;,\r\n                  &quot;names&quot;: {\r\n                    &quot;de&quot;: &quot;USA&quot;,\r\n                    &quot;en&quot;: &quot;United States&quot;,\r\n                    &quot;es&quot;: &quot;Estados Unidos&quot;,\r\n                    &quot;fr&quot;: &quot;&#201;tats-Unis&quot;,\r\n                    &quot;ja&quot;: &quot;アメリカ合衆国&quot;,\r\n                    &quot;pt-BR&quot;: &quot;Estados Unidos&quot;,\r\n                    &quot;ru&quot;: &quot;США&quot;,\r\n                    &quot;zh-CN&quot;: &quot;美国&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          ],\r\n          &quot;Lookup&quot;: &quot;8.8.8.8&quot;\r\n        }\r\n\r\n\r\nReferring this this [post][2], do I need to flatting out the JSON output first?\r\n\r\nMaybe Python3 instead of using jq which be easier...\r\n\r\n\r\n  [1]: https://github.com/maxmind/mmdbinspect/\r\n  [2]: https://stackoverflow.com/questions/52125879/jq-cannot-index-array-with-string-id",
        "link": "https://stackoverflow.com/questions/64618513/parsing-maxmind-json-with-jq-or-python3",
        "title": "Parsing Maxmind JSON with jq (or python3)?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1604224050,
                "last_edit_date": 1604224050,
                "creation_date": 1604158275,
                "answer_id": 64623386,
                "question_id": 64623254,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq 1.5 or later, with your input (i.e., a stream of JSON objects) and\r\n\r\n    colors=(&quot;Blue&quot; &quot;Red&quot; &quot;Green&quot; &quot;Blue&quot;)\r\n\r\nthe following produces an array of the desired JSON objects:\r\n```\r\njq -s &#39;\r\n  ($ARGS.positional | map({Colors: .})) as $colors\r\n  | [., $colors] | transpose | map(add)\r\n&#39; --args &quot;${colors[@]}&quot;\r\n```\r\n\r\nIf you want the result to be a stream of the JSON objects, you could tack on `[]` or\r\nchange `transpose | map(add)` to `transpose[] | add`\r\n\r\n## Caveats\r\n(1) The above solution will work even if some colors have spaces in their names, but in general it may be necessary to pass in the contents of the array using some other mechanism.\r\n\r\n(2) If your jq does not support positional parameters (--args), now may be a good time to upgrade; if that is not an option, you could devise a workaround, e.g. using the --argfile option if your jq supports that.",
                "title": "How to add a bash array into the fields of a JSON array using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604200522,
                "last_edit_date": 1604200522,
                "creation_date": 1604198971,
                "answer_id": 64628248,
                "question_id": 64623254,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that has been tested with versions of jq from 1.4 onwards:\r\n\r\n```  \r\njq -R -s --argfile json &lt;(echo &quot;$items&quot;) &#39;\r\n  (split(&quot;\\n&quot;) | map(select(length&gt;0))) as $colors\r\n  | [ range(0; $colors|length) | $json[.] + {Colors: $colors[.]} ]\r\n&#39; &lt;( printf &quot;%s\\n&quot; &quot;${colors[@]}&quot; )\r\n```\r\n\r\nThe subtlety here is that ``-argfile`` will combine the stream of JSON objects into a single array.",
                "title": "How to add a bash array into the fields of a JSON array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1604224050,
        "creation_date": 1604157400,
        "question_id": 64623254,
        "body_markdown": "I currently have the following JSON output from `echo $items | jq`:\r\n\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 1&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;335&quot;\r\n    }\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 2&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;215&quot;\r\n    }\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 9&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;159&quot;\r\n    }\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 4&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;500&quot;\r\n    }\r\n\r\n\r\nI also have a bash array `colors` of the same size looking like \r\n\r\n    &quot;Blue&quot; &quot;Red&quot; &quot;Green&quot; &quot;Blue&quot;\r\n\r\nHow can I use `jq` so that I get something like\r\n\r\n \r\n\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 1&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;335&quot;,\r\n      &quot;Colors&quot;: &quot;Blue&quot;\r\n    }\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 2&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;215&quot;,\r\n      &quot;Colors&quot;: &quot;Red&quot;\r\n    }\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 9&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;159&quot;,\r\n      &quot;Colors&quot;: &quot;Green&quot;\r\n    }\r\n    {\r\n      &quot;Family_Name&quot;: &quot;Type 4&quot;,\r\n      &quot;Quantity_On_Hand&quot;: &quot;500&quot;,\r\n      &quot;Colors&quot;: &quot;Blue&quot;\r\n    }\r\n\r\nI tried using something like `jq --arg` or `jq -n &#39;.{} |= [$colors]&#39;` but cannot get it correct.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64623254/how-to-add-a-bash-array-into-the-fields-of-a-json-array-using-jq",
        "title": "How to add a bash array into the fields of a JSON array using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604250154,
                "creation_date": 1604250154,
                "answer_id": 64634549,
                "question_id": 64633716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple addition to your already well made attempt is all you need. Replace the `|` with the [update assignment][1] and optionally group into parenthesis `(..)`. The part after `|=` recreates the object from `.` and assigns to the path on the LHS\r\n\r\n    .Statement[0] |= ( .Principal.AWS as $orig | .Principal.AWS = [$orig] + [&quot;foo&quot;, &quot;bar&quot;] )\r\n    #            ^^^\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Update-assignment:%7C=",
                "title": "Editing value in nested array using variables"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604293950,
                "last_edit_date": 1604293950,
                "creation_date": 1604293034,
                "answer_id": 64639973,
                "question_id": 64633716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to ensure that you don&#39;t change the input context using pipes at the top level. Assignments preserve the input so try to write your filter as an assignment.\r\n\r\nThe intermediate variable is unnecessary, you could do without it. I&#39;d write it like this:\r\n\r\n    .Statement[].Principal.AWS |= [(arrays // [.])[], &quot;foo&quot;, &quot;bar&quot;]\r\n\r\nIf `Principal.AWS` was already an array, it&#39;ll just append your new values to that array, otherwise assumes the current value is the first item of the new array.",
                "title": "Editing value in nested array using variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1604293950,
        "creation_date": 1604245464,
        "last_edit_date": 1604265369,
        "question_id": 64633716,
        "body_markdown": "I have the following JQ problem that I can&#39;t solve. Given JSON:\r\n\r\n```lang-json\r\n{\r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n    &quot;Statement&quot;: [\r\n        {\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Principal&quot;: {\r\n                &quot;AWS&quot;: &quot;arn:aws:iam::111122223333:root&quot;\r\n            },\r\n            &quot;Action&quot;: &quot;sts:AssumeRole&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI need to take the value `.Principal.AWS` and save that in a variable `$orig` or something, and then readd that variable as an element in an array that will become the new document.\r\n\r\nThis almost works:\r\n\r\n```\r\n&#39;.Statement[0]\r\n    | .Principal.AWS as $orig\r\n    | .Principal.AWS = [$orig] + [&quot;foo&quot;, &quot;bar&quot;]&#39;\r\n```\r\n\r\nDoing that, however, I lose the Version and Statement level. Meanwhile, doing this nearly does what I want:\r\n\r\n```\r\n&#39;(.Statement[] | .Principal.AWS) = [&quot;foo&quot;, &quot;bar&quot;]&#39;\r\n```\r\n\r\nSo I expected this to also work but it doesn&#39;t:\r\n\r\n```\r\n&#39;(.Statement[] | .Principal.AWS as $orig | .Principal.AWS) = [$orig, &quot;foo&quot;, &quot;bar&quot;]&#39;\r\n```\r\n\r\nThen I get an invalid path expression error. \r\n\r\nHow can I correct this syntax? The expected result is:\r\n\r\n```lang-json\r\n{\r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n    &quot;Statement&quot;: [\r\n        {\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Principal&quot;: {\r\n                &quot;AWS&quot;: [&quot;arn:aws:iam::111122223333:root&quot;, &quot;foo&quot;, &quot;bar&quot;]\r\n            },\r\n            &quot;Action&quot;: &quot;sts:AssumeRole&quot;\r\n        }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/64633716/editing-value-in-nested-array-using-variables",
        "title": "Editing value in nested array using variables"
    },
    {
        "tags": [
            "jq",
            "kubectl"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1604255365,
                "last_edit_date": 1604255365,
                "creation_date": 1604254685,
                "answer_id": 64635351,
                "question_id": 64635160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So you already know how to get the cluster and user by name separately, first step is to select them both within a single filter:\r\n\r\n```\r\n(.clusters[] | select(.name == $name).cluster), (.users[] | select(.name == $name).user)\r\n```\r\n\r\nThis will yield two separate objects, the cluster, then the user. But we want to merge them. There&#39;s plenty of ways to do this. You could add them (`+`) directly or merge them (`*`) but no real difference there. You&#39;ll just want to remap the properties to the names you wanted where needed.\r\n\r\n```\r\n(.clusters[] | select(.name == $name).cluster | {url: .server, cert: .&quot;certificate-authority-data&quot;})\r\n+\r\n(.users[] | select(.name == $name).user | {username, password})\r\n```\r\n\r\nPass the name in as a parameter to your filter;\r\n\r\n```\r\n$ kubectl config view --raw -o json | jq --arg name some-name &#39;\r\n(.clusters[] | select(.name == $name).cluster | {url: .server, cert: .&quot;certificate-authority-data&quot;})\r\n+\r\n(.users[] | select(.name == $name).user | {username, password})\r\n&#39;\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\nFor the second part of your question, if it turns out the mapped user is missing key properties and you want to omit them, just add another `select` filter to the end to test for those properties and replace with an empty object if nothing is found:\r\n\r\n```\r\n... | select(has(&quot;username&quot;) and has(&quot;password&quot;)) // {}\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/u_1_YzGgWC)",
                "title": "JQ, two queries, over different part of json, Merge it back"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604267582,
        "creation_date": 1604253614,
        "last_edit_date": 1604267582,
        "question_id": 64635160,
        "body_markdown": "I am trying to extract kubeconfig data with jq. \r\n\r\n```kubectl config view --raw -o json | jq ...```\r\n\r\nThere is a json produced of this kind:\r\n\r\n```\r\n{\r\n    &quot;kind&quot;: &quot;Config&quot;,\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;preferences&quot;: {},\r\n    &quot;clusters&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;some-name&quot;,\r\n            &quot;cluster&quot;: {\r\n                &quot;server&quot;: &quot;https://some-url&quot;,\r\n                &quot;certificate-authority-data&quot;: &quot;some-cert&quot;\r\n            }\r\n        },\r\n      {\r\n          &quot;name&quot;: &quot;another-name&quot;,\r\n          &quot;cluster&quot;: {\r\n              &quot;server&quot;: &quot;https://another-url&quot;,\r\n              &quot;certificate-authority-data&quot;: &quot;another-cert&quot;\r\n          }\r\n      }\r\n    ],\r\n    &quot;users&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;some-name&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;some-user&quot;,\r\n                &quot;password&quot;: &quot;some-password&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;another-name&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;another-user&quot;,\r\n                &quot;password&quot;: &quot;another-password&quot;\r\n            }\r\n        }\r\n    ],\r\n    &quot;contexts&quot;: [],\r\n    &quot;current-context&quot;: &quot;some-context&quot;\r\n}\r\n```\r\n\r\n**Question #1:**\r\nFor a given name ,&quot;some-name&quot;, I&#39;d like to extract json:\r\n\r\n```\r\n{\r\n  url: &quot;https://some-url&quot;,\r\n  cert: &quot;some-cert&quot;,\r\n  username: &quot;some-user&quot;,\r\n  password: &quot;some-password&quot;\r\n}\r\n```\r\n\r\n**Question #2:**\r\n&quot;users&quot; sub-section can have other format\r\n\r\n```\r\n&quot;users&quot;: [\r\n\t{\r\n\t\t&quot;name&quot;: &quot;...&quot;,\r\n\t\t&quot;user&quot;: {\r\n\t\t\t&quot;exec&quot;: {\r\n\t\t\t\t...\r\n\t\t\t}\r\n```\r\n\r\nWhere `.user.username` or `.user.password` or both can be missing\r\n\r\nIn this case overall query should return &quot;{}&quot;, even though, &quot;clusters&quot; query/branch has result\r\n\r\n----\r\n**Question 3**, as a follow up to Jeff Mercado answer:\r\n\r\nI want to get all clusters, joined (grouped by) name:\r\n\r\nLooking at the manual, https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions , \r\n\r\nsection &quot;Multiplication, division, modulo: *, /, and %&quot;, example:  \r\n\r\n```\r\njq &#39;{&quot;k&quot;: {&quot;a&quot;: 1, &quot;b&quot;: 2}} * {&quot;k&quot;: {&quot;a&quot;: 0,&quot;c&quot;: 3}}&#39; =&gt; {&quot;k&quot;: {&quot;a&quot;: 0, &quot;b&quot;: 2, &quot;c&quot;: 3}}&#39;\r\n``` \r\ngives presumably right result, assuming &quot;k&quot; is value of &quot;name&quot;. So, grouping by &quot;k&quot;, merging (*) the results.\r\n\r\nI produced following query:\r\n\r\n```\r\necho &quot;${json}&quot; | jq -r  &#39;(.clusters[] | {(.name): {url: .cluster.server, cert: .cluster[&quot;certificate-authority-data&quot;]}}) * (.users[] | {(.name): {user: .user.username, password: .user.password}})&#39;\r\n```\r\n\r\nFirst part returns {&quot;name&quot;: {url: cert}}, second part is {&quot;name&quot;: {username, password}}\r\nHowever, result is not merge as in jq Manual, but something else ... product ?\r\n\r\n```\r\n{\r\n  &quot;some-name&quot;: {\r\n    &quot;url&quot;: &quot;https://some-url&quot;,\r\n    &quot;cert&quot;: &quot;some-cert&quot;,\r\n    &quot;user&quot;: &quot;some-user&quot;,\r\n    &quot;password&quot;: &quot;some-password&quot;\r\n  }\r\n}\r\n{\r\n  &quot;another-name&quot;: {\r\n    &quot;url&quot;: &quot;https://another-url&quot;,\r\n    &quot;cert&quot;: &quot;another-cert&quot;\r\n  },\r\n  &quot;some-name&quot;: {\r\n    &quot;user&quot;: &quot;some-user&quot;,\r\n    &quot;password&quot;: &quot;some-password&quot;\r\n  }\r\n}\r\n{\r\n  &quot;some-name&quot;: {\r\n    &quot;url&quot;: &quot;https://some-url&quot;,\r\n    &quot;cert&quot;: &quot;some-cert&quot;\r\n  },\r\n  &quot;another-name&quot;: {\r\n    &quot;user&quot;: &quot;another-user&quot;,\r\n    &quot;password&quot;: &quot;another-password&quot;\r\n  }\r\n}\r\n{\r\n  &quot;another-name&quot;: {\r\n    &quot;url&quot;: &quot;https://another-url&quot;,\r\n    &quot;cert&quot;: &quot;another-cert&quot;,\r\n    &quot;user&quot;: &quot;another-user&quot;,\r\n    &quot;password&quot;: &quot;another-password&quot;\r\n  }\r\n}\r\n\r\n```\r\n\r\nWhy/what is it ? Kind of following idea of the product (&#39;*&#39;) but not of the jq tutorial as I (most likely, incorrectly) understand it\r\n\r\n---\r\n**Experimentation:**\r\nI have 2 queries now producing partial result.\r\n\r\nLet&#39;s grab original json (above) in and parse:\r\n```\r\nread -d &#39;&#39; json &lt;&lt; EOF\r\n...\r\nEOF\r\n```\r\nqueries:\r\n```\r\necho &quot;${json}&quot; | jq -r &#39;.clusters[] | select(.name==&quot;some-name&quot;) | .cluster | {url: .server, cert: .[&quot;certificate-authority-data&quot;]}&#39; &amp;&amp;\\\r\necho &quot;${json}&quot; | jq -r &#39;.users[] | select(.name==&quot;some-name&quot;) | .user | {user: .username, password: .password}&#39;\r\n\r\n```\r\n\r\nWill produce the split output:\r\n```\r\n{\r\n  &quot;url&quot;: &quot;https://some-url&quot;,\r\n  &quot;cert&quot;: &quot;some-cert&quot;\r\n}\r\n{\r\n  &quot;user&quot;: &quot;some-user&quot;,\r\n  &quot;password&quot;: &quot;some-password&quot;\r\n}\r\n\r\n```\r\n\r\nOr, with key added for further merge:\r\n```\r\necho &quot;${json}&quot; | jq -r &#39;.clusters[] | select(.name==&quot;some-name&quot;) | {name: .name, url: .cluster.server, cert: .cluster[&quot;certificate-authority-data&quot;]}&#39; &amp;&amp;\\\r\necho &quot;${json}&quot; | jq -r &#39;.users[] | select(.name==&quot;some-name&quot;) | {name: .name, user: .user.username, password: .user.password}&#39;\r\n```\r\n\r\nWill produce:\r\n\r\n```\r\n\r\n{\r\n  &quot;name&quot;: &quot;some-name&quot;,\r\n  &quot;url&quot;: &quot;https://some-url&quot;,\r\n  &quot;cert&quot;: &quot;some-cert&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;some-name&quot;,\r\n  &quot;user&quot;: &quot;some-user&quot;,\r\n  &quot;password&quot;: &quot;some-password&quot;\r\n}\r\n\r\n```\r\n\r\n&quot;name&quot; is not needed but can be used as a join operation\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64635160/jq-two-queries-over-different-part-of-json-merge-it-back",
        "title": "JQ, two queries, over different part of json, Merge it back"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604324016,
                "post_id": 64646374,
                "comment_id": 114304551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604324535,
                "post_id": 64646374,
                "comment_id": 114304795,
                "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": 1604330064,
                "post_id": 64646374,
                "comment_id": 114307520,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604332073,
                "post_id": 64646374,
                "comment_id": 114308558,
                "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": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1604388387,
                "post_id": 64646374,
                "comment_id": 114325179,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1604335311,
                "creation_date": 1604335311,
                "answer_id": 64649640,
                "question_id": 64646374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another alternative is handling all the arguments within `jq`:\r\n\r\n```sh\r\n#!/usr/bin/env sh\r\n\r\n# Assign the template file to a template var\r\nget_template() {\r\n  template=&#39;{\r\n    &quot;anomalyDetection&quot;: {\r\n        &quot;loadingTimeThresholds&quot;: {\r\n            &quot;enabled&quot;: false,\r\n            &quot;thresholds&quot;: []\r\n        },\r\n        &quot;outageHandling&quot;: {\r\n            &quot;globalOutage&quot;: true,\r\n            &quot;localOutage&quot;: true,\r\n            &quot;localOutagePolicy&quot;: {\r\n                &quot;affectedLocations&quot;: 1,\r\n                &quot;consecutiveRuns&quot;: 2\r\n            }\r\n        }\r\n    }\r\n}&#39;\r\n}\r\n\r\nmodify_json() {\r\n  # Call the template assignment\r\n  get_template\r\n\r\n  updated_JSON=$(\r\n    jq \\\r\n      --arg update_affectedLocations &quot;$1&quot; \\\r\n      --arg update_consecutiveRuns &quot;$2&quot; \\\r\n      --null-input \\\r\n      &quot;$template&quot;&#39;|\r\nif $update_affectedLocations | try tonumber catch false\r\nthen\r\n  .anomalyDetection.outageHandling.localOutagePolicy.affectedLocations |= (\r\n    $update_affectedLocations | tonumber\r\n  )\r\nelse .\r\nend |\r\nif $update_consecutiveRuns | try tonumber catch false\r\nthen\r\n  .anomalyDetection.outageHandling.localOutagePolicy.consecutiveRuns |= (\r\n    $update_consecutiveRuns | tonumber\r\n  )\r\nelse .\r\nend &#39;\r\n  )\r\n}\r\n\r\nmodify_json 42 666\r\necho &quot;$updated_JSON&quot;\r\n```",
                "title": "Dynamically modify JSON file in bash script with jq - use heredocs or key assignments?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604419700,
                "last_edit_date": 1604419700,
                "creation_date": 1604386167,
                "answer_id": 64657968,
                "question_id": 64646374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I too would suggest a different approach for the reasons outlined below.\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nfunction template {\r\n    cat&lt;&lt;EOF\r\n{\r\n    &quot;anomalyDetection&quot;: {\r\n        &quot;loadingTimeThresholds&quot;: {\r\n            &quot;enabled&quot;: false,\r\n            &quot;thresholds&quot;: []\r\n        },\r\n        &quot;outageHandling&quot;: {\r\n            &quot;globalOutage&quot;: true,\r\n            &quot;localOutage&quot;: true,\r\n            &quot;localOutagePolicy&quot;: {\r\n                &quot;affectedLocations&quot;: 1,\r\n                &quot;consecutiveRuns&quot;: 2\r\n            }\r\n        }\r\n    }\r\n}\r\nEOF\r\n}\r\n\r\nfunction modify_json() {\r\n    template |\t\r\n    jq --argjson update_affectedLocations &quot;${1:-1}&quot; \\\r\n       --argjson update_consecutiveRuns &quot;${2:-2}&quot; &#39;\r\n       .anomalyDetection.outageHandling.localOutagePolicy\r\n         |= (.affectedLocations |= $update_affectedLocations\r\n             | .consecutiveRuns |= $update_consecutiveRuns )\r\n    &#39;\r\n}\r\n\r\nupdated_JSON=$(modify_json 42 666)\r\necho &quot;$updated_JSON&quot;\r\n```\r\n\r\n## Considerations\r\n\r\n1. It is generally ill-advised to write functions which set &quot;global&quot; variables (such as `$template`) if possible.  By defining a function (`template`), we also introduce only one name instead of one for the function and one for the variable.\r\n\r\n2. It appears that the parameters `update_affectedLocations` and `update_consecutiveRuns` are supposed to be numbers, so using --argjson makes sense, especially if some resilience and simplicity are considerations. \r\n\r\n3. The jq program achieves &quot;DRY-ness&quot; (i.e. it avoids unnecessary repetition) by using the update-assignment operator freely.\r\n\r\n4. Using &quot;|&quot; at the beginning of lines in a jq program makes it easy to achieve a certain amount of visual elegance while highlighting the logic.\r\n\r\nNotice also that the suggested script is quite succinct and uncomplicated, while being reasonably robust.\r\n\r\nSome would deprecate using the keyword `function` to define shell functions, but it does make locating function definitions trivially easy, both for human eyes and human fingers at the keyboard.\r\n\r\n ",
                "title": "Dynamically modify JSON file in bash script with jq - use heredocs or key assignments?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1604419700,
        "creation_date": 1604323196,
        "question_id": 64646374,
        "body_markdown": "Below is the part of my JSON file, the JSON file itself is longer.\r\n```\r\n{\r\n    &quot;anomalyDetection&quot;: {\r\n        &quot;loadingTimeThresholds&quot;: {\r\n            &quot;enabled&quot;: false,\r\n            &quot;thresholds&quot;: []\r\n        },\r\n        &quot;outageHandling&quot;: {\r\n            &quot;globalOutage&quot;: true,\r\n            &quot;localOutage&quot;: true,\r\n            &quot;localOutagePolicy&quot;: {\r\n                &quot;affectedLocations&quot;: 1,\r\n                &quot;consecutiveRuns&quot;: 2\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\nHere I need to modify ``affectedLocations`` and ``consecutiveRuns`` values with supplied parameters, assign the modified JSON to a var which then is used during the API call.\r\n\r\nI created two different solutions with bash to accomplish the above. \r\n\r\n**Option 1 - use heredocs**\r\n```\r\n# Assign the template file to a template var\r\nget_template() {\r\n    read -r -d &#39;&#39; template &lt;&lt;JSONTEMPLATE\r\n{\r\n    &quot;anomalyDetection&quot;: {\r\n        &quot;loadingTimeThresholds&quot;: {\r\n            &quot;enabled&quot;: false,\r\n            &quot;thresholds&quot;: []\r\n        },\r\n        &quot;outageHandling&quot;: {\r\n            &quot;globalOutage&quot;: true,\r\n            &quot;localOutage&quot;: true,\r\n            &quot;localOutagePolicy&quot;: {\r\n                &quot;affectedLocations&quot;: 1,\r\n                &quot;consecutiveRuns&quot;: 2\r\n            }\r\n        }\r\n    }\r\n}\r\nJSONTEMPLATE\r\n}\r\n\r\nmodify_json_with_heredoc() {\r\n\r\n    # Call the template var assignment\r\n    get_template\r\n\r\n    read -r -d &#39;&#39; json_keys_updated &lt;&lt;JSONSTRING\r\n{\r\n    &quot;globalOutage&quot;: true,\r\n    &quot;localOutage&quot;: true,\r\n    &quot;localOutagePolicy&quot;: {\r\n        &quot;affectedLocations&quot;: ${1:-1},\r\n        &quot;consecutiveRuns&quot;: ${2:-2}\r\n    }\r\n}\r\nJSONSTRING\r\n\r\n    # Replace key values from the template with the updated parameters\r\n\r\n    updated_JSON=$(jq --argjson update_outageHandling &quot;$json_keys_updated&quot; \\\r\n        &#39;.anomalyDetection.outageHandling|=$update_outageHandling&#39; \\\r\n        &lt;&lt;&lt;&quot;$template&quot;)\r\n}\r\n```\r\n**Option 2 - modify keys in the JSON directly**\r\n```\r\nmodify_json_with_vars() {\r\n\r\n    # Call the template assignment\r\n    get_template\r\n\r\n    updated_JSON=$(jq --argjson update_affectedLocations &quot;${1:-1}&quot; --argjson update_consecutiveRuns &quot;${2:-2}&quot; \\\r\n        &#39; .anomalyDetection.outageHandling.globalOutage|=true\r\n        | .anomalyDetection.outageHandling.localOutagePolicy.affectedLocations|=$update_affectedLocations\r\n        | .anomalyDetection.outageHandling.localOutagePolicy.consecutiveRuns|=$update_consecutiveRuns&#39; \\\r\n        &lt;&lt;&lt;&quot;$template&quot;)\r\n\r\n}\r\n```\r\nI need to be able to call functions with/without parameters. If functions are called without parameters, then need to keep the default values for keys, that&#39;s why ``${1:-1}`` ``${2:-2}`` are there. \r\n \r\n\r\nBoth options work fine - for example,``modify_json_with_vars 2 3`` or ``modify_json_with_heredoc``. My question is which of the above is better/faster/safer, as well as more &#39;right&#39; thing to do.\r\n\r\nAs I&#39;ve mentioned, the template file is larger. At this moment I need to modify only the keys in the object ``.anomalyDetection.outageHandling.localOutagePolicy``, however, in the future I might need to change other keys as well and need a solution which is scalable and maintainable.\r\n\r\nI think that the first option is neater because jq is called only with one parameter. But if I will need to change keys all over the source template JSON file, probably the second option is more scalable.\r\n\r\nSuggestions are welcome.",
        "link": "https://stackoverflow.com/questions/64646374/dynamically-modify-json-file-in-bash-script-with-jq-use-heredocs-or-key-assign",
        "title": "Dynamically modify JSON file in bash script with jq - use heredocs or key assignments?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604327316,
                "creation_date": 1604327316,
                "answer_id": 64647438,
                "question_id": 64647262,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\njq -r &#39;\r\n    .InstanceStatuses[] | \r\n    .InstanceId as $id |\r\n    .Events[] | \r\n    [$id, .InstanceEventId, .Code, .Description, .NotBefore] |\r\n    @tsv\r\n&#39; file.json\r\n```\r\nNewlines added for readability: remove them if you need to.",
                "title": "I want the below json data in to below format i am using jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604327723,
        "creation_date": 1604326661,
        "last_edit_date": 1604327723,
        "question_id": 64647262,
        "body_markdown": "I want the output in the below format like in a single row. Can some one help me to get the output.\r\n\r\n    jq -r &#39;(.InstanceStatuses[].InstanceId,.InstanceStatuses[].Events[].InstanceEventId,.InstanceStatuses[].Events[].Code,.InstanceStatuses[].Events[].Description,.InstanceStatuses[].Events[].NotBefore)|@tsv&#39;\r\n\r\nRequired output:\r\n\r\n    i-004f8269b087ec123 instance-event-0ad7ad7a2011a4123 instance-stop The instance is running on degraded hardware 2020-11-16T10:00:00.000Z\r\n\r\n```\r\n{\r\n    &quot;InstanceStatuses&quot;: [\r\n        {\r\n            &quot;AvailabilityZone&quot;: &quot;us-east-1b&quot;,\r\n            &quot;Events&quot;: [\r\n                {\r\n                    &quot;InstanceEventId&quot;: &quot;instance-event-0ad7ad7a2011a4123&quot;,\r\n                    &quot;Code&quot;: &quot;instance-stop&quot;,\r\n                    &quot;Description&quot;: &quot;The instance is running on degraded hardware&quot;,\r\n                    &quot;NotBefore&quot;: &quot;2020-11-16T10:00:00.000Z&quot;\r\n                }\r\n            ],\r\n            &quot;InstanceId&quot;: &quot;i-004f8269b087ec123&quot;,\r\n            &quot;InstanceState&quot;: {\r\n                &quot;Code&quot;: 16,\r\n                &quot;Name&quot;: &quot;running&quot;\r\n            },\r\n            &quot;InstanceStatus&quot;: {\r\n                &quot;Details&quot;: [\r\n                    {\r\n                        &quot;ImpairedSince&quot;: &quot;2020-11-01T23:36:00.000Z&quot;,\r\n                        &quot;Name&quot;: &quot;reachability&quot;,\r\n                        &quot;Status&quot;: &quot;failed&quot;\r\n                    }\r\n                ],\r\n                &quot;Status&quot;: &quot;impaired&quot;\r\n            },\r\n            &quot;SystemStatus&quot;: {\r\n                &quot;Details&quot;: [\r\n                    {\r\n                        &quot;ImpairedSince&quot;: &quot;2020-11-01T23:36:00.000Z&quot;,\r\n                        &quot;Name&quot;: &quot;reachability&quot;,\r\n                        &quot;Status&quot;: &quot;failed&quot;\r\n                    }\r\n                ],\r\n                &quot;Status&quot;: &quot;impaired&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/64647262/i-want-the-below-json-data-in-to-below-format-i-am-using-jq-command",
        "title": "I want the below json data in to below format i am using jq command"
    },
    {
        "tags": [
            "bash",
            "shell",
            "sed",
            "filter",
            "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": 1604329591,
                "post_id": 64647762,
                "comment_id": 114307310,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1604552837,
                "last_edit_date": 1604552837,
                "creation_date": 1604329896,
                "answer_id": 64648150,
                "question_id": 64647762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your JSON, an invocation along the lines of:\r\n\r\n    jq -r &#39;.result.filter.expression\r\n      | capture(&quot;{(?&lt;ips&gt;[^}]*)}&quot;).ips&#39; example.json\r\n\r\nwould yield the string of IP addresses:\r\n\r\n    192.168.1.1 192.168.1.2 2408:14c:dc83:9119:f9f6:c105:923:a5e3\r\n\r\n\r\nThe rest should be easy sailing.\r\n",
                "title": "Use JQ and similar to filter IPv4 and IPv6 addresses in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604552837,
        "creation_date": 1604328461,
        "question_id": 64647762,
        "body_markdown": "I&#39;m trying to extract IPv4 and IPv6 addresses from a Cloudflare firewall rule, to use in another command.\r\n\r\nHere&#39;s a full example `json` response that I want to filter:\r\n```json\r\n{\r\n    &quot;result&quot;: {\r\n        &quot;id&quot;: &quot;78839c481cd8424fa8f0f06abd33b55f&quot;,\r\n        &quot;paused&quot;: false,\r\n        &quot;description&quot;: &quot;Test&quot;,\r\n        &quot;action&quot;: &quot;block&quot;,\r\n        &quot;priority&quot;: 1,\r\n        &quot;filter&quot;: {\r\n            &quot;id&quot;: &quot;68f2efc4fa6e43f584dd4b60aca09901&quot;,\r\n            &quot;expression&quot;: &quot;(ip.src in {192.168.1.1 192.168.1.2 2408:14c:dc83:9119:f9f6:c105:923:a5e3})&quot;,\r\n            &quot;paused&quot;: false\r\n        },\r\n        &quot;created_on&quot;: &quot;2020-11-02T13:48:31Z&quot;,\r\n        &quot;modified_on&quot;: &quot;2020-11-02T13:49:02Z&quot;\r\n    },\r\n    &quot;success&quot;: true,\r\n    &quot;errors&quot;: [],\r\n    &quot;messages&quot;: []\r\n}\r\n```\r\n\r\nI just want to extract any IPv4 or IPv6 address that is inside the expression field, so in this case, `192.168.1.1 192.168.1.2`\r\n\r\nHow can I do this in `bash`?\r\n\r\nThank you!",
        "link": "https://stackoverflow.com/questions/64647762/use-jq-and-similar-to-filter-ipv4-and-ipv6-addresses-in-bash",
        "title": "Use JQ and similar to filter IPv4 and IPv6 addresses in bash"
    },
    {
        "tags": [
            "json",
            "escaping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1604392548,
                "last_edit_date": 1604392548,
                "creation_date": 1604362516,
                "answer_id": 64655065,
                "question_id": 64654911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following does the trick:\r\n```\r\necho &#39;{&quot;x&quot;: &quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;}&#39; | jq -r .x | jq .a\r\n```\r\nHere the `-r` step ensures that the output is **raw strings**, not JSON texts. Therefore: \r\n```\r\n&quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot; -&gt; {&quot;a&quot;: &quot;b&quot;},\r\n``` \r\nwhere this &quot;raw string&quot; can subsequently be taken as JSON input for `jq .a`, returning `&quot;b&quot;` (or `b` when used with `-r` flag).\r\n\r\n**EDIT**: Calling `jq` twice is not ideal (thanks @peak), the previous command can be combined in this oneliner\r\n```\r\n| jq -r &#39;.x|fromjson.a&#39;\r\n```",
                "title": "extracting json inside json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604392548,
        "creation_date": 1604361081,
        "question_id": 64654911,
        "body_markdown": "I often find myself wanting to parse json with the `jq` command, but one of the values inside the json is an escaped string of json. \r\n\r\ne.g. if I generate data with python like this:\r\n\r\n```\r\nimport json\r\ninner = {&#39;a&#39;: &#39;b&#39;}\r\nouter = {&#39;x&#39;: json.dumps(inner)}\r\njson.dumps(outer)\r\n```\r\n\r\nI get:\r\n\r\n```\r\n{&quot;x&quot;: &quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;}\r\n```\r\n\r\nHow do I get `&quot;b&quot;` using the `jq` command?\r\n\r\n```\r\n$ echo &#39;{&quot;x&quot;: &quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;}&#39; | jq .x\r\n&quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;\r\n```\r\nOk, that&#39;s the first step.\r\nBut the result isn&#39;t a json dictionary. It&#39;s a string that needs to be escaped and parsed into json.\r\n\r\n`jq .x.a` throws an error: `jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;a&quot;`\r\n\r\nIs there an argument I can add to `jq` to chain together two `jq` steps?\r\nOr is there another command I can use instead?\r\n\r\ne.g.\r\n\r\n```\r\necho &#39;{&quot;x&quot;: &quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;}&#39; | jq .x | jq --some-argument .a\r\n```\r\n\r\nor\r\n\r\n```\r\necho &#39;{&quot;x&quot;: &quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;}&#39; | jq .x | something-else | jq .a\r\n```",
        "link": "https://stackoverflow.com/questions/64654911/extracting-json-inside-json-with-jq",
        "title": "extracting json inside json with jq"
    },
    {
        "tags": [
            "ubuntu",
            "dynamic",
            "ansible",
            "jq",
            "inventory"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1604507061,
                "last_edit_date": 1604507061,
                "creation_date": 1604395728,
                "answer_id": 64660057,
                "question_id": 64659785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In contrary to the [Ansible inventory format](https://docs.ansible.com/ansible/latest/user_guide/intro_inventory.html#inventory-basics-formats-hosts-and-groups), the inventory plugin [*script.py*](https://github.com/ansible/ansible/blob/devel/lib/ansible/plugins/inventory/script.py#L182) expects the attribute *hosts* to be a **list** (e.g. *hosts:[ host1, host2, host3 ]*) not a **dictionary** (e.g. *hosts:{ host, host2, host3 }*).\r\n\r\n&lt;hr&gt;\r\n\r\n**Inventory plugin [yaml.py](https://github.com/ansible/ansible/blob/devel/lib/ansible/plugins/inventory/yaml.py) works with dictionaries of hosts**\r\n\r\nThe JSON (or YAML, because JSON is a subset of YAML) inventory works fine\r\n\r\n```yaml\r\nshell&gt; cat hosts.json\r\n{\r\n    &quot;all&quot;: {\r\n        &quot;hosts&quot;: {\r\n            &quot;ip-172-31-39-30.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-44-224.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-42-6.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-32-68.eu-west-1.compute.internal&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\n```yaml\r\nshell&gt; ansible-inventory -i hosts.json --list -vvv\r\n...\r\nParsed /scratch/tmp/hosts.json inventory source with yaml plugin\r\n{\r\n    &quot;_meta&quot;: {\r\n        &quot;hostvars&quot;: {}\r\n    },\r\n    &quot;all&quot;: {\r\n        &quot;children&quot;: [\r\n            &quot;ungrouped&quot;\r\n        ]\r\n    },\r\n    &quot;ungrouped&quot;: {\r\n        &quot;hosts&quot;: [\r\n            &quot;ip-172-31-32-68.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-39-30.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-42-6.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-44-224.eu-west-1.compute.internal&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nBut, the same file provided by the script will fail\r\n\r\n```sh\r\nshell&gt; cat hosts.sh \r\n#!/bin/bash\r\ncat hosts.json\r\n```\r\n\r\n```yaml\r\nshell&gt; ansible-inventory -i hosts.sh --list -vvv\r\n...\r\nParsed /scratch/tmp/hosts.sh inventory source with script plugin\r\n```\r\n\r\n&gt;[WARNING]: Failed to parse /scratch/tmp/hosts.sh with script plugin: You\r\ndefined a group &#39;all&#39; with bad data for the host list:  {&#39;hosts&#39;: {&#39;ip-172-31-39-30.eu-\r\nwest-1.compute.internal&#39;: None, &#39;ip-172-31-44-224.eu-west-1.compute.internal&#39;: None,\r\n&#39;ip-172-31-42-6.eu-west-1.compute.internal&#39;: None, &#39;ip-172-31-32-68.eu-\r\nwest-1.compute.internal&#39;: None}}\r\n...\r\n```yaml\r\n{\r\n    &quot;_meta&quot;: {\r\n        &quot;hostvars&quot;: {}\r\n    },\r\n    &quot;all&quot;: {\r\n        &quot;children&quot;: [\r\n            &quot;ungrouped&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n**Inventory plugin [script.py](https://github.com/ansible/ansible/blob/devel/lib/ansible/plugins/inventory/script.py) works with lists of hosts**\r\n\r\n\r\nThe inventory plugin *script.py* works as expected when the attribute hosts is a **list**\r\n\r\n```yaml\r\nshell&gt; cat hosts.json\r\n{\r\n    &quot;all&quot;: {\r\n        &quot;hosts&quot;: [\r\n            &quot;ip-172-31-39-30.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-44-224.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-42-6.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-32-68.eu-west-1.compute.internal&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\n```yaml\r\nshell&gt; ansible-inventory -i hosts.sh --list -vvv\r\n...\r\nParsed /scratch/tmp/hosts.sh inventory source with script plugin\r\n{\r\n    &quot;_meta&quot;: {\r\n       ...\r\n    },\r\n    &quot;all&quot;: {\r\n        &quot;children&quot;: [\r\n            &quot;ungrouped&quot;\r\n        ]\r\n    },\r\n    &quot;ungrouped&quot;: {\r\n        &quot;hosts&quot;: [\r\n            &quot;ip-172-31-32-68.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-39-30.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-42-6.eu-west-1.compute.internal&quot;,\r\n            &quot;ip-172-31-44-224.eu-west-1.compute.internal&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n&lt;hr&gt;\r\n\r\nNotes\r\n\r\n* The script *hosts.sh* is not implemented properly and serves the purpose of this example only. Quoting from [script.py](https://github.com/ansible/ansible/blob/devel/lib/ansible/plugins/inventory/script.py#L35):\r\n\r\n&gt;description:\r\n        - The source provided must be an executable that returns Ansible inventory JSON\r\n        - The source must accept C(--list) and C(--host &lt;hostname&gt;) as arguments.\r\n          C(--host) will only be used if no C(_meta) key is present.",
                "title": "Ansible dynamic inventory script - odd behaviour"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604507061,
        "creation_date": 1604394578,
        "last_edit_date": 1604410658,
        "question_id": 64659785,
        "body_markdown": "I&#39;m trying to create a basic dynamic inventory script for ansible based on JSON output. I&#39;m new to jq but I&#39;ve hit an issue where the dynamic script on ansible v2.9.14 &amp; 2.9.15 doesn&#39;t like the output, but if I send the output to a file and then run Ansible against the output in the file, ansible works.\r\n\r\nThis is what happens:\r\n\r\ndynamic inventory script output:\r\n```$ ./dynamic1.sh\r\n{\r\n  &quot;all&quot;: {\r\n      &quot;hosts&quot;: {\r\n&quot;ip-172-31-39-30.eu-west-1.compute.internal&quot;: null,\r\n&quot;ip-172-31-44-224.eu-west-1.compute.internal&quot;: null,\r\n&quot;ip-172-31-42-6.eu-west-1.compute.internal&quot;: null,\r\n&quot;ip-172-31-32-68.eu-west-1.compute.internal&quot;: null,\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\nAnsible run and error:\r\n```\r\n$ ansible -i ./dynamic1.sh all -m ping -u ubuntu\r\n[WARNING]:  * Failed to parse /home/ubuntu/dynamic1.sh with script plugin: failed to parse executable inventory script results from /home/ubuntu/dynamic1.sh:\r\nExpecting property name enclosed in double quotes: line 8 column 5 (char 242)\r\n[WARNING]:  * Failed to parse /home/ubuntu/dynamic1.sh with ini plugin: /home/ubuntu/dynamic1.sh:2: Expected key=value host variable assignment, got: {\r\n[WARNING]: Unable to parse /home/ubuntu/dynamic1.sh as an inventory source\r\n[WARNING]: No inventory was parsed, only implicit localhost is available\r\n[WARNING]: provided hosts list is empty, only localhost is available. Note that the implicit localhost does not match &#39;all&#39;\r\n```\r\n\r\nNow, if I output the dynamic script to a file, then run ansible again, it works:\r\n```\r\n$ ./dynamic1.sh &gt; output.json\r\n\r\n$ cat output.json\r\n{\r\n  &quot;all&quot;: {\r\n      &quot;hosts&quot;: {\r\n&quot;ip-172-31-39-30.eu-west-1.compute.internal&quot;: null,\r\n&quot;ip-172-31-44-224.eu-west-1.compute.internal&quot;: null,\r\n&quot;ip-172-31-42-6.eu-west-1.compute.internal&quot;: null,\r\n&quot;ip-172-31-32-68.eu-west-1.compute.internal&quot;: null,\r\n    }\r\n  }\r\n}\r\n\r\n$ ansible -i output.json all -m ping -u ubuntu\r\n[DEPRECATION WARNING]: Distribution Ubuntu 16.04 on host ip-172-31-42-6.eu-west-1.compute.internal should use /usr/bin/python3, but is using /usr/bin/python for\r\nbackward compatibility with prior Ansible releases. A future Ansible release will default to using the discovered platform python for this host. See\r\nhttps://docs.ansible.com/ansible/2.9/reference_appendices/interpreter_discovery.html for more information. This feature will be removed in version 2.12. Deprecation\r\nwarnings can be disabled by setting deprecation_warnings=False in ansible.cfg.\r\nip-172-31-42-6.eu-west-1.compute.internal | SUCCESS =&gt; {\r\n    &quot;ansible_facts&quot;: {\r\n        &quot;discovered_interpreter_python&quot;: &quot;/usr/bin/python&quot;\r\n    },\r\n    &quot;changed&quot;: false,\r\n    &quot;ping&quot;: &quot;pong&quot;\r\n}\r\nip-172-31-39-30.eu-west-1.compute.internal | SUCCESS =&gt; {\r\n    &quot;ansible_facts&quot;: {\r\n        &quot;discovered_interpreter_python&quot;: &quot;/usr/bin/python3&quot;\r\n    },\r\n    &quot;changed&quot;: false,\r\n    &quot;ping&quot;: &quot;pong&quot;\r\n}\r\nip-172-31-32-68.eu-west-1.compute.internal | SUCCESS =&gt; {\r\n    &quot;ansible_facts&quot;: {\r\n        &quot;discovered_interpreter_python&quot;: &quot;/usr/bin/python3&quot;\r\n    },\r\n    &quot;changed&quot;: false,\r\n    &quot;ping&quot;: &quot;pong&quot;\r\n}\r\nip-172-31-44-224.eu-west-1.compute.internal | SUCCESS =&gt; {\r\n    &quot;ansible_facts&quot;: {\r\n        &quot;discovered_interpreter_python&quot;: &quot;/usr/bin/python3&quot;\r\n    },\r\n    &quot;changed&quot;: false,\r\n    &quot;ping&quot;: &quot;pong&quot;\r\n}\r\n```\r\nSo it works...\r\n\r\nThis is the contents of dynamic1.sh. I know there will be better ways to do this but I just need a list of servers based on a matching variable in the JSON output that ansible can use.\r\n\r\n```\r\n$ cat dynamic1.sh\r\n#!/bin/bash\r\necho &quot;{&quot;\r\necho &quot;  \\&quot;all\\&quot;: {&quot;\r\necho &quot;      \\&quot;hosts\\&quot;: {&quot;\r\ncurl --silent -X GET https://url.com/api/servers -H &quot;Authorization: Token $token&quot; -H &quot;Content-Type: text/json&quot;  -H &quot;Accept:application/json&quot; | jq -r &#39;.Result.servers[] | select(.ansible_local.local.local_facts.instance_type | tostring | contains(&quot;t2.micro&quot;)) | (.ansible_fqdn+&quot;\\&quot;: null,&quot;)&#39; | sed &#39;s/^/&quot;/g&#39;\r\necho &quot;    }&quot;\r\necho &quot;  }&quot;\r\necho &quot;}&quot;\r\n```\r\n\r\nCan anyone give me any help on why ansible accepts the file but not the output of the script?\r\n",
        "link": "https://stackoverflow.com/questions/64659785/ansible-dynamic-inventory-script-odd-behaviour",
        "title": "Ansible dynamic inventory script - odd behaviour"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604397162,
                "creation_date": 1604397162,
                "answer_id": 64660450,
                "question_id": 64660269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .[] | select(.value==&quot;ami-asd637ccb094d&quot;) | .name\r\n\r\n\r\nhttps://jqplay.org/s/kvahxrql43",
                "title": "Get name of the field by value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1604397412,
                "last_edit_date": 1604397412,
                "creation_date": 1604397390,
                "answer_id": 64660501,
                "question_id": 64660269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found the solution \r\n\r\n    jq &#39;.[] | select(.value==&quot;ami-0f5c399636ccb094d&quot;) | .name?&#39; | tr -d &#39;&quot;&quot;&#39; file.json",
                "title": "Get name of the field by value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1604420637,
        "creation_date": 1604396538,
        "last_edit_date": 1604420637,
        "question_id": 64660269,
        "body_markdown": "Hello i have the current json \r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;2020-11-02-160548&quot;,\r\n        &quot;value&quot;: &quot;ami-asd637ccb094d&quot;\r\n      }\r\n    ]\r\n\r\nI want to extract the name of the field name: when i know the value: ami-asd637ccb094d. I`m trying to do it with jq . The expected result is 2020-11-02-160548. Any help?",
        "link": "https://stackoverflow.com/questions/64660269/get-name-of-the-field-by-value",
        "title": "Get name of the field by value"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1604417400,
                "last_edit_date": 1604417400,
                "creation_date": 1604416903,
                "answer_id": 64665669,
                "question_id": 64663297,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `getpath` function. Use `paths` to identify all the paths leading upto `.comments` and get the paths&#39; value\r\n\r\n```none\r\njq &#39;[ getpath ( paths | select( .[-1] == &quot;comments&quot; ) ) ]&#39;\r\n```\r\nOr use a recursive descent to filter objects containing `.comments` and get its value\r\n\r\n```none\r\njq &#39;[ recurse | select(has(&quot;comments&quot;)?).comments ]&#39;\r\n```",
                "title": "Get array with all values for certain key in JSON wih JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604420595,
        "creation_date": 1604408308,
        "last_edit_date": 1604420595,
        "question_id": 64663297,
        "body_markdown": "Say I have the following JSON:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: 0,\r\n  &quot;b&quot;: &quot;c&quot;,\r\n  &quot;d&quot;: {\r\n    &quot;e&quot;: {\r\n      &quot;f&quot;: &quot;g&quot;,\r\n      &quot;comments&quot;: {\r\n        &quot;leading&quot;: &quot;Lorem ipsum&quot;\r\n      },\r\n      &quot;h&quot;: {\r\n        &quot;i&quot;: {\r\n          &quot;j&quot;: [\r\n            1,\r\n            2\r\n          ]\r\n        },\r\n        &quot;comments&quot;: {\r\n          &quot;trailing&quot;: &quot;dolor sit&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;comments&quot;: {\r\n      &quot;leading&quot;: &quot;amet.&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI want to get an array with the values of all the fields named `comments` (which can be nested in any level). So, in this case I want to get:\r\n```json\r\n[\r\n  {\r\n    &quot;leading&quot;: &quot;Lorem ipsum&quot;\r\n  },\r\n  {\r\n    &quot;trailing&quot;: &quot;dolor sit&quot;\r\n  },\r\n  {\r\n    &quot;leading&quot;: &quot;amet.&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe order of the array doesn&#39;t matter.\r\n\r\nHow can this be achieved with `jq`? I have only performed basic stuff with it and haven&#39;t been able to produce anything close to what I need.\r\n\r\nThanks in advance ☺️",
        "link": "https://stackoverflow.com/questions/64663297/get-array-with-all-values-for-certain-key-in-json-wih-jq",
        "title": "Get array with all values for certain key in JSON wih JQ"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "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": 1604469040,
                "post_id": 64674729,
                "comment_id": 114353862,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16708895,
                    "reputation": 57,
                    "user_id": 12076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Mp6X3.jpg?s=256",
                    "display_name": "n00b",
                    "link": "https://stackoverflow.com/users/12076640/n00b"
                },
                "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": 1604469451,
                "post_id": 64674729,
                "comment_id": 114353961,
                "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": 1604469718,
                "post_id": 64674729,
                "comment_id": 114354029,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16708895,
                    "reputation": 57,
                    "user_id": 12076640,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Mp6X3.jpg?s=256",
                    "display_name": "n00b",
                    "link": "https://stackoverflow.com/users/12076640/n00b"
                },
                "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": 1604469899,
                "post_id": 64674729,
                "comment_id": 114354063,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1604474706,
                "last_edit_date": 1604474706,
                "creation_date": 1604473554,
                "answer_id": 64675498,
                "question_id": 64674729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A glib answer would be to say to use the following if/then/else structure:\r\n\r\n    if .result.CVE_Items[].configurations.nodes[] | has(&quot;children&quot;)\r\n    then ...\r\n    else ...\r\n    end\r\n\r\nBut what is to say that each of the arrays has length equal to 1? Or that the item in the `nodes` array is a JSON object?\r\n\r\nSo perhaps it would be better to write something like:\r\n\r\n    .result.CVE_Items[0].configurations.nodes[0] as $node\r\n    | if ($node | ( type == &quot;object&quot; and has(&quot;children&quot;) ))\r\n      then ...\r\n      else ...\r\n      end\r\n\r\nBut the same problem exists with the rest of your query, which runs the risk not only of generating an error, but also of generating an unwanted combinatorial explosion.\r\n\r\nSo what you should probably do is introduce jq variables along the way to ensure that you are only selecting as many items as you really want, as illustrated in the following section.\r\n\r\nOn a minor note: instead of (. | E) you can simply write E.\r\n\r\n## Example\r\n```\r\n    if .totalResults == 1 \r\n    then .result.CVE_Items[] \r\n    | .cve.CVE_data_meta.ID as $ID\r\n    | .cve.description.description_data[].value as $value\r\n    | .configurations.nodes[] as $node\r\n    | if $node | (type == &quot;object&quot; and has(&quot;children&quot;))\r\n      then .impact.baseMetricV3\r\n      |  {CVE: $ID,\r\n          Description: $value, \r\n          &quot;CVSS V3 Score&quot;:  .cvssV3.baseSeverity,\r\n          &quot;Attack Vector&quot;:  .cvssV3.attackVector,\r\n          &quot;Privileges Required&quot;: .cvssV3.privilegesRequired,\r\n          &quot;User Interaction&quot;: .cvssV3.userInteraction,\r\n          &quot;Impact Score&quot;: .impactScore,\r\n          &quot;Products Affected&quot;: [$node.children[].cpe_match[].cpe23Uri]}\r\n      else {Results: .message} \r\n      end\r\n    else {Results: .message} \r\n    end\r\n\r\n```\r\n",
                "title": "How to determine if an array is present in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604481878,
                "last_edit_date": 1604481878,
                "creation_date": 1604478625,
                "answer_id": 64676493,
                "question_id": 64674729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So @peak gave me some ideas on how to solve this... this code solves it.\r\n\r\n```bash\r\ncurl -s https://services.nvd.nist.gov/rest/json/cve/1.0/CVE-2020-11066 \r\n| jq -r &#39;if .totalResults == 1 then .result.CVE_Items[] \r\n| .cve.CVE_data_meta.ID as $ID \r\n| .cve.description.description_data[].value as $value \r\n| .configurations.nodes[] as $node \r\n| if $node | (type == &quot;object&quot; and has(&quot;children&quot;)) \r\nthen .impact.baseMetricV3 | \r\n{CVE: $ID, Description: $value, \r\n&quot;CVSS V3 Score&quot;: .cvssV3.baseSeverity, \r\n&quot;Attack Vector&quot;: .cvssV3.attackVector, \r\n&quot;Privileges Required&quot;: .cvssV3.privilegesRequired, \r\n&quot;User Interaction&quot;: .cvssV3.userInteraction, \r\n&quot;Impact Score&quot;: .impactScore, \r\n&quot;Products Affected&quot;: [$node.children[].cpe_match[].cpe23Uri]} \r\nelse .impact.baseMetricV3 | \r\n{CVE: $ID, Description: $value, \r\n&quot;CVSS V3 Score&quot;: .cvssV3.baseSeverity, \r\n&quot;Attack Vector&quot;: .cvssV3.attackVector, \r\n&quot;Privileges Required&quot;: .cvssV3.privilegesRequired, \r\n&quot;User Interaction&quot;: .cvssV3.userInteraction, \r\n&quot;Impact Score&quot;: .impactScore, \r\n&quot;Products Affected&quot;: [$node.cpe_match[].cpe23Uri]} \r\nend else . | {Results: .message} end&#39;\r\n```\r\n\r\nSo basically if you follow the above answer, @peak showed us how to place an if statement to check if the object class children is present inside an if statement. The else statement fixes our issue and we are good to go.",
                "title": "How to determine if an array is present in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1604481878,
        "creation_date": 1604468101,
        "last_edit_date": 1604475419,
        "question_id": 64674729,
        "body_markdown": "Hi so I have a curl command for checking some data on an api, then using jq to parse the data for only relevant information.\r\n\r\nThe issue is some of the data contains a certain class known as `.result.CVE_Items[].configurations.nodes[].children[]` but others do not have it. So I am trying to write an if, elif and else statement that will parse the data. I am trying to figure out how to place an elif statement to check if this class is present `.result.CVE_Items[].configurations.nodes[].children[]` and if it is present for it to query the data.\r\n\r\nBelow are the two commands where one contains the class and the other one doesn&#39;t contain the class and brings an error:\r\n\r\n```bash\r\n\r\n# First command works: has the class \r\n\r\ncurl -s https://services.nvd.nist.gov/rest/json/cve/1.0/CVE-2020-12389 | jq -r &#39;if .totalResults == 1 then . | {CVE: .result.CVE_Items[].cve.CVE_data_meta.ID, Description: .result.CVE_Items[].cve.description.description_data[].value, &quot;CVSS V3 Score&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.baseSeverity, &quot;Attack Vector&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.attackVector, &quot;Privileges Required&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.privilegesRequired, &quot;User Interaction&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.userInteraction, &quot;Impact Score&quot;: .result.CVE_Items[].impact.baseMetricV3.impactScore, &quot;Products Affected&quot;: [.result.CVE_Items[].configurations.nodes[].children[].cpe_match[].cpe23Uri]} else . | {Results: .message} end&#39;\r\n\r\nOutput:\r\n\r\n{\r\n  &quot;CVE&quot;: &quot;CVE-2020-12389&quot;,\r\n  &quot;Description&quot;: &quot;The Firefox content processes did not sufficiently lockdown access control which could result in a sandbox escape. *Note: this issue only affects Firefox on Windows operating systems.*. This vulnerability affects Firefox ESR &lt; 68.8 and Firefox &lt; 76.&quot;,\r\n  &quot;CVSS V3 Score&quot;: &quot;CRITICAL&quot;,\r\n  &quot;Attack Vector&quot;: &quot;NETWORK&quot;,\r\n  &quot;Privileges Required&quot;: &quot;NONE&quot;,\r\n  &quot;User Interaction&quot;: &quot;NONE&quot;,\r\n  &quot;Impact Score&quot;: 6,\r\n  &quot;Products Affected&quot;: [\r\n    &quot;cpe:2.3:a:mozilla:firefox:*:*:*:*:*:*:*:*&quot;,\r\n    &quot;cpe:2.3:a:mozilla:firefox_esr:*:*:*:*:*:*:*:*&quot;,\r\n    &quot;cpe:2.3:o:microsoft:windows:-:*:*:*:*:*:*:*&quot;\r\n  ]\r\n}\r\n\r\n\r\n\r\n# Second command as the above but different data output and doesn&#39;t contain the class hence errors out.\r\n\r\ncurl -s https://services.nvd.nist.gov/rest/json/cve/1.0/CVE-2020-0796 | jq -r &#39;if .totalResults == 1 then . | {CVE: .result.CVE_Items[].cve.CVE_data_meta.ID, Description: .result.CVE_Items[].cve.description.description_data[].value, &quot;CVSS V3 Score&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.baseSeverity, &quot;Attack Vector&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.attackVector, &quot;Privileges Required&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.privilegesRequired, &quot;User Interaction&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.userInteraction, &quot;Impact Score&quot;: .result.CVE_Items[].impact.baseMetricV3.impactScore, &quot;Products Affected&quot;: [.result.CVE_Items[].configurations.nodes[].children[].cpe_match[].cpe23Uri]} else . | {Results: .message} end&#39;\r\n\r\nOutput:\r\n\r\njq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)\r\n\r\n# Error is mainly at the Products affected .... when you remove .children[] it works\r\n\r\n\r\ncurl -s https://services.nvd.nist.gov/rest/json/cve/1.0/CVE-2020-0796 | jq -r &#39;if .totalResults == 1 then . | {CVE: .result.CVE_Items[].cve.CVE_data_meta.ID, Description: .result.CVE_Items[].cve.description.description_data[].value, &quot;CVSS V3 Score&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.baseSeverity, &quot;Attack Vector&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.attackVector, &quot;Privileges Required&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.privilegesRequired, &quot;User Interaction&quot;: .result.CVE_Items[].impact.baseMetricV3.cvssV3.userInteraction, &quot;Impact Score&quot;: .result.CVE_Items[].impact.baseMetricV3.impactScore, &quot;Products Affected&quot;: [.result.CVE_Items[].configurations.nodes[].cpe_match[].cpe23Uri]} else . | {Results: .message} end&#39;\r\n\r\nOutput:\r\n\r\n{\r\n  &quot;CVE&quot;: &quot;CVE-2020-0796&quot;,\r\n  &quot;Description&quot;: &quot;A remote code execution vulnerability exists in the way that the Microsoft Server Message Block 3.1.1 (SMBv3) protocol handles certain requests, aka &#39;Windows SMBv3 Client/Server Remote Code Execution Vulnerability&#39;.&quot;,\r\n  &quot;CVSS V3 Score&quot;: &quot;CRITICAL&quot;,\r\n  &quot;Attack Vector&quot;: &quot;NETWORK&quot;,\r\n  &quot;Privileges Required&quot;: &quot;NONE&quot;,\r\n  &quot;User Interaction&quot;: &quot;NONE&quot;,\r\n  &quot;Impact Score&quot;: 6,\r\n  &quot;Products Affected&quot;: [\r\n    &quot;cpe:2.3:o:microsoft:windows_10:1903:*:*:*:*:*:*:*&quot;,\r\n    &quot;cpe:2.3:o:microsoft:windows_10:1909:*:*:*:*:*:*:*&quot;,\r\n    &quot;cpe:2.3:o:microsoft:windows_server_2016:1903:*:*:*:*:*:*:*&quot;,\r\n    &quot;cpe:2.3:o:microsoft:windows_server_2016:1909:*:*:*:*:*:*:*&quot;\r\n  ]\r\n}\r\n\r\n\r\n```\r\n\r\nI have tried has(&quot;children&quot;) and has(&quot;children[]&quot;) but nothing has worked and I really don&#39;t have a clue, I have checked all the github issues raised for checking an element before parsing and also did a search on stackoverflow. I have also checked the docs. I would love it to be in one command where it first check if totalResults == 1 and has(children) == false to query the information elif totalResults == 1 and has(children) == true to query the information else to print out the error message which means the data is not available.\r\n\r\nKindly assist\r\n\r\nthanks.\r\n\r\n\\n00b\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64674729/how-to-determine-if-an-array-is-present-in-jq",
        "title": "How to determine if an array is present in JQ"
    },
    {
        "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": 0,
                "creation_date": 1604481329,
                "post_id": 64677102,
                "comment_id": 114357710,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19800061,
                    "reputation": 23,
                    "user_id": 14501288,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e69893519cbd1db35c11873cc129669a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "84d7dc197",
                    "link": "https://stackoverflow.com/users/14501288/84d7dc197"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1604482057,
                "post_id": 64677102,
                "comment_id": 114358044,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604483823,
                "creation_date": 1604483823,
                "answer_id": 64677794,
                "question_id": 64677102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With really big files, I&#39;d look into a primarily disk based approach instead of trying to load everything into memory. The following script leverages sqlite&#39;s [JSON1](https://www.sqlite.org/json1.html) extension to load the JSON files into a database and generate the grouped results:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nDB=json.db\r\n\r\n# Delete existing database if any.\r\nrm -f &quot;$DB&quot;\r\n\r\n# Create table. Assuming each host,port pair is unique.\r\nsqlite3 -batch &quot;$DB&quot; &lt;&lt;&#39;EOF&#39;\r\nCREATE TABLE data(host TEXT, port INTEGER, data TEXT,\r\n                  PRIMARY KEY (host, port)) WITHOUT ROWID;\r\nEOF\r\n\r\n# Insert the objects from the files into the database.\r\nfor file in file*.json; do\r\n    sqlite3 -batch &quot;$DB&quot; &lt;&lt;EOF\r\nINSERT INTO data(host, port, data)\r\nSELECT json_extract(j, &#39;\\$.host&#39;), json_extract(j, &#39;\\$.port&#39;), json_extract(j, &#39;\\$.data&#39;)\r\nFROM (SELECT json(readfile(&#39;$file&#39;)) AS j) as json;\r\nEOF\r\ndone\r\n\r\n# And display the results of joining the objects Could use\r\n# json_group_array() instead of this sed hackery, but we&#39;re trying to\r\n# avoid building a giant string with the entire results. It might still\r\n# run into sqlite maximum string length limits...\r\nsqlite3 -batch -noheader -list &quot;$DB&quot; &lt;&lt;&#39;EOF&#39; | sed &#39;1s/^/[/; $s/,$/]/&#39;\r\nSELECT json_object(&#39;host&#39;, host,\r\n                   &#39;data&#39;, json_group_object(port, json(data))) || &#39;,&#39;\r\nFROM data\r\nGROUP BY host\r\nORDER BY host;\r\nEOF\r\n```\r\n\r\nRunning this on your sample data prints out:\r\n\r\n```none\r\n[{&quot;host&quot;:&quot;127.0.0.1&quot;,&quot;data&quot;:{&quot;80&quot;:{},&quot;443&quot;:{}}},\r\n{&quot;host&quot;:&quot;127.0.0.2&quot;,&quot;data&quot;:{&quot;502&quot;:{}}}]\r\n```",
                "title": "JQ Group Multiple Files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1604502563,
                "last_edit_date": 1604502563,
                "creation_date": 1604500136,
                "answer_id": 64681965,
                "question_id": 64677102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the goal is really to produce a single ginormous JSON entity, then presumably that entity is still small enough to have a chance of fitting into the memory of some computer, say C.  So there is a good chance of jq being up to the job on C.  At any rate, to utilize memory efficiently, you would:\r\n\r\n1. use `inputs` while performing the grouping operation;\r\n2. avoid the built-in `group_by` (since it requires an in-memory sort).\r\n\r\nHere then is a two-step candidate using jq, which assumes grouping.jq contains the following program:\r\n```\r\n# emit a stream of arrays assuming that f is always string-valued\r\ndef GROUPS_BY(stream; f): \r\n  reduce stream as $x ({}; ($x|f) as $s | .[$s] += [$x]) | .[];\r\n\r\nGROUPS_BY(inputs | .data=.port | del(.port); .host)\r\n| {host: .[0].host, data: map({(.data): {}}) | add} \r\n```\r\nIf the JSON files can be captured by `*.json`, you could then consider:\r\n\r\n    jq -n -f grouping.jq *.json | jq -s .\r\n\r\nOne advantage of this approach is that if it fails, you could try using a temporary file to hold the output of the first step, and then processing it later, either by &quot;slurping&quot; it, or perhaps more sensibly distributing it amongst several files, one per `.host`.\r\n\r\n## Removing extraneous data\r\nObviously, if the input files contain extraneous data, you might want to remove it first, e.g. by running\r\n\r\n    for f in *.json ; do\r\n      jq &#39;{host,port}&#39; &quot;$f&quot; | sponge $f\r\n    done\r\n\r\nor by performing the projection in program.jq, e.g. using:\r\n\r\n    GROUPS_BY(inputs | {host, data: .port}; .host)\r\n    | {host: .[0].host, data: map( {(.data):{}} )}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "JQ Group Multiple Files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1604557201,
                "last_edit_date": 1604557201,
                "creation_date": 1604506235,
                "answer_id": 64683688,
                "question_id": 64677102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a script which uses jq to solve the problem without requiring more memory than is needed for the largest group. For simplicity:\r\n\r\n* it reads *.json and directs output to $OUT as defined at the top of the script.\r\n* it uses `sponge`\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\n# Requires: sponge\r\n\r\nOUT=big.json\r\n\r\n/bin/rm -i &quot;$OUT&quot;\r\n\r\nif [ -s &quot;$OUT&quot; ] ; then\r\n    echo $OUT already exists\r\n    exit 1\r\nfi\r\n\r\n### Step 0: setup\r\n\r\nTDIR=$(mktemp -d /tmp/grouping.XXXX)\r\n\r\nfunction cleanup {\r\n  if [ -d &quot;$TDIR&quot; ] ; then\r\n    /bin/rm -r &quot;$TDIR&quot;\r\n  fi\r\n}\r\ntrap cleanup EXIT\r\n\r\n### Step 1: find the groups\r\n\r\nfor f in *.json ; do\r\n    host=$(jq -r &#39;.host&#39; &quot;$f&quot;)\r\n    echo &quot;$f&quot; &gt;&gt; &quot;$TDIR/$host&quot;\r\ndone\r\n\r\nfor f in $TDIR/* ; do\r\n  echo $f ...\r\n  jq -n &#39;reduce (inputs | {host, data: {(.port): {} }}) as $in (null; \r\n     .host=$in.host | .data += [$in.data])&#39; $(cat $f) | sponge &quot;$f&quot;\r\ndone\r\n\r\n### Step 2: assembly\r\ni=0\r\necho &quot;[&quot; &gt; $OUT\r\nfind $TDIR -type f | while read f ; do\r\n    i=$((i + 1))\r\n    if [ $i -gt 1 ] ; then echo , &gt;&gt; $OUT ; fi\r\n    cat &quot;$f&quot; &gt;&gt; $OUT\r\ndone    \r\necho &quot;]&quot; &gt;&gt; $OUT\r\n```\r\n\r\n## Discussion\r\nBesides requiring enough memory to handle the largest group, the main deficiencies of the above implementation are:\r\n1. it assumes that the `.host` string is suitable as a file name.  \r\n2. the resultant file is not strictly speaking pretty-printed.\r\n\r\nThese two issues could however be addressed quite easily with minor modifications to the script without requiring additional memory.\r\n\r\n",
                "title": "JQ Group Multiple Files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700853924,
                "creation_date": 1700853924,
                "answer_id": 77545296,
                "question_id": 64677102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**My propose is:** \r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host, data:(map( { (.port): {} } ))|add }&#39; | jq &#39;.&#39; -s\r\n    [\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;80&quot;: {},\r\n          &quot;443&quot;: {}\r\n        }\r\n      },\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;502&quot;: {}\r\n        }\r\n      }\r\n    ]\r\n\r\n**Explanation:**\r\n\r\nFirst we have several individual files, in our example 3:\r\n\r\n    $ cat file1.jsonl\r\n    { &quot;host&quot; : &quot;127.0.0.1&quot;, &quot;port&quot; : &quot;80&quot;, &quot;data&quot;: {}}\r\n    \r\n    $ cat file2.jsonl\r\n    { &quot;host&quot; : &quot;127.0.0.2&quot;, &quot;port&quot; : &quot;502&quot;, &quot;data&quot;: {}}\r\n    \r\n    $ cat file3.jsonl\r\n    { &quot;host&quot; : &quot;127.0.0.1&quot;, &quot;port&quot; : &quot;443&quot;, &quot;data&quot;: {}}\r\n\r\nNext, all files file*.json are joined as one, with this command:\r\n\r\n    $  jq &#39;.&#39; file*.jsonl\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;port&quot;: &quot;80&quot;,\r\n      &quot;data&quot;: {}\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n      &quot;port&quot;: &quot;502&quot;,\r\n      &quot;data&quot;: {}\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;port&quot;: &quot;443&quot;,\r\n      &quot;data&quot;: {}\r\n    }\r\n\r\nNext, we put all objects into an array (with -s parameter) :\r\n\r\n    $  jq &#39;.&#39; file*.jsonl -s\r\n    [\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n        &quot;port&quot;: &quot;80&quot;,\r\n        &quot;data&quot;: {}\r\n      },\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n        &quot;port&quot;: &quot;502&quot;,\r\n        &quot;data&quot;: {}\r\n      },\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n        &quot;port&quot;: &quot;443&quot;,\r\n        &quot;data&quot;: {}\r\n      }\r\n    ]\r\n\r\nNext, we group by .host field: (Note the output is 2 arrays contained into one array)\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)&#39;\r\n    [\r\n      [\r\n        {\r\n          &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n          &quot;port&quot;: &quot;80&quot;,\r\n          &quot;data&quot;: {}\r\n        },\r\n        {\r\n          &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n          &quot;port&quot;: &quot;443&quot;,\r\n          &quot;data&quot;: {}\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n          &quot;port&quot;: &quot;502&quot;,\r\n          &quot;data&quot;: {}\r\n        }\r\n      ]\r\n    ]\r\n\r\nNext, we avoid the outer array with this command: (now we have only 2 arrays)\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]&#39;\r\n    [\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n        &quot;port&quot;: &quot;80&quot;,\r\n        &quot;data&quot;: {}\r\n      },\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n        &quot;port&quot;: &quot;443&quot;,\r\n        &quot;data&quot;: {}\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n        &quot;port&quot;: &quot;502&quot;,\r\n        &quot;data&quot;: {}\r\n      }\r\n    ]\r\n\r\nNext, we begin to build the final object structure, with the first field &quot;host&quot;: \r\n\r\nNote the &quot;host&quot; field can be named differently, ex: &quot;my_hosts&quot;.\r\n\r\nThis first field was built with the member 0 of each of our 2 arrays.\r\n\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host }&#39;\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.1&quot;\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.2&quot;\r\n    }\r\n\r\nNext, we begin tu build the second field &quot;data&quot; in our final structure:\r\n\r\nIn this case &quot;.&quot; is each one of the arrays that cointains the grouped objects.\r\n\r\nNote here the fieldname &quot;data&quot; cuould be named as &quot;my_data&quot;.\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host ,data:(.) }&#39;\r\n    \r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n          &quot;port&quot;: &quot;80&quot;,\r\n          &quot;data&quot;: {}\r\n        },\r\n        {\r\n          &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n          &quot;port&quot;: &quot;443&quot;,\r\n          &quot;data&quot;: {}\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n          &quot;port&quot;: &quot;502&quot;,\r\n          &quot;data&quot;: {}\r\n        }\r\n      ]\r\n    }\r\n\r\nNext, we iterate of each one of the arrays (map) and we are going building small objects with one fied named as the port and its value is {} (an empty object):\r\n\r\nNote here the fieldname .port is between &quot;()&quot;,  is an expression to use the value of the port as key.\r\n\r\nNote the field &quot;data&quot; is an array of objects.\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host ,data:( map({(.port):{} }) ) }&#39;\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;80&quot;: {}\r\n        },\r\n        {\r\n          &quot;443&quot;: {}\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;502&quot;: {}\r\n        }\r\n      ]\r\n    }\r\n\r\nNext, we concatenate all the objects in the field &quot;data&quot; with the command &quot;add&quot;:\r\n\r\nNote how data has been converted from an array to an object (in this case a dictionary).\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host ,data:( map({(.port):{} })|add ) }&#39;\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;80&quot;: {},\r\n        &quot;443&quot;: {}\r\n      }\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;127.0.0.2&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;502&quot;: {}\r\n      }\r\n    }\r\n\r\nFinally, we can display the results in compact format (one object by line) with the parameter (-c):\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host ,data:( map({(.port):{} })|add ) }&#39; -c\r\n    {&quot;host&quot;:&quot;127.0.0.1&quot;,&quot;data&quot;:{&quot;80&quot;:{},&quot;443&quot;:{}}}\r\n    {&quot;host&quot;:&quot;127.0.0.2&quot;,&quot;data&quot;:{&quot;502&quot;:{}}}\r\n\r\nIf you want the results in compact format all into an array, only add jq &#39;.&#39; -s -c  to the pipe:\r\n\r\n    $ jq &#39;.&#39; file*.jsonl -s  | jq  &#39;group_by(.host)[]|{ host:.[0].host ,data:( map({(.port):{} })|add ) }&#39; -c | jq &#39;.&#39; -s -c\r\n    [{&quot;host&quot;:&quot;127.0.0.1&quot;,&quot;data&quot;:{&quot;80&quot;:{},&quot;443&quot;:{}}},{&quot;host&quot;:&quot;127.0.0.2&quot;,&quot;data&quot;:{&quot;502&quot;:{}}}]\r\n    \r\n    \r\nI hope  this explanation can be useful for you.\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": "JQ Group Multiple Files"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1700853924,
        "creation_date": 1604481122,
        "last_edit_date": 1604481793,
        "question_id": 64677102,
        "body_markdown": "I have a set of JSON that all contain JSON in the following format: \r\n\r\nFile 1: \r\n\r\n    { &quot;host&quot; : &quot;127.0.0.1&quot;, &quot;port&quot; : &quot;80&quot;, &quot;data&quot;: {}} \r\n\r\nFile 2: \r\n\r\n    { &quot;host&quot; : &quot;127.0.0.2&quot;, &quot;port&quot; : &quot;502&quot;, &quot;data&quot;: {}} \r\n\r\nFile 3:\r\n\r\n    { &quot;host&quot; : &quot;127.0.0.1&quot;, &quot;port&quot; : &quot;443&quot;, &quot;data&quot;: {}} \r\n\r\nThese files can be rather large, up to several gigabytes. \r\n\r\nI want to use JQ or some other bash json processing tool that can merge these json files into one file with a grouped format like so: \r\n\r\n    [{ &quot;host&quot; : &quot;127.0.0.1&quot;, &quot;data&quot;: {&quot;80&quot;: {}, &quot;443&quot; : {}}},\r\n    { &quot;host&quot; : &quot;127.0.0.2&quot;, &quot;data&quot;: {&quot;502&quot;: {}}}]\r\n\r\nIs this possible with jq and if yes, how could I possibly do this? I have looked at the group_by function in jq, but it seems like I need to combine all files first and then group on this big file. However, since the files can be very large, it might make sense to stream the data and group them on the fly. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/64677102/jq-group-multiple-files",
        "title": "JQ Group Multiple Files"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604501096,
                "last_edit_date": 1604501096,
                "creation_date": 1604498224,
                "answer_id": 64681439,
                "question_id": 64680963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your solution using `map_values({foo, bar})` is certainly a good candidate for being minimal, but it depends on your exact requirements.  For example, if you wanted to impose the requirement recursively, you could consider:\r\n\r\n    walk(if type==&quot;object&quot; and .foo then {foo,bar} else . end)\r\n\r\nAt least you get some mileage here by avoiding `map_values`.\r\n",
                "title": "Select keys of all subobjects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604501096,
        "creation_date": 1604496273,
        "last_edit_date": 1604496755,
        "question_id": 64680963,
        "body_markdown": "I have an input object with nested objects like this:\r\n\r\n```json\r\n{\r\n  &quot;qux&quot;: {\r\n    &quot;foo&quot;: 1,\r\n    &quot;bar&quot;: 2,\r\n    &quot;baz&quot;: 3\r\n  },\r\n  &quot;zyx&quot;: {\r\n    &quot;foo&quot;: 4,\r\n    &quot;bar&quot;: 5,\r\n    &quot;baz&quot;: 6\r\n  }\r\n}\r\n```\r\n\r\nI&#39;d like to restrict the sub-objects by the same set of keys, say `foo` and `bar`:\r\n\r\n```json\r\n{\r\n  &quot;qux&quot;: {\r\n    &quot;foo&quot;: 1,\r\n    &quot;bar&quot;: 2\r\n  },\r\n  &quot;zyx&quot;: {\r\n    &quot;foo&quot;: 4,\r\n    &quot;bar&quot;: 5\r\n  }\r\n}\r\n```\r\n\r\nI can do this with `map_values`, but it&#39;s such a basic thing I want to do that I feel like I must be missing something:\r\n\r\n```bash\r\n$ jq &#39;map_values({foo, bar})&#39; &lt;&lt;EOF\r\n{\r\n  &quot;qux&quot;: {\r\n    &quot;foo&quot;: 1,\r\n    &quot;bar&quot;: 2,\r\n    &quot;baz&quot;: 3\r\n  },\r\n  &quot;zyx&quot;: {\r\n    &quot;foo&quot;: 4,\r\n    &quot;bar&quot;: 5,\r\n    &quot;baz&quot;: 6\r\n  }\r\n}\r\nEOF\r\n{\r\n  &quot;qux&quot;: {\r\n    &quot;foo&quot;: 1,\r\n    &quot;bar&quot;: 2\r\n  },\r\n  &quot;zyx&quot;: {\r\n    &quot;foo&quot;: 4,\r\n    &quot;bar&quot;: 5\r\n  }\r\n}\r\n```\r\n\r\nIs this the simplest and most readable way of selecting a set of keys from all sub-objects?\r\n\r\nI was kind of thinking there would be a `.*.{foo, bar}` type thing.",
        "link": "https://stackoverflow.com/questions/64680963/select-keys-of-all-subobjects-with-jq",
        "title": "Select keys of all subobjects with jq"
    },
    {
        "tags": [
            "json",
            "addition",
            "jq",
            "items"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604509010,
                "last_edit_date": 1604509010,
                "creation_date": 1604508576,
                "answer_id": 64684304,
                "question_id": 64683785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If data.json contains the new data, and template.json contains the template with NEWKEY1, etc, then the following invocation produces the desired output:\r\n\r\n    jq --argfile in data.json &#39;.NEWKEY2[0].NEWKEY4 = $in[0]&#39; template.json\r\n\r\n## Quibble\r\nYes, I know that the jq manual deprecates `--argfile`, so feel free to use one of the many alternatives, but all currently available versions of jq support it, which is more than can be said for the *similar* alternatives....",
                "title": "Want to add more parent keys to JSON with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604509010,
        "creation_date": 1604506536,
        "question_id": 64683785,
        "body_markdown": "I have this JSON:\r\n\r\n    [\r\n      {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;,\r\n        &quot;key3&quot;: &quot;value3&quot;,\r\n        &quot;key4&quot;: &quot;value4,\r\n        &quot;key5&quot;: {\r\n          &quot;subkey1&quot;: &quot;subvalue1&quot;,\r\n          &quot;subkey2&quot;: &quot;subvalue2&quot;,\r\n          &quot;subkey3&quot;: &quot;subvalue3&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\ni want to build a new JSON using JQ, and add more items, let me explain, i want to get this:\r\n\r\n    {\r\n      &quot;NEWKEY1&quot;: &quot;NEWVALUE2&quot;,\r\n      &quot;NEWKEY2&quot;: [\r\n        {\r\n          &quot;NEWKEY3&quot;: &quot;UPSNEWVALUE3&quot;,\r\n          &quot;NEWKEY4&quot;: {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;,\r\n            &quot;key3&quot;: &quot;value3&quot;,\r\n            &quot;key4&quot;: &quot;value4,\r\n            &quot;key5&quot;: {\r\n              &quot;subkey1&quot;: &quot;subvalue1&quot;,\r\n              &quot;subkey2&quot;: &quot;subvalue2&quot;,\r\n              &quot;subkey3&quot;: &quot;subvalue3&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nHow i can get that? \r\n\r\nThanks all",
        "link": "https://stackoverflow.com/questions/64683785/want-to-add-more-parent-keys-to-json-with-jq",
        "title": "Want to add more parent keys to JSON with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1873273,
                    "reputation": 2651,
                    "user_id": 1695049,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2702af7f9a74cb1bae1c92e2fa701c3b?s=256&d=identicon&r=PG",
                    "display_name": "Martin",
                    "link": "https://stackoverflow.com/users/1695049/martin"
                },
                "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": 1604511419,
                "post_id": 64684980,
                "comment_id": 114371509,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1873273,
                    "reputation": 2651,
                    "user_id": 1695049,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2702af7f9a74cb1bae1c92e2fa701c3b?s=256&d=identicon&r=PG",
                    "display_name": "Martin",
                    "link": "https://stackoverflow.com/users/1695049/martin"
                },
                "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": 1604511538,
                "post_id": 64684980,
                "comment_id": 114371572,
                "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": 1604511602,
                "post_id": 64684980,
                "comment_id": 114371602,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1873273,
                    "reputation": 2651,
                    "user_id": 1695049,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2702af7f9a74cb1bae1c92e2fa701c3b?s=256&d=identicon&r=PG",
                    "display_name": "Martin",
                    "link": "https://stackoverflow.com/users/1695049/martin"
                },
                "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": 1604512197,
                "post_id": 64684980,
                "comment_id": 114371831,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1604514987,
                "last_edit_date": 1604514987,
                "creation_date": 1604512212,
                "answer_id": 64685217,
                "question_id": 64684980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.data[].content | if type == &quot;array&quot; then .[] else . end | .name?&#39;\r\n\r\n(The trailing ? is there just in case.)\r\n\r\nMore succinctly:\r\n\r\n    jq &#39;.data[].content | .name? // .[].name?&#39;",
                "title": "jq process json where an element can be an array or object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1604514987,
        "creation_date": 1604511113,
        "last_edit_date": 1604512089,
        "question_id": 64684980,
        "body_markdown": "The output from the tool I am using is creating an element in the json that is an object when there is only 1 item but an array when there is more than 1. \r\n\r\nHow do I parse this with jq to return the full list of names only from within content?\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;data block1&quot;,\r\n          &quot;content&quot;: {\r\n            &quot;name&quot;: &quot;1 bit of data&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;data block2&quot;,\r\n          &quot;content&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;first bit&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;another bit&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;last bit&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat I can&#39;t work out is how to switch depending on the type of `content`.\r\n\r\n    # jq &#39;.data[].content.name&#39; test.json\r\n    &quot;1 bit of data&quot;\r\n    jq: error (at test.json:22): Cannot index array with string &quot;name&quot;\r\n    # jq &#39;.data[].content[].name&#39; test.json\r\n    jq: error (at test.json:22): Cannot index string with string &quot;name&quot;\r\n\r\nI am sure I should be able to use `type` but my jq-fu is not strong enough!\r\n\r\n    # jq &#39;.data[].content | type==&quot;array&quot;&#39; test.json\r\n    false\r\n    true\r\n\r\n--------------\r\njq version 1.5",
        "link": "https://stackoverflow.com/questions/64684980/jq-process-json-where-an-element-can-be-an-array-or-object",
        "title": "jq process json where an element can be an array or object"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1604519617,
                "post_id": 64686634,
                "comment_id": 114374780,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1604519517,
                "creation_date": 1604519517,
                "answer_id": 64686817,
                "question_id": 64686634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key is to convert `.result` to an array of key/value pairs using `to_entries`, then outputing a set of strings (created using string interpolation) in raw mode.\r\n\r\n    % cat tmp.json\r\n    {\r\n    &quot;result&quot;: {\r\n        &quot;key1&quot;: &quot;val1&quot;,\r\n        &quot;key2&quot;: &quot;val2&quot;,\r\n        &quot;key3&quot;: &quot;val3&quot;\r\n     }\r\n    }\r\n    % jq -r &#39;{&quot;KEYS&quot;: &quot;VALUES&quot;} + .result | to_entries[] | &quot;\\(.key)\\t\\(.value)&quot;&#39; tmp.json\r\n    KEYS\tVALUES\r\n    key1\tval1\r\n    key2\tval2\r\n    key3\tval3\r\n\r\nI added the header to the input before conversion to the key/value list.",
                "title": "How to output key values from json to a table using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623927079,
                "creation_date": 1623927079,
                "answer_id": 68017865,
                "question_id": 64686634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "by adding the column call at the end the alignment will work for longer values as well ... \r\nNote the usage of the `@` char as token separator ... of course if your data contains it this will not work ... \r\n\r\n\r\n     aws cognito-idp list-user-pools --max-results 20 | \\\r\n     jq -r &#39;.UserPools[]|to_entries[]|select (.key == &quot;Name&quot;)|(&quot;\\(.key):@\\(.value)&quot;)&#39;| column -t -s&#39;@&#39;\r\n\r\noutput \r\n\r\n\r\n     Name:  corp_stg_user_pool\r\n     Name:  corp_dev_user_pool",
                "title": "How to output key values from json to a table using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1623927079,
        "creation_date": 1604518648,
        "question_id": 64686634,
        "body_markdown": "I have this json which I get from an API.\r\n\r\n    {\r\n    &quot;result&quot;: {\r\n        &quot;key1&quot;: &quot;val1&quot;,\r\n        &quot;key2&quot;: &quot;val2&quot;,\r\n        &quot;key3&quot;: &quot;val3&quot;\r\n     }\r\n    }\r\n\r\nI have the following shell script which creates headers for table in a text file. I want to extract key values from the above `result` object and put in the same text file where keys should go under `KEYS` and values under `VALUES` in the table. I am new to jq and shell and struggling to achieve this.\r\n\r\n    echo &quot;%table&quot;\r\n    echo -e &quot;KEYS\\tVALUES&quot; &gt; outputfile.txt\r\n    KEYVALS=$(curl -uuser:password \r\n    &quot;http://localhost:8080/customapi&quot;)\r\n    # here I want to split the key values using jq and write to the outputfile.txt \r\n    cat outputfile.txt\r\n\r\nOutcome I am expecting is:\r\n\r\n    KEYS      VALUES\r\n    key1      val1\r\n    key2      val2\r\n    key3      val3\r\n\r\nHow can I achieve this?",
        "link": "https://stackoverflow.com/questions/64686634/how-to-output-key-values-from-json-to-a-table-using-jq",
        "title": "How to output key values from json to a table using jq?"
    },
    {
        "tags": [
            "shell",
            "jq",
            "double-quotes"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604529464,
                "post_id": 64688691,
                "comment_id": 114378164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5161187,
                    "reputation": 365,
                    "user_id": 4132818,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://graph.facebook.com/100003527004275/picture?type=large",
                    "display_name": "Bryan Tan",
                    "link": "https://stackoverflow.com/users/4132818/bryan-tan"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604529493,
                "post_id": 64688691,
                "comment_id": 114378172,
                "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": 1604686384,
                "post_id": 64688691,
                "comment_id": 114432331,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5161187,
                    "reputation": 365,
                    "user_id": 4132818,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://graph.facebook.com/100003527004275/picture?type=large",
                    "display_name": "Bryan Tan",
                    "link": "https://stackoverflow.com/users/4132818/bryan-tan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604710037,
                "post_id": 64688691,
                "comment_id": 114438982,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1604530040,
                "last_edit_date": 1604530040,
                "creation_date": 1604529664,
                "answer_id": 64688739,
                "question_id": 64688691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The dollar must be escaped when used inside a [double quoted string][1] in the shell. Otherwise the shell would interpret it and expand the statement to:\r\n\r\n    jq --argjson value &#39;{&quot;foo&quot;: &quot;bar&quot;, &quot;bar&quot;: &quot;foo&quot;}&#39; &quot;.x = &quot; &lt;&lt;&lt; &quot;$json&quot;\r\n                         empty since not set in the shell  ^^^\r\n\r\nI suggest to wrap the jq command in single quotes:\r\n\r\n    jq --argjson value &#39;{&quot;foo&quot;: &quot;bar&quot;, &quot;bar&quot;: &quot;foo&quot;}&#39; &#39;.x = $value&#39; &lt;&lt;&lt; &quot;$json&quot;\r\n\r\n\r\n  [1]: https://www.gnu.org/software/bash/manual/html_node/Double-Quotes.html",
                "title": "How do you assign json objects in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604534037,
        "creation_date": 1604529312,
        "last_edit_date": 1604534037,
        "question_id": 64688691,
        "body_markdown": "I tried `jq --argjson value &#39;{&quot;foo&quot;: &quot;bar&quot;, &quot;bar&quot;: &quot;foo&quot;}&#39; &quot;.x = $value&quot; &lt;&lt;&lt; &quot;$json&quot;`\r\n\r\nValue of $json\r\n```\r\n{\r\n   &quot;x&quot;:{\r\n      &quot;foo&quot;: &quot;hello&quot;\r\n   },\r\n   &quot;y&quot;:{\r\n      &quot;foo&quot;: &quot;world&quot;\r\n   }\r\n}\r\n```\r\n\r\nAll I get is `jq: 1 compile error`\r\n\r\nI expect:\r\n\r\n```\r\n{\r\n   &quot;x&quot;:{\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;bar&quot;: &quot;foo&quot;\r\n   },\r\n   &quot;y&quot;:{\r\n      &quot;foo&quot;: &quot;world&quot;\r\n   }\r\n}\r\n```\r\nI&#39;ve tried adding quotes around $value but it complains about bash quoting issues, and I believe it&#39;s trying to save the entire json object as a string\r\n      ",
        "link": "https://stackoverflow.com/questions/64688691/how-do-you-assign-json-objects-in-jq",
        "title": "How do you assign json objects in jq?"
    },
    {
        "tags": [
            "json",
            "max",
            "jq",
            "min"
        ],
        "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": 1604599337,
                "post_id": 64698091,
                "comment_id": 114402945,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1633128868,
                "last_edit_date": 1633128868,
                "creation_date": 1604595250,
                "answer_id": 64701732,
                "question_id": 64698091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    ([ .[].number ] | min) as $m| map(select(.number== $m))\r\n\r\nSee https://jqplay.org/s/bUwtNrfAE-\r\n\r\n## first\r\n\r\nTo retrieve the first minimal item:\r\n\r\n    ([ .[].number ] | min) as $m| first(.[]|select(.number== $m))\r\n\r\n\r\n## min_by, minimal_by, etc\r\n\r\njq has the built-ins `max_by` and `min_by`, as documented at\r\nhttps://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions\r\n\r\nFor a definition of `maximal_by`, see the jq cookbook at https://github.com/stedolan/jq/wiki/Cookbook#find-the-maximal-elements-of-an-array-or-stream. That section also has stream-oriented definitions.",
                "title": "jq select record from array with min or max value of field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1703250655,
        "creation_date": 1604582479,
        "last_edit_date": 1703250655,
        "question_id": 64698091,
        "body_markdown": "I have a json with records like this:\r\n\r\n```\r\n[\r\n {&quot;number&quot;:1},\r\n {&quot;number&quot;:3}\r\n]\r\n```\r\n\r\nand want to select (filter) a record with a max or min value of the field &quot;number&quot;.\r\n\r\nI can get a min or max value of &quot;number&quot; like this:\r\n\r\n`$ echo &#39;[{&quot;number&quot;:1},{&quot;number&quot;:3}]&#39; | jq &#39; [ .[].number ] | min&#39;`\r\n\r\n(emits 1)\r\n\r\nand I can output booleans:\r\n\r\n```\r\n$ echo &#39;[{&quot;number&quot;:1},{&quot;number&quot;:3}]&#39; | jq &#39;.[].number==([ .[].number ] | min)&#39;\r\ntrue\r\nfalse\r\n```\r\n\r\nbut when I try to put that together with select, it fails:\r\n\r\n```\r\n$ echo &#39;[{&quot;number&quot;:1},{&quot;number&quot;:3}]&#39; | jq &#39;map(select(.[].number==([ .[].number ] | min)))&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with string &quot;number&quot;\r\n```\r\n\r\nI feel like I am close, but stuck. What am I doing wrong? \r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/64698091/jq-select-record-from-array-with-min-or-max-value-of-field",
        "title": "jq select record from array with min or max value of field"
    },
    {
        "tags": [
            "json",
            "jq",
            "destructuring"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604617708,
                "last_edit_date": 1604617708,
                "creation_date": 1604603446,
                "answer_id": 64703845,
                "question_id": 64700815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to generate the output you expect is by using `? //` rather than `?//`:\r\n\r\n```\r\n.data[]\r\n| (.details | (.colour? // (.[] | .colour))) as $colour\r\n| &quot;\\(.fruit) - \\($colour)&quot;\r\n\r\n```\r\n\r\nAs for `?//`, you might be barking up the wrong tree: the destructuring-alternative operator is not stream-oriented. That is, when a non-empty array is matched with [$foo], $foo will only match the first item in the array, not the items in sequence.  \r\n\r\nHowever, if you really wanted to use `?//`, for your particular case you could write:\r\n```\r\n.data[]\r\n| .details as [$colour1, $colour2] ?// $colour1\r\n| &quot;\\(.fruit) - \\($colour1|.colour)&quot;,\r\n  &quot;\\(.fruit) - \\($colour2//empty|.colour)&quot;\r\n```\r\n",
                "title": "Using the Destructuring Alternative Operator ?// in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604648243,
        "creation_date": 1604592020,
        "last_edit_date": 1604648243,
        "question_id": 64700815,
        "body_markdown": "In the latest jq version 1.6 there is a feature [Destructuring Alternative Operator: ?//][1] I am trying to use this to parse my *clumsily converted XML*.\r\n\r\nThis is the simplified example I have been playing with on [jq play][2]:\r\n\r\n    {&quot;data&quot;:[\r\n        {&quot;fruit&quot;:&quot;orange&quot;,&quot;details&quot;:  {&quot;colour&quot;:&quot;orange&quot;}},\r\n        {&quot;fruit&quot;:&quot;apple&quot;, &quot;details&quot;: [{&quot;colour&quot;:&quot;red&quot;},{&quot;colour&quot;:&quot;green&quot;}]}\r\n    ]}\r\n\r\nThe key point is sometimes `details` is an object and sometimes it&#39;s an array of objects, and to quote from the doc *&quot;We can use the destructuring alternative operator to handle this structural change simply&quot;*\r\n\r\nIf I change the input data so `details` is always an array I can easily create [the output I want][3]\r\n\r\n    .data[] | &quot;\\(.fruit) - \\(.details[].colour)&quot;\r\n\r\n\r\n    {&quot;data&quot;:[\r\n        {&quot;fruit&quot;:&quot;orange&quot;,&quot;details&quot;: [{&quot;colour&quot;:&quot;orange&quot;}]},\r\n        {&quot;fruit&quot;:&quot;apple&quot;, &quot;details&quot;: [{&quot;colour&quot;:&quot;red&quot;},{&quot;colour&quot;:&quot;green&quot;}]}\r\n    ]}\r\n\r\n\r\n    &quot;orange - orange&quot;\r\n    &quot;apple - red&quot;\r\n    &quot;apple - green&quot;\r\n\r\nHowever using the original data with ?// the best [I can come up with][4] is:\r\n\r\n    .data[] as {$fruit, details: $colour} ?// {$fruit, details: $colour} | &quot;\\($fruit) - \\($colour)&quot;\r\n\r\n    &quot;orange - {\\&quot;colour\\&quot;:\\&quot;orange\\&quot;}&quot;\r\n    &quot;apple - [{\\&quot;colour\\&quot;:\\&quot;red\\&quot;},{\\&quot;colour\\&quot;:\\&quot;green\\&quot;}]&quot;\r\n\r\n[and this][5] (which is pretty much a copy of [one of the examples][6]):\r\n\r\n    .data[] as {$fruit, details: {$colour}} ?// {$fruit, details: [{$colour}]} | &quot;\\($fruit) - \\($colour)&quot;\r\n\r\n    &quot;orange - orange&quot;\r\n    &quot;apple - red&quot;\r\n\r\nThere are [solutions using if else][7] but I am particularly interested in how this feature works and what I need to do to get it to create the output I want.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Advancedfeatures\r\n  [2]: https://jqplay.org/\r\n  [3]: https://jqplay.org/s/SMLuwux5R8\r\n  [4]: https://jqplay.org/s/s7kAODIcj1\r\n  [5]: https://jqplay.org/s/jOVViuXLZ2\r\n  [6]: https://jqplay.org/jq?q=.%5B%5D%20as%20%7B%24a%2C%20%24b%2C%20c%3A%20%7B%24d%7D%7D%20%3F%2F%2F%20%7B%24a%2C%20%24b%2C%20c%3A%20%5B%7B%24e%7D%5D%7D%20%7C%20%7B%24a%2C%20%24b%2C%20%24d%2C%20%24e%7D&amp;j=%5B%7B%22a%22%3A%201%2C%20%22b%22%3A%202%2C%20%22c%22%3A%20%7B%22d%22%3A%203%2C%20%22e%22%3A%204%7D%7D%2C%20%7B%22a%22%3A%201%2C%20%22b%22%3A%202%2C%20%22c%22%3A%20%5B%7B%22d%22%3A%203%2C%20%22e%22%3A%204%7D%5D%7D%5D\r\n  [7]: https://jqplay.org/s/ijrzPQXykC",
        "link": "https://stackoverflow.com/questions/64700815/using-the-destructuring-alternative-operator-in-jq",
        "title": "Using the Destructuring Alternative Operator ?// in 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": 1604647437,
                "post_id": 64709503,
                "comment_id": 114416010,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6633846,
                    "reputation": 3,
                    "user_id": 14588251,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/673aca4872a0e2d96cab34df739b213a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chay Shioi",
                    "link": "https://stackoverflow.com/users/14588251/chay-shioi"
                },
                "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": 1604650085,
                "post_id": 64709503,
                "comment_id": 114416922,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1604646907,
                "last_edit_date": 1604646907,
                "creation_date": 1604646393,
                "answer_id": 64710202,
                "question_id": 64709503,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The posted JSON is not quite valid, so the following assumes the superfluous comma has been removed.\r\n\r\n2. With the corrected JSON, the posted program produces what one would expect:\r\n```\r\n{\r\n  &quot;UserStatus&quot;: &quot;FORCE_CHANGE_PASSWORD&quot;,\r\n  &quot;Values&quot;: [\r\n    &quot;&quot;,\r\n    &quot;true&quot;,\r\n    &quot;jane@example.com&quot;\r\n  ]\r\n}\r\n```\r\n3. Since you indicate you only want the email address, you will probably want something closer to:\r\n```\r\n.Users[]\r\n| select(.UserStatus | contains(&quot;FORCE_CHANGE_PASSWORD&quot;))\r\n| {UserStatus, email: (.Attributes | from_entries.email) }\r\n\r\n```\r\nwhich produces:\r\n```\r\n{\r\n  &quot;UserStatus&quot;: &quot;FORCE_CHANGE_PASSWORD&quot;,\r\n  &quot;email&quot;: &quot;jane@example.com&quot;\r\n}\r\n```\r\n\r\nOr for just the value of .email:\r\n```\r\n.Users[]\r\n| select(.UserStatus | contains(&quot;FORCE_CHANGE_PASSWORD&quot;))\r\n| .Attributes[]\r\n| select(.Name == &quot;email&quot;).Value\r\n```\r\n\r\n4. If you want to filter based on .UserStatus being equal to &quot;FORCE_CHANGE_PASSWORD&quot;, you would of course use `==`.\r\n\r\n5. Notice that `UserStatus: .UserStatus` can be abbreviated to just `UserStatus` within a literal object specification.\r\n",
                "title": "Filter JSON based on value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604646907,
        "creation_date": 1604641818,
        "last_edit_date": 1604646709,
        "question_id": 64709503,
        "body_markdown": "I am looking to grab the email address only from the records with the UserStatus = FORCE_CHANGE_PASSWORD.\r\n\r\n```\r\n{\r\n    &quot;Users&quot;: [\r\n        {\r\n            &quot;Username&quot;: &quot;&quot;,\r\n            &quot;Attributes&quot;: [\r\n                {\r\n                    &quot;Name&quot;: &quot;sub&quot;,\r\n                    &quot;Value&quot;: &quot;&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;email_verified&quot;,\r\n                    &quot;Value&quot;: &quot;true&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;email&quot;,\r\n                    &quot;Value&quot;: &quot;john@example.com&quot;\r\n                }\r\n            ],\r\n            &quot;UserCreateDate&quot;: &quot;&quot;,\r\n            &quot;UserLastModifiedDate&quot;: &quot;&quot;,\r\n            &quot;Enabled&quot;: true,\r\n            &quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n        },\r\n\t\t{\r\n            &quot;Username&quot;: &quot;&quot;,\r\n            &quot;Attributes&quot;: [\r\n                {\r\n                    &quot;Name&quot;: &quot;sub&quot;,\r\n                    &quot;Value&quot;: &quot;&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;email_verified&quot;,\r\n                    &quot;Value&quot;: &quot;true&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;email&quot;,\r\n                    &quot;Value&quot;: &quot;jane@example.com&quot;\r\n                }\r\n            ],\r\n            &quot;UserCreateDate&quot;: &quot;&quot;,\r\n            &quot;UserLastModifiedDate&quot;: &quot;&quot;,\r\n            &quot;Enabled&quot;: true,\r\n            &quot;UserStatus&quot;: &quot;FORCE_CHANGE_PASSWORD&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nI&#39;ve got the following expression below to work but now I need to figure out how to fetch the 3rd Value key that contains the email address while omitting the first 2 Value keys.\r\n\r\n```\r\njq &quot;.Users[] | select(.UserStatus | contains(\\&quot;FORCE_CHANGE_PASSWORD\\&quot;)) | {UserStatus: .UserStatus, Values: [.Attributes[].Value]}&quot; userlist.json\r\n```",
        "link": "https://stackoverflow.com/questions/64709503/filter-json-based-on-value",
        "title": "Filter JSON based on value"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1604654920,
                "post_id": 64711904,
                "comment_id": 114418840,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4102742,
                    "reputation": 5,
                    "user_id": 3367760,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13cf15f029294a5cd2f1c1ef802cc53e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3367760",
                    "link": "https://stackoverflow.com/users/3367760/user3367760"
                },
                "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": 1604666746,
                "post_id": 64711904,
                "comment_id": 114423678,
                "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": 1604679233,
                "post_id": 64711904,
                "comment_id": 114429382,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1604694927,
                "last_edit_date": 1604694927,
                "creation_date": 1604678104,
                "answer_id": 64717801,
                "question_id": 64711904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Presumably you would want the output to be grouped by row, so let&#39;s first consider:\r\n\r\n    .rows[].cells\r\n    | map(select(.columnId==&quot;nameColumn&quot; or .columnId==&quot;infoColumn&quot;))\r\n\r\nThis produces a stream of JSON arrays, the first of which using your main example would be:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;columnId&quot;: &quot;nameColumn&quot;,\r\n    &quot;value&quot;: &quot;name1&quot;\r\n  },\r\n  {\r\n    &quot;columnId&quot;: &quot;infoColumn&quot;,\r\n    &quot;value&quot;: &quot;info1&quot;\r\n  }\r\n]\r\n```\r\n\r\nIf you want the output in some alternative format, then you could tweak the above jq program accordingly.\r\n\r\nIf you wanted to select a large number of columns, the use of a long &quot;or&quot; expression might become unwieldy, so you might also want to consider using a &quot;whitelist&quot;. See e.g. https://stackoverflow.com/questions/43833974/whitelisting-objects-using-select\r\n\r\nOr you might want to use `del` to delete the unwanted columns.\r\n\r\n## Producing CSV\r\nOne way would be to use `@csv` with the -r command-line option, e.g. with:\r\n\r\n```.rows[].cells\r\n| map(select(.columnId==&quot;nameColumn&quot; or .columnId==&quot;infoColumn&quot;)\r\n      | {(.columnId): .value} )\r\n| add\r\n| [.nameColumn, .infoColumn]\r\n| @csv\r\n```\r\n\r\n\r\n",
                "title": "jq - retrieve values from json table on one line for specific columns"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604694927,
        "creation_date": 1604654555,
        "last_edit_date": 1604690244,
        "question_id": 64711904,
        "body_markdown": "I&#39;m trying to get cell values from a json formatted table but only for specific columns and have it output into its own object.\r\n\r\njson example -\r\n\r\n```\r\n{\r\n   &quot;rows&quot;:[\r\n      {\r\n         &quot;id&quot;:409363222161284,\r\n         &quot;rowNumber&quot;:1,\r\n         &quot;cells&quot;:[\r\n            {\r\n               &quot;columnId&quot;:&quot;nameColumn&quot;,\r\n               &quot;value&quot;:&quot;name1&quot;\r\n            },\r\n            {\r\n               &quot;columnId&quot;:&quot;infoColumn&quot;,\r\n               &quot;value&quot;:&quot;info1&quot;\r\n            },\r\n            {\r\n               &quot;columnId&quot;:&quot;excessColumn&quot;,\r\n               &quot;value&quot;:&quot;excess1&quot;\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;id&quot;:11312541213,\r\n         &quot;rowNumber&quot;:2,\r\n         &quot;cells&quot;:[\r\n            {\r\n               &quot;columnId&quot;:&quot;nameColumn&quot;,\r\n               &quot;value&quot;:&quot;name2&quot;\r\n            },\r\n            {\r\n               &quot;columnId&quot;:&quot;infoColumn&quot;,\r\n               &quot;value&quot;:&quot;info2&quot;\r\n            },\r\n            {\r\n               &quot;columnId&quot;:&quot;excessColumn&quot;,\r\n               &quot;value&quot;:&quot;excess2&quot;\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;id&quot;:11312541213,\r\n         &quot;rowNumber&quot;:3,\r\n         &quot;cells&quot;:[\r\n            {\r\n               &quot;columnId&quot;:&quot;nameColumn&quot;,\r\n               &quot;value&quot;:&quot;name3&quot;\r\n            },\r\n            {\r\n               &quot;columnId&quot;:&quot;infoColumn&quot;,\r\n               &quot;value&quot;:&quot;info3&quot;\r\n            },\r\n            {\r\n               &quot;columnId&quot;:&quot;excessColumn&quot;,\r\n               &quot;value&quot;:&quot;excess3&quot;\r\n            }\r\n         ]\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nIdeal output would be filtered by two columns - **nameColumn**, **infoColumn** - with each row being a single line of the values. \r\n\r\nOutput example - \r\n\r\n```\r\n{ \r\n  &quot;name&quot;: &quot;name1&quot;,\r\n  &quot;info&quot;: &quot;info1&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;name2&quot;,\r\n  &quot;info&quot;: &quot;info2&quot;\r\n}\r\n{ \r\n  &quot;name&quot;: &quot;name3&quot;,\r\n  &quot;info&quot;: &quot;info3&quot;\r\n}\r\n```\r\nI&#39;ve tried quite a few different combinations of things with select statements and this is the closest I&#39;ve come but it only uses one. \r\n\r\n```\r\njq &#39;.rows[].cells[] | {name: (select(.columnId==&quot;nameColumn&quot;) .value), info: &quot;infoHereHere&quot;}&#39;\r\n\r\n{ \r\n  &quot;name&quot;: &quot;name1&quot;,\r\n  &quot;info&quot;: &quot;infoHere&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;name2&quot;,\r\n  &quot;info&quot;: &quot;infoHere&quot;\r\n}\r\n{ \r\n  &quot;name&quot;: &quot;name3&quot;,\r\n  &quot;info&quot;: &quot;infoHere&quot;\r\n}\r\n```\r\n\r\nIf I try to combine another one, it&#39;s not so happy. \r\n```\r\njq -j &#39;.rows[].cells[] | {name: (select(.columnId==&quot;nameColumn&quot;) .value), info: (select(.columnId==&quot;infoColumn&quot;) .value)}&#39;\r\n```\r\nNothing is output.\r\n\r\n** Edit **\r\nApologies for being unclear with this. The final output would ideally be a csv for the selected columns values\r\n\r\n```\r\nname1,info1\r\nname2,info2\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/64711904/jq-retrieve-values-from-json-table-on-one-line-for-specific-columns",
        "title": "jq - retrieve values from json table on one line for specific columns"
    },
    {
        "tags": [
            "json",
            "shell",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604690276,
                "creation_date": 1604690276,
                "answer_id": 64720434,
                "question_id": 64719770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is quite simple once you figure out how to find the difference among two list items and add/unique them. One way would be to\r\n\r\n    jq --slurpfile s 2.json -f script.jq 1.json\r\n\r\nWhere my script contents are\r\n\r\n    #!/usr/bin/env jq -f\r\n    \r\n    # backup list_1, list_2 from 1.json\r\n    .list_1 as $l1  |\r\n    .list_2 as $l2  |\r\n    # Perform the operation of removing file1 keys not present in 2.json\r\n    # for both list_1 and list_2\r\n    ( ( $l1 - ( $l1 - $s[].list_1 ) ) +  $s[].list_1 | unique ) as $f1 |\r\n    ( ( $l2 - ( $l2 - $s[].list_2 ) ) +  $s[].list_2 | unique ) as $f2 |\r\n    # Update the original result 1.json with the modified content\r\n    .list_1 |= $f1 |\r\n    .list_2 |= $f2\r\n\r\nor directly from the command line as\r\n\r\n    jq --slurpfile s 2.json &#39;\r\n      .list_1 as $l1  |\r\n      .list_2 as $l2  |\r\n      ( ( $l1 - ( $l1 - $s[].list_1 ) ) +  $s[].list_1 | unique ) as $f1 |\r\n      ( ( $l2 - ( $l2 - $s[].list_2 ) ) +  $s[].list_2 | unique ) as $f2 |\r\n      .list_1 |= $f1 |\r\n      .list_2 |= $f2\r\n    &#39; 1.json",
                "title": "Remove mismatch and add missing json jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604690276,
        "creation_date": 1604686863,
        "question_id": 64719770,
        "body_markdown": "Hi I have two file for example: \r\n\r\nfile1.json \r\n\r\n    {\r\n      &quot;id&quot;: &quot;001&quot;,\r\n      &quot;name&quot; : &quot;my_policy&quot;,\r\n    \r\n      &quot;list_1&quot;: [&quot;111111111&quot;, &quot;22222222&quot;,&quot;33333333&quot;],\r\n      &quot;list_2&quot;: [&quot;a&quot;, &quot;b&quot;,&quot;c&quot;],\r\n      .....\r\n    }\r\n\r\nThen I have file2.json (not always has the same field as f1) \r\n\r\n    {    \r\n      &quot;list_1&quot;: [&quot;111111111&quot;,&quot;111111122&quot;,&quot;33333333&quot;],\r\n      &quot;list_2&quot;: [&quot;a&quot;, &quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;],\r\n      .....\r\n    }\r\n\r\nHow I can via jq merge same keys  values in the two file json and in addiction to the merge operation remove from file1 keys the values non present in file2 ? \r\nSo get this result:\r\n\r\n    {\r\n     &quot;id&quot;: &quot;001&quot;,\r\n     &quot;policy&quot; : &quot;my_policy&quot;,\r\n     &quot;list_1&quot;: [&quot;111111111&quot;,&quot;111111122&quot;,&quot;33333333&quot;],\r\n     &quot;list_2&quot;: [&quot;a&quot;, &quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;],\r\n      .....\r\n    }\r\n                        \r\nI solved the merge operation via:\r\n\r\n    jq -s &#39;reduce .[] as $item ({}; reduce ($item | keys_unsorted[]) as $key (.; $item[$key] as $val | ( $val | type) as $ type | .[$key] = if ( $type == &quot;array&quot;) then (.[$key] + $val | unique) elif ($type == &quot;object&quot;) then (.[$key] + $val) else $val end ))&#39; file1.json f2.json\r\n\r\nHow I can solve? Or is impossible via jq?",
        "link": "https://stackoverflow.com/questions/64719770/remove-mismatch-and-add-missing-json-jq",
        "title": "Remove mismatch and add missing json jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1604772065,
                "last_edit_date": 1604772065,
                "creation_date": 1604755687,
                "answer_id": 64728157,
                "question_id": 64727825,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use `flatten` to explode/flatten the arrays first, before you can store the data as CSV. This will create a record for each element of the array.\r\n```bash\r\n$ jq -r &#39;flatten | @csv&#39; output2.json\r\n&quot;193.176.211.70&quot;,&quot;2697131889764497b2beef1bac8e742d&quot;\r\n&quot;193.176.211.70&quot;,&quot;2697131889764497b2beef1bac8e742d&quot;\r\n&quot;205.169.39.30&quot;\r\n&quot;65.155.30.101&quot;\r\n&quot;45.64.241.129&quot;,&quot;2697131889764497b2beef1bac8e742d&quot;\r\n&quot;45.64.241.129&quot;,&quot;2697131889764497b2beef1bac8e742d&quot;\r\n```",
                "title": "jq error “object is not valid in a csv row”"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1604772065,
        "creation_date": 1604753387,
        "question_id": 64727825,
        "body_markdown": "I&#39;m trying to convert a json object into csv via jq. The following is the sample structure:\r\n\r\n    [\r\n      &quot;193.176.211.70&quot;,\r\n      [\r\n        &quot;2697131889764497b2beef1bac8e742d&quot;\r\n      ]\r\n    ]\r\n    [\r\n      &quot;193.176.211.70&quot;,\r\n      [\r\n        &quot;2697131889764497b2beef1bac8e742d&quot;\r\n      ]\r\n    ]\r\n    [\r\n      &quot;205.169.39.30&quot;,\r\n      []\r\n    ]\r\n    [\r\n      &quot;65.155.30.101&quot;,\r\n      []\r\n    ]\r\n    [\r\n      &quot;45.64.241.129&quot;,\r\n      [\r\n        &quot;2697131889764497b2beef1bac8e742d&quot;\r\n      ]\r\n    ]\r\n    [\r\n      &quot;45.64.241.129&quot;,\r\n      [\r\n        &quot;2697131889764497b2beef1bac8e742d&quot;\r\n      ]\r\n    ]\r\n\r\nTried with ```jq -r &#39;. | @csv&#39; output2.json &gt; output.csv``` but it returns ```jq: error (at output2.json:9486): array ([&quot;269713188...) is not valid in a csv row``` \r\n\r\nReferring to the only question related to jq on stackoverflow, is not working either\r\nAny advice?",
        "link": "https://stackoverflow.com/questions/64727825/jq-error-object-is-not-valid-in-a-csv-row",
        "title": "jq error “object is not valid in a csv row”"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5937190,
                    "reputation": 647,
                    "user_id": 4669759,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/BXLwK.jpg?s=256",
                    "display_name": "Nikit Swaraj",
                    "link": "https://stackoverflow.com/users/4669759/nikit-swaraj"
                },
                "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": 1604815248,
                "post_id": 64731626,
                "comment_id": 114458692,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1604834091,
                "last_edit_date": 1604834091,
                "creation_date": 1604815213,
                "answer_id": 64735253,
                "question_id": 64731626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am able to resolve it via script. Basically, I was struggling with single quotes and double qoutes. \r\n\r\nBelow is the sample script\r\n\r\n    #!/bin/bash\r\n    \r\n    if [ -f ./serv_details.json ]; \r\n    then \r\n        arrayCount=`jq &#39;.server_details | length&#39; ./serv_details.json`\r\n        for (( ac=0; ac&lt;arrayCount; ac++ ))\r\n        do \r\n            SITE=$(jq -r &quot;.server_details[$ac].site&quot; serv.json)\r\n            LOC=$(jq -r &quot;.server_details[$ac].environment&quot; serv.json )\r\n            SEQ=$(jq -r &quot;.server_details[$ac].seqNo&quot; serv.json)\r\n            HO=`./hostsample.sh $SITE $LOC $SEQ`;   # It generates the concated Value\r\n            echo $HO\r\n            cat serv.json | jq &#39;.server_details[&#39;&quot;$ac&quot;&#39;] += {&quot;hostname&quot;: &quot;&#39;&quot;$HO&quot;&#39;&quot;}&#39; | sponge serv.json\r\n            \r\n        done\r\n    else\r\n        echo &quot;pls pass the value file&quot;\r\n    fi\r\n\r\n\r\n\r\n\r\nThen the output will be\r\n\r\n    {\r\n      &quot;server_details&quot;: [\r\n        {\r\n          &quot;seqNo&quot;: &quot;01&quot;,\r\n          &quot;storage&quot;: &quot;IBM&quot;,\r\n          &quot;datastore&quot;: &quot;IDS-G400-VS-DC-DE-T2-P01-NR02&quot;,\r\n          &quot;cpu&quot;: 4,\r\n          &quot;site&quot;: &quot;SGDC&quot;,\r\n          &quot;servertype&quot;: &quot;Virtual Machine&quot;,\r\n          &quot;location&quot;: &quot;Serangoon&quot;,\r\n          &quot;operatingsystem&quot;: &quot;Linux&quot;,\r\n          &quot;systemcode&quot;: &quot;BOC&quot;,\r\n          &quot;ram&quot;: 64,\r\n          &quot;databasesoftware&quot;: &quot;MSSQL 2016&quot;,\r\n          &quot;usagetype&quot;: &quot;Database Server&quot;,\r\n          &quot;environment&quot;: &quot;Production_WithCustData&quot;,\r\n          &quot;domain&quot;: &quot;DAPAC&quot;,\r\n          &quot;IPAddress&quot;: &quot;10.117.254.25&quot;,\r\n          &quot;DNS&quot;: &quot;10.118.76.34&quot;,\r\n          &quot;Gateway&quot;: &quot;10.118.76.1&quot;,\r\n          &quot;drives&quot;: [\r\n            {\r\n              &quot;C&quot;: &quot;100&quot;\r\n            },\r\n            {\r\n              &quot;D&quot;: &quot;50&quot;\r\n            }\r\n          ],\r\n          &quot;hostname&quot;: &quot;SGDS01&quot;\r\n        },\r\n        {\r\n          &quot;seqNo&quot;: &quot;02&quot;,\r\n          &quot;storage&quot;: &quot;HITACHI&quot;,\r\n          &quot;datastore&quot;: &quot;HDS-G400-VS-DC-DE-T2-P01-NR02&quot;,\r\n          &quot;cpu&quot;: 4,\r\n          &quot;site&quot;: &quot;SGDR&quot;,\r\n          &quot;servertype&quot;: &quot;Virtual Machine&quot;,\r\n          &quot;location&quot;: &quot;DRC&quot;,\r\n          &quot;operatingsystem&quot;: &quot;Windows&quot;,\r\n          &quot;systemcode&quot;: &quot;WOC&quot;,\r\n          &quot;ram&quot;: 64,\r\n          &quot;databasesoftware&quot;: &quot;NA&quot;,\r\n          &quot;usagetype&quot;: &quot;Web Server&quot;,\r\n          &quot;environment&quot;: &quot;Production_NonCustData&quot;,\r\n          &quot;domain&quot;: &quot;DAPAC&quot;,\r\n          &quot;IPAddress&quot;: &quot;10.117.254.26&quot;,\r\n          &quot;DNS&quot;: &quot;10.118.76.34&quot;,\r\n          &quot;Gateway&quot;: &quot;10.118.76.1&quot;,\r\n          &quot;drives&quot;: [\r\n            {\r\n              &quot;C&quot;: &quot;100&quot;\r\n            },\r\n            {\r\n              &quot;D&quot;: &quot;50&quot;\r\n            }\r\n          ],\r\n          &quot;hostname&quot;: &quot;SGDD02&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "Extract the key/value pair from all blocks of JSON Array and then append it as new key/value pair in each block of JSON Array using BASH and JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604834091,
        "creation_date": 1604777685,
        "question_id": 64731626,
        "body_markdown": "I am trying to create a script that extracts a few key/value from all the blocks of an array and then run another shell script using that value to generate a new value and then append that new key/value in all the blocks respectively. \r\n\r\nfor e.g,\r\n\r\nserverdetails.json file\r\n\r\n    {\r\n      &quot;server_details&quot;: [\r\n        {\r\n          &quot;seqNo&quot;: &quot;01&quot;,\r\n          &quot;storage&quot;: &quot;IBM&quot;,\r\n          &quot;datastore&quot;: &quot;IDS-NR02&quot;,\r\n          &quot;cpu&quot;: 4,\r\n          &quot;site&quot;: &quot;SGDC&quot;,\r\n          &quot;servertype&quot;: &quot;Virtual Machine&quot;,\r\n          &quot;location&quot;: &quot;Serangoon&quot;,\r\n          &quot;operatingsystem&quot;: &quot;Linux&quot;,\r\n          &quot;systemcode&quot;: &quot;BOC&quot;,\r\n          &quot;ram&quot;: 64,\r\n          &quot;databasesoftware&quot;: &quot;MSSQL 2016&quot;,\r\n          &quot;usagetype&quot;: &quot;Database Server&quot;,\r\n          &quot;environment&quot;: &quot;Production_WithCustData&quot;,\r\n          &quot;domain&quot;: &quot;DAPAC&quot;,\r\n          &quot;IPAddress&quot;: &quot;10.117.254.25&quot;,\r\n          &quot;DNS&quot;: &quot;10.118.76.34&quot;,\r\n          &quot;Gateway&quot;: &quot;10.118.76.1&quot;,\r\n          &quot;drives&quot;: [\r\n            {\r\n              &quot;C&quot;: &quot;100&quot;\r\n            },\r\n            {\r\n              &quot;D&quot;: &quot;50&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;seqNo&quot;: &quot;02&quot;,\r\n          &quot;storage&quot;: &quot;HITACHI&quot;,\r\n          &quot;datastore&quot;: &quot;HDS-NR02&quot;,\r\n          &quot;cpu&quot;: 4,\r\n          &quot;site&quot;: &quot;SGDR&quot;,\r\n          &quot;servertype&quot;: &quot;Virtual Machine&quot;,\r\n          &quot;location&quot;: &quot;DRC&quot;,\r\n          &quot;operatingsystem&quot;: &quot;Windows&quot;,\r\n          &quot;systemcode&quot;: &quot;WOC&quot;,\r\n          &quot;ram&quot;: 64,\r\n          &quot;databasesoftware&quot;: &quot;NA&quot;,\r\n          &quot;usagetype&quot;: &quot;Web Server&quot;,\r\n          &quot;environment&quot;: &quot;Production_NonCustData&quot;,\r\n          &quot;domain&quot;: &quot;EDAPAC&quot;,\r\n          &quot;IPAddress&quot;: &quot;10.117.254.26&quot;,\r\n          &quot;DNS&quot;: &quot;10.118.76.34&quot;,\r\n          &quot;Gateway&quot;: &quot;10.118.76.1&quot;,\r\n          &quot;drives&quot;: [\r\n            {\r\n              &quot;C&quot;: &quot;100&quot;\r\n            },\r\n            {\r\n              &quot;D&quot;: &quot;50&quot;\r\n            }\r\n          ]\r\n        },\r\n       {\r\n         //can be n no of blocks\r\n       }\r\n      ]\r\n    }\r\n\r\n \r\nNow Let&#39;s say block 1 has &quot;site&quot; value as &quot;SGDC&quot;, &quot;domain&quot; as &quot;DAPAC&quot;, &quot;usagetype&quot; as &quot;Database Server&quot;, I will pass these values in another shell script(I ALREADY HAVE THIS Shell SCRIPT) as a parameter to generate a new value &quot;SGDDAPACDS&quot; and use this as a new key/value pair i.e &quot;hostname&quot;: &quot;SGDDAPACDB&quot; and append it into block 1. Similarly, block 2 will have &quot;hostname&quot;: &quot;SGDEDAPACWS&quot;. So in the end, the JSON should look like this, \r\n\r\n\r\n    {\r\n      &quot;server_details&quot;: [\r\n        {\r\n          &quot;seqNo&quot;: &quot;01&quot;,\r\n          &quot;storage&quot;: &quot;IBM&quot;,\r\n          &quot;datastore&quot;: &quot;IDS-NR02&quot;,\r\n          &quot;cpu&quot;: 4,\r\n          &quot;site&quot;: &quot;SGDC&quot;,\r\n          &quot;servertype&quot;: &quot;Virtual Machine&quot;,\r\n          &quot;location&quot;: &quot;Serangoon&quot;,\r\n          &quot;operatingsystem&quot;: &quot;Linux&quot;,\r\n          &quot;systemcode&quot;: &quot;BOC&quot;,\r\n          &quot;ram&quot;: 64,\r\n          &quot;databasesoftware&quot;: &quot;MSSQL 2016&quot;,\r\n          &quot;usagetype&quot;: &quot;Database Server&quot;,\r\n          &quot;environment&quot;: &quot;Production_WithCustData&quot;,\r\n          &quot;domain&quot;: &quot;DAPAC&quot;,\r\n          &quot;IPAddress&quot;: &quot;10.117.254.25&quot;,\r\n          &quot;DNS&quot;: &quot;10.118.76.34&quot;,\r\n          &quot;Gateway&quot;: &quot;10.118.76.1&quot;,\r\n          &quot;drives&quot;: [\r\n            {\r\n              &quot;C&quot;: &quot;100&quot;\r\n            },\r\n            {\r\n              &quot;D&quot;: &quot;50&quot;\r\n            }\r\n          ],\r\n          &quot;hostname&quot;: &quot;SGDDAPACDS&quot;            //new value\r\n        },\r\n        {\r\n          &quot;seqNo&quot;: &quot;02&quot;,\r\n          &quot;storage&quot;: &quot;HITACHI&quot;,\r\n          &quot;datastore&quot;: &quot;HDS-NR02&quot;,\r\n          &quot;cpu&quot;: 4,\r\n          &quot;site&quot;: &quot;SGDR&quot;,\r\n          &quot;servertype&quot;: &quot;Virtual Machine&quot;,\r\n          &quot;location&quot;: &quot;DRC&quot;,\r\n          &quot;operatingsystem&quot;: &quot;Windows&quot;,\r\n          &quot;systemcode&quot;: &quot;WOC&quot;,\r\n          &quot;ram&quot;: 64,\r\n          &quot;databasesoftware&quot;: &quot;NA&quot;,\r\n          &quot;usagetype&quot;: &quot;Web Server&quot;,\r\n          &quot;environment&quot;: &quot;Production_NonCustData&quot;,\r\n          &quot;domain&quot;: &quot;EDAPAC&quot;,\r\n          &quot;IPAddress&quot;: &quot;10.117.254.26&quot;,\r\n          &quot;DNS&quot;: &quot;10.118.76.34&quot;,\r\n          &quot;Gateway&quot;: &quot;10.118.76.1&quot;,\r\n          &quot;drives&quot;: [\r\n            {\r\n              &quot;C&quot;: &quot;100&quot;\r\n            },\r\n            {\r\n              &quot;D&quot;: &quot;50&quot;\r\n            }\r\n          ],\r\n          &quot;hostname&quot;: &quot;SGDEDAPACWS&quot;       //new value\r\n        },\r\n       {\r\n         //can be n no of blocks\r\n       }\r\n      ]\r\n    }\r\n\r\nThanks in advance\r\n",
        "link": "https://stackoverflow.com/questions/64731626/extract-the-key-value-pair-from-all-blocks-of-json-array-and-then-append-it-as-n",
        "title": "Extract the key/value pair from all blocks of JSON Array and then append it as new key/value pair in each block of JSON Array using BASH and JQ"
    },
    {
        "tags": [
            "jq",
            "operator-precedence"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604985878,
                "last_edit_date": 1604985878,
                "creation_date": 1604791905,
                "answer_id": 64733453,
                "question_id": 64733252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In jq, for most purposes, including that of object addition, an explicit null value in the object on the right is not the same as the absence of a key.\r\n\r\nThus if A is `{&quot;a&quot;: 1}` then `A + {}` is A but `A + {&quot;a&quot;: null}` is {&quot;a&quot;: null}.\r\n\r\nThus the &quot;right-most value&quot; rule must be understood to mean &quot;right-most explicit value&quot;.\r\n\r\nWhether any of this has to do with &quot;eagerness&quot; depends on your understanding of that term.\r\n\r\n## Non-lazy evaluation\r\nIn jq, object addition (and indeed addition in general) proceeds from right to left and is of course non-lazy, as can be seen in the following example, which also illustrates the RHS-dominance mentioned above.\r\n```\r\njq -n &#39;{a:(1|debug)} + {b: (2|debug)} + {a:(3|debug)}&#39;\r\n[&quot;DEBUG:&quot;,3]\r\n[&quot;DEBUG:&quot;,2]\r\n[&quot;DEBUG:&quot;,1]\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: 2\r\n}\r\n```\r\nSo far as I know, though, the right-associativity might not be guaranteed.",
                "title": "Is the jq + operator eager?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604809276,
                "creation_date": 1604809276,
                "answer_id": 64734785,
                "question_id": 64733252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So maybe you&#39;re looking for an explanation in terms of operator precedence.\r\n\r\nLet:\r\n\r\n A represent `.data.viewer.zones[]`\r\n\r\n B represent `.httpRequests1mGroups[0].sum`\r\n\r\n C represent `with_entries(select(.key|endswith(&quot;Map&quot;)|not))`  \r\n\r\nThen your first jq expression is equivalent to\r\n\r\n    A | B | C + {zoneTag}\r\n\r\nwhereas your second is equivalent to:\r\n\r\n    A  | {zoneTag} + B | C\r\n\r\nSo in the first case, `{zoneTag}` gets its value from B but in the\r\nsecond case, it comes from A.",
                "title": "Is the jq + operator eager?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1604985878,
        "creation_date": 1604790133,
        "last_edit_date": 1604896020,
        "question_id": 64733252,
        "body_markdown": "I originally wrote my jq command as\r\n\r\n    .data.viewer.zones[] | .httpRequests1mGroups[0].sum|with_entries(select(.key|endswith(&quot;Map&quot;)|not))  + {&quot;zoneTag&quot;: .zoneTag} \r\n\r\nand got this result:\r\n\r\n    {\r\n      &quot;bytes&quot;: 2875120330,\r\n      &quot;cachedBytes&quot;: 1475518778,\r\n      &quot;zoneTag&quot;: null\r\n    }\r\n    {\r\n      &quot;bytes&quot;: 2875120330,\r\n      &quot;cachedBytes&quot;: 1475518778,\r\n      &quot;zoneTag&quot;: null\r\n    }\r\n`zoneTag` is the last attribute in a `zones` object.\r\n\r\nI rewrote the command as\r\n\r\n    .data.viewer.zones[] |  {&quot;zoneTag&quot;: .zoneTag} +   .httpRequests1mGroups[0].sum|with_entries(select(.key|endswith(&quot;Map&quot;)|not))  \r\n\r\nand get what I expected:\r\n\r\n    {\r\n      &quot;zoneTag&quot;: &quot;zone 1&quot;,\r\n      &quot;bytes&quot;: 2875120330,\r\n      &quot;cachedBytes&quot;: 1475518778,\r\n    }\r\n    {\r\n      &quot;zoneTag&quot;: &quot;zone 2&quot;,\r\n      &quot;bytes&quot;: 2875120330,\r\n      &quot;cachedBytes&quot;: 1475518778,\r\n    }\r\n\r\nMy question is why? Is `+` eager? (I get the same results using `*`.)\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/64733252/is-the-jq-operator-eager",
        "title": "Is the jq + operator eager?"
    },
    {
        "tags": [
            "bash",
            "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": 1604849075,
                "post_id": 64739344,
                "comment_id": 114466148,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604849353,
                "post_id": 64739344,
                "comment_id": 114466232,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19868998,
                    "reputation": 21,
                    "user_id": 14555612,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/faf3f91564cc69ad6f4e534652d14eb9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dddd4",
                    "link": "https://stackoverflow.com/users/14555612/dddd4"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604849401,
                "post_id": 64739344,
                "comment_id": 114466246,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604849506,
                "post_id": 64739344,
                "comment_id": 114466280,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604849541,
                "post_id": 64739344,
                "comment_id": 114466299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19868998,
                    "reputation": 21,
                    "user_id": 14555612,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/faf3f91564cc69ad6f4e534652d14eb9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dddd4",
                    "link": "https://stackoverflow.com/users/14555612/dddd4"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604849791,
                "post_id": 64739344,
                "comment_id": 114466365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19868998,
                    "reputation": 21,
                    "user_id": 14555612,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/faf3f91564cc69ad6f4e534652d14eb9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dddd4",
                    "link": "https://stackoverflow.com/users/14555612/dddd4"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604854451,
                "post_id": 64739344,
                "comment_id": 114467759,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604854552,
                "post_id": 64739344,
                "comment_id": 114467794,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1604855071,
                "post_id": 64739344,
                "comment_id": 114467941,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1604894556,
                "last_edit_date": 1604894556,
                "creation_date": 1604854836,
                "answer_id": 64740769,
                "question_id": 64739344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An efficient approach would be based on using `any`, e.g. along the lines of the following:\r\n```\r\njq --arg db $database --argjson Today $Today &#39;\r\n    select(.db_name==$db and\r\n           any(.daily[], .monthly[], .yearly[]; . == $Today) ) \r\n&#39; file.json\r\n```\r\n\r\nNote that both parameters ($database and $Today) should be passed in as command-line arguments rather than provided using shell-based string interpolation.  Using --argjson will ensure that any leading 0s in the shell variable $Today do not cause problems.\r\n\r\nNote also that the above query will return a stream of 0 or more values.  You might want to guarantee the names are distinct, e.g. by using the jq built-in filter `unique` (defined for arrays), or the stream-oriented filter `uniques` defined in the [jq Cookbook][1].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "Loop through JSON file in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604894556,
        "creation_date": 1604846359,
        "last_edit_date": 1604854184,
        "question_id": 64739344,
        "body_markdown": "I have a bash script that user enter name of a database and then my script needs to loop through this database config file. my JSON looks like this:\r\n```\r\n{\r\n\t&quot;_id&quot;:1,\r\n\t&quot;db_name&quot;:&quot;postgres&quot;,\r\n\t&quot;username&quot;:&quot;postgres_user&quot;,\r\n\t&quot;password&quot;:&quot;postgres_pass&quot;,\r\n\t&quot;daily&quot; : {\r\n               &quot;days_to_backup&quot; : [1,2],\r\n               &quot;delete_after&quot; : 14,\r\n               &quot;compressed&quot; : true,\r\n\t       &quot;path&quot; : &quot;localhost&quot;\r\n         },\r\n\t&quot;monthly&quot; : {\r\n               &quot;days_to_backup&quot; : [2,5,30],\r\n               &quot;delete_after&quot; : 7,\r\n               &quot;compressed&quot; : false,\r\n\t       &quot;path&quot; :&quot; localhost&quot;\r\n         },\r\n\t&quot;yearly&quot; : {\r\n               &quot;days_to_backup&quot; : [100],\r\n               &quot;delete_after&quot; : 14,\r\n               &quot;compressed&quot; : true,\r\n\t       &quot;path&quot; : &quot;localhost&quot;\r\n          }\r\n}\r\n{\r\n\t&quot;_id&quot;:2,\r\n\t&quot;db_name&quot;:&quot;test&quot;,\r\n\t&quot;username&quot;:&quot;test_user&quot;,\r\n\t&quot;password&quot;:&quot;test_pass&quot;,\r\n\t&quot;daily&quot; : {\r\n               &quot;days_to_backup&quot; : [1,7],\r\n               &quot;delete_after&quot; : 14,\r\n               &quot;compressed&quot; : true,\r\n\t       &quot;path&quot; : &quot;localhost&quot;\r\n           },\r\n\r\n\t&quot;monthly&quot; : {\r\n               &quot;days_to_backup&quot; : [2,5,25],\r\n               &quot;delete_after&quot; : 7,\r\n               &quot;compressed&quot; : false,\r\n\t       &quot;path&quot; : &quot;localhost&quot;\r\n           },\r\n\r\n\t&quot;yearly&quot; : {\r\n               &quot;days_to_backup&quot; : [50],\r\n               &quot;delete_after&quot; : 14,\r\n               &quot;compressed&quot; : true,\r\n\t       &quot;path&quot; : &quot;localhost&quot;\r\n           }\r\n\r\n\r\n}\r\n```\r\nNow once user run the script with particular database name, i want to loop through the &quot;days_to_backup&quot; numbers and for each day look it it&#39;s equal for today date. The problem is that i don&#39;t know how to fetch the daily/monthly/yealy.days_to_backup and then loop through the days.\r\nI tried with jq :\r\n```\r\n#! /bin/sh\r\n\r\n#monday is first day of the week\r\nexport Today=$(date +%d)\r\nwhile getopts d: flag\r\ndo\r\n    case &quot;${flag}&quot; in\r\n        d) database=${OPTARG};;\r\n\r\n\r\n    esac\r\ndone\r\n\r\nif jq .db_name file.json | grep $database\r\nthen\r\n        jq &#39;select(.db_name==&quot;&#39;$database&#39;&quot;)&#39; file.json\r\n        ##this one returns the whole document of the specified database\r\n        ##loop here for daily/monthly_yearly.days_to_backup???\r\nelse\r\n        echo &quot;database not found&quot;\r\nfi\r\n```\r\n\r\n\r\nEdit: my input is the name of the database ( &quot; postgres &quot; ) and then i will iterate through the daily/monthly/yearly array and if the number is like current date ( today is 8 of the month) so the output will be - echo &quot;backup today&quot;.\r\n\r\n\r\nEdit2: sorry my bad. for daily it means that day of the week so (1,7) are sunday and saturday and if current date is sunday or saturday i want and echo &quot;backup today&quot;. for monthly it means the day of the month, so if i have monthly (01,08) it will echo &quot;backup today&quot; because today is the 8th of the month. and for yearly i want days since the first day of the year.\r\n\r\n\r\nOk so I succeeded to loop through the array but the problem now is that it run over the array of the 2 big objects (id 1 + 2) \r\n```\r\nfor i in $(jq -r &quot;.daily.days_to_backup | .[]&quot; file.json)\r\n  do\r\n    echo $i &quot;im number&quot;\r\n  done\r\n```\r\nhow do I select that it will run only over _id:1 / db_name: postgres?",
        "link": "https://stackoverflow.com/questions/64739344/loop-through-json-file-in-bash-script",
        "title": "Loop through JSON file in bash script"
    },
    {
        "tags": [
            "python",
            "json",
            "group-by",
            "aggregate",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6136522,
                    "reputation": 77978,
                    "user_id": 4785185,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ChR5h.jpg?s=256",
                    "display_name": "Prune",
                    "link": "https://stackoverflow.com/users/4785185/prune"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1604900803,
                "post_id": 64746372,
                "comment_id": 114477548,
                "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": 1604901746,
                "post_id": 64746372,
                "comment_id": 114477778,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1604905773,
                "creation_date": 1604905773,
                "answer_id": 64747152,
                "question_id": 64746372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be helpful if your requirements were clearer, and in particular if your example satisfied the [mcve][1] guidelines.  The following query does, however, meet one interpretation of your specification:\r\n```\r\ngroup_by(.labels)\r\n| map( { labels: (.[0].labels),\r\n         targets: (map(.targets)|add)} )\r\n```\r\n\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "Reduce array of dicts based on key which is a dict"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604943742,
        "creation_date": 1604900494,
        "last_edit_date": 1604943742,
        "question_id": 64746372,
        "body_markdown": "I&#39;m looking for a jq expression that can reduce the json by  grouping them on &quot;labels&quot;.I want the output to have a list of targets that share the same labels.\r\n\r\nI tried using some combinations of group_by and reduce but wasn&#39;t able to get what I wanted.\r\n\r\nINPUT:\r\n```\r\n[{\r\n      &quot;targets&quot;: [\r\n        &quot;host1&quot;\r\n      ],\r\n      &quot;labels&quot;: {\r\n        &quot;platform&quot;: &quot;VMware&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;,\r\n        &quot;datacenter&quot;: &quot;dc1&quot;,\r\n        &quot;environment&quot;: &quot;Production&quot;\r\n      }\r\n    },{\r\n      &quot;targets&quot;: [\r\n        &quot;host2&quot;\r\n      ],\r\n      &quot;labels&quot;: {\r\n        &quot;platform&quot;: &quot;VMware&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;,\r\n        &quot;datacenter&quot;: &quot;dc1&quot;,\r\n        &quot;environment&quot;: &quot;Production&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;targets&quot;: [\r\n             &quot;host3&quot;\r\n      ],\r\n      &quot;labels&quot;: {\r\n        &quot;platform&quot;: &quot;VMware&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;,\r\n        &quot;datacenter&quot;: &quot;dc2&quot;,\r\n        &quot;environment&quot;: &quot;Production&quot;\r\n      }\r\n    }\r\n]\r\n```\r\nOUTPUT:\r\n```\r\n[{\r\n      &quot;targets&quot;: [\r\n        &quot;host1&quot;,\r\n        &quot;host2&quot;\r\n      ],\r\n      &quot;labels&quot;: {\r\n        &quot;platform&quot;: &quot;VMware&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;,\r\n        &quot;datacenter&quot;: &quot;dc1&quot;,\r\n        &quot;environment&quot;: &quot;Production&quot;\r\n      }\r\n    },\r\n{\r\n      &quot;targets&quot;: [\r\n        &quot;host3&quot;,\r\n      ],\r\n      &quot;labels&quot;: {\r\n        &quot;platform&quot;: &quot;VMware&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;,\r\n        &quot;datacenter&quot;: &quot;dc2&quot;,\r\n        &quot;environment&quot;: &quot;Production&quot;\r\n      }\r\n    }\r\n]\r\n```\r\nP.S The sample input doesn&#39;t have all the keys in &quot;labels&quot; and that list can vary .\r\n",
        "link": "https://stackoverflow.com/questions/64746372/reduce-array-of-dicts-based-on-key-which-is-a-dict",
        "title": "Reduce array of dicts based on key which is a dict"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1604914867,
                "creation_date": 1604914867,
                "answer_id": 64749154,
                "question_id": 64748758,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; echo $diffresult \r\n\r\nUnquoted results of expansions undergo word splitting expansion. As a general rule, when you write `$` it should be inside `&quot;`.\r\n\r\n&gt; IFS=&#39;,&#39; read -ra array &lt;&lt;&lt; &quot;$diffresult&quot;\r\n\r\n`read` reads until the first newline. It then splits _one line_ on `IFS` and assigns the result to arguments. As such, your `read` reads only the first line `2c2`.\r\n\r\nYou may want to use `bash` extension and read lines:\r\n\r\n    readarray -t array &lt;&lt;&lt;&quot;$diffresult&quot;\r\n\r\nResearch [how to read a stream line by line](https://mywiki.wooledge.org/BashFAQ/001) , [how to load lines from a stream to an array](https://mywiki.wooledge.org/BashFAQ/005#Loading_lines_from_a_file_or_stream) and [about quotes](https://mywiki.wooledge.org/Quotes).",
                "title": "Cannot Split Diff Output to Array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1604914867,
        "creation_date": 1604913201,
        "question_id": 64748758,
        "body_markdown": "I have not really used bash for something this complicated before so pardon very simple mistakes.\r\n\r\nSo I am trying to split the output of a diff into array by doing the following : \r\n\r\n    diffresult=$(diff &lt;(jq . actualProp.json) &lt;(jq . standardProp.json) | tr -d &#39;&lt;&gt;-&#39;)\r\n    echo $diffresult #returns 2c2 &quot;access&quot;: &quot;Deny&quot;, &quot;access&quot;: &quot;Allow&quot;, 5c5 &quot;destinationPortRange&quot;: &quot;33899&quot;, &quot;destinationPortRange&quot;: &quot;3389&quot;, 8c8 &quot;priority&quot;: 3009, &quot;priority&quot;: 300,\r\n\r\n    #split diffresult into array \r\n    IFS=&#39;,&#39; read -ra array &lt;&lt;&lt; &quot;$diffresult&quot;\r\n\r\n    #check the length\r\n    echo &quot;${#array[@]}&quot; #returns 1\r\n\r\n    #loop through the array\r\n    for element in &quot;${array[@]}&quot;\r\n    do\r\n      echo &quot;$element&quot; \r\n    done\r\n    #returns 2c2\r\n\r\nWhat am I doing wrong, why cant I split the output of the diff into an array?\r\n    ",
        "link": "https://stackoverflow.com/questions/64748758/cannot-split-diff-output-to-array",
        "title": "Cannot Split Diff Output to Array"
    },
    {
        "tags": [
            "json",
            "jq",
            "whitelist"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16532773,
                    "reputation": 97,
                    "user_id": 11945562,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/01998f8679fb55985dfc2ac450a51521?s=256&d=identicon&r=PG",
                    "display_name": "pnocti",
                    "link": "https://stackoverflow.com/users/11945562/pnocti"
                },
                "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": 1604918364,
                "post_id": 64749621,
                "comment_id": 114483795,
                "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": 1604921242,
                "post_id": 64749621,
                "comment_id": 114484970,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604924845,
                "last_edit_date": 1604924845,
                "creation_date": 1604921655,
                "answer_id": 64750869,
                "question_id": 64749621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adopting the answer from the linked question in comments with _slight_ modification to suit the use-case of OP\r\n\r\n```bash\r\njq -n --argjson names &#39;[&quot;Bob&quot;, &quot;Alice&quot;]&#39; &#39;\r\n(reduce $names[] as $name ({}; .[$name] = true)) as $set\r\n    | inputs | map(select($set[.Name]))&#39; json\r\n```\r\n\r\nThe `reduce` function basically creates a hash-map of truth values mapped for each entry of your input names array. Later apply the map on each of the input object. If the condition satisfies, print the object desired.\r\n\r\nOr alternatively use the `any/2` function\r\n\r\n```bash\r\njq --argjson names &#39;[&quot;Bob&quot;, &quot;Alice&quot;]&#39; &#39;\r\n map(select( .Name as $a | any( $names[]; . == $a) ))&#39; json\r\n```",
                "title": "How to loop through a json array and find a match for each item in bigger json fille?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1606116686,
        "creation_date": 1604916831,
        "last_edit_date": 1606116686,
        "question_id": 64749621,
        "body_markdown": "For example, I have this json file:\r\n```\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;Bob&quot;,\r\n    &quot;Grade&quot;: &quot;Pass&quot;\r\n  },\r\n  { \r\n    &quot;Name&quot;: &quot;Alice&quot;,\r\n    &quot;Grade&quot;: &quot;Fail&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Mallory&quot;,\r\n    &quot;Grade&quot;: &quot;Fail&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd this array ```[&quot;Bo&quot;, &quot;Al&quot;]```\r\n\r\nHow do I loop through the array to check the json file for those students only and output their {Name, Grade}?\r\n\r\nAlso a note, I can do a series of pipes of ```select(test(.Name == &quot;Bob&quot;))``` but I can&#39;t hardcode it as the array is being generated dynamically depending on a selection.\r\n\r\nLet me know if you need further clearance.\r\n\r\nThank you!\r\n\r\nNote: Edited to ask how to do this for substrings, like &quot;Bo&quot; and &quot;Al&quot; for &quot;Bob&quot; and &quot;Alice&quot;. Apologies as I&#39;m really quite new to jq advanced topics. Thank you again!",
        "link": "https://stackoverflow.com/questions/64749621/how-to-loop-through-a-json-array-and-find-a-match-for-each-item-in-bigger-json-f",
        "title": "How to loop through a json array and find a match for each item in bigger json fille?"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1604956150,
                "last_edit_date": 1604956150,
                "creation_date": 1604940317,
                "answer_id": 64755703,
                "question_id": 64755461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.[] | .&quot;throughput (K tps)&quot; |= . / 1000&#39;\r\n```\r\n\r\nShould edit each `throughput (K tps)` by dividing it by 1000.\r\n\r\n[Try it online!](https://jqplay.org/s/PTeezE-Lad)\r\n\r\n&lt;hr&gt;\r\n",
                "title": "Modifying the same field in an array of objects using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1604940397,
                "creation_date": 1604940397,
                "answer_id": 64755718,
                "question_id": 64755461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Tell `jq` to replace the value in &quot;throughput (K tps)&quot; by itself divided by 1000:\r\n\r\n    jq &#39;.[].&quot;throughput (K tps)&quot; |= . / 1000&#39; file.json",
                "title": "Modifying the same field in an array of objects using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1604944646,
                "creation_date": 1604944646,
                "answer_id": 64756823,
                "question_id": 64755461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use either of `map` or `map_values` for your problem. But the problem with your attempt was you were _only_ modifying the field `&quot;throughput (K tps)&quot;` for printing into output. \r\n\r\nWithout the `|=` update assignment operator, only the field mentioned in the expression will be printed to console. \r\n\r\nYou can use the [Update-assignment][1] operator\r\n\r\n```jq\r\nmap(.&quot;throughput (K tps)&quot; |= . / 1000)\r\n```\r\n\r\nBut `jq` gives you much more to do [Arithmetic update assignments][2] of form `+=`, `*=` and also `/=`, so that you can do\r\n\r\n```jq\r\nmap(.&quot;throughput (K tps)&quot; /= 1000)\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Update-assignment:%7C=\r\n  [2]: https://stedolan.github.io/jq/manual/#Arithmeticupdate-assignment:+=,-=,*=,/=,%25=,//=",
                "title": "Modifying the same field in an array of objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1604956150,
        "creation_date": 1604939381,
        "last_edit_date": 1604955634,
        "question_id": 64755461,
        "body_markdown": "I have an array of objects, where each object is structured as:\r\n```\r\n {\r\n   &quot;impl&quot;: &quot;pmdk&quot;,\r\n   &quot;pc_writes&quot;: 50,\r\n   &quot;threads&quot;: 1,\r\n   &quot;throughput (K tps)&quot;: 703014,\r\n   &quot;med_latency (ns)&quot;: 1334,\r\n   &quot;99_latency (ns)&quot;: 2358,\r\n   &quot;exec_time (s)&quot;: 14224471006\r\n }\r\n```\r\nI would like to divide the `&quot;throughput (K tps)&quot;` field in each object by 1000 and return the array in the same format. I tried using `map_values` in the following way:\r\n```\r\nmap_values(.&quot;throughput (K tps)&quot;/1000)\r\n```\r\nBut it only returns an array of modified values as:\r\n```\r\n[703.014,...]\r\n```\r\nInstead of the entire objects, like this:\r\n```\r\n [{\r\n   &quot;impl&quot;: &quot;pmdk&quot;,\r\n   &quot;pc_writes&quot;: 50,\r\n   &quot;threads&quot;: 1,\r\n   &quot;throughput (K tps)&quot;: 703.014,\r\n   &quot;med_latency (ns)&quot;: 1334,\r\n   &quot;99_latency (ns)&quot;: 2358,\r\n   &quot;exec_time (s)&quot;: 14224471006\r\n },\r\n ...\r\n ]\r\n```\r\nHow do I return an array of objects after dividing one of its fields by 1000?",
        "link": "https://stackoverflow.com/questions/64755461/modifying-the-same-field-in-an-array-of-objects-using-jq",
        "title": "Modifying the same field in an array of objects using jq"
    },
    {
        "tags": [
            "python",
            "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": 1604995590,
                "post_id": 64764896,
                "comment_id": 114510234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11999473,
                    "reputation": 301,
                    "user_id": 8779890,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/318f8e601359e165db1e9af323454170?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "El Cid",
                    "link": "https://stackoverflow.com/users/8779890/el-cid"
                },
                "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": 1604995693,
                "post_id": 64764896,
                "comment_id": 114510273,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604998576,
                "last_edit_date": 1604998576,
                "creation_date": 1604995837,
                "answer_id": 64765056,
                "question_id": 64764896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Evidently the version of jq installed via pip was version 1.3 (which is ancient history) or earlier. `index/1` was only introduced as a built-in filter after the release of jq 1.3.\r\n\r\nIf you are absolutely stuck with jq 1.3, you could use `contains/1` if you don&#39;t need the integer index.\r\n ",
                "title": "Jq index() Not Found"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604995848,
                "creation_date": 1604995848,
                "answer_id": 64765060,
                "question_id": 64764896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note that `pip install jq` does not install the executable that you can use interactively from the command line, but as a python package, which you can use only in scripts.\r\n\r\nAs for the disparity in the usage of `index()` function, you seem to be using an older/outdated version of `jq-1.3` in CentOS which does not have the `index()`, `rindex()` functions.\r\n\r\nFrom the [changelog][1]\r\n\r\n&gt; New features in 1.4 since 1.3:\r\n&gt; - string built-ins:\r\n&gt; - **index, rindex, indices**\r\n\r\nYour version on MacOS `jq-1.6` has those functions available.\r\n\r\n  [1]: https://raw.githubusercontent.com/stedolan/jq/master/NEWS",
                "title": "Jq index() Not Found"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1604998576,
        "creation_date": 1604995097,
        "last_edit_date": 1604995716,
        "question_id": 64764896,
        "body_markdown": "Executing the following jq command works fine on Mac OS Catalina (jq version 1.6) :\r\n\r\n    echo $(jq &#39;.paths | to_entries | map(select(.value[].tags | index(&quot;Tag123&quot;))) | from_entries&#39; custom.json)\r\n\r\nHowever executing it on CentOS (CentOS release 6.9 (Final)) (jq version 1.3) returns the following error :\r\n\r\n    echo $(jq &#39;.paths | to_entries | map(select(.value[].tags | index(&quot;Shell&quot;))) | from_entries&#39; custom.json)\r\n    error: index is not defined\r\n    .paths | to_entries | map(select(.value[].tags | index(&quot;Shell&quot;))) | from_entries\r\n                                                     ^^^^^\r\n    1 compile error\r\n",
        "link": "https://stackoverflow.com/questions/64764896/jq-index-not-found",
        "title": "Jq index() Not Found"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "csvtojson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605051253,
                "post_id": 64778327,
                "comment_id": 114533595,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605061605,
                "last_edit_date": 1605061605,
                "creation_date": 1605051610,
                "answer_id": 64778407,
                "question_id": 64778327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a concise, efficient, and conceptually simple solution based on just `map` and `reduce`:\r\n```\r\n. as $in\r\n| reduce (.[0] | keys_unsorted[]) as $k ( {}; .[$k] = ($in|map(.[$k])))\r\n```\r\n\r\n## Converting all number-valued strings to numbers\r\n```\r\n. as $in\r\n| reduce (.[0] | keys_unsorted[]) as $k ( {}; \r\n    .[$k] = ($in|map(.[$k] | (tonumber? // .))))\r\n```\r\n\r\n",
                "title": "How to convert object keys to arrays with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1618577216,
        "creation_date": 1605051023,
        "last_edit_date": 1618577216,
        "question_id": 64778327,
        "body_markdown": "I am trying to convert a csv where the headers are keys and the values in the column are a list.\r\n\r\nFor example I have the following csv\r\n\r\n```\r\n               mpg   cyl  disp  hp   drat  wt     qsec   vs  am  gear  carb\r\nMazda RX4      21    6    160   110  3.9   2.62   16.46  0   1   4     4\r\nMazda RX4 Wag  21    6    160   110  3.9   2.875  17.02  0   1   4     4\r\nDatsun 710     22.8  4    108   93   3.85  2.32   18.61  1   1   4     1\r\n```\r\n\r\nI would like the following format.\r\n\r\n```\r\n{\r\n    &quot;field1&quot; : [Mazda RX4 ,Mazda RX4 Wag,Datsun 710],    \r\n    &quot;mpg&quot; : [21,21,22.8],    \r\n    &quot;cyl&quot; : [6,6,6],        \r\n    &quot;disp&quot; : [160,160,108],    \r\n   ...\r\n}\r\n```\r\n\r\nNote that the numerical values are not quoted. I am assuming that the columns all have the same type.\r\n\r\nI am using the following `jq` command.\r\n\r\n```\r\n curl https://raw.githubusercontent.com/vincentarelbundock/Rdatasets/master/csv/datasets/mtcars.csv  cars.csv | head -n4 | csvtojson | jq &#39;.&#39;\r\n```\r\n\r\n```\r\n[\r\n  {\r\n    &quot;field1&quot;: &quot;Mazda RX4&quot;,\r\n    &quot;mpg&quot;: &quot;21&quot;,\r\n    &quot;cyl&quot;: &quot;6&quot;,\r\n    &quot;disp&quot;: &quot;160&quot;,\r\n    &quot;hp&quot;: &quot;110&quot;,\r\n    &quot;drat&quot;: &quot;3.9&quot;,\r\n    &quot;wt&quot;: &quot;2.62&quot;,\r\n    &quot;qsec&quot;: &quot;16.46&quot;,\r\n    &quot;vs&quot;: &quot;0&quot;,\r\n    &quot;am&quot;: &quot;1&quot;,\r\n    &quot;gear&quot;: &quot;4&quot;,\r\n    &quot;carb&quot;: &quot;4&quot;\r\n  },\r\n  {\r\n    &quot;field1&quot;: &quot;Mazda RX4 Wag&quot;,\r\n    &quot;mpg&quot;: &quot;21&quot;,\r\n    &quot;cyl&quot;: &quot;6&quot;,\r\n    &quot;disp&quot;: &quot;160&quot;,\r\n    &quot;hp&quot;: &quot;110&quot;,\r\n    &quot;drat&quot;: &quot;3.9&quot;,\r\n    &quot;wt&quot;: &quot;2.875&quot;,\r\n    &quot;qsec&quot;: &quot;17.02&quot;,\r\n    &quot;vs&quot;: &quot;0&quot;,\r\n    &quot;am&quot;: &quot;1&quot;,\r\n    &quot;gear&quot;: &quot;4&quot;,\r\n    &quot;carb&quot;: &quot;4&quot;\r\n  },\r\n  {\r\n    &quot;field1&quot;: &quot;Datsun 710&quot;,\r\n    &quot;mpg&quot;: &quot;22.8&quot;,\r\n    &quot;cyl&quot;: &quot;4&quot;,\r\n    &quot;disp&quot;: &quot;108&quot;,\r\n    &quot;hp&quot;: &quot;93&quot;,\r\n    &quot;drat&quot;: &quot;3.85&quot;,\r\n    &quot;wt&quot;: &quot;2.32&quot;,\r\n    &quot;qsec&quot;: &quot;18.61&quot;,\r\n    &quot;vs&quot;: &quot;1&quot;,\r\n    &quot;am&quot;: &quot;1&quot;,\r\n    &quot;gear&quot;: &quot;4&quot;,\r\n    &quot;carb&quot;: &quot;1&quot;\r\n  }\r\n]\r\n```\r\n\r\n## Complete working solution\r\n\r\n```\r\ncat &lt;csv_data&gt; | csvtojson | jq &#39;. as $in | reduce (.[0] | keys_unsorted[]) as $k ( {}; .[$k] = ($in|map(.[$k])))&#39;\r\n```\r\n\r\n## jq play - Converting all numbers to strings\r\n\r\nhttps://jqplay.org/s/HKjHLVp9KZ",
        "link": "https://stackoverflow.com/questions/64778327/how-to-convert-object-keys-to-arrays-with-jq",
        "title": "How to convert object keys to arrays with jq"
    },
    {
        "tags": [
            "shell",
            "command-line-arguments",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1605102244,
                "post_id": 64785337,
                "comment_id": 114548617,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605102049,
                "creation_date": 1605102049,
                "answer_id": 64787569,
                "question_id": 64785337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, assuming your jq allows it, you could use `—argfile` or `—slurpfile` but in your case you can simply avoid the issue by invoking jq just once instead of twice. For example, to keep things clear:\r\n\r\n     ( .paths | to_entries | map(select(.value[].tags | index(&quot;Filter&quot;))) | from_entries ) as $prefix\r\n     | .paths=$prefix\r\n\r\n Even better, simply use `|=`:\r\n\r\n     .paths |= ( to_entries | map(select(.value[].tags | index(&quot;Filter&quot;))) | from_entries)\r\n\r\nor better yet, use `with_entries`.\r\n\r\n",
                "title": "JQ - Argument list too long error - Large Input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1605102210,
        "creation_date": 1605093242,
        "last_edit_date": 1605102210,
        "question_id": 64785337,
        "body_markdown": "I use Jq to perform some filtering on a large json file using :\r\n\r\n    paths=$(jq &#39;.paths | to_entries | map(select(.value[].tags | index(&quot;Filter&quot;))) | from_entries&#39; input.json)\r\n\r\nand write the result to a new file using :\r\n\r\n    jq --argjson prefix &quot;$paths&quot; &#39;.paths=$prefix&#39; input.json &gt; output.json\r\n\r\nBut this ^ fails as $paths has a very high line count (order of 100,000).\r\n\r\nError :\r\n\r\n    jq: Argument list too long\r\n\r\nI also went through : https://stackoverflow.com/questions/59854249/usr-bin-jq-argument-list-too-long-error-bash , understood the same problem there, but did not get the solution.",
        "link": "https://stackoverflow.com/questions/64785337/jq-argument-list-too-long-error-large-input",
        "title": "JQ - Argument list too long error - Large Input"
    },
    {
        "tags": [
            "json",
            "jq",
            "to-json",
            "fromjson"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605102873,
                "creation_date": 1605102873,
                "answer_id": 64787792,
                "question_id": 64787692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to update the value, you would use `|=`, and don’t forget the call to `tojson`:\r\n\r\n    .content |= (fromjson | (.firstName = &quot;abcdef&quot;) | tojson)",
                "title": "How do I update values in a json string using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1605704960,
        "creation_date": 1605102466,
        "last_edit_date": 1605704960,
        "question_id": 64787692,
        "body_markdown": "I have a JSON file with content this:-\r\n\r\n    {\r\n      &quot;content&quot;: &quot;{\\&quot;accountNumber\\&quot;:\\&quot;12345\\&quot;,\\&quot;transactionId\\&quot;:\\&quot;568\\&quot;,\\&quot;socialSecurityNumber\\&quot;:\\&quot;123456796\\&quot;,\\&quot;identificationNumber\\&quot;:1,\\&quot;securityCode\\&quot;:\\&quot;1234\\&quot;,\\&quot;dateOfBirth\\&quot;:\\&quot;1000-01-01\\&quot;,\\&quot;firstName\\&quot;:\\&quot;qwerty\\&quot;,\\&quot;lastName\\&quot;:\\&quot;xyz\\&quot;,\\&quot;balance\\&quot;:123}&quot;,\r\n      &quot;contentType&quot;: &quot;application/json&quot;,\r\n      &quot;createdAt&quot;: &quot;2020-11-11T12:55:41.350+0000&quot;,\r\n      &quot;cryptoKeyId&quot;: null\r\n    }\r\n\r\nI just want to update the value of **firstName**.\r\nEnd result I want is \r\n\r\n    {\r\n      &quot;content&quot;: &quot;{\\&quot;accountNumber\\&quot;:\\&quot;12345\\&quot;,\\&quot;transactionId\\&quot;:\\&quot;568\\&quot;,\\&quot;socialSecurityNumber\\&quot;:\\&quot;123456796\\&quot;,\\&quot;identificationNumber\\&quot;:1,\\&quot;securityCode\\&quot;:\\&quot;1234\\&quot;,\\&quot;dateOfBirth\\&quot;:\\&quot;1000-01-01\\&quot;,\\&quot;firstName\\&quot;:\\&quot;abcdef\\&quot;,\\&quot;lastName\\&quot;:\\&quot;xyz\\&quot;,\\&quot;balance\\&quot;:123}&quot;,\r\n      &quot;contentType&quot;: &quot;application/json&quot;,\r\n      &quot;createdAt&quot;: &quot;2020-11-11T12:55:41.350+0000&quot;,\r\n      &quot;cryptoKeyId&quot;: null\r\n    }\r\nI tried this\r\n\r\n     ( .content | fromjson.firstName = &quot;abcdef&quot;  )\r\n\r\nbut no success.\r\nCan you help me here?\r\nThanks\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64787692/how-do-i-update-values-in-a-json-string-using-jq",
        "title": "How do I update values in a json string using jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1605167334,
                "last_edit_date": 1605167334,
                "creation_date": 1605135998,
                "answer_id": 64795495,
                "question_id": 64795033,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You state that the selection criterion is:\r\n\r\n    .spec.components[].type == &quot;jobmanager&quot; and\r\n    .spec.components[].image != &quot;test.com/jobmanager:1.1.1&quot;\r\n\r\nbut that does not make much sense, given the semantics of `.[]`.\r\n\r\nI suspect you meant that you want to select items from `.spec.components` such that\r\n\r\n    .type == &quot;jobmanager&quot; and .image != &quot;test.com/jobmanager:1.1.1&quot;\r\n\r\nIf that&#39;s the case, you could use `any`, so that your query would look like this:\r\n```\r\n.items[]\r\n| select( any(.spec.components[];\r\n              (.name? | contains(&quot;jobmanager01&quot;)) and\r\n              .image != &quot;test.com/jobmanager:1.1.1&quot;) )\r\n| .metadata.namespace\r\n```\r\n\r\n## all distinct\r\nIf you want all the distinct .namespace values satisfying the condition, you could go with:\r\n\r\n```\r\n[.items[]\r\n | .metadata.namespace as $it\r\n | .spec.components[]\r\n | select( (.name? | contains(&quot;jobmanager01&quot;)) and\r\n          .image != &quot;test.com/jobmanager:1.1.1&quot; )\r\n | $it]\r\n| unique[]\r\n```\r\n\r\n## Efficient version of &quot;all-distinct&quot; solution\r\nTo avoid unnecessary checks, if .namespace is always a string, we could write:\r\n```\r\nreduce .items[] as $item ({};\r\n   $item.metadata.namespace as $it\r\n   | if .[$it] then .   # already seen\r\n     elif any( $item.spec.components[];\r\n               ((.name? | contains(&quot;jobmanager01&quot;)) and\r\n               .image != &quot;test.com/jobmanager:1.1.1&quot;) )\r\n     then .[$it] = true\r\n     else . end )\r\n| keys_unsorted[]     \r\n```\r\n",
                "title": "jq - select object if condition on different object is met"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605167334,
        "creation_date": 1605133193,
        "last_edit_date": 1605164565,
        "question_id": 64795033,
        "body_markdown": "Let&#39;s say I have more namespaces with the similar k8s resource (some might have different images used). I am trying to get .metadata.namespace using jq from the following json object (let&#39;s call it test.json):\r\n```\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;app&quot;,\r\n                &quot;namespace&quot;: &quot;test1&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;components&quot;: [\r\n                    {\r\n                        &quot;database&quot;: {\r\n                            &quot;from&quot;: &quot;service&quot;,\r\n                            &quot;value&quot;: &quot;redis&quot;\r\n                        },\r\n                        &quot;image&quot;: &quot;test.com/lockmanager:1.1.1&quot;,\r\n                        &quot;name&quot;: &quot;lockmanager01&quot;,\r\n                        &quot;replicas&quot;: 2,\r\n                        &quot;type&quot;: &quot;lockmanager&quot;\r\n                    },\r\n                    {\r\n                        &quot;database&quot;: {\r\n                            &quot;from&quot;: &quot;service&quot;,\r\n                            &quot;value&quot;: &quot;postgresql&quot;\r\n                        },\r\n                        &quot;image&quot;: &quot;test.com/jobmanager:1.1.1&quot;,\r\n                        &quot;name&quot;: &quot;jobmanager01&quot;,\r\n                        &quot;replicas&quot;: 2,\r\n                        &quot;type&quot;: &quot;jobmanager&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\nif following condition is met:\r\n\r\n.spec.components[].type == &quot;jobmanager&quot; and .spec.components[].image != &quot;test.com/jobmanager:1.1.1&quot;\r\n\r\nbut can&#39;t find the correct statement.\r\n\r\nI tried:\r\n\r\n```\r\ncat test.json | jq &#39;.items[] | select((.spec.components[].name? | contains(&quot;jobmanager01&quot;)) and (.spec.components[].image != &quot;test.com/jobmanager:1.1.1&quot;)) | .metadata.namespace&#39;&#39;\r\n```\r\n\r\nbut it returns all namespaces and, moreover, those I am interested in (because I know they contain different image), are returned twice.\r\n\r\nPlease advise what am I doing wrong?",
        "link": "https://stackoverflow.com/questions/64795033/jq-select-object-if-condition-on-different-object-is-met",
        "title": "jq - select object if condition on different object is met"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605185302,
                "creation_date": 1605185302,
                "answer_id": 64804234,
                "question_id": 64803904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you have not given any details about your attempts, let me, in the spirit of &quot;How to Solve It&quot;, suggest a strategy for doing so.\r\n\r\nSpecifically, let&#39;s formulate and solve the obvious &quot;subproblem&quot; which should make the solution to the original problem easy to the point of almost being trivial.  The obvious &quot;subproblem&quot; is: given a reference object, $ref, how to update another object so that null-valued keys in the latter are taken from $ref if available?\r\n\r\n    def infer($ref): \r\n      with_entries( if .value == null then $ref[.key] else . end);\r\n\r\nNow the original problem becomes much easier, right?",
                "title": "jq - Copy values of first array element if other values are null"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605193908,
                "last_edit_date": 1605193908,
                "creation_date": 1605185490,
                "answer_id": 64804279,
                "question_id": 64803904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing the errors in your JSON file so it&#39;s valid:\r\n\r\n```sh\r\njq &#39;. as $orig |\r\n    .offices |= map(.website //= $orig.offices[0].website |\r\n                    .email //= $orig.offices[0].email)&#39; input.json\r\n{\r\n  &quot;id&quot;: 123,\r\n  &quot;offices&quot;: [\r\n    {\r\n      &quot;officeId&quot;: 12345,\r\n      &quot;name&quot;: &quot;Name LLP&quot;,\r\n      &quot;website&quot;: &quot;www.example.com&quot;,\r\n      &quot;email&quot;: &quot;website@example.com&quot;,\r\n      &quot;officeType&quot;: &quot;HO&quot;\r\n    },\r\n    {\r\n      &quot;officeId&quot;: 123456,\r\n      &quot;name&quot;: &quot;Name&quot;,\r\n      &quot;website&quot;: &quot;www.example.com&quot;,\r\n      &quot;email&quot;: &quot;website@example.com&quot;,\r\n      &quot;officeType&quot;: &quot;BRANCH&quot;\r\n    },\r\n    {\r\n      &quot;officeId&quot;: 1234567,\r\n      &quot;name&quot;: &quot;Name&quot;,\r\n      &quot;website&quot;: &quot;www.example.com&quot;,\r\n      &quot;email&quot;: &quot;example@website.com&quot;,\r\n      &quot;officeType&quot;: &quot;BRANCH&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "jq - Copy values of first array element if other values are null"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1605193908,
        "creation_date": 1605183977,
        "question_id": 64803904,
        "body_markdown": "I have an object which contains an array of objects. I want to replace null values of a specific key value pair with the value of the 0th array index. In the example below I want for array elements 1 to contain &quot;website&quot; and &quot;email&quot; of the &quot;email&quot; and &quot;website&quot; of the 0th array element because they are both null. For element 2 I only expect the &quot;website&quot; to be set with the result of the 0th array element as only that is null.\r\n\r\nThe json that I have is\r\n\r\n            {\r\n                &quot;id&quot;: 123,\r\n                &quot;offices&quot;: [\r\n                    {\r\n                        &quot;officeId&quot;: 12345,\r\n                        &quot;name&quot;: &quot;Name LLP&quot;,\r\n                        &quot;website&quot;: &quot;www.example.com&quot;,\r\n                        &quot;email&quot;: &quot;website@example.com&quot;,\r\n                        &quot;officeType&quot;: &quot;HO&quot;\r\n                    },\r\n                    {\r\n                        &quot;officeId&quot;: 123456,\r\n                        &quot;name&quot;: &quot;Name&quot;, \r\n                        &quot;website&quot;: null,\r\n                        &quot;email&quot;: null,\r\n                        &quot;officeType&quot;: &quot;BRANCH&quot;\r\n                    },\r\n                    {\r\n                        &quot;officeId&quot;: 1234567,\r\n                        &quot;name&quot;: &quot;Name&quot;, \r\n                        &quot;website&quot;: null,\r\n                        &quot;email&quot;: &quot;example@website.com&quot;,\r\n                        &quot;officeType&quot;: &quot;BRANCH&quot;\r\n                    },\r\n                ],\r\n            }\r\n\r\n\r\nMy expected json output would be\r\n\r\n                {\r\n                    &quot;id&quot;: 123,\r\n                    &quot;offices&quot;: [\r\n                        {\r\n                            &quot;officeId&quot;: 12345,\r\n                            &quot;name&quot;: &quot;Name LLP&quot;,\r\n                            &quot;website&quot;: &quot;www.example.com&quot;,\r\n                            &quot;email&quot;: &quot;website@example.com&quot;,\r\n                            &quot;officeType&quot;: &quot;HO&quot;\r\n                        },\r\n                        {\r\n                            &quot;officeId&quot;: 123456,\r\n                            &quot;name&quot;: &quot;Name&quot;, \r\n                            &quot;website&quot;: &quot;www.example.com&quot;,\r\n                            &quot;email&quot;: &quot;website@example.com&quot;,\r\n                            &quot;officeType&quot;: &quot;BRANCH&quot;\r\n                        },\r\n                        {\r\n                            &quot;officeId&quot;: 1234567,\r\n                            &quot;name&quot;: &quot;Name&quot;, \r\n                            &quot;website&quot;: &quot;www.example.com&quot;,\r\n                            &quot;email&quot;: &quot;example@website.com&quot;,\r\n                            &quot;officeType&quot;: &quot;BRANCH&quot;\r\n                        },\r\n                    ],\r\n                }\r\n\r\nI have attempted to solve this using map and walk but cannot seem to find the correct way to solve it",
        "link": "https://stackoverflow.com/questions/64803904/jq-copy-values-of-first-array-element-if-other-values-are-null",
        "title": "jq - Copy values of first array element if other values are null"
    },
    {
        "tags": [
            "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": 1605185885,
                "post_id": 64804111,
                "comment_id": 114577113,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "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": 1605186214,
                "post_id": 64804111,
                "comment_id": 114577257,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "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": 1605186331,
                "post_id": 64804111,
                "comment_id": 114577303,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "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": 1605187355,
                "post_id": 64804111,
                "comment_id": 114577789,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1605188503,
                "last_edit_date": 1605188503,
                "creation_date": 1605187143,
                "answer_id": 64804671,
                "question_id": 64804111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a program that might be a solution to the general problem you are describing, but if not at least illustrates how problems of this type can be solved. Note in particular that there is no explicit reference to a field named &quot;other&quot;, and that (thanks to `walk`) the update function is applied to all candidate JSON objects in the input.\r\n\r\n```\r\ndef update($n):\r\n  if .items | length &gt; 0\r\n  then ((.items[0]|keys_unsorted) - [&quot;id&quot;]) as $keys\r\n  | if ($keys | length) == 1 \r\n    then $keys[0] as $key\r\n    | (.items|map(.id) | max + 1) as $newid\r\n    | .items |= . + [.[] | select(.id == $n) as $orig | .id=$newid | .[$key]=($orig[$key] | sub(&quot;e&quot;;&quot;x&quot;))]\r\n    else .\r\n    end\r\n  else .\r\n  end;\r\n\r\nwalk(if type == &quot;object&quot; and has(&quot;items&quot;) then update(2) else . end)\r\n```",
                "title": "regex replacement for whole object tree / reverse operation to `tostring`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605188503,
        "creation_date": 1605184820,
        "question_id": 64804111,
        "body_markdown": "So I have big json, where I need to take some subtree and copy it to other place, but with some properties updated (a lot of them). So for example: \r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        { &quot;id&quot;: 1, &quot;other&quot;: &quot;abc&quot;},\r\n        { &quot;id&quot;: 2, &quot;other&quot;: &quot;def&quot;},\r\n        { &quot;id&quot;: 3, &quot;other&quot;: &quot;ghi&quot;}\r\n      ]\r\n    }\r\n\r\nand say, that i&#39;d like to duplicate record having id == 2, and replace char `e` in `other` field with char `x` using regex. That could go (I&#39;m sure there is a better way, but I&#39;m beginner) something like:\r\n\r\n    jq &#39;.items |= . + [.[]|select (.id == 2) as $orig | .id=4 | .other=($orig.other | sub(&quot;e&quot;;&quot;x&quot;))]&#39;&lt;sample.json\r\n\r\nproducing\r\n\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;other&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;other&quot;: &quot;def&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;other&quot;: &quot;ghi&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 4,\r\n          &quot;other&quot;: &quot;dxf&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nNow that&#39;s great. But suppose, that there ins&#39;t just one `other` field. There are multitude of them, and over deep tree. Well I can issue multiple `sub` operations, but assuming, that replacement pattern is sufficiently selective, maybe we can turn the whole JSON subtree to string (trivial, tostring method) and replace all occurences using singe sub call. But how to turn that substituted string back to — is it call object? — to be able to add it back to items array?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64804111/regex-replacement-for-whole-object-tree-reverse-operation-to-tostring",
        "title": "regex replacement for whole object tree / reverse operation to `tostring`"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1605203015,
                "creation_date": 1605203015,
                "answer_id": 64809025,
                "question_id": 64806010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want the string `&quot;c&quot;` instead of `2` in the output, this will work:\r\n\r\n```sh\r\n$ jq &#39;.data[] | .id as $ID | .info | to_entries[] | select(.value.number &gt;= 2) | [$ID, .key]&#39; input.json\r\n[\r\n  &quot;1a2b3c&quot;,\r\n  &quot;c&quot;\r\n]\r\n```",
                "title": "jq - Get a higher level key after a selection"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1605210417,
        "creation_date": 1605191978,
        "last_edit_date": 1605210417,
        "question_id": 64806010,
        "body_markdown": "Given a JSON like the following:\r\n```\r\n{\r\n  &quot;data&quot;: [{\r\n    &quot;id&quot;: &quot;1a2b3c&quot;,\r\n    &quot;info&quot;: {\r\n      &quot;a&quot;: {\r\n        &quot;number&quot;: 0\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;number&quot;: 1\r\n      },\r\n      &quot;c&quot;: {\r\n        &quot;number&quot;: 2\r\n      }\r\n    }\r\n  }]\r\n}\r\n```\r\n\r\nI want to select on a number that is greater than or equal to 2 and for that selection I want to return the values of `id` and `number`. I did this like so:\r\n```\r\n$ jq -r &#39;.data[] | .id as $ID | .info[] | select(.number &gt;= 2) | [$ID, .number]&#39; in.json\r\n[\r\n  &quot;1a2b3c&quot;,\r\n  2\r\n]\r\n```\r\n\r\nNow I would also like to return a higher level key for my selection, in my case I need to return `c`. How can I accomplish this?",
        "link": "https://stackoverflow.com/questions/64806010/jq-get-a-higher-level-key-after-a-selection",
        "title": "jq - Get a higher level key after a selection"
    },
    {
        "tags": [
            "json",
            "average",
            "jq",
            "median"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1605206022,
                "last_edit_date": 1605206022,
                "creation_date": 1605205517,
                "answer_id": 64809645,
                "question_id": 64809334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Answer:\r\n```\r\nsort |\r\n  if length == 0 then null\r\n  elif length % 2 == 0 then (.[length/2] + .[length/2-1])/2\r\n  else .[length/2|floor] end\r\n```\r\n\r\nIt&#39;s a straightforward implementation of the specified algorithm.",
                "title": "How to calculate median using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628546397,
                "creation_date": 1628546397,
                "answer_id": 68719018,
                "question_id": 64809334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This approach takes advantage of the fact that the center of the array, which can elementwise be &quot;the middle one&quot; or &quot;the middle two&quot;, is by definition always equidistant from the array&#39;s both ends. That is, in a sorted array the distance from the lower middle value back to the first element is the same as the distance from the upper middle value to the last element, regardless of the lower and the upper middle values residing in the same element or not. Thus we only have to compute one of the two, move that far from both ends, take those elements and calculate their mean value. (If they happen to be the same, calculating the mean of two identical values won&#39;t harm.) The only obstacle we have to overcome is that jq counts 0-based when starting from the beginning but 1-based (and negative) when starting from the end of the array, so the two indices must be one apart in absolute values and have opposing signs.\r\n\r\nFor calculating the mean value, one would traditionally first add up the values and then cut the sum in half. However, when dealing with empty arrays, adding up the (non-existent) values would yield `null`, and a subsequent application of `/2` would raise an error. However, if we halve the values first and use `?` to skip where it&#39;s not applicable, then getting `null` for the final `add` would not pose a problem as it is supposedly the expected output when inputting an empty array.\r\n\r\n    sort | [ .[length/2 | ceil | -.,.-1] /2? ] | add",
                "title": "How to calculate median using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1628546397,
        "creation_date": 1605204272,
        "last_edit_date": 1605215911,
        "question_id": 64809334,
        "body_markdown": "How would you calculate the median (P50) of an array using jq? The jq manual describes how to calculate the mean, but I&#39;d like to get the median.\r\n\r\nAlgorithm: Given a list of numbers, sort it. If there are an odd number of entries then pick the middle one. If there are an even number of entries then calculate the mean of the middle two.\r\n\r\nExamples:\r\n```\r\necho &#39;[1,5,9,3]&#39; | jq &lt;ANSWER&gt;  # should output 4, since it&#39;s the mean of 3 and 5\r\necho &#39;[1,9,2]&#39; | jq &lt;ANSWER&gt;  # should output 2, since it&#39;s the middle element\r\necho &#39;[]&#39; | jq &lt;ANSWER&gt;  # undefined\r\n```",
        "link": "https://stackoverflow.com/questions/64809334/how-to-calculate-median-using-jq",
        "title": "How to calculate median using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "merge",
            "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": 1605212572,
                "post_id": 64809910,
                "comment_id": 114589507,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1605211262,
                "last_edit_date": 1605211262,
                "creation_date": 1605210087,
                "answer_id": 64810677,
                "question_id": 64809910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n```sh\r\n$ jq --slurpfile file2 file2.json &#39;\r\n   { countries:\r\n      [ .countries[] |\r\n        . as $curr |\r\n        $curr + { capital: (($file2[0].countries[] | select(.name == $curr.name) | .capital) // &quot;&quot;) }\r\n      ]\r\n    }&#39; file1.json\r\n{\r\n  &quot;countries&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;china&quot;,\r\n      &quot;continent&quot;: &quot;asia&quot;,\r\n      &quot;capital&quot;: &quot;beijing&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;france&quot;,\r\n      &quot;continent&quot;: &quot;europe&quot;,\r\n      &quot;capital&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAn alternative:\r\n\r\n```sh\r\n $ jq -n &#39;{ countries: ([inputs] | map(.countries) | flatten | group_by(.name) |\r\n                        map(select(.[] | has(&quot;continent&quot;)) | add | .capital //= &quot;&quot;))\r\n          }&#39; file[12].json\r\n```",
                "title": "JSON/JQ: Merge 2 files on key-value with condition"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605211699,
                "last_edit_date": 1605211699,
                "creation_date": 1605211139,
                "answer_id": 64810919,
                "question_id": 64809910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could first construct a dictionary from File2, and then perform the update, e.g. like so:\r\n```\r\njq --argfile dict File2.json &#39;\r\n  ($dict.countries | map( {(.name): .capital}) | add) as $capitals\r\n  | .countries |= map( .capital = ($capitals[.name] // &quot;&quot;))\r\n&#39; File2.json \r\n```\r\n\r\nFrom a JSON-esque perspective, it would probably be better to use `null` for missing values; in that case, you could simplify the above by omitting `// &quot;&quot;`.\r\n\r\n## Using `INDEX/2`\r\nIf your jq has `INDEX/2`, then the $capitals dictionary could be constructed using the expression:\r\n```\r\nINDEX($dict.countries[]; .name) | map_values(.capital)\r\n```\r\nUsing INDEX makes the intention clearer, but if efficiency were a major concern, you&#39;d probably be better off using `reduce` explicitly:\r\n\r\n    reduce $dict.countries[] as $c ({}; . + ($c | {(.name): .capital}))\r\n\r\n ",
                "title": "JSON/JQ: Merge 2 files on key-value with condition"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1605211895,
        "creation_date": 1605206714,
        "last_edit_date": 1605211895,
        "question_id": 64809910,
        "body_markdown": "I have 2 JSON files. I would like to use jq to take the value of &quot;capital&quot; from File 2 and merge it with File 1 for each element where the same &quot;name&quot;-value pair occurs. Otherwise, the element from File 2 should not occur in the output. If there is no &quot;name&quot;-value pair for an element in File 1, it should have empty text for &quot;capital.&quot;\r\n\r\nFile 1:\r\n\r\n    {\r\n       &quot;countries&quot;:[\r\n          {\r\n             &quot;name&quot;:&quot;china&quot;,\r\n             &quot;continent&quot;:&quot;asia&quot;\r\n          },\r\n          {\r\n             &quot;name&quot;:&quot;france&quot;,\r\n             &quot;continent&quot;:&quot;europe&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nFile 2:\r\n\r\n    {\r\n       &quot;countries&quot;:[\r\n          {\r\n             &quot;name&quot;:&quot;china&quot;,\r\n             &quot;capital&quot;:&quot;beijing&quot;\r\n          },\r\n          {\r\n             &quot;name&quot;:&quot;argentina&quot;,\r\n             &quot;capital&quot;:&quot;buenos aires&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nDesired result:\r\n\r\n    {\r\n       &quot;countries&quot;:[\r\n          {\r\n             &quot;name&quot;:&quot;china&quot;,\r\n             &quot;continent&quot;:&quot;asia&quot;,\r\n             &quot;capital&quot;:&quot;beijing&quot;\r\n          },\r\n          {\r\n             &quot;name&quot;:&quot;france&quot;,\r\n             &quot;continent&quot;:&quot;europe&quot;,\r\n             &quot;capital&quot;:&quot;&quot;\r\n          }\r\n       ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/64809910/json-jq-merge-2-files-on-key-value-with-condition",
        "title": "JSON/JQ: Merge 2 files on key-value with condition"
    },
    {
        "tags": [
            "python",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1605248909,
                "post_id": 64815926,
                "comment_id": 114598307,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19358627,
                    "reputation": 327,
                    "user_id": 14154352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7cebaa8c8bbb16112a35af49ae22ae9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zliangmd",
                    "link": "https://stackoverflow.com/users/14154352/zliangmd"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605288502,
                "post_id": 64815926,
                "comment_id": 114613779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1605289121,
                "post_id": 64815926,
                "comment_id": 114614002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1605291591,
                "post_id": 64815926,
                "comment_id": 114614953,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19358627,
                    "reputation": 327,
                    "user_id": 14154352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7cebaa8c8bbb16112a35af49ae22ae9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zliangmd",
                    "link": "https://stackoverflow.com/users/14154352/zliangmd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605291691,
                "post_id": 64815926,
                "comment_id": 114614996,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605770587,
                "post_id": 64815926,
                "comment_id": 114754992,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1605771138,
                "post_id": 64815926,
                "comment_id": 114755184,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 4,
        "last_activity_date": 1605306091,
        "creation_date": 1605245118,
        "last_edit_date": 1605306091,
        "question_id": 64815926,
        "body_markdown": "    %pip install jq\r\n\r\nreturns the following error\r\n\r\n```\r\n  ERROR: Command errored out with exit status 1:\r\n   command: &#39;C:\\Users\\myacn\\anaconda3\\python.exe&#39; &#39;C:\\Users\\myacn\\anaconda3\\lib\\site-packages\\pip\\_vendor\\pep517\\_in_process.py&#39; build_wheel &#39;C:\\Users\\myacn\\AppData\\Local\\Temp\\tmpygza7t_7&#39;\r\n       cwd: C:\\Users\\myacn\\AppData\\Local\\Temp\\pip-install-l6yh1hi9\\jq\r\n  Complete output (7 lines):\r\n  running bdist_wheel\r\n  running build\r\n  running build_ext\r\n  Downloading https://github.com/kkos/oniguruma/releases/download/v6.9.4/onig-6.9.4.tar.gz\r\n  Downloaded https://github.com/kkos/oniguruma/releases/download/v6.9.4/onig-6.9.4.tar.gz\r\n  Executing: ./configure CFLAGS=-fPIC --prefix=C:\\Users\\myacn\\AppData\\Local\\Temp\\pip-install-l6yh1hi9\\jq\\_deps\\onig-install-6.9.4\r\n  error: [WinError 2] The system cannot find the file specified\r\n  ----------------------------------------\r\n  ERROR: Failed building wheel for jq\r\nERROR: Could not build wheels for jq which use PEP 517 and cannot be installed directly\r\n```\r\n\r\nLooking online this [link][1] resolves for mac and linux, I&#39;m not entirely familiar with the right installation for windows, trying `%pip install autoconf automake libtool` gives\r\n\r\n```\r\nCollecting autoconf\r\n  Using cached autoconf-0.7.1-py3-none-any.whl (10 kB)\r\nNote: you may need to restart the kernel to use updated packages.\r\nERROR: Could not find a version that satisfies the requirement automake (from versions: none)\r\nERROR: No matching distribution found for automake\r\nCollecting jq\r\n  Using cached jq-1.1.1.tar.gz (69 kB)\r\n  Installing build dependencies: started\r\n  Installing build dependencies: finished with status &#39;done&#39;\r\n  Getting requirements to build wheel: started\r\n  Getting requirements to build wheel: finished with status &#39;done&#39;\r\n    Preparing wheel metadata: started\r\n    Preparing wheel metadata: finished with status &#39;done&#39;\r\nBuilding wheels for collected packages: jq\r\n  Building wheel for jq (PEP 517): started\r\n  Building wheel for jq (PEP 517): finished with status &#39;error&#39;\r\nFailed to build jq\r\nNote: you may need to restart the kernel to use updated packages.\r\nLOAD DURATION:  0:00:11.548563\r\n  ERROR: Command errored out with exit status 1:\r\n   command: &#39;C:\\Users\\myacn\\anaconda3\\python.exe&#39; &#39;C:\\Users\\myacn\\anaconda3\\lib\\site-packages\\pip\\_vendor\\pep517\\_in_process.py&#39; build_wheel &#39;C:\\Users\\myacn\\AppData\\Local\\Temp\\tmpygza7t_7&#39;\r\n       cwd: C:\\Users\\myacn\\AppData\\Local\\Temp\\pip-install-l6yh1hi9\\jq\r\n  Complete output (7 lines):\r\n  running bdist_wheel\r\n  running build\r\n  running build_ext\r\n  Downloading https://github.com/kkos/oniguruma/releases/download/v6.9.4/onig-6.9.4.tar.gz\r\n  Downloaded https://github.com/kkos/oniguruma/releases/download/v6.9.4/onig-6.9.4.tar.gz\r\n  Executing: ./configure CFLAGS=-fPIC --prefix=C:\\Users\\myacn\\AppData\\Local\\Temp\\pip-install-l6yh1hi9\\jq\\_deps\\onig-install-6.9.4\r\n  error: [WinError 2] The system cannot find the file specified\r\n  ----------------------------------------\r\n  ERROR: Failed building wheel for jq\r\nERROR: Could not build wheels for jq which use PEP 517 and cannot be installed directly\r\n```\r\n\r\nSeems like automake was the issue.\r\n\r\nReading another thread [here][2], the error message is slightly different: the link talks about bottleneck, but mine does not. Going through that thread I first tried downgrading pip `pip install pip==18.1`, restarted kernel, \r\n\r\nHere&#39;s the new errror:\r\n\r\n```\r\n  Failed building wheel for jq\r\nCommand &quot;C:\\Users\\myacn\\anaconda3\\python.exe -u -c &quot;import setuptools, tokenize;__file__=&#39;C:\\\\Users\\\\myacn\\\\AppData\\\\Local\\\\Temp\\\\pip-install-m3mejes3\\\\jq\\\\setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; install --record C:\\Users\\myacn\\AppData\\Local\\Temp\\pip-record-_38z9t11\\install-record.txt --single-version-externally-managed --compile&quot; failed with error code 1 in C:\\Users\\myacn\\AppData\\Local\\Temp\\pip-install-m3mejes3\\jq\\\r\nYou are using pip version 18.1, however version 20.3b1 is available.\r\nYou should consider upgrading via the &#39;python -m pip install --upgrade pip&#39; command.\r\n```\r\n\r\nI then downloaded Visual Studio, specifically checking C++ install tools like the steps indicated; I tried re-running with updated pip and 18.1, and get the same errors. \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/42262960/pip-install-jq-generates-errors-on-mac-and-windows\r\n  [2]: https://github.com/pydata/bottleneck/issues/281",
        "link": "https://stackoverflow.com/questions/64815926/multiple-errors-trying-to-install-jq",
        "title": "Multiple errors trying to install jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10328218,
                    "reputation": 2884,
                    "user_id": 7619034,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b8915cb5b6fc50601890a512732441bb?s=256&d=identicon&r=PG",
                    "display_name": "Rob Evans",
                    "link": "https://stackoverflow.com/users/7619034/rob-evans"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1605262550,
                "post_id": 64818664,
                "comment_id": 114602879,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1605266451,
                "post_id": 64818664,
                "comment_id": 114604432,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4452849,
                    "reputation": 137,
                    "user_id": 3624149,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/b093fffb15542e1976a59d7ba5d7a452?s=256&d=identicon&r=PG",
                    "display_name": "codelinx",
                    "link": "https://stackoverflow.com/users/3624149/codelinx"
                },
                "reply_to_user": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605568886,
                "post_id": 64818664,
                "comment_id": 114685494,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606133372,
                "post_id": 64818664,
                "comment_id": 114859171,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4452849,
                    "reputation": 137,
                    "user_id": 3624149,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/b093fffb15542e1976a59d7ba5d7a452?s=256&d=identicon&r=PG",
                    "display_name": "codelinx",
                    "link": "https://stackoverflow.com/users/3624149/codelinx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612477564,
                "post_id": 64818664,
                "comment_id": 116787035,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662671857,
                "post_id": 64818664,
                "comment_id": 130066510,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4452849,
                    "reputation": 137,
                    "user_id": 3624149,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/b093fffb15542e1976a59d7ba5d7a452?s=256&d=identicon&r=PG",
                    "display_name": "codelinx",
                    "link": "https://stackoverflow.com/users/3624149/codelinx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671669538,
                "post_id": 64818664,
                "comment_id": 132150914,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663758192,
                "last_edit_date": 1663758192,
                "creation_date": 1663591079,
                "answer_id": 73773461,
                "question_id": 64818664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming neither of your 3 property values contains any whitespace, the solution becomes almost trivial (eliminating all the issues that `eval` of untrusted data brings):\r\n\r\n```\r\n#!/bin/sh\r\n\r\naws iam list-policies |\r\n  jq -r &#39;.Policies[] | &quot;\\(.PolicyName) \\(.Arn) \\(.DefaultVersionId)&quot;&#39; |\r\n  while read -r name arn version rest; do\r\n    aws iam get-policy-version --policy-arn &quot;$arn&quot; --version-id &quot;$version&quot;\r\n  done\r\n```\r\n\r\n* The jq filter will print all name, arn, version of one policy per line\r\n* `while read -r name arn version rest` will assign each word in a line to the variable (if there are more than 3 words, all remaining words go into &quot;rest&quot;)\r\n* The loopy body then calls the second command with the variable values\r\n\r\n(Note that you never used &quot;name&quot; in your question, so it could be removed from jq and read. Secondly note, that `jq` needs only be invoked once).\r\n\r\nPlease let us know if whitespace must be support as part of the values.",
                "title": "Pass values to variables in script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663758192,
        "creation_date": 1605260685,
        "question_id": 64818664,
        "body_markdown": "**`Goal:`**\r\n1. get all the policy names in account\r\n2. get the policy version for each of the above policies\r\n3. pass these as variables to a second cli command\r\n\r\n*What i have so far:*\r\n\r\n```\r\n#!/bin/bash\r\n\r\npolicy=$(aws iam list-policies | jq -r &#39;.Policies[] | {name:.PolicyName,arn:.Arn,version:.DefaultVersionId}&#39; | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot;)\r\n\r\nfor key in $policy; do\r\n    eval ${key}\r\n    aws iam get-policy-version --policy-arn ${arn} --version-id ${version}\r\ndone\r\n```\r\n\r\nthe script will run but will constantly return an error because i think there is a mismatch in the values being used.\r\n\r\n`Error:`\r\n\r\n```\r\nAn error occurred (NoSuchEntity) when calling the GetPolicyVersion operation: \r\nPolicy arn:aws:iam::xxxxxxx:policy/service-role/SOME_POLICY_NAME version v2 \r\ndoes not exist or is not attachable.\r\n```",
        "link": "https://stackoverflow.com/questions/64818664/pass-values-to-variables-in-script",
        "title": "Pass values to variables in script"
    },
    {
        "tags": [
            "function",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605305424,
                "last_edit_date": 1605305424,
                "creation_date": 1605301225,
                "answer_id": 64827972,
                "question_id": 64827742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;comma&quot; operator (as in `2,5`) produces a stream.  So `2,5` emits two integers, which is why `[2,5]` evaluates to an array of two integers.\r\n\r\nIn general, if `E/1` has been defined using a form equivalent to `def E($x):` (i.e., as a &quot;regular&quot; function), then `E(a,b)` emits the stream `E(a)` followed by the stream `E(b)`.\r\n\r\nAnd indeed `range/1` has been defined as a &quot;regular function&quot;.\r\n\r\n## Non-regular functions\r\n\r\nHere&#39;s an example of a non-regular function:\r\n```\r\n# Emit a single JSON object (&quot;bow&quot; is short for &quot;bag of words&quot;)\r\ndef bow(stream): \r\n  reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n```\r\nNotice that the function argument here (`stream`) is passed to `reduce`, which of course handles its first argument in a special way.  \r\n\r\nSince `def E($x):` is equivalent to `def E(x): x as $x`, defining `bow` as\r\n\r\n    def bow($s): reduce $s as $word ({}; .[($word|tostring)] += 1);\r\n\r\nwould have completely different (and useless) semantics.",
                "title": "difference between range(2,5) and range(2;5)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1605323442,
                "creation_date": 1605323442,
                "answer_id": 64830569,
                "question_id": 64827742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "peak&#39;s answer is correct, but I feel it glazes over the most basic part of the answer... the comma is simply not used to separate function args in jq, because it&#39;s &quot;already taken&quot; and jq has very little syntax overloading.\r\n\r\nBecause all functions implicitly take a stream (input as `.`) and evaluate to a stream, a very large number of functions are syntactically 0-adic (e.g. `tostring`), and the majority of the rest are syntactically 1-adic (e.g. `split(str)` which takes the separator as an argument, and the values to be split using that separator implicitly). For the rare functions like `range` and `sub` that take more than one explicit argument, the semicolon is used as a separator, not the comma.\r\n\r\nAnd since jq isn&#39;t a statement-oriented language, that&#39;s *almost* the only use of the semicolon. The only other place it shows up is to mark the end of a function definition, which doesn&#39;t cause much confusion.",
                "title": "difference between range(2,5) and range(2;5)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1605450128,
        "creation_date": 1605299913,
        "last_edit_date": 1605450128,
        "question_id": 64827742,
        "body_markdown": "Template\r\n\r\n`range(2;5)`\r\n\r\nproducing:\r\n\r\n    2\r\n    3\r\n    4\r\n\r\nisn&#39;t that interesting, as this is explained by manual. However for imperative-style programmer is only matter of time, when he will mistakenly separate parameters by comma (actually I misread the manual, so this was my first attempt), and try template:\r\n\r\n    range(2, 5)\r\n\r\nproducing surprising:\r\n\r\n    0\r\n    1\r\n    0\r\n    1\r\n    2\r\n    3\r\n    4\r\n\r\nWhat is that? How is it defined/explained?",
        "link": "https://stackoverflow.com/questions/64827742/difference-between-range2-5-and-range25",
        "title": "difference between range(2,5) and range(2;5)"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605334227,
                "creation_date": 1605334227,
                "answer_id": 64831417,
                "question_id": 64831224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just convert the input value to a JSON text.\r\n```\r\n$ jq -r &#39;[ .a, tojson ] | @tsv&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;:1}&#39;\r\n1\t{&quot;a&quot;:1}\r\n```",
                "title": "How to print JSON text along with other things in TSV?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1605334380,
        "creation_date": 1605331648,
        "last_edit_date": 1605334380,
        "question_id": 64831224,
        "body_markdown": "```\r\n$ jq -r &#39;.a&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;: 1}&#39;\r\n1\r\n```\r\n\r\n```\r\n$ jq -M -c &#39;.&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;: 1}&#39;\r\n{&quot;a&quot;:1}\r\n```\r\n\r\nI&#39;d like to print the above two results in TSV (\\&lt;TAB\\&gt; is a tab character). Is there a way to do so with `jq`?\r\n\r\n```\r\n1&lt;TAB&gt;{&quot;a&quot;:1}\r\n```",
        "link": "https://stackoverflow.com/questions/64831224/how-to-print-json-text-along-with-other-things-in-tsv",
        "title": "How to print JSON text along with other things in TSV?"
    },
    {
        "tags": [
            "bash",
            "filtering",
            "eval",
            "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": 1605360581,
                "post_id": 64834378,
                "comment_id": 114629158,
                "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": 1605360643,
                "post_id": 64834378,
                "comment_id": 114629175,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1605360815,
                "post_id": 64834378,
                "comment_id": 114629217,
                "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": 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": 1605366543,
                "post_id": 64834378,
                "comment_id": 114630571,
                "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": 1605366624,
                "post_id": 64834378,
                "comment_id": 114630593,
                "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": 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": 1605369704,
                "post_id": 64834378,
                "comment_id": 114631537,
                "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": 1605370159,
                "post_id": 64834378,
                "comment_id": 114631664,
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605370665,
                "post_id": 64834378,
                "comment_id": 114631805,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1605370749,
                "post_id": 64834378,
                "comment_id": 114631835,
                "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": 1605387925,
                "post_id": 64834378,
                "comment_id": 114636372,
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605414513,
                "post_id": 64834378,
                "comment_id": 114641002,
                "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"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1605432690,
                "post_id": 64834378,
                "comment_id": 114643494,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1605363684,
                "last_edit_date": 1605363684,
                "creation_date": 1605361645,
                "answer_id": 64834570,
                "question_id": 64834378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq does not have an `eval` function for evaluating arbitrary jq expressions, but it does provide functions that can be used to achieve much the same effect, the key idea being that certain JSON values can be used to specify query operations.\r\n\r\nIn your case, you would have to translate the jq query into a suitable jq operation, such as:\r\n\r\n    jq --argjson a &#39;[&quot;Header&quot;,&quot;Tenant&quot;]&#39; &#39;\r\n       getpath(paths|select( .[- ($a|length) :]== $a))\r\n    &#39; test.json\r\n\r\n## Extending jq&#39;s JSON-based query language\r\n\r\nMore interestingly, you could write your own `eval`, e.g.\r\n\r\n```\r\njq --argjson a &#39;[[], &quot;Header&quot;,&quot;Tenant&quot;]&#39; &#39;\r\n\r\n  def eval($expr):\r\n    if $expr == [] then .\r\n    else $expr[0] as $op\r\n    | if $op == [] then .[] | eval($expr[1:])\r\n      else getpath([$op]) | eval($expr[1:])\r\n      end\r\n    end;\r\n   eval($a)\r\n&#39; test.json\r\n```\r\n## With eval.jq as a module\r\n\r\nIf the above def of `eval` were put in a file, say ~/jq/eval.jq, then you could simply write:\r\n\r\n```\r\njq -L ~/jq --argjson a &#39;[[], &quot;Header&quot;,&quot;Tenant&quot;]&#39; &#39;\r\n  include &quot;eval&quot;;\r\n  eval($a)&#39; test.json\r\n```\r\nOr you could specify the search path in the jq program:\r\n```\r\njq --argjson a &#39;[[], &quot;Header&quot;,&quot;Tenant&quot;]&#39; &#39;\r\n  include &quot;eval&quot; { &quot;search&quot;: &quot;~/jq&quot; };\r\n  eval($a)&#39; input.json\r\n```\r\n\r\nOr you could use `import` ...\r\n\r\n",
                "title": "use bash string as jq filter"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1605370540,
                "creation_date": 1605370540,
                "answer_id": 64835983,
                "question_id": 64834378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**TLDR;** The following code does the job:\r\n```\r\n$ a=&quot;.[].Header.Tenant&quot;; jq -f  &lt;(echo &quot;[$a]&quot;) test.json\r\n[\r\n  &quot;Tenant1&quot;,\r\n  &quot;Tenant2&quot;\r\n]\r\n```\r\nOne as well can add/modify the filter in the jq call, if needed: \r\n```\r\n$ a=&quot;.[].Header.Tenant&quot;; jq -f  &lt;(echo &quot;[$a]|length&quot;)   test.json\r\n2\r\n```\r\n\r\n**Longer explanation**\r\n\r\nMy ultimate goal was to figure out how I can define the lowest common denominator jq filter in a variable and use it when calling jq, plus add additional parameters if necessary. If you have a really complex jq filter spanning multiple lines that you call frequently, you probably want to template it somehow and use that template when calling jq.\r\n\r\nWhile *peak* demonstrated how it can be done, I think it is overengineering the simple task. \r\n\r\nHowever, using process substitution combined with the jq&#39;s ``-f`` option to read a filter from the file does solve my problem. ",
                "title": "use bash string as jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1605370540,
        "creation_date": 1605360291,
        "last_edit_date": 1605363126,
        "question_id": 64834378,
        "body_markdown": "I don&#39;t understand what I&#39;m doing wrong or why this does not work.\r\n\r\n``test.json`` file:\r\n```\r\n[\r\n  {\r\n    &quot;Header&quot;: {\r\n      &quot;Region&quot;: &quot;US&quot;,\r\n      &quot;Tenant&quot;: &quot;Tenant1&quot;,\r\n      &quot;Stage&quot;: &quot;testing&quot;,\r\n      &quot;ProductType&quot;: &quot;old&quot;\r\n    },\r\n    &quot;Body&quot;: []\r\n  },\r\n  {\r\n    &quot;Header&quot;: {\r\n      &quot;Region&quot;: &quot;EU&quot;,\r\n      &quot;Tenant&quot;: &quot;Tenant2&quot;,\r\n      &quot;Stage&quot;: &quot;development&quot;,\r\n      &quot;ProductType&quot;: &quot;new&quot;\r\n    },\r\n    &quot;Body&quot;: []\r\n  }\r\n]\r\n```\r\n\r\nI want to display the values of the ``.Header.Tenant`` key. So the simple jq call does its job:\r\n```\r\n$ jq &#39;[.[].Header.Tenant]&#39; test.json\r\n[\r\n  &quot;Tenant1&quot;,\r\n  &quot;Tenant2&quot;\r\n]\r\n```\r\n\r\nNow I want to assign that jq filter to a bash variable and use it with jq&#39;s ``--arg`` variable. \r\n\r\nAnd I am getting this:\r\n```\r\n$ a=&quot;.[].Header.Tenant&quot;; jq --arg xx &quot;$a&quot; &#39;[$xx]&#39; test.json\r\n[\r\n  &quot;.[].Header.Tenant&quot;\r\n]\r\n```\r\n\r\nWhat is wrong?\r\n",
        "link": "https://stackoverflow.com/questions/64834378/use-bash-string-as-jq-filter",
        "title": "use bash string as jq filter"
    },
    {
        "tags": [
            "json",
            "jq",
            "object-slicing"
        ],
        "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": 1605498957,
                "post_id": 64851773,
                "comment_id": 114659649,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605496675,
                "creation_date": 1605496675,
                "answer_id": 64852259,
                "question_id": 64851773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you wish to differentiate between &quot;version&quot; being absent or null:\r\n```\r\n{services}\r\n| .services |= map_values(select(has(&quot;version&quot;)) | {version} )\r\n```\r\n",
                "title": "How to remove unnecessary items from an JSON with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605607378,
                "last_edit_date": 1605607378,
                "creation_date": 1605498378,
                "answer_id": 64852453,
                "question_id": 64851773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Translating your expression `.services.*.version` quite generically, you could use `tostream` as follows:\r\n```\r\nreduce (tostream\r\n        | select(length==2 and\r\n                 (.[0] | (.[0] == &quot;services&quot; and\r\n                          .[-1] == &quot;version&quot;)))) as $pv (null;\r\n    setpath($pv[0]; $pv[1]) )\r\n```\r\n## Using jq&#39;s streaming parser\r\nTo reduce memory requirements, you could modify the above solution to use jq&#39;s streaming parser, either with `reduce` as above, or with `fromstream`:\r\n```\r\njq -n --stream -f program.jq input.json\r\n```\r\nwhere program.jq contains:\r\n```\r\nfromstream(inputs\r\n    | select( if length == 2\r\n\t          then .[0] | (.[0] == &quot;services&quot; and\r\n                           .[-1] == &quot;version&quot;)\r\n              else . end ) )\r\n\r\n```\r\n### `.services.*.version.*`\r\nInterpreting `.services.*.version` more broadly so as not to require the terminal component of the path to be `.version`, simply replace \r\n`.[-1] == &quot;version&quot;`\r\nwith:\r\n```\r\nindex(&quot;version&quot;)\r\n```\r\nin the above.",
                "title": "How to remove unnecessary items from an JSON with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1605607727,
        "creation_date": 1605492038,
        "last_edit_date": 1605607727,
        "question_id": 64851773,
        "body_markdown": "I need from this: (example)\r\n```\r\n{\r\n  &quot;jobs&quot;: [\r\n      {},\r\n      {}\r\n    ],\r\n  &quot;services&quot;: {\r\n    &quot;service-1&quot;: {\r\n      &quot;version&quot;: &quot;master&quot;\r\n    },\r\n    &quot;service-2&quot;: {\r\n      &quot;foo&quot;: true,\r\n      &quot;version&quot;: &quot;master&quot;\r\n    },\r\n    &quot;service-3&quot;: {\r\n      &quot;bar&quot;: &quot;baz&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nMake this:\r\n```\r\n{\r\n  &quot;services&quot;: {\r\n    &quot;service-1&quot;: {\r\n      &quot;version&quot;: &quot;master&quot;\r\n    },\r\n    &quot;service-2&quot;: {\r\n      &quot;version&quot;: &quot;master&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nSo delete all except `.services.*.version`. Help please, can&#39;t handle it with my knowledge of the JQ.",
        "link": "https://stackoverflow.com/questions/64851773/how-to-remove-unnecessary-items-from-an-json-with-jq",
        "title": "How to remove unnecessary items from an JSON with JQ?"
    },
    {
        "tags": [
            "json",
            "syntax",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605513222,
                "creation_date": 1605513222,
                "answer_id": 64854298,
                "question_id": 64854105,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.labels[&quot;service.istio.io/canonical-name&quot;]&#39;\r\n```",
                "title": "jq: error: canonical/0 is not defined at &lt;top-level&gt;, line 1. Not able to read \\ in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605531054,
        "creation_date": 1605511834,
        "last_edit_date": 1605531054,
        "question_id": 64854105,
        "body_markdown": "```json\r\n{\r\n    &quot;labels&quot;: {\r\n                    &quot;chart&quot;: &quot;boss&quot;,\r\n                    &quot;heritage&quot;: &quot;back&quot;,\r\n                    &quot;istio&quot;: &quot;gw&quot;,\r\n                    &quot;released&quot;: &quot;istio&quot;,\r\n                    &quot;service.istio.io/canonical-name&quot;: &quot;istio&quot;\r\n                }\r\n}\r\n```\r\n\r\nThis is my json. I would like to read the below key value using jq.\r\n.labels.released : i am getting the value of istio.\r\n&lt;br/&gt;\r\nsimilarly\r\ni would like to read &quot;service.istio.io/canonical-name&quot; this key. But getting the error of \r\njq: error: canonical/0 is not defined at &lt;top-level&gt;, line 1:",
        "link": "https://stackoverflow.com/questions/64854105/jq-error-canonical-0-is-not-defined-at-top-level-line-1-not-able-to-read",
        "title": "jq: error: canonical/0 is not defined at &lt;top-level&gt;, line 1. Not able to read \\ in json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "iteration",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605533226,
                "last_edit_date": 1605533226,
                "creation_date": 1605530550,
                "answer_id": 64858241,
                "question_id": 64857525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should only enumerate once:\r\n\r\n    .statuses[] | &quot;\\(.name), \\(.jobId)&quot;\r\n\r\nIncidentally, you might wish to consider using `@csv` instead of interpolation.",
                "title": "get json output with jq comma separated duplicate my output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605533226,
        "creation_date": 1605527571,
        "last_edit_date": 1605533088,
        "question_id": 64857525,
        "body_markdown": "I&#39;m trying to get 2 json registers of a query in same line comma separated but allways duplicate me the output. \r\nCould you help me please? Thanks\r\n\r\n    bash-4.2$ rm run works:status::get -s &quot;ctm=SERVERA&amp;work=*&amp;status=Failed&quot; | $PATH_API/jq -r &#39;.statuses[].name, .statuses[].jobId  // empty&#39; --raw-output\r\n    JOBA\r\n    JOBA\r\n    SERVERA:0rhh0\r\n    SERVERA:0rhgz\r\n \r\n    bash-4.2$\r\n    bash-4.2$ rm run works:status::get -s &quot;ctm=SERVERA&amp;work=*&amp;status=Failed&quot; | $PATH_API/jq -r &#39;&quot;\\(.statuses[].name), \\(.statuses[].jobId)&quot;&#39;  --raw-output\r\n    JOBA, SERVERA:0rhh0\r\n    JOBA, SERVERA:0rhh0\r\n    JOBA, SERVERA:0rhgz\r\n    JOBA, SERVERA:0rhgz",
        "link": "https://stackoverflow.com/questions/64857525/get-json-output-with-jq-comma-separated-duplicate-my-output",
        "title": "get json output with jq comma separated duplicate my output"
    },
    {
        "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": 1605535314,
                "post_id": 64858905,
                "comment_id": 114671902,
                "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": 1605535457,
                "post_id": 64858905,
                "comment_id": 114671977,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1605535144,
                "creation_date": 1605535144,
                "answer_id": 64859428,
                "question_id": 64858905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the status names are sufficiently uncomplicated, you could add an extra pair of parentheses:\r\n\r\n    try=($(tm run ....))\r\n\r\n(Consider also invoking jq without the -r option.)\r\n\r\nOtherwise, you could consider using `readarray`, or other techniques for initializing bash arrays.",
                "title": "why get all results of jq in a single array element in bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605535144,
        "creation_date": 1605533275,
        "question_id": 64858905,
        "body_markdown": "I&#39;m trying to get all results of jq query in a array in bash, but it gives me all results in the first array element. \r\nCould you help me? I would like to having every result in one array element\r\n\r\n    bash-4.2$ try=$(tm run jobs:status::get -s &quot;tm=serverA&amp;work=*&amp;status=Failed&quot; | $PATH_API/jq -r &#39;.statuses[].name // empty&#39;)\r\n    bash-4.2$ echo $try\r\n    job_B job_C\r\n    bash-4.2$ echo &quot;${#try[@]}&quot;\r\n    1\r\n    bash-4.2$",
        "link": "https://stackoverflow.com/questions/64858905/why-get-all-results-of-jq-in-a-single-array-element-in-bash",
        "title": "why get all results of jq in a single array element in bash"
    },
    {
        "tags": [
            "json",
            "nested",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2999407,
                    "reputation": 707,
                    "user_id": 2545164,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/b2bb637e54b421cabcb9d8c66517ec7f?s=256&d=identicon&r=PG",
                    "display_name": "William Grimes",
                    "link": "https://stackoverflow.com/users/2545164/william-grimes"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1605537892,
                "post_id": 64859291,
                "comment_id": 114673088,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2999407,
                    "reputation": 707,
                    "user_id": 2545164,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/b2bb637e54b421cabcb9d8c66517ec7f?s=256&d=identicon&r=PG",
                    "display_name": "William Grimes",
                    "link": "https://stackoverflow.com/users/2545164/william-grimes"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1605539426,
                "post_id": 64859291,
                "comment_id": 114673810,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1605613719,
                "last_edit_date": 1605613719,
                "creation_date": 1605536923,
                "answer_id": 64859834,
                "question_id": 64859291,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n```sh\r\n$&#160;jq -r &#39;\r\n  [[&quot;name&quot;,&quot;unit&quot;,&quot;timestamp&quot;,&quot;value&quot;]], \r\n   [ .[] \r\n     | [ .name, .unit ] + \r\n       (.values[] | [.timestamp,.value]) ] \r\n  | .[] \r\n  | @csv&#39; input.json \r\n&quot;name&quot;,&quot;unit&quot;,&quot;timestamp&quot;,&quot;value&quot;\r\n&quot;PM2.5&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:21.135Z&quot;,3.696\r\n&quot;PM2.5&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:31.649Z&quot;,3.696\r\n&quot;PM2.5&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:42.35Z&quot;,3.696\r\n&quot;PM2.5&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:52.953Z&quot;,3.696\r\n&quot;PM10&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:21.135Z&quot;,7.596\r\n&quot;PM10&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:31.649Z&quot;,7.596\r\n&quot;PM10&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:42.35Z&quot;,7.596\r\n&quot;PM10&quot;,&quot;ug/m3&quot;,&quot;2020-11-16T13:10:52.953Z&quot;,7.596\r\n```\r\n\r\nBuilds an array of arrays, one per row including a header line, and then formats them all as CSV records.",
                "title": "Convert json to csv using jq, with array nested within array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1605613719,
        "creation_date": 1605534690,
        "last_edit_date": 1605567983,
        "question_id": 64859291,
        "body_markdown": "How can I flatten this json array and write out to a csv file using jq so that each row contains all the fields i.e. \r\n\r\nI&#39;m a bit of a novice with jq but started with this, which does not capture the inner nested array\r\n\r\n`jq -r &#39;(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ]])[]&#39;`\r\n\r\n```\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;PM2.5&quot;,\r\n      &quot;unit&quot;:&quot;ug/m3&quot;,\r\n      &quot;values&quot;:[\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:21.135Z&quot;,\r\n            &quot;value&quot;:3.696\r\n         },\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:31.649Z&quot;,\r\n            &quot;value&quot;:3.696\r\n         },\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:42.35Z&quot;,\r\n            &quot;value&quot;:3.696\r\n         },\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:52.953Z&quot;,\r\n            &quot;value&quot;:3.696\r\n         }\r\n      ]\r\n   },\r\n   {\r\n      &quot;name&quot;:&quot;PM10&quot;,\r\n      &quot;unit&quot;:&quot;ug/m3&quot;,\r\n      &quot;values&quot;:[\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:21.135Z&quot;,\r\n            &quot;value&quot;:7.596\r\n         },\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:31.649Z&quot;,\r\n            &quot;value&quot;:7.596\r\n         },\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:42.35Z&quot;,\r\n            &quot;value&quot;:7.596\r\n         },\r\n         {\r\n            &quot;timestamp&quot;:&quot;2020-11-16T13:10:52.953Z&quot;,\r\n            &quot;value&quot;:7.596\r\n         }\r\n      ]\r\n   }\r\n]\r\n```\r\n\r\nTo a csv as follows:\r\n\r\n```\r\n&quot;name&quot;, &quot;unit&quot;, &quot;timestamp&quot;, &quot;value&quot;\r\n&quot;PM2.5&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:21.135Z&quot;, 3.696\r\n&quot;PM2.5&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:31.649Z&quot;, 3.696\r\n&quot;PM2.5&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:42.35Z&quot;, 3.696\r\n&quot;PM2.5&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:52.953Z&quot;, 3.696  \r\n&quot;PM10&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:21.135Z&quot;, 7.596\r\n&quot;PM10&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:31.649Z&quot;, 7.596\r\n&quot;PM10&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:42.35Z&quot;, 7.596\r\n&quot;PM10&quot;, &quot;ug/m3&quot;, &quot;2020-11-16T13:10:52.953Z&quot;, 7.596\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/64859291/convert-json-to-csv-using-jq-with-array-nested-within-array",
        "title": "Convert json to csv using jq, with array nested within array"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605621346,
                "post_id": 64876606,
                "comment_id": 114701980,
                "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": 2,
                "creation_date": 1605621347,
                "post_id": 64876606,
                "comment_id": 114701982,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1605630226,
                "last_edit_date": 1605630226,
                "creation_date": 1605628904,
                "answer_id": 64878817,
                "question_id": 64876606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Each time you write `.Tags[]`, you are iterating over `.Tags`, so the way you&#39;ve written the selection criterion cannot achieve the desired effect.  \r\n\r\nOne way to reformulate your query would be to use `any/2` and/or `all/2` as appropriate.  Presumably, for example, the criterion you want based on .Value would be (equivalent to):\r\n\r\n    all(.Instances[0].Tags[].Value; \r\n        contains(&quot;NFTPerformanceTest&quot;)|not)\r\n\r\n## Example\r\nFor efficiency, it would make sense to re-order the selection criteria, so you might end up with something like:\r\n```\r\n.Reservations\r\n| map(select(.Instances[0]\r\n             | ( .State.Name==&quot;running&quot; and\r\n\t             any(.Tags[]; .Value==$env) and\r\n                 all(.Instances[0].Tags[].Value;\r\n                     contains(&quot;NFTPerformanceTest&quot;)|not) )))\r\n```\r\n",
                "title": "jq - Filtering instances for not contain is not working"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605630226,
        "creation_date": 1605621165,
        "question_id": 64876606,
        "body_markdown": "I am trying to filter instances within my AWS environment that are currently running. I am using jq to filter the instances:\r\n\r\n    INSTANCE_METADATA=$(aws ec2 --profile $ACCOUNT describe-instances | jq --arg env $ENVIRONMENT &#39;.Reservations|map(select((.Instances[0].Tags[].Value==$env) and (.Instances[0].State.Name==&quot;running&quot;) ))&#39;)\r\n\r\nI am then creating a variable for the InstanceIDs:\r\n\r\n    RUNNING_INSTANCE_IDS=$(jq -r &#39;.[].Instances[0].InstanceId&#39; &lt;&lt;&lt;&quot;${BEANSTALK_INSTANCE_METADATA}&quot;)\r\n\r\nThis works perfectly fine. \r\n\r\nHowever, there is one instance within the environment that I do not want to include in this list, so I have tried to include another filter within the original jq. I have tried it 2 different ways:\r\n\r\n    $(aws ec2 --profile $ACCOUNT describe-instances | jq --arg env $ENVIRONMENT &#39;.Reservations|map(select((.Instances[0].Tags[].Value==$env) and (.Instances[0].State.Name==&quot;running&quot;) and (.Instances[0].Tags[].Value|contains(&quot;NFTPerformanceTest&quot;)|not)) ))&#39;)\r\n\r\nand\r\n\r\n    $(aws ec2 --profile $ACCOUNT describe-instances | jq --arg env $ENVIRONMENT &#39;.Reservations|map(select((.Instances[0].Tags[].Value==$env) and (.Instances[0].State.Name==&quot;running&quot;) and (.Instances[0].Tags[].Value!=&quot;NFTPerformanceTest&quot;) ))&#39;)\r\n\r\nNeither of these successfully filter out the Instance in question. What am I missing here? ",
        "link": "https://stackoverflow.com/questions/64876606/jq-filtering-instances-for-not-contain-is-not-working",
        "title": "jq - Filtering instances for not contain is not working"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1605688036,
                "last_edit_date": 1605688036,
                "creation_date": 1605669142,
                "answer_id": 64886488,
                "question_id": 64886393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, here&#39;s a solution which is completely agnostic about where &quot;ms-madison&quot; appears but which will change every occurrence of the target string:\r\n\r\n```\r\nwalk(if . == &quot;ms-madison&quot; then &quot;mr-harmison&quot; else . end)\r\n```\r\n\r\nSecond, if one only wanted to change at most one occurrence:\r\n```\r\n. as $in\r\n| (first(paths | select(. as $p | $in | getpath($p) == &quot;ms-madison&quot;)) // null) as $p\r\n| if $p then setpath($p; &quot;mr-harmison&quot;) else . end\r\n```\r\n## Restricting changes to a specific context\r\n\r\nHere&#39;s an illustration of how to &quot;walk&quot; `.containers` to change all occurrences of the target string that occur as top-level elements of every array-valued &quot;args&quot; keys:\r\n```\r\n.containers |= walk( if type==&quot;object&quot;\r\n                        and (.args|type)==&quot;array&quot;\r\n                     then .args\r\n                        |= map_values(\r\n                             if . == &quot;ms-madison&quot; \r\n                             then &quot;mr-harmison&quot;\r\n                             else . end)\r\n                     else . end)\r\n```\r\n",
                "title": "replace arguements in a json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605672606,
                "creation_date": 1605672606,
                "answer_id": 64886964,
                "question_id": 64886393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A prosaic but robust solution:\r\n```\r\n(.containers[0].args | index(&quot;ms-madison&quot;)) as $ix\r\n| if $ix then .containers[0].args[$ix] = &quot;mr-harmison&quot; else . end\r\n```",
                "title": "replace arguements in a json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1605688036,
        "creation_date": 1605668506,
        "last_edit_date": 1605668700,
        "question_id": 64886393,
        "body_markdown": "```\r\n{\r\n&quot;containers&quot;: [\r\n          {\r\n            &quot;args&quot;: [\r\n              &quot;water&quot;,\r\n              &quot;fight&quot;,\r\n              &quot;--homein&quot;,\r\n              &quot;$(POD_NAMESPACE).svc.cluster.local&quot;,\r\n              &quot;--proxyLogLevel=warning&quot;,\r\n              &quot;--proxyComponentLogLevel=misc:error&quot;,\r\n              &quot;--log_output_level=default:info&quot;,\r\n              &quot;ms-madison&quot;,\r\n              &quot;--trust-domain=cluster.local&quot;\r\n            ]}]\r\n}\r\n```\r\n\r\nI am able to replace ms-madison with mr-harmison with an ugly solution\r\n.containers[0].args[8] |= &quot;mr-harmison&quot;&#39;\r\n\r\nms-madison can come at any position. Can you suggest to me a better way to deal with this?\r\n",
        "link": "https://stackoverflow.com/questions/64886393/replace-arguements-in-a-json-using-jq",
        "title": "replace arguements in a json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605712905,
                "last_edit_date": 1605712905,
                "creation_date": 1605711710,
                "answer_id": 64895698,
                "question_id": 64895007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could begin by simply renaming the &quot;--arg&quot; variables:\r\n```\r\njq -r --arg cancel Cancelled \\\r\n      --arg start Started    \\\r\n      --arg stop Stopped     \\\r\n      --arg replace Active &#39;\r\n.result|= map(if .is_cancelled == true then (.is_cancelled=$cancel) else . end)\r\n| .result|= map(if .is_started == true then (.is_started=$start) else . end)\r\n| .result|= map(if .is_started == false then (.is_started=$stop) else . end)\r\n| .result|= map(if .is_cancelled == false then (.is_cancelled=$replace) else . end)\r\n&#39; \r\n```\r\n\r\nThe next step would be to rephrase this to avoid the repeated iterations through the array, so that the jq filter might look like this:\r\n```\r\n  .result |= \r\n     map(if .is_cancelled == true then (.is_cancelled=$cancel) \r\n         elif .is_cancelled == false then (.is_cancelled=$replace) \r\n         else . \r\n         end\r\n         | if .is_started == true then (.is_started=$start) \r\n           elif .is_started == false then (.is_started=$stop) \r\n           else .\r\n           end )\r\n\r\n```\r\n\r\n## Potential simplification\r\n\r\nYou might also wish to consider the following, which however might be an oversimplification:\r\n\r\n```\r\n  .result |= \r\n     map(.is_cancelled |= if . then $cancel else $replace end\r\n         | .is_started |= if . then $start else $stop end)\r\n```\r\n## An alternative way to pass in the parameters\r\n\r\nThere are several less tedious ways to pass in the four parameters; you might like to consider this possibility, for example:\r\n```\r\njq -r --argjson v &#39;\r\n    {&quot;cancel&quot;: &quot;Cancelled&quot;, &quot;start&quot;: &quot;Started&quot;, &quot;stop&quot;: &quot;Stopped&quot;,  &quot;replace&quot;: &quot;Active&quot;}&#39; &#39;\r\n  .result |= \r\n     map(.is_cancelled |= if . then $v.cancel else $v.replace end\r\n         | .is_started |= if . then $v.start else $v.stop end)\r\n&#39;\r\n```\r\n",
                "title": "How to conditionally change multiple values on all records with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1605712905,
        "creation_date": 1605709496,
        "question_id": 64895007,
        "body_markdown": "I managed to get what I needed, but I think I could possibly do it without having to call jq multiple times. Do you know how I can do the same with only one jq call ?\r\n\r\n```\r\n|jq -r --arg replace &#39;Cancelled&#39; &#39;.result|= map(if .is_cancelled == true then (.is_cancelled=$replace) else . end)&#39; \\\r\n|jq -r --arg replace &#39;Started&#39; &#39;.result|= map(if .is_started == true then (.is_started=$replace) else . end)&#39; \\\r\n|jq -r --arg replace &#39;Stopped&#39; &#39;.result|= map(if .is_started == false then (.is_started=$replace) else . end)&#39; \\\r\n|jq -r --arg replace &#39;Active&#39; &#39;.result|= map(if .is_cancelled == false then (.is_cancelled=$replace) else . end)&#39; \r\n```\r\n\r\nThe data passed to jq looks like this :\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;id&quot;: 8893,\r\n      &quot;entry_time&quot;: &quot;2020-11-04T16:02:43+01:00&quot;,\r\n      &quot;author_id&quot;: 24,\r\n      &quot;author_name&quot;: &quot;joe&quot;,\r\n      &quot;host_id&quot;: 2115,\r\n      &quot;service_id&quot;: 0,\r\n      &quot;is_cancelled&quot;: false,\r\n      &quot;comment&quot;: &quot;Test 5236&quot;,\r\n      &quot;deletion_time&quot;: null,\r\n      &quot;duration&quot;: 4302000,\r\n      &quot;end_time&quot;: &quot;2020-12-24T13:48:22+01:00&quot;,\r\n      &quot;internal_id&quot;: 513,\r\n      &quot;is_fixed&quot;: true,\r\n      &quot;poller_id&quot;: 2,\r\n      &quot;start_time&quot;: &quot;2020-11-04T18:48:22+01:00&quot;,\r\n      &quot;actual_start_time&quot;: &quot;2020-11-18T12:08:16+01:00&quot;,\r\n      &quot;actual_end_time&quot;: null,\r\n      &quot;is_started&quot;: true\r\n    },\r\n    {\r\n      &quot;id&quot;: 8894,\r\n      &quot;entry_time&quot;: &quot;2020-11-04T16:02:43+01:00&quot;,\r\n      &quot;author_id&quot;: 24,\r\n      &quot;author_name&quot;: &quot;joe&quot;,\r\n      &quot;host_id&quot;: 2115,\r\n[…]\r\n    }\r\n  ],\r\n  &quot;meta&quot;: {\r\n    &quot;pagination&quot;: {\r\n      &quot;page&quot;: 1,\r\n      &quot;limit&quot;: 999999999,\r\n      &quot;search&quot;: {},\r\n      &quot;sort_by&quot;: {\r\n        &quot;host.name&quot;: &quot;DESC&quot;\r\n      },\r\n      &quot;total&quot;: 118\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe result is something like that :\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;id&quot;: 8893,\r\n      &quot;entry_time&quot;: &quot;2020-11-04T16:02:43+01:00&quot;,\r\n      &quot;author_id&quot;: 24,\r\n      &quot;author_name&quot;: &quot;joe&quot;,\r\n      &quot;host_id&quot;: 2115,\r\n      &quot;service_id&quot;: 0,\r\n      &quot;is_cancelled&quot;: &quot;Active&quot;,\r\n      &quot;comment&quot;: &quot;Test 5236&quot;,\r\n      &quot;deletion_time&quot;: null,\r\n      &quot;duration&quot;: 4302000,\r\n      &quot;end_time&quot;: &quot;2020-12-24T13:48:22+01:00&quot;,\r\n      &quot;internal_id&quot;: 513,\r\n      &quot;is_fixed&quot;: true,\r\n      &quot;poller_id&quot;: 2,\r\n      &quot;start_time&quot;: &quot;2020-11-04T18:48:22+01:00&quot;,\r\n      &quot;actual_start_time&quot;: &quot;2020-11-18T12:08:16+01:00&quot;,\r\n      &quot;actual_end_time&quot;: null,\r\n      &quot;is_started&quot;: &quot;Started&quot;\r\n    },\r\n[…]\r\n```\r\n\r\nfalse and true values are replaced with some other values for the fields &quot;is_started&quot; and &quot;is_cancelled&quot;, on all records of .result.\r\n\r\nIs it possible to do the same change with calling jq only once ?\r\n",
        "link": "https://stackoverflow.com/questions/64895007/how-to-conditionally-change-multiple-values-on-all-records-with-jq",
        "title": "How to conditionally change multiple values on all records with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605735601,
                "creation_date": 1605735601,
                "answer_id": 64901830,
                "question_id": 64901377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [Update-assignment operator](https://stedolan.github.io/jq/manual/v1.6/#Assignment) `|=` to modify the values of &quot;e&quot; and &quot;t&quot;.\r\n\r\n    jq -r &#39;.e |= join(&quot;,&quot;)\r\n         | .t |= join(&quot;,&quot;)\r\n         | [.e, .t, .n, .linkedin, .a]\r\n         | @tsv&#39;",
                "title": "JQ remove the output commas between data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605735601,
        "creation_date": 1605733503,
        "question_id": 64901377,
        "body_markdown": "Hello i&#39;m trying to extract this data below\r\n\r\n    {\r\n    \t&quot;a&quot;: &quot;orlando, florida, united states&quot;,\r\n    \t&quot;t&quot;: [&quot;007-414-7001&quot;, &quot;1-007-414-7002&quot;, &quot;0074147003&quot;, &quot;1-007-414-7005&quot;],\r\n    \t&quot;e&quot;: [&quot;demo@example.com&quot;, &quot;demo1@example.com&quot;, &quot;demo2@example.com&quot;, &quot;demo3@example.com&quot;],\r\n    \t&quot;liid&quot;: &quot;empty&quot;,\r\n    \t&quot;linkedin&quot;: &quot;empty&quot;,\r\n    \t&quot;n&quot;: &quot;phil demo&quot;\r\n    }\r\n\r\nmy command is `jq -r &#39;[.e[], .t[], .n, .linkedin, .a] | @tsv&#39;` \r\nSo i got an output like this\r\n\r\n    demo@example.com        demo1@example.com       demo2@example.com       demo3@example.com       007-414-7001   1-007-414-7002  0074147003      1-007-414-7005  phil demo       empty   orlando, florida, united states\r\n*As you can see for &quot;e&quot; field its just one column but in csv or tsv result give multiple columns not just one.*\r\n\r\nMy question now how i can get between data in both fields of &quot;e&quot; and &quot;t&quot; separated by commas?\r\n\r\nI need to get a result like this:\r\n\r\n    demo@example.com,demo1@example.com,demo2@example.com,demo3@example.com       007-414-7001,1-007-414-7002,0074147003,1-007-414-7005  phil demo       empty   orlando, florida, united states\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64901377/jq-remove-the-output-commas-between-data",
        "title": "JQ remove the output commas between data"
    },
    {
        "tags": [
            "dictionary",
            "jq",
            "reduce"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1605742668,
                "last_edit_date": 1605742668,
                "creation_date": 1605740962,
                "answer_id": 64902849,
                "question_id": 64902535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there. To convert from multiple results to a single object, you can run another `jq` in slurp mode:\r\n\r\n```bash\r\necho -e &quot;1\\n2\\n\\n\\n3\\n4\\n5&quot; \\\r\n| jq --raw-input &#39;select (. != &quot;&quot;) | {(.):123}&#39; \\\r\n| jq --slurp &#39;reduce .[] as $o ({}; . + $o)&#39;\r\n```",
                "title": "reduction of stream of object does not work for me"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1605742301,
                "creation_date": 1605742301,
                "answer_id": 64903050,
                "question_id": 64902535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, the initial `.|` is unnecessary.\r\n\r\nSecond, since your input is a stream, you will either need to use the -s option, or better, use the -n option with `inputs`.\r\n\r\nSo you could go with:\r\n```\r\necho -e &quot;1\\n2\\n\\n\\n3\\n4\\n5&quot; | \r\n  jq -nR &#39;reduce (inputs|select(. != &quot;&quot;)) as $i ({}; . + {($i): 123})&#39;\r\n```\r\n\r\nthough maybe `{($i): null}` might be more appropriate.",
                "title": "reduction of stream of object does not work for me"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1605742668,
        "creation_date": 1605739099,
        "last_edit_date": 1605742620,
        "question_id": 64902535,
        "body_markdown": "I wrote several reductions, where I had array to begin with. But if I try to read raw data and transform each line into object, I don&#39;t have much luck reducing them together\r\n\r\n    echo -e &quot;1\\n2\\n\\n\\n3\\n4\\n5&quot; | jq --raw-input &#39;. | select (. != &quot;&quot;) | {(.):123} | reduce . as $i ({}; . + $i)&#39;\r\n\r\nthe reduction does nothing. Why? How to correct the reduction to produce single object having keys 1,2,3,4,5?",
        "link": "https://stackoverflow.com/questions/64902535/reduction-of-stream-of-object-does-not-work-for-me",
        "title": "reduction of stream of object does not work for me"
    },
    {
        "tags": [
            "json",
            "matrix",
            "multidimensional-array",
            "jq",
            "dimensions"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605985524,
                "last_edit_date": 1605985524,
                "creation_date": 1605753458,
                "answer_id": 64904579,
                "question_id": 64904537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pipe each separate dimension into `length`:\r\n\r\n    $ echo &#39;{\r\n      &quot;data&quot;: [\r\n        [1,2,3,4],\r\n        [5,6,7,8]\r\n      ]\r\n    }&#39; | jq &#39;.data | [length, (.[0] | length)]&#39;\r\n    [\r\n      2,\r\n      4\r\n    ]\r\n\r\nThe filter could also be written as\r\n\r\n    .data | [., .[0]] | map(length)\r\n\r\n",
                "title": "jq: Get dimensions of 2d array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1606220286,
                "last_edit_date": 1606220286,
                "creation_date": 1605756617,
                "answer_id": 64905003,
                "question_id": 64904537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a general solution for a strictly regular, n-dimensional array:\r\n```\r\n.data | [recurse( .[0]? | select(type==&quot;array&quot;)) |  length]\r\n```\r\n\r\nFor more about the concept of strict regularity, see below.\r\n \r\n## As a function\r\n\r\nWith\r\n```\r\ndef rho: [recurse( .[0]? | select(type==&quot;array&quot;)) |  length];\r\n```\r\n\r\n`[ [[1,1],[2,2]], [[1,1],[2,2]], [[1,1],[2,2]]] | rho`\r\n\r\nwould yield: [3,2,2]\r\n\r\n## Strict regularity\r\n\r\nFor present purposes, let&#39;s say a &quot;matrix&quot; is strictly regular if none of its entries is an array, and that\r\nan n-dimensional JSON array is strictly regular if and only if the corresponding n-dimensional matrix is strictly regular.\r\n\r\nTo check that a JSON array is strictly regular in this sense, we can define `is_strictly_regular` (using the above definition of `rho`) as follows:\r\n\r\n```\r\n# Check whether the input has precisely the specified\r\n# dimensions, and no additional arrays.\r\n# It is assumed that $dimensions is an array of non-negative integers.\r\n# If $dimensions is [], then return type!=&quot;array&quot;.\r\ndef strictcheck($dimensions):\r\n  if type == &quot;array&quot;\r\n  then ($dimensions|length) &gt; 0\r\n       and length == $dimensions[0]\r\n       and all(.[]; strictcheck($dimensions[1:]))\r\n  else $dimensions == []\r\n  end;\r\n\r\ndef is_strictly_regular:\r\n  rho as $d\r\n  | strictcheck($d);\r\n```",
                "title": "jq: Get dimensions of 2d array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1606220286,
        "creation_date": 1605753046,
        "last_edit_date": 1605756763,
        "question_id": 64904537,
        "body_markdown": "I&#39;d like to retrieve the dimensions of a 2D array with `jq`.\r\n\r\ntest.json:\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    [1,2,3,4],\r\n    [5,6,7,8]\r\n  ]\r\n}\r\n```\r\n\r\nI can get the major dimension:\r\n\r\n```sh\r\n$ jq &lt; test.json &#39;.data | length&#39;\r\n2\r\n```\r\n\r\nI can get the minor dimension:\r\n```sh\r\n$ jq &lt; test.json &#39;.data[0] | length&#39;\r\n4\r\n```\r\n\r\nI would like to get both at once, ie: (does not work, expected output)\r\n```\r\n$ jq &lt; test.json &#39;.data | [length, .[0] ???? ]&#39;\r\n[\r\n  2,\r\n  4\r\n]\r\n```\r\n\r\nIs there any way to produce this expected output with jq?\r\n```",
        "link": "https://stackoverflow.com/questions/64904537/jq-get-dimensions-of-2d-array",
        "title": "jq: Get dimensions of 2d array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605791318,
                "post_id": 64911926,
                "comment_id": 114764045,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7326262,
                    "reputation": 1364,
                    "user_id": 5580578,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39bfb7cbf5fdab75f4662b8ca470307d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user5580578",
                    "link": "https://stackoverflow.com/users/5580578/user5580578"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605791592,
                "post_id": 64911926,
                "comment_id": 114764170,
                "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": 1605791746,
                "post_id": 64911926,
                "comment_id": 114764231,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605792097,
                "last_edit_date": 1605792097,
                "creation_date": 1605791442,
                "answer_id": 64912386,
                "question_id": 64911926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like\r\n\r\n\r\n```sh\r\n$ jq --slurpfile source source.json &#39;.values = $source[0]&#39; target.json\r\n{\r\n  &quot;header&quot;: &quot;stuff&quot;,\r\n  &quot;values&quot;: {\r\n    &quot;test&quot;: &quot;value&quot;,\r\n    &quot;test1&quot;: &quot;value2&quot;\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "Include json file as value of another json file using bash and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1605792097,
        "creation_date": 1605789830,
        "last_edit_date": 1605791948,
        "question_id": 64911926,
        "body_markdown": "how can I integrate the following json file\r\n\r\n    [source.json]\r\n    {\r\n      &quot;test&quot;: &quot;value&quot;, \r\n      &quot;test1&quot;: &quot;value2&quot;\r\n    }\r\n\r\ninto this json file using jq?\r\n\r\n    [target.json] \r\n    {\r\n      &quot;header&quot;: &quot;stuff&quot;\r\n      &quot;values&quot; : \r\n      {\r\n        &quot;test&quot;: &quot;value&quot;,   //from source.json\r\n        &quot;test1&quot;: &quot;value2&quot;   //from source.json\r\n      }\r\n    }\r\n\r\n\r\nIt is possible that the &quot;values&quot; key in the target json file does not yet exist or that it already contains values. In both cases, the target.json file shown here should be created.",
        "link": "https://stackoverflow.com/questions/64911926/include-json-file-as-value-of-another-json-file-using-bash-and-jq",
        "title": "Include json file as value of another json file using bash and jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "curl",
            "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": 1605802402,
                "post_id": 64915205,
                "comment_id": 114769531,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19467456,
                    "reputation": 15,
                    "user_id": 14240487,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2edec5ba99d88ca5dfca404ca7dcdb0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alfador",
                    "link": "https://stackoverflow.com/users/14240487/alfador"
                },
                "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": 1605802620,
                "post_id": 64915205,
                "comment_id": 114769631,
                "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": 1605861588,
                "post_id": 64915205,
                "comment_id": 114787555,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19467456,
                    "reputation": 15,
                    "user_id": 14240487,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2edec5ba99d88ca5dfca404ca7dcdb0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alfador",
                    "link": "https://stackoverflow.com/users/14240487/alfador"
                },
                "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": 1605861842,
                "post_id": 64915205,
                "comment_id": 114787665,
                "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": 1605877664,
                "post_id": 64915205,
                "comment_id": 114794187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19467456,
                    "reputation": 15,
                    "user_id": 14240487,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2edec5ba99d88ca5dfca404ca7dcdb0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alfador",
                    "link": "https://stackoverflow.com/users/14240487/alfador"
                },
                "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": 1,
                "creation_date": 1605913860,
                "post_id": 64915205,
                "comment_id": 114808664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1605960204,
                "last_edit_date": 1605960204,
                "creation_date": 1605809405,
                "answer_id": 64917552,
                "question_id": 64915205,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Basing the jq statement on the example provided, you can pipe the output to awk to do the date comparisons and generate the commands required.\r\n\r\n    cat file | jq -r &#39;.hits[] | .lastModified + &quot;;&quot; + .name&#39; | awk -v compdat=&quot;2020-11-20 13:13:45&quot; -F\\; &#39;\r\n        \r\n          BEGIN { \r\n                  &quot;date -d \\&quot;&quot;compdat&quot;\\&quot; +%s&quot; | getline csdat \r\n                } \r\n          $2 ~ /zip$/ { \r\n                   split($1,dats,&quot; &quot;);\r\n                   &quot;date -d \\&quot;&quot;$1&quot;\\&quot; +%s&quot; | getline sdat;\r\n                   if (sdat &lt; csdat) { \r\n                                       print &quot;rm &quot;$2 \r\n                   } \r\n                 }&#39;\r\n\r\nOne liner:\r\n\r\n    cat file | jq -r &#39;.hits[] | .lastModified + &quot;;&quot; + .name&#39; | awk -v compdat=&quot;2020-05-20 13:13:45&quot; -F\\; &#39;BEGIN { &quot;date -d \\&quot;&quot;compdat&quot;\\&quot; +%s&quot; | getline csdat } $2 ~ /zip$/ { split($1,dats,&quot; &quot;);&quot;date -d \\&quot;&quot;$1&quot;\\&quot; +%s&quot; | getline sdat;if (sdat &lt; csdat) { print &quot;rm &quot;$2 } }&#39;\r\n\r\nIn the begin block, we generate the passed date (compdat) in epoch format using awk&#39;s getline, passing the result of the date command into a variable csdat. Then we take the ; comma separated variables ($1 - lastModified, $2 - name) and again get the epoch version of lastModified, reading the result into a variable csdat. We then compare csdat to sdat and print a rm command for the zip file if sdat is less the csdat.\r\n\r\nOnce you have verified that the commands display as expected (this part is important!), you can run the actual command by utilising awk&#39;s system function, replacing the print for the system function and so:\r\n\r\n    cat file | jq -r &#39;.hits[] | .lastModified + &quot;;&quot; + .name&#39; | awk -v compdat=&quot;2020-05-20 13:13:45&quot; -F\\; &#39;BEGIN { &quot;date -d \\&quot;&quot;compdat&quot;\\&quot; +%s&quot; | getline csdat } $2 ~ /zip$/ { split($1,dats,&quot; &quot;);&quot;date -d \\&quot;&quot;$1&quot;\\&quot; +%s&quot; | getline sdat;if (sdat &lt; csdat) { system(&quot;rm &quot;$2) } }&#39;",
                "title": "Output specific part for each block"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605914776,
                "last_edit_date": 1605914776,
                "creation_date": 1605827034,
                "answer_id": 64921337,
                "question_id": 64915205,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq cannot execute a &quot;rm&quot; command, but assuming you are running jq in a bash or bash-like environment, you could proceed as suggested by the following:\r\n```\r\njq &#39;.hits[] | select( .lastModified[:10] &lt;= &quot;2020-06-25&quot;) | .name&#39; | \r\n  while read -r f ; do\r\n    echo rm &quot;$f&quot;         # `echo` for testing\r\n  done   \r\n```\r\n\r\nThis of course assumes that the .lastModified field starts with the YYYY-MM-DD form of the date. If either any of those assumptions is incorrect, you could adjust the above accordingly.\r\n",
                "title": "Output specific part for each block"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1605973364,
        "creation_date": 1605801152,
        "last_edit_date": 1605973364,
        "question_id": 64915205,
        "body_markdown": "I have a json parsed by jq, but I need to go through each block and get the name  and lastModified and then store them so I can delete the zip file which is older then a specific date. For this example lets say 2020-06-25 is an &quot;old package&quot;\r\nSo we have da-editor-user-groups-1.7.0.zip and lastModified 2020-06-25\r\nI need to filter it by all such packages by lastModified  attribute with jq\r\n\r\n    {\r\n        &quot;success&quot;: true,\r\n        &quot;results&quot;: 6,\r\n        &quot;total&quot;: 6,\r\n        &quot;more&quot;: false,\r\n        &quot;offset&quot;: 0,\r\n        &quot;hits&quot;: [\r\n            {\r\n                &quot;path&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;excerpt&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;name&quot;: &quot;change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;title&quot;: &quot;change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;lastModified&quot;: &quot;2020-06-25 17:50:12&quot;,\r\n                &quot;created&quot;: &quot;2020-06-25 17:50:12&quot;,\r\n                &quot;size&quot;: &quot;36 KB&quot;,\r\n                &quot;mimeType&quot;: &quot;application/zip&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip/jcr:content/vlt:definition/thumbnail.png&quot;,\r\n                &quot;excerpt&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip/jcr:content/vlt:definition/thumbnail.png&quot;,\r\n                &quot;name&quot;: &quot;thumbnail.png&quot;,\r\n                &quot;title&quot;: &quot;thumbnail.png&quot;,\r\n                &quot;lastModified&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;created&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;size&quot;: &quot;2 KB&quot;,\r\n                &quot;mimeType&quot;: &quot;image/png&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;excerpt&quot;: &quot;/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;name&quot;: &quot;change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;title&quot;: &quot;change-editor-user-accounts-1.3.0.zip&quot;,\r\n                &quot;lastModified&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;created&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;size&quot;: &quot;7 KB&quot;,\r\n                &quot;mimeType&quot;: &quot;application/zip&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;excerpt&quot;: &quot;/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;name&quot;: &quot;change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;title&quot;: &quot;change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;lastModified&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;created&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;size&quot;: &quot;12 KB&quot;,\r\n                &quot;mimeType&quot;: &quot;application/zip&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;excerpt&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;name&quot;: &quot;change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;title&quot;: &quot;change-editor-user-groups-1.7.0.zip&quot;,\r\n                &quot;lastModified&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;created&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;size&quot;: &quot;31 KB&quot;,\r\n                &quot;mimeType&quot;: &quot;application/zip&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip/jcr:content/vlt:definition/thumbnail.png&quot;,\r\n                &quot;excerpt&quot;: &quot;/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip/jcr:content/vlt:definition/thumbnail.png&quot;,\r\n                &quot;name&quot;: &quot;thumbnail.png&quot;,\r\n                &quot;title&quot;: &quot;thumbnail.png&quot;,\r\n                &quot;lastModified&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;created&quot;: &quot;2020-06-25 17:50:13&quot;,\r\n                &quot;size&quot;: &quot;2 KB&quot;,\r\n                &quot;mimeType&quot;: &quot;image/png&quot;\r\n            }\r\n    ]\r\n    }\r\n\r\nQuestion is question how to create a cycle which will first check contents of the given block ",
        "link": "https://stackoverflow.com/questions/64915205/output-specific-part-for-each-block",
        "title": "Output specific part for each block"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605870421,
                "last_edit_date": 1605870421,
                "creation_date": 1605870114,
                "answer_id": 64928296,
                "question_id": 64927543,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Join given and family names by semicolons separately, then pass resulting strings as fields to the TSV filter.\r\n```\r\n[&quot;DOI&quot;, &quot;givenName&quot;, &quot;familyName&quot;],\r\n(inputs | [.DOI, (.author | map(.given), map(.family) | join(&quot;; &quot;))])\r\n| @tsv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/itxCRBC5V4)&lt;/sup&gt;\r\n\r\nNote that you need to invoke JQ with **-r** and **-n** flags for this to work and produce a valid TSV output.",
                "title": "Iterate over array and output TSV report"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666590324,
        "creation_date": 1605867137,
        "last_edit_date": 1666590324,
        "question_id": 64927543,
        "body_markdown": "I have file with 30, 000 JSON lines delimited by new line. I am using JQ to process it.\r\n\r\nBelow is each line schema (new.json).\r\n```json\r\n{\r\n  &quot;indexed&quot;: {\r\n    &quot;date-parts&quot;: [\r\n      [\r\n        2020,\r\n        8,\r\n        13\r\n      ]\r\n    ],\r\n    &quot;date-time&quot;: &quot;2020-08-13T06:27:26Z&quot;,\r\n    &quot;timestamp&quot;: 1597300046660\r\n  },\r\n  &quot;reference-count&quot;: 42,\r\n  &quot;publisher&quot;: &quot;American Chemical Society (ACS)&quot;,\r\n  &quot;issue&quot;: &quot;3&quot;,\r\n  &quot;content-domain&quot;: {\r\n    &quot;domain&quot;: [],\r\n    &quot;crossmark-restriction&quot;: false\r\n  },\r\n  &quot;short-container-title&quot;: [\r\n    &quot;Org. Lett.&quot;\r\n  ],\r\n  &quot;published-print&quot;: {\r\n    &quot;date-parts&quot;: [\r\n      [\r\n        2005,\r\n        2\r\n      ]\r\n    ]\r\n  },\r\n  &quot;DOI&quot;: &quot;10.1021/ol047829t&quot;,\r\n  &quot;type&quot;: &quot;journal-article&quot;,\r\n  &quot;created&quot;: {\r\n    &quot;date-parts&quot;: [\r\n      [\r\n        2005,\r\n        1,\r\n        27\r\n      ]\r\n    ],\r\n    &quot;date-time&quot;: &quot;2005-01-27T05:53:29Z&quot;,\r\n    &quot;timestamp&quot;: 1106805209000\r\n  },\r\n  &quot;page&quot;: &quot;383-386&quot;,\r\n  &quot;source&quot;: &quot;Crossref&quot;,\r\n  &quot;is-referenced-by-count&quot;: 38,\r\n  &quot;title&quot;: [\r\n    &quot;Liquid-Crystalline [60]Fullerene-TTF Dyads&quot;\r\n  ],\r\n  &quot;prefix&quot;: &quot;10.1021&quot;,\r\n  &quot;volume&quot;: &quot;7&quot;,\r\n  &quot;author&quot;: [\r\n    {\r\n      &quot;given&quot;: &quot;Emmanuel&quot;,\r\n      &quot;family&quot;: &quot;Allard&quot;,\r\n      &quot;affiliation&quot;: []\r\n    },\r\n    {\r\n      &quot;given&quot;: &quot;Fr&#233;d&#233;ric&quot;,\r\n      &quot;family&quot;: &quot;Oswald&quot;,\r\n      &quot;affiliation&quot;: []\r\n    },\r\n    {\r\n      &quot;given&quot;: &quot;Bertrand&quot;,\r\n      &quot;family&quot;: &quot;Donnio&quot;,\r\n      &quot;affiliation&quot;: []\r\n    },\r\n    {\r\n      &quot;given&quot;: &quot;Daniel&quot;,\r\n      &quot;family&quot;: &quot;Guillon&quot;,\r\n      &quot;affiliation&quot;: []\r\n    }\r\n  ],\r\n  &quot;member&quot;: &quot;316&quot;,\r\n  &quot;container-title&quot;: [\r\n    &quot;Organic Letters&quot;\r\n  ],\r\n  &quot;original-title&quot;: [],\r\n  &quot;link&quot;: [\r\n    {\r\n      &quot;URL&quot;: &quot;https://pubs.acs.org/doi/pdf/10.1021/ol047829t&quot;,\r\n      &quot;content-type&quot;: &quot;unspecified&quot;,\r\n      &quot;content-version&quot;: &quot;vor&quot;,\r\n      &quot;intended-application&quot;: &quot;similarity-checking&quot;\r\n    }\r\n  ],\r\n  &quot;deposited&quot;: {\r\n    &quot;date-parts&quot;: [\r\n      [\r\n        2020,\r\n        4,\r\n        7\r\n      ]\r\n    ],\r\n    &quot;date-time&quot;: &quot;2020-04-07T13:39:55Z&quot;,\r\n    &quot;timestamp&quot;: 1586266795000\r\n  },\r\n  &quot;score&quot;: null,\r\n  &quot;subtitle&quot;: [],\r\n  &quot;short-title&quot;: [],\r\n  &quot;issued&quot;: {\r\n    &quot;date-parts&quot;: [\r\n      [\r\n        2005,\r\n        2\r\n      ]\r\n    ]\r\n  },\r\n  &quot;references-count&quot;: 42,\r\n  &quot;alternative-id&quot;: [\r\n    &quot;10.1021/ol047829t&quot;\r\n  ],\r\n  &quot;URL&quot;: &quot;http://dx.doi.org/10.1021/ol047829t&quot;,\r\n  &quot;relation&quot;: {},\r\n  &quot;ISSN&quot;: [\r\n    &quot;1523-7060&quot;,\r\n    &quot;1523-7052&quot;\r\n  ],\r\n  &quot;issn-type&quot;: [\r\n    {\r\n      &quot;value&quot;: &quot;1523-7060&quot;,\r\n      &quot;type&quot;: &quot;print&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: &quot;1523-7052&quot;,\r\n      &quot;type&quot;: &quot;electronic&quot;\r\n    }\r\n  ],\r\n  &quot;subject&quot;: [\r\n    &quot;Physical and Theoretical Chemistry&quot;,\r\n    &quot;Organic Chemistry&quot;,\r\n    &quot;Biochemistry&quot;\r\n  ]\r\n}\r\n```\r\nFor every `DOI`, I need to obtain the values of `given` and `family` key in the same cell of the same row of that DOI in the CSV/TSV format.\r\n\r\nThe expected output for the above json is (in CSV/TSV format):\r\n\r\n    |DOI| givenName|familyName|\r\n    |10.1021/ol047829t|Emmanuel; Fr&#233;d&#233;ric; Bertrand; Daniel;|Allard; Oswald; Donnio; Guillon|\r\n\r\n\r\nI am using the below command line but it is throwing error and when I try to alter I am unable to get CSV/TSV output at all.\\\r\n`cat new.json | jq -r &quot;[.DOI, .publisher, .author[] | .given] | @tsv&quot; &gt; manage.tsv`\r\n\r\n*******************************************************************************************************\r\nThe same logic applies for `subject` key also. I am using the below command line to output values of `subject` key to CSV but it is throwing only the first element (in this case only: &quot;Physical and Theoretical Chemistry&quot;)\\\r\n`cat new.json | jq -c -r &quot;[.DOI, .publisher, .subject[0]] | @csv&quot; &gt; manage.csv`\r\n\r\n\r\nAny pointers for right jq command line will be of great help.",
        "link": "https://stackoverflow.com/questions/64927543/iterate-over-array-and-output-tsv-report",
        "title": "Iterate over array and output TSV report"
    },
    {
        "tags": [
            "sh",
            "posix",
            "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": 1605910747,
                "post_id": 64937500,
                "comment_id": 114807875,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2902640,
                    "reputation": 339,
                    "user_id": 5116761,
                    "user_type": "registered",
                    "accept_rate": 47,
                    "profile_image": "https://lh3.googleusercontent.com/-cjJ4Hfwwfrs/AAAAAAAAAAI/AAAAAAAACdQ/JqUy1XprJMY/s256-rj/photo.jpg",
                    "display_name": "Jorman Franzini",
                    "link": "https://stackoverflow.com/users/5116761/jorman-franzini"
                },
                "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": 1605911541,
                "post_id": 64937500,
                "comment_id": 114808113,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1606481031,
                "last_edit_date": 1606481031,
                "creation_date": 1606409419,
                "answer_id": 65026222,
                "question_id": 64937500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand you correctly, the problem you&#39;re looking for help with is this:\r\n\r\nYou have a shell variable `$jq_filter` that contains the text of a JQ filter. You have a shell variable `$BestRegion` that contains a plain text string. You want to pass the former in as part of a larger JQ filter while passing the latter in as a JQ variable.\r\n\r\nTry:\r\n\r\n```\r\njq --arg REGION_ID &quot;$BestRegion&quot; &quot;$jq_filter&quot;&#39;| select(.id==$REGION_ID)&#39;\r\n```\r\n\r\nSpecifically, you want the _shell_ to expand `$jq_filter` before passing it to JQ, so you put it in double quotes, but you want _JQ_ to process `$REGION_ID` so you keep it in single quotes. Note that there is no space between the double quote and the single quote - this ensures the shell combines both strings together as one argument to JQ.",
                "title": "jq 1.5 multiple bash variables as argument"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606481031,
        "creation_date": 1605909591,
        "last_edit_date": 1605911005,
        "question_id": 64937500,
        "body_markdown": "I&#39;m working on a script for my openwrt, a watchdog for my pia connection. I&#39;m trying to make this little jq filter but every time I try I get error\r\nI&#39;ve more options and I &quot;compose&quot; the jq filter\r\n\r\n    all_region_data=$(curl -s &quot;https://serverlist.piaservers.net/vpninfo/servers/v4&quot; | head -1)\r\n    BestRegion=&quot;italy&quot;\r\n    \r\n\tjq_filter=&#39;.regions[]&#39;\r\n\r\n\tif [ -z &quot;$BestRegion&quot; ]; then # BestRegion not forced\r\n\t\tif [ &quot;$pia_pf&quot; = &quot;true&quot; ]; then\r\n\t\t\tjq_filter=&quot;${jq_filter} | select(.port_forward==true)&quot;\r\n\t\tfi\r\n\r\n\t\tif [ &quot;$pia_no_geo&quot; = &quot;false&quot; ]; then\r\n\t\t\tjq_filter=&quot;${jq_filter} | select(.geo==false)&quot;\r\n\t\tfi\r\n\r\n\t\tif [ &quot;$pia_no_geo&quot; = &quot;true&quot; ]; then\r\n\t\t\tjq_filter=&quot;${jq_filter} | select(.geo==true)&quot;\r\n\t\tfi\r\n\r\n\t\tjq_filter=&quot;${jq_filter} | .servers.meta[0].ip+\\&quot; \\&quot;+.id+\\&quot; \\&quot;+.name+\\&quot; \\&quot;+(.geo|tostring)&quot;\r\n\r\n\t\tsummarized_region_data=$(echo &quot;$all_region_data&quot; | jq -r &quot;${jq_filter}&quot;)\r\n\r\n\t\tbest_region # function to extract best_region\r\n\r\n\t\tif [ -z &quot;$BestRegion&quot; ]; then\r\n\t\t\tlog &quot;...&quot;\r\n\t\t\tlog &quot;No region responded within ${max_latency}s, consider using a higher timeout.&quot;\r\n\t\t\trm -rf &quot;$wg_script_lock_file&quot;\r\n\t\t\treturn\r\n\t\tfi\r\n\telse # BestRegion forced\r\n\t\tif [ &quot;$pia_pf&quot; = &quot;true&quot; ]; then\r\n\t\t\tjq_filter=&quot;${jq_filter} | select(.port_forward==true)&quot;\r\n\t\tfi\r\n\r\n\t\tif [ &quot;$pia_no_geo&quot; = &quot;false&quot; ]; then\r\n\t\t\tjq_filter=&quot;${jq_filter} | select(.geo==false)&quot;\r\n\t\tfi\r\n\r\n\t\tif [ &quot;$pia_no_geo&quot; = &quot;true&quot; ]; then\r\n\t\t\tjq_filter=&quot;${jq_filter} | select(.geo==true)&quot;\r\n\t\tfi\r\n\tfi\r\n\r\nThe first `if cycle` works, the function do the dirty works. But I want to have the opportunity to &quot;force&quot; the `BestRegion` so I created the `else cycle`. Here I&#39;ve the problem!\r\n\r\nThis&#39;s what I&#39;m trying to do\r\n\r\n    echo $all_region_data | jq --arg REGION_ID &quot;$BestRegion&quot; --arg JQ_FILTER &quot;$jq_filter&quot; -r &#39;$JQ_FILTER | select(.id==$REGION_ID)&#39;\r\n\r\nI can&#39;t use these two `var`, I get this error\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;id&quot;\r\n\r\nHow would you do it?",
        "link": "https://stackoverflow.com/questions/64937500/jq-1-5-multiple-bash-variables-as-argument",
        "title": "jq 1.5 multiple bash variables as argument"
    },
    {
        "tags": [
            "json",
            "jq",
            "negation"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1605941790,
                "creation_date": 1605941790,
                "answer_id": 64940611,
                "question_id": 64940610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While writing this question, I found the [builtin `del(path_expression)` function][1] which solves the issue:\r\n\r\n&gt; The builtin function del removes a key and its corresponding value from an object.\r\n\r\n```bash\r\n$ echo &#39;{&quot;a&quot;: 0, &quot;b&quot;: 1, &quot;c&quot;: 2}&#39; | jq &#39;del(.c)&#39;\r\n{\r\n  &quot;a&quot;: 0,\r\n  &quot;b&quot;: 1\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "How to output inverted matches using the jq command-line JSON processor?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1605964547,
                "last_edit_date": 1605964547,
                "creation_date": 1605958712,
                "answer_id": 64942633,
                "question_id": 64940610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is generally quite minimalist, so when in doubt while looking for the opposite of something, `not` is always available to come to the rescue, e.g.\r\n\r\n    with_entries(select(.key == &quot;c&quot;|not))\r\n\r\nThe thing that&#39;s probably unfamiliar here is that `not` in jq is a normal 0-arity filter.\r\n\r\nOf course `!=` is also supported:\r\n \r\n    with_entries(select(.key != &quot;c&quot;))\r\n\r\nSince you mentioned `grep`, it may be worth noting that the jq &quot;equivalent&quot; of `grep -v &quot;REGEX&quot;` would be `test(&quot;REGEX&quot;)|not`.\r\n\r\nIncidentally, that initial `. |` in your first attempt would not be necessary.",
                "title": "How to output inverted matches using the jq command-line JSON processor?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1606047579,
        "creation_date": 1605941790,
        "last_edit_date": 1606047579,
        "question_id": 64940610,
        "body_markdown": "Is it possible to output inverted matches using the [jq command-line JSON processor][1]? The tool `grep` supports the option `-v, --invert-match: select non-matching lines` for this.\r\n\r\nAs an example, I&#39;m searching for a command such as the following. However, `without(...)` doesn&#39;t exist:\r\n\r\n```bash\r\n$  echo &#39;{&quot;a&quot;: 0, &quot;b&quot;: 1, &quot;c&quot;: 2}&#39; | jq &#39;. | without(c)&#39; \r\n{\r\n  &quot;a&quot;: 0,\r\n  &quot;b&quot;: 1\r\n}\r\n\r\n```\r\n\r\n* There is no program option such as `grep -v` for `jq`.\r\n* I failed to find a [basic filter][2] for this.\r\n\r\nAre inverted matches supported?\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://stedolan.github.io/jq/manual/#Basicfilters",
        "link": "https://stackoverflow.com/questions/64940610/how-to-output-inverted-matches-using-the-jq-command-line-json-processor",
        "title": "How to output inverted matches using the jq command-line JSON processor?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1605984743,
                "last_edit_date": 1605984743,
                "creation_date": 1605981557,
                "answer_id": 64946332,
                "question_id": 64945822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq --raw-output &#39;to_entries[0] | .key as $url | .value[] | &quot;\\($url)?\\(.)=gg&quot;&#39; &lt;your json file here&gt;\r\n```\r\n\r\nWhere\r\n\r\n1. `to_entries[0]` yields `{&quot;key&quot;:&quot;https://test.com/gg&quot;,&quot;value&quot;:[&quot;msg&quot;,&quot;popup&quot;,&quot;url&quot;]}`\r\n2. (Save `.key as $url` for later)\r\n3. Then &quot;emit&quot; all values with `.value[]`\r\n4. For each &quot;emitted&quot; value, produce the string `&quot;\\($url)?\\(.)=gg&quot;` where `.` is the current value\r\n",
                "title": "How to access the value of an unknown key?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606043951,
        "creation_date": 1605978728,
        "last_edit_date": 1606043951,
        "question_id": 64945822,
        "body_markdown": "I have the following JSON file\r\n\r\n```json\r\n{\r\n    &quot;https://test.com/gg&quot;: [\r\n        &quot;msg&quot;,\r\n        &quot;popup&quot;,\r\n        &quot;url&quot;\r\n    ]\r\n}\r\n```\r\n\r\nWhat I want to achieve is to parse the values to output the following\r\n\r\n```lang-none\r\nhttps://test.com/gg?msg=gg\r\nhttps://test.com/gg?popup=gg\r\nhttps://test.com/gg?url=gg\r\n```\r\n\r\nI&#39;m assuming it can be done using jq but I&#39;m not sure how.\r\n\r\nThe way i know is if the elemets were named like bellow:\r\n\r\n```\r\n{\r\n    &quot;url&quot;:&quot;https://test.com/gg&quot;: [\r\n        &quot;p1&quot;:&quot;msg&quot;,\r\n    ]\r\n}\r\n```\r\n\r\nI would pull the elements like:\r\n\r\n`cat json | jq &quot;url.[p1]&quot;`\r\n\r\nBut in my case is it not named.",
        "link": "https://stackoverflow.com/questions/64945822/how-to-access-the-value-of-an-unknown-key",
        "title": "How to access the value of an unknown key?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1605995437,
                "last_edit_date": 1605995437,
                "creation_date": 1605983326,
                "answer_id": 64946622,
                "question_id": 64946480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.items | sort_by(.status.startTime) | map(.status) | reverse\r\n```\r\n\r\nWhere:\r\n\r\n1. Take out `.items`\r\n2. Sort items on the `.status.startTime` (ascending order)\r\n3. Then for each item only keep status\r\n4. And finally reverse the list\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;environments&quot;: [\r\n      {\r\n        &quot;dev&quot;: &quot;test&quot;\r\n      }\r\n    ],\r\n    &quot;phase&quot;: &quot;Running&quot;,\r\n    &quot;startTime&quot;: &quot;2020-11-17T15:42:26Z&quot;\r\n  },\r\n  {\r\n    &quot;phase&quot;: &quot;Failed&quot;,\r\n    &quot;startTime&quot;: &quot;2020-11-15T15:42:26Z&quot;\r\n  },\r\n  {\r\n    &quot;environments&quot;: [\r\n      {\r\n        &quot;dev&quot;: &quot;test2&quot;\r\n      }\r\n    ],\r\n    &quot;phase&quot;: &quot;Running&quot;,\r\n    &quot;startTime&quot;: &quot;2020-11-10T15:42:26Z&quot;\r\n  }\r\n]\r\n```",
                "title": "Sort array on a nested property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606213348,
        "creation_date": 1605982462,
        "last_edit_date": 1606213348,
        "question_id": 64946480,
        "body_markdown": "I have this json in a file\r\n```\r\n{\r\n    &quot;items&quot; : [\r\n        {\r\n            &quot;status&quot; : {\r\n                &quot;phase&quot;: &quot;Failed&quot;,\r\n                &quot;startTime&quot;: &quot;2020-11-15T15:42:26Z&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;status&quot; : {\r\n                &quot;environments&quot;: [\r\n                    {\r\n                        &quot;dev&quot;: &quot;test&quot;\r\n                    }\r\n                ],\r\n                &quot;phase&quot;: &quot;Running&quot;,\r\n                &quot;startTime&quot;: &quot;2020-11-17T15:42:26Z&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;status&quot; : {\r\n                &quot;environments&quot;: [\r\n                    {\r\n                        &quot;dev&quot;: &quot;test2&quot;\r\n                    }\r\n                ],\r\n                &quot;phase&quot;: &quot;Running&quot;,\r\n                &quot;startTime&quot;: &quot;2020-11-10T15:42:26Z&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI would like to order this json based on startTime, I want to return the list ordered by the latest date.\r\nI tried this query\r\n`jq -r &#39;.items[].status | sort_by(.startTime)&#39;`\r\n\r\nbut it gives the following error:\r\n` jq: error (at &lt;stdin&gt;:4399): Cannot index string with string &quot;startTime&quot;`\r\n\r\nAny help?",
        "link": "https://stackoverflow.com/questions/64946480/sort-array-on-a-nested-property",
        "title": "Sort array on a nested property"
    },
    {
        "tags": [
            "bash",
            "jq",
            "uuid",
            "jsonlines"
        ],
        "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": 1605994601,
                "post_id": 64948257,
                "comment_id": 114825691,
                "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": 1605994757,
                "post_id": 64948257,
                "comment_id": 114825731,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1605994773,
                "post_id": 64948257,
                "comment_id": 114825734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1605994841,
                "post_id": 64948257,
                "comment_id": 114825749,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1605994866,
                "post_id": 64948257,
                "comment_id": 114825756,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1605994920,
                "post_id": 64948257,
                "comment_id": 114825772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1605995596,
                "post_id": 64948257,
                "comment_id": 114825951,
                "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": 1605995619,
                "post_id": 64948257,
                "comment_id": 114825956,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1605996874,
                "post_id": 64948257,
                "comment_id": 114826228,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1605997820,
                "post_id": 64948257,
                "comment_id": 114826473,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1606030876,
                "last_edit_date": 1606030876,
                "creation_date": 1605994871,
                "answer_id": 64948390,
                "question_id": 64948257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input file is already well-formed JSONL, then a simple bash solution would be:\r\n\r\n```\r\nwhile IFS= read -r line; do\r\n  printf &quot;{\\&quot;id\\&quot;: \\&quot;%s\\&quot;}\\n&quot; $(uuidgen)\r\n  printf &#39;%s\\n&#39; &quot;$line&quot;\r\ndone &lt; test.json\r\n```\r\n\r\nThis might well be the best trivial solution if test.json is very large and known to be valid JSONL.\r\n\r\nIf the input file is not already JSONL, then you could still use the above approach by piping in `jq -c . test.json`. And if ‘read’ is too slow, you could still use the above text-processing approach with `awk`.\r\n\r\nFor the record, a single-call-to-jq solution along the lines you have in mind could be constructed as follows: \r\n\r\n```\r\njq -n -c -R --slurpfile objects test.json &#39;\r\n  $objects[] | {&quot;id&quot;: input}, .&#39; &lt;(while true ; do uuidgen ; done)\r\n```\r\n\r\nObviously you cannot &quot;slurp&quot; the unbounded stream of uuidgen values; less obviously perhaps, if you were simply to pipe in the stream, the process will hang.",
                "title": "jq: insert new objects while reading inputs from json file and bash stdout"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605996057,
                "last_edit_date": 1605996057,
                "creation_date": 1605995264,
                "answer_id": 64948446,
                "question_id": 64948257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since [@peak has already covered the jq side of the problem](https://stackoverflow.com/a/64948390/14122), I&#39;m going to take a shot at doing this more efficiently using Python, still wrapped so it can be called in a shell script.\r\n\r\nThis assumes that your input is JSONL, with one document per line. If it isn&#39;t, consider piping through `jq -c .` before piping into the below.\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\npy_prog=$(cat &lt;&lt;&#39;EOF&#39;\r\nimport json, sys, uuid\r\n\r\nfor line in sys.stdin:\r\n    print(json.dumps({&quot;id&quot;: str(uuid.uuid4())}))\r\n    sys.stdout.write(line)\r\nEOF\r\n)\r\n\r\npython -c &quot;$py_prog&quot; &lt;in.json &gt;out.json\r\n```",
                "title": "jq: insert new objects while reading inputs from json file and bash stdout"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606030584,
                "last_edit_date": 1606030584,
                "creation_date": 1605996115,
                "answer_id": 64948550,
                "question_id": 64948257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input was not known in advance to be valid JSONL,\r\none of the following bash+jq solutions might make sense \r\nsince the overhead of counting the number of objects would be relatively small.\r\n\r\nIf the input is small enough to fit in memory, you could go with a simple solution:\r\n\r\n```\r\nn=$(jq -n &#39;reduce inputs as $in (0; .+1)&#39; test.json)\r\n\r\nfor ((i=0; i &lt; $n; i++)); do uuidgen ; done |\r\njq -n -c -R --slurpfile objects test.json &#39;\r\n  $objects[] | {&quot;id&quot;: input}, .&#39;\r\n```\r\n\r\nOtherwise, that is, if the input is very large, then one could avoid slurping it as follows:\r\n\r\n```\r\nn=$(jq -n &#39;reduce inputs as $in (0; .+1)&#39; test.json)\r\njq -nc --rawfile ids &lt;(for ((i=0; i &lt; $n; i++)); do uuidgen ; done) &#39;\r\n  $ids | split(&quot;\\n&quot;) as $ids\r\n  | foreach inputs as $in (-1; .+1; {id: $ids[.]}, $in)\r\n&#39; test.json \r\n```",
                "title": "jq: insert new objects while reading inputs from json file and bash stdout"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1605996567,
                "creation_date": 1605996567,
                "answer_id": 64948609,
                "question_id": 64948257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach where `jq` is handling input as raw string, already muxed by a separate copy of bash.\r\n\r\n```\r\nwhile IFS= read -r line; do\r\n  uuidgen\r\n  printf &#39;%s\\n&#39; &quot;$line&quot;\r\ndone | jq -Rrc &#39;({ &quot;id&quot;: . }, input)&#39;\r\n```\r\n\r\nIt still has all the performance overhead of calling `uuidgen` once per input line (plus some extra overhead because bash&#39;s `read` operates one byte at a time) -- but it operates in a fixed amount of memory without needing Python.",
                "title": "jq: insert new objects while reading inputs from json file and bash stdout"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1606030876,
        "creation_date": 1605993968,
        "last_edit_date": 1606002638,
        "question_id": 64948257,
        "body_markdown": "I want to insert new json objects in between json objects using bash generated uuid.\r\n\r\ninput json file `test.json`\r\n\r\n    {&quot;name&quot;:&quot;a&quot;,&quot;type&quot;:1}\r\n    {&quot;name&quot;:&quot;b&quot;,&quot;type&quot;:2}\r\n    {&quot;name&quot;:&quot;c&quot;,&quot;type&quot;:3}\r\n\r\ninput bash command `uuidgen -r`\r\n\r\ntarget output json\r\n\r\n    {&quot;id&quot;: &quot;7e3ca7b0-48f1-41fe-9a19-092a62cba0dc&quot;}\r\n    {&quot;name&quot;:&quot;a&quot;,&quot;type&quot;:1}\r\n    {&quot;id&quot;: &quot;3f793fdd-ec3b-4306-8153-12f3f9faf2c1&quot;}\r\n    {&quot;name&quot;:&quot;b&quot;,&quot;type&quot;:2}\r\n    {&quot;id&quot;: &quot;cbcd759a-37e7-4da7-b7fe-7572f474ec31&quot;}\r\n    {&quot;name&quot;:&quot;c&quot;,&quot;type&quot;:3}\r\n\r\nbasic jq program to insert new objects\r\n\r\n    jq -c &#39;{&quot;id&quot;}, .&#39; test.json\r\n\r\noutput json\r\n\r\n    {&quot;id&quot;:null}\r\n    {&quot;name&quot;:&quot;a&quot;,&quot;type&quot;:1}\r\n    {&quot;id&quot;:null}\r\n    {&quot;name&quot;:&quot;b&quot;,&quot;type&quot;:2}\r\n    {&quot;id&quot;:null}\r\n    {&quot;name&quot;:&quot;c&quot;,&quot;type&quot;:3}\r\n\r\njq program to insert uuid generated from bash:\r\n\r\n    jq -c &#39;{&quot;id&quot; | input}, .&#39; test.json &lt; &lt;(uuidgen)\r\n\r\nUnsure about how to handle two inputs, bash command used to create a value in the new object, and the input file to be transformed (new object inserted in between each object).\r\n\r\nI want to process small and large json files up to a few gigabytes each.\r\n\r\nGreatly appeaciate some help with a well designed solution(s) that would scale for large files and perform the operations quickly and efficiently.\r\n\r\nThanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/64948257/jq-insert-new-objects-while-reading-inputs-from-json-file-and-bash-stdout",
        "title": "jq: insert new objects while reading inputs from json file and bash stdout"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606056934,
                "last_edit_date": 1606056934,
                "creation_date": 1606056578,
                "answer_id": 64955558,
                "question_id": 64955068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could start with this:\r\n\r\n    walk(if type == &quot;object&quot;\r\n         then with_entries(\r\n           if .key != &quot;name&quot; and (.value|type)==&quot;string&quot;\r\n           then .value=&quot;&quot; else . end)\r\n         else . end)\r\n\r\n\r\nhttps://jqplay.org/s/1tNFqGiYsO",
                "title": "How to use jq to create a clean json template file without values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606061851,
                "creation_date": 1606061851,
                "answer_id": 64956490,
                "question_id": 64955068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update every string value with the empty string except those with the keyname **name**.\r\n```\r\nreduce (paths(strings) | select(.[-1] != &quot;name&quot;)) as $p (.; setpath($p; &quot;&quot;))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/NpsHyg2uUq)&lt;/sup&gt;",
                "title": "How to use jq to create a clean json template file without values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1606061851,
        "creation_date": 1606053770,
        "last_edit_date": 1606057279,
        "question_id": 64955068,
        "body_markdown": "I&#39;m trying to create a &quot;template&quot; of a .json configuration file, in which all the keys are present (and the structure is completely preserved), but all the values (which may contain sensitive data such as database credentials) are removed. This &quot;cleaned&quot; file may then be committed to source control as a template file.\r\n\r\n\r\nInput **file.json**:\r\n\r\n```json\r\n{\r\n\t&quot;global_foo&quot;: &quot;987&quot;,\r\n\t&quot;global_bar&quot;: &quot;qwertz&quot;,\r\n\t&quot;global_baz&quot;: &quot;123&quot;,\r\n\t&quot;environment_a&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;baz&quot;,\r\n\t\t\t&quot;value&quot;: &quot;456&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;environment_b&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;value&quot;: &quot;123&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;bar&quot;,\r\n\t\t\t&quot;value&quot;: &quot;abc&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;environment_test&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;value&quot;: &quot;123&quot;\r\n\t\t}\r\n\t]\r\n}\r\n\r\n```\r\n\r\n**Desired output** (i.e., replace all top-level values with empty strings, and replace leaf values with key &#39;value&#39;, see nested values in `environment_*`, with empty strings).\r\n\r\n```json\r\n{\r\n\t&quot;global_foo&quot;: &quot;&quot;,\r\n\t&quot;global_bar&quot;: &quot;&quot;,\r\n\t&quot;global_baz&quot;: &quot;&quot;,\r\n\t&quot;environment_a&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;baz&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;environment_b&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;bar&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;environment_test&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t}\r\n\t]\r\n}\r\n\r\n```\r\n\r\nAn obvious solution is `jq`, but I&#39;m not very familiar with it yet. What I tried so far (this does **not** work with multiple `environment_*` arrays, but only works with a single one called &quot;environment&quot;): https://jqplay.org/s/cK2Bn5OR54 \r\n\r\nI&#39;m looking for a solution which covers an arbitrary number of `environment_*` (top-level keys beginning with `environment_` and not only a single one). Additionally, I&#39;m sure that my attempt is overly complicated and there exists a more elegant solution.\r\n\r\nMany thanks for your advice!",
        "link": "https://stackoverflow.com/questions/64955068/how-to-use-jq-to-create-a-clean-json-template-file-without-values",
        "title": "How to use jq to create a clean json template file without values"
    },
    {
        "tags": [
            "json",
            "jq",
            "zero-padding"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1606076967,
                "last_edit_date": 1606076967,
                "creation_date": 1606070711,
                "answer_id": 64958079,
                "question_id": 64957982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given this JSON document:\r\n\r\n```json\r\n7\r\n```\r\n\r\nYou can achieve `&quot;007&quot;` with the following filter: (or `&quot;042&quot;` with `42`)\r\n\r\n```\r\ntostring | (length | if . &gt;= 3 then &quot;&quot; else &quot;0&quot; * (3 - .) end) as $padding | &quot;\\($padding)\\(.)&quot;\r\n```\r\n\r\n1. `tostring` convert `7` into `&quot;7&quot;`\r\n2. If number had 3 or more digits then set padding to `&quot;&quot;` otherwise set to `&quot;0&quot; * (3 - length)`. _(When a string is multiplied by a number it is repeated that many time e.g. `&quot;foo&quot; * 3` -&gt; `&quot;foofoofoo&quot;`)_\r\n3. And append the number to the end\r\n\r\n",
                "title": "How to pad numbers with JQ?"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1606073083,
                "creation_date": 1606073083,
                "answer_id": 64958532,
                "question_id": 64957982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could define these functions at the start of your filter or adding it to your `~/.jq` file then use it to pad the numbers.\r\n\r\n```\r\ndef pad_left($len; $chr):\r\n    (tostring | length) as $l\r\n    | &quot;\\($chr * ([$len - $l, 0] | max) // &quot;&quot;)\\(.)&quot;\r\n    ;\r\ndef pad_left($len):\r\n    pad_left($len; &quot; &quot;)\r\n    ;\r\n```\r\n\r\nThen to use it to pad your value with three `0`s:\r\n\r\n```\r\npad_left(3; &quot;0&quot;)\r\n```",
                "title": "How to pad numbers with JQ?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1606121873,
                "last_edit_date": 1606121873,
                "creation_date": 1606081601,
                "answer_id": 64959937,
                "question_id": 64957982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on the jq-esque definition from https://stackoverflow.com/questions/49502120/in-jq-how-to-get-tonumber-to-output-decimal-instead-of-scientific-notation :\r\n\r\n    def lpad(n):\r\n      tostring\r\n      | if (n &gt; length) then ((n - length) * &quot;0&quot;) + . else . end;\r\n\r\nAs for jq module managers, there is nothing in jq’s official development pipeline, but jqnpm has nothing to do with npm, and is pretty safe to use, at least if you don’t run it with sudo.",
                "title": "How to pad numbers with JQ?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1706819775,
                "creation_date": 1706819775,
                "answer_id": 77923221,
                "question_id": 64957982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are sure the number will not overflow the format digits, you can simulate a &quot;%03d&quot; with:\r\n\r\n    aNumber+1000|tostring[1:]",
                "title": "How to pad numbers with JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1717535842,
                "last_edit_date": 1717535842,
                "creation_date": 1717437012,
                "answer_id": 78571820,
                "question_id": 64957982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that handles overflow as well. It can pad any number:\r\n\r\n```sh-session\r\n$ jq &#39;3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: 1}&#39;\r\n&quot;001&quot;\r\n$ jq &#39;3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: 12}&#39;\r\n&quot;012&quot;\r\n$ jq &#39;3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: 123}&#39;\r\n&quot;123&quot;\r\n$ jq &#39;3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: 1234}&#39;\r\n&quot;1234&quot;\r\n```\r\n\r\nwith any number of leading zeros:\r\n\r\n```\r\n$ jq &#39;4 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: 1234}&#39;\r\n&quot;1234&quot;\r\n$ jq &#39;5 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: 1234}&#39;\r\n&quot;01234&quot;\r\n```\r\n\r\nand this handles negative numbers as well, by ignoring/treating them as 0:\r\n\r\n```\r\n$ jq &#39;3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|&quot;0&quot;]|join(&quot;&quot;)[fmax($D; $D-$pad):]+$N&#39; &lt;&lt;&lt;&#39;{&quot;aNumber&quot;: -123213}&#39;\r\n&quot;000&quot;\r\n```",
                "title": "How to pad numbers with JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1725863915,
                "last_edit_date": 1725863915,
                "creation_date": 1725854917,
                "answer_id": 78963855,
                "question_id": 64957982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Same principle as shown in [this answer](https://stackoverflow.com/a/77923221/401059), but shorter:\r\n\r\n```jq\r\n&quot;00\\(.)&quot;[-3:]\r\n```\r\n\r\nSome notes\r\n * This answer fails with non-whole numbers \r\n * Many (all?) answers here (including this one) fail with negative numbers and large numbers (from somewhere above 1e16)\r\n * This answer only returns the last three digits with (small) numbers &gt; 999",
                "title": "How to pad numbers with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 6,
        "last_activity_date": 1725863915,
        "creation_date": 1606070172,
        "last_edit_date": 1606098285,
        "question_id": 64957982,
        "body_markdown": "I&#39;d like to add leading/trailing zeros to strings from numbers — resultant string needs to contain &quot;01&quot; or &quot;001&quot; and not &quot;1&quot;. I noticed project `https://github.com/joelpurra/jq-zeros` but I have jq installed from package manager (dnf, fedora) so requirement of some `jqnpm` is not feasible for me (at first sight), not to mention my fear of npm, as stuff `sudo npm -g` ruined my system several times already.\r\n\r\nQuestion: \r\n\r\n1) these package managers for jq, are they even in process of being accepted into mainstream or not?\r\n2) the padding itself — how to do it without this extra library?",
        "link": "https://stackoverflow.com/questions/64957982/how-to-pad-numbers-with-jq",
        "title": "How to pad numbers with JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "syntax-error",
            "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": 1606088763,
                "post_id": 64960452,
                "comment_id": 114846571,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2971526,
                    "reputation": 1017,
                    "user_id": 3745692,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9e6e91b4d19ab46d2283dee26d7d5f60?s=256&d=identicon&r=PG",
                    "display_name": "Ale",
                    "link": "https://stackoverflow.com/users/3745692/ale"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663497817,
                "post_id": 64960452,
                "comment_id": 130249606,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1606088043,
                "last_edit_date": 1606088043,
                "creation_date": 1606086839,
                "answer_id": 64960639,
                "question_id": 64960452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `$(cat &lt;&lt; EOF ...)` construct is passing the single quotes along as part of the data, ie:\r\n\r\n    $ jsonStr=$(cat &lt;&lt; EOF\r\n    &#39;{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}&#39; \r\n    EOF\r\n    )\r\n    $ echo &quot;${jsonStr}&quot;\r\n    &#39;{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}&#39;\r\n\r\nNotice the leading/trailing single quotes.\r\n\r\nTo get past the parsing error you want to get rid of the single quotes, eg:\r\n\r\n    $ jsonStr=$(cat &lt;&lt; EOF\r\n    {&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}\r\n    EOF\r\n    )\r\n    \r\n    # or\r\n    \r\n    $ jsonStr=&#39;{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}&#39;\r\n\r\nBoth of the above give us:\r\n\r\n    $ echo &quot;${jsonStr}&quot;\r\n    {&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}\r\n\r\nAnd now the `jq/del` works as expected:\r\n\r\n    $ jq &#39;del(.key3)&#39; &lt;&lt;&lt; &quot;${jsonStr}&quot;\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;\r\n    }\r\n\r\nAnd then the `+` operation also works:\r\n\r\n    $ STRING=&quot;hello&quot;\r\n    $ jq &#39;del(.key3)&#39; &lt;&lt;&lt; &quot;${jsonStr}&quot;  | jq &#39;. + {&#39;&quot;$STRING&quot;&#39;: &quot;value4&quot;}&#39;\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;hello&quot;: &quot;value4&quot;\r\n    }\r\n\r\n-----------------------\r\n\r\nPulling this all together:\r\n\r\n    jsonStr=&#39;{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}&#39;\r\n    jsonStr=$(jq &#39;del(.key3)&#39; &lt;&lt;&lt; &quot;${jsonStr}&quot;)\r\n    STRING=&quot;hello&quot;\r\n    jsonStr=$(jq &#39;. + {&#39;&quot;${STRING}&quot;&#39;: &quot;value4&quot;}&#39; &lt;&lt;&lt; &quot;${jsonStr}&quot;)\r\n    echo &quot;${jsonStr}&quot;\r\n\r\nWhich generates:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;hello&quot;: &quot;value4&quot;\r\n    }\r\n\r\n",
                "title": "parse error: Invalid numeric literal at line 1, column 2 (bash)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1661171425,
        "creation_date": 1606085438,
        "last_edit_date": 1606663617,
        "question_id": 64960452,
        "body_markdown": "I&#39;m working with json in bash, but I&#39;m getting this parse error:\r\n\r\n    parse error: Invalid numeric literal at line 1, column 2\r\n\r\nWhat&#39;s wrong with this block of code?\r\n\r\n    jsonStr=$(cat &lt;&lt; EOF\r\n    &#39;{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;, &quot;key3&quot;: &quot;value3&quot;}&#39;\r\n    EOF\r\n    )\r\n    jsonStr=$(jq &#39;del(.key3)&#39; &lt;&lt;&lt;&quot;$jsonStr&quot;)\r\n    STRING=&quot;hello&quot;\r\n    jsonStr=$(jq &#39;. + {&#39;&quot;$STRING&quot;&#39;: &quot;value4&quot;}&#39; &lt;&lt;&lt;&quot;$jsonStr&quot;)\r\n    echo $jsonStr\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64960452/parse-error-invalid-numeric-literal-at-line-1-column-2-bash",
        "title": "parse error: Invalid numeric literal at line 1, column 2 (bash)"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606168170,
                "post_id": 64976998,
                "comment_id": 114875513,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606171993,
                "post_id": 64976998,
                "comment_id": 114876778,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1606169421,
                "last_edit_date": 1606169421,
                "creation_date": 1606169057,
                "answer_id": 64977197,
                "question_id": 64976998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `map()` in combination with the _update assignment_ operator `|=`:\r\n\r\n    jq &#39;(.ObjectStates)|=map(.GMNotes=.Description)&#39; file.json\r\n\r\nhttps://jqplay.org/s/vFV_H4brlH\r\n\r\nPS: instead of using `map` you could also just use the following command, the key is using `|=`.\r\n\r\n    jq &#39;.ObjectStates[]|=(.GMNotes=.Description)&#39; file.json\r\n\r\nthanks chepner!\r\n\r\nhttps://jqplay.org/s/NCGezXPjLE",
                "title": "Using JQ to copy one field of an object into another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1606169421,
        "creation_date": 1606168116,
        "question_id": 64976998,
        "body_markdown": "In my JSON are some objects with a `Description` property. How do I copy this value over to the `GMNotes` property of the same object using JQ? \r\n\r\nIn other words, how does one go from\r\n\r\n```json\r\n{\r\n   &quot;ObjectStates&quot;: [\r\n      {\r\n         &quot;Description&quot;: &quot;&quot;,\r\n         &quot;GMNotes&quot;: &quot;&quot;\r\n      },\r\n      {\r\n         &quot;Description&quot;: &quot;foo&quot;,\r\n         &quot;GMNotes&quot;: &quot;&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nto\r\n\r\n```json\r\n{\r\n   &quot;ObjectStates&quot;: [\r\n      {\r\n         &quot;Description&quot;: &quot;&quot;,\r\n         &quot;GMNotes&quot;: &quot;&quot;\r\n      },\r\n      {\r\n         &quot;Description&quot;: &quot;foo&quot;,\r\n         &quot;GMNotes&quot;: &quot;foo&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\n`.ObjectStates[] | .GMNotes = .Description` only returns the modified objects, as shown in the [sandbox](https://jqplay.org/s/MjA2aFijGv).\r\n\r\n(I could easily do this in Perl. The point is using `jq`.)\r\n",
        "link": "https://stackoverflow.com/questions/64976998/using-jq-to-copy-one-field-of-an-object-into-another",
        "title": "Using JQ to copy one field of an object into another"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606246647,
                "creation_date": 1606246647,
                "answer_id": 64993635,
                "question_id": 64993513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would suggest a filter like this one\r\n```\r\ndef condition1: any(.key_c == &quot;Value_3&quot;);\r\ndef condition2: any(.key_c == &quot;Value_4&quot;) | not;\r\nselect(.measurements|condition1 and condition2)\r\n```\r\n[Try it online!](https://tio.run/##tZHLCoMwEEX3@YqQlYJIfLWg@A9ddVOKRJ2CbYzUB0XUb7eJfWmhuzqLwL1zc2ZIztdxTOGEk0KkWZ0VwvIxE61mXqCNEhyGmOwZbyByiB6gRdL@kXSJjnssijpAFXBIas3MgVVNCTmIuuo/o@T9dMbTx7FDROEs4mPSFDYxHtqW@sR4BVLPWdI@ICyrm05VU57Jhmg4N5Z2LG1na3pfdqKmvXafWoPxV@puFaqzCpVS68lFx@frO6ob38rXb7hv9iQ9xbToZmNSNNwB &quot;jq – Try It Online&quot;)",
                "title": "Jq: How to select an object if the object has an array of objects, that have a key with a value that does not match?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606257352,
                "creation_date": 1606257352,
                "answer_id": 64995861,
                "question_id": 64993513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As a scrunched one-liner:\r\n```\r\nselect(.measurements|any(.key_c==&quot;Value_3&quot;) and all(.key_c!=&quot;Value_4&quot;))\r\n```",
                "title": "Jq: How to select an object if the object has an array of objects, that have a key with a value that does not match?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1606257352,
        "creation_date": 1606246123,
        "question_id": 64993513,
        "body_markdown": "I have this JSON object that I want to extract with Jq:\r\n\r\n    {\r\n    &quot;key_1&quot;: &quot;uo2&quot;,\r\n    &quot;key_2&quot;: false,\r\n    &quot;measurements&quot;: [\r\n        {\r\n            &quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_P&quot;\r\n        },\r\n        {\r\n\t\t\t&quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_3&quot;\r\n        },\r\n        {\r\n            &quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_001&quot;\r\n        }\r\n    ],\r\n    &quot;key_3&quot;: &quot;bwr&quot;,\r\n    &quot;key_4&quot;: null,\r\n    &quot;key_5&quot;: 31066.0\r\n    }\r\n\r\nNow I want to select this object, if the array measurements has an object that has key_c==&quot;Value 3&quot;, as long as it does not have any object that has key_c==&quot;Value 4&quot;. The object above should be selected, but not the one below.\r\n\r\n    {\r\n    &quot;key_1&quot;: &quot;uo2&quot;,\r\n    &quot;key_2&quot;: false,\r\n    &quot;measurements&quot;: [\r\n        {\r\n            &quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_4&quot;\r\n        },\r\n\t\t{\r\n            &quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_P&quot;\r\n        },\r\n        {\r\n\t\t\t&quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_3&quot;\r\n        },\r\n        {\r\n            &quot;key_a&quot;: null,\r\n            &quot;key_b&quot;: 37.5,\r\n            &quot;key_c&quot;: &quot;Value_001&quot;\r\n        }\r\n    ],\r\n    &quot;key_3&quot;: &quot;bwr&quot;,\r\n    &quot;key_4&quot;: null,\r\n    &quot;key_5&quot;: 31066.0\r\n    }\r\n\r\nThe array measurements can be of any length, and is not sorted.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/64993513/jq-how-to-select-an-object-if-the-object-has-an-array-of-objects-that-have-a-k",
        "title": "Jq: How to select an object if the object has an array of objects, that have a key with a value that does not match?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606296329,
                "creation_date": 1606296329,
                "answer_id": 65001781,
                "question_id": 65000653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ignoring for the moment that the expected output as shown is not strictly speaking valid JSON, one possible solution would be to use an invocation such as:\r\n\r\n    jq -nf program.jq input.json\r\n\r\nwhere program.jq contains:\r\n```\r\n\r\n[inputs\r\n | {id} +\r\n   ((.extra[]? // {})\r\n    | {&quot;extra_domain_id&quot;: .domain.id,\r\n       &quot;extra_domain_name&quot;: .domain.name,\r\n       &quot;extra_entity_label&quot;: .entity.label,\r\n       &quot;extra_entity_serial&quot;: .entity.serial} ) ]\r\n```\r\nThis produces an array with the desired objects.  If you wish to produce the invalid JSON as shown in the Q, feel free to employ whatever devious device that occurs to you, e.g. stripping away the leading and trailing square brackets.\r\n## Notes\r\n1. `{&quot;id&quot;: .id}` can be abbreviated as shown. \r\n2. Notice how the combinatorial explosion is avoided by specifying the itemization just once.\r\n3. The postfix &quot;?&quot; in an expression `E?` has the effect of `try E catch empty`\r\n4. To handle the `empty` case, `//` has been used. \r\n5. If you wanted a stream of valid JSON objects as the output, you could simplify things a bit by dropping the `-n` option and the use of `inputs` to wrap everything into an array.\r\n",
                "title": "Unwind nested JSON object with possible null values using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606296329,
        "creation_date": 1606291483,
        "last_edit_date": 1606292227,
        "question_id": 65000653,
        "body_markdown": "I have a json response with 3 items that looks like this:\r\n\r\n    {\r\n        &quot;id&quot;: 44,\r\n        &quot;extra&quot;: [{\r\n            &quot;domain&quot;: {\r\n                &quot;id&quot;: 3,\r\n                &quot;name&quot;: &quot;person&quot;\r\n            },\r\n            &quot;entity&quot;: {\r\n                &quot;label&quot;: &quot;Noon&quot;,\r\n                &quot;serial&quot;: 8938493\r\n            }\r\n        },\r\n        {\r\n            &quot;domain&quot;: {\r\n                &quot;id&quot;: 4,\r\n                &quot;name&quot;: &quot;place&quot;\r\n            },\r\n            &quot;entity&quot;: {\r\n                &quot;label&quot;: &quot;Rad&quot;,\r\n                &quot;serial&quot;: 8932321\r\n            }\r\n        }]\r\n    }\r\n    {\r\n        &quot;id&quot;: 45,\r\n        &quot;extra&quot;: null\r\n        \r\n    }\r\n    {\r\n        &quot;id&quot;: 46,\r\n        &quot;extra&quot;: [{\r\n            &quot;domain&quot;: {\r\n                &quot;id&quot;: 90,\r\n                &quot;name&quot;: &quot;animal&quot;\r\n            },\r\n            &quot;entity&quot;: {\r\n                &quot;label&quot;: &quot;Foo&quot;,\r\n                &quot;serial&quot;: 892121\r\n            }\r\n        },\r\n        {\r\n            &quot;domain&quot;: {\r\n                &quot;id&quot;: 91\r\n            },\r\n            &quot;entity&quot;: {\r\n                &quot;label&quot;: &quot;Ear&quot;,\r\n                &quot;serial&quot;: 823414\r\n            }\r\n        },\r\n        {\r\n            &quot;domain&quot;: {\r\n                &quot;id&quot;: 92\r\n            },\r\n            &quot;entity&quot;: {\r\n                &quot;label&quot;: &quot;Owl&quot;,\r\n                &quot;serial&quot;: 889232\r\n            }\r\n        }]\r\n    }\r\n\r\nMy goal is to get this response into:\r\n\r\n    {\r\n    \t&quot;id&quot;: 44,\r\n    \t&quot;extra_domain_id&quot;: 3,\r\n    \t&quot;extra_domain_name&quot;: &quot;person&quot;,\r\n    \t&quot;extra_entity_label&quot;: &quot;Noon&quot;,\r\n    \t&quot;extra_entity_serial&quot;: 8938493\r\n    },\r\n    {\r\n    \t&quot;id&quot;: 44,\r\n    \t&quot;extra_domain_id&quot;: 4,\r\n    \t&quot;extra_domain_name&quot;: &quot;place&quot;,\r\n    \t&quot;extra_entity_label&quot;: &quot;Rad&quot;,\r\n    \t&quot;extra_entity_serial&quot;: 8932321\r\n    },\r\n    {\r\n    \t&quot;id&quot;: 45,\r\n    \t&quot;extra_domain_id&quot;: null,\r\n    \t&quot;extra_domain_name&quot;: null,\r\n    \t&quot;extra_entity_label&quot;: null,\r\n    \t&quot;extra_entity_serial&quot;: null\r\n    },\r\n    {\r\n    \t&quot;id&quot;: 46,\r\n    \t&quot;extra_domain_id&quot;: 90,\r\n    \t&quot;extra_domain_name&quot;: &quot;animal&quot;,\r\n    \t&quot;extra_entity_label&quot;: &quot;Foo&quot;,\r\n    \t&quot;extra_entity_serial&quot;: 892121\r\n    },\r\n    {\r\n    \t&quot;id&quot;: 46,\r\n    \t&quot;extra_domain_id&quot;: 91,\r\n    \t&quot;extra_domain_name&quot;: null,\r\n    \t&quot;extra_entity_label&quot;: &quot;Ear&quot;,\r\n    \t&quot;extra_entity_serial&quot;: 823414\r\n    },\r\n    {\r\n    \t&quot;id&quot;: 46,\r\n    \t&quot;extra_domain_id&quot;: 92,\r\n    \t&quot;extra_domain_name&quot;: null,\r\n    \t&quot;extra_entity_label&quot;: &quot;Owl&quot;,\r\n    \t&quot;extra_entity_serial&quot;: 889232\r\n    }\r\n\r\n\r\nNotice how in the third item with `id` 46, `domain.name` is missing in the last two entries, 91 and 92 of the `extra` array, so they&#39;re replaced with null. &lt;br/&gt;&lt;br/&gt;\r\nThis is what I tried\r\n\r\n    {&quot;id&quot;: .id, &quot;extra_domain_id&quot;: .extra[].domain.id, &quot;extra_domain_name&quot;: .extra[].domain.name, &quot;extra_entity_label&quot;: .extra[].entity.label, &quot;extra_entity_serial&quot;: .extra[].entity.serial}\r\n\r\nbut it doesn&#39;t give me the desired output, it returns a cartesian product of all possible combinations in each item in the response!",
        "link": "https://stackoverflow.com/questions/65000653/unwind-nested-json-object-with-possible-null-values-using-jq",
        "title": "Unwind nested JSON object with possible null values using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1606298048,
                "creation_date": 1606298048,
                "answer_id": 65002244,
                "question_id": 65002113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`any/1`](https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition)).\r\n```\r\n.[] | select(.code | any(.name == &quot;foo&quot;))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/wOg22IU6uh)&lt;/sup&gt;",
                "title": "Top level JSON object with multiple matches returned for each match"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606298271,
        "creation_date": 1606297588,
        "last_edit_date": 1606298271,
        "question_id": 65002113,
        "body_markdown": "I have this kind of JSON file:\r\n\r\n```json\r\n[{\r\n\t&quot;name&quot;: &quot;model1&quot;,\r\n\t&quot;reference&quot;: 0.1,\r\n\t&quot;code&quot;: [{\r\n\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t&quot;value&quot;: 0.2\r\n\t},{\r\n\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t&quot;version&quot;: &quot;b&quot;,\r\n\t\t&quot;value&quot;: 0.2\r\n\t},{\r\n\t\t&quot;name&quot;: &quot;bar&quot;,\r\n\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t&quot;value&quot;: 0.15\r\n\t}]\r\n},{\r\n\t&quot;name&quot;: &quot;model2&quot;,\r\n\t&quot;reference&quot;: 0.12,\r\n\t&quot;code&quot;: [{\r\n\t\t&quot;name&quot;: &quot;bar&quot;,\r\n\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t&quot;value&quot;: 0.09\r\n\t},{\r\n\t\t&quot;name&quot;: &quot;baz&quot;,\r\n\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t&quot;value&quot;: 0.15\r\n\t}]\r\n}]\r\n``` \r\n\r\nWhat I want is to get all the top level objects for a certain `code.name`, let’s say `foo`. So I wrote the following query:\r\n```\r\n.[] | select( .code[].name == &quot;foo&quot; )\r\n```\r\nThe problem is that since there is two sub-objects with `foo` as name, the top level object is returned twice. I’d like to have it only once, is that possible?",
        "link": "https://stackoverflow.com/questions/65002113/top-level-json-object-with-multiple-matches-returned-for-each-match",
        "title": "Top level JSON object with multiple matches returned for each match"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1606394050,
                "last_edit_date": 1606394050,
                "creation_date": 1606303598,
                "answer_id": 65003755,
                "question_id": 65003395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Many similar questions have been asked before&lt;sup&gt;[\\[1\\]](/q/63572261)[\\[2\\]](/q/62519154)[\\[3\\]](/q/62198965)[\\[4\\]](/q/56065822)...&lt;/sup&gt;. You need to avoid expanding the same array more than once as shown below to prevent a combinatorial explosion.\r\n```\r\n.[].models[] | {model: .name} + (.code[] | {name, version})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/vL89Iq6Dhe)&lt;/sup&gt;",
                "title": "Flatten JSON structure with jq without duplicates"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606394050,
        "creation_date": 1606302264,
        "last_edit_date": 1606303911,
        "question_id": 65003395,
        "body_markdown": "I’m starting from this structure:\r\n\r\n```json\r\n[{\r\n\t&quot;experiment&quot;: &quot;ex1&quot;,\r\n\t&quot;models&quot;: [{\r\n\t\t&quot;name&quot;: &quot;model1&quot;,\r\n\t\t&quot;reference&quot;: 0.1,\r\n\t\t&quot;code&quot;: [{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t\t&quot;value&quot;: 0.2\r\n\t\t},{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;version&quot;: &quot;b&quot;,\r\n\t\t\t&quot;value&quot;: 0.2\r\n\t\t},{\r\n\t\t\t&quot;name&quot;: &quot;bar&quot;,\r\n\t\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t\t&quot;value&quot;: 0.15\r\n\t\t}]\r\n\t},{\r\n\t\t&quot;name&quot;: &quot;model2&quot;,\r\n\t\t&quot;reference&quot;: 0.12,\r\n\t\t&quot;code&quot;: [{\r\n\t\t\t&quot;name&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t\t&quot;value&quot;: 0.09\r\n\t\t},{\r\n\t\t\t&quot;name&quot;: &quot;baz&quot;,\r\n\t\t\t&quot;version&quot;: &quot;a&quot;,\r\n\t\t\t&quot;value&quot;: 0.15\r\n\t\t}]\r\n\t}]\r\n}]\r\n```\r\n\r\nand I want this as the result:\r\n\r\n```json\r\n{\r\n  &quot;model&quot;: &quot;model1&quot;,\r\n  &quot;code&quot;: &quot;foo&quot;,\r\n  &quot;version&quot;: &quot;a&quot;\r\n}\r\n{\r\n  &quot;model&quot;: &quot;model1&quot;,\r\n  &quot;code&quot;: &quot;foo&quot;,\r\n  &quot;version&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;model&quot;: &quot;model1&quot;,\r\n  &quot;code&quot;: &quot;bar&quot;,\r\n  &quot;version&quot;: &quot;a&quot;\r\n}\r\n{\r\n  &quot;model&quot;: &quot;model2&quot;,\r\n  &quot;code&quot;: &quot;foo&quot;,\r\n  &quot;version&quot;: &quot;a&quot;\r\n}\r\n{\r\n  &quot;model&quot;: &quot;model2&quot;,\r\n  &quot;code&quot;: &quot;baz&quot;,\r\n  &quot;version&quot;: &quot;a&quot;\r\n}\r\n```\r\n\r\nSo I wrote the following query.\r\n```\r\n.[] | { &quot;model&quot;: .name, &quot;code&quot;: .code[].name, &quot;version&quot;: .code[].version }\r\n```\r\nThe problem is that for each use of `.code[]` in the output structure the results are multiplied, resulting in many duplicates. How can I avoid that, and get only the desired result?",
        "link": "https://stackoverflow.com/questions/65003395/flatten-json-structure-with-jq-without-duplicates",
        "title": "Flatten JSON structure with jq without duplicates"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1351165,
                    "reputation": 61454,
                    "user_id": 1290731,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8IINT.png?s=256",
                    "display_name": "jthill",
                    "link": "https://stackoverflow.com/users/1290731/jthill"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1606349830,
                "post_id": 65014334,
                "comment_id": 114941158,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1606349841,
                "last_edit_date": 1606349841,
                "creation_date": 1606349478,
                "answer_id": 65014436,
                "question_id": 65014334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n\r\nYou need to quote your variables in the shell to prevent from [word splitting][1]:\r\n\r\n    #!/bin/bash\r\n\r\n    work_dir=&quot;/foo/bar&quot;\r\n\r\n    validateAndNotify() {\r\n        echo &quot;${1}&quot;\r\n    }\r\n    \r\n    appls=$(jq -c &#39;.apps[]?&#39; &quot;${work_dir}/scripts/applications.json&quot;)\r\n    \r\n    echo &quot;*****&quot;\r\n    echo &quot;${appls}&quot;\r\n    echo &quot;*****&quot;\r\n    while read -r row ; do\r\n      validateAndNotify &quot;${row}&quot;\r\n    done &lt;&lt;&lt; &quot;${appls}&quot;\r\n\r\nPS: Shortened the jq command. Thanks [jthill][2]\r\n\r\n\r\n  [1]: https://www.gnu.org/software/bash/manual/html_node/Word-Splitting.html\r\n  [2]: https://stackoverflow.com/questions/65014334/parse-json-array-with-spaces-in-bash/65014436#comment114941158_65014334",
                "title": "parse JSON Array with spaces in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606349841,
        "creation_date": 1606348605,
        "question_id": 65014334,
        "body_markdown": "I&#39;m trying to parse the below json array and get the values from it. But it is not working with spaces as values. I did find some solutions in [stackoverflow][1] but nothing seems to work.\r\n\r\nJSON\r\n\r\n   \r\n\r\n     {\r\n      &quot;apps&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Root Certification Authority - G2&quot;,\r\n          &quot;expiryDate&quot;: &quot;Monday, 09 October 2023 20:03:25&quot;,\r\n          &quot;impactStatement&quot;: &quot;Apps using this root certificate will have an actual impact&quot;,\r\n          &quot;notifyBeforeInDays&quot;: 60\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Bamboo&quot;,\r\n          &quot;expiryDate&quot;: &quot;Sunday, 20 November 2022 03:25:23&quot;,\r\n          &quot;impactStatement&quot;: &quot;CI/CD wont be working&quot;,\r\n          &quot;sop&quot;: &quot;https://somelink/Bamboo+SOPs&quot;,\r\n          &quot;notifyBeforeInDays&quot;: 30\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Vault - Client&quot;,\r\n          &quot;expiryDate&quot;: &quot;Monday, 09 October 2023 20:03:25&quot;,\r\n          &quot;impactStatement&quot;: &quot;All Mule applications for that particular environment will stop working&quot;,\r\n          &quot;notifyBeforeInDays&quot;: 60\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Consul&quot;,\r\n          &quot;expiryDate&quot;: &quot;Monday, 21 August 2023 14:43:56&quot;,\r\n          &quot;impactStatement&quot;: &quot;No Direct impact or never had any such scenario so far&quot;,\r\n          &quot;notifyBeforeInDays&quot;: 30\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;bitbucket&quot;,\r\n          &quot;expiryDate&quot;: &quot;08 September 2021 13:16:06&quot;,\r\n          &quot;impactStatement&quot;: &quot;No Impact&quot;,\r\n          &quot;notifyBeforeInDays&quot;: 15\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I&#39;m using the below code to parse the json\r\n\r\n    appls=$(awk &#39;{print $0}&#39; ${work_dir}/scripts/applications.json | jq -c &#39;. |select(.apps !=null) |.apps[]&#39;)\r\n    echo &quot;*****&quot;\r\n    echo $appls\r\n    echo &quot;*****&quot;\r\n    for row in ${appls}; do\r\n      echo $row\r\n      validateAndNotify $row\r\n    done\r\n\r\nAnd when i print the above variable following output is printed, which is not a valid one.\r\n\r\n    *****\r\n     {&quot;name&quot;:&quot;bitbucket&quot;,&quot;expiryDate&quot;:&quot;08 September 2021 13:16:06&quot;,&quot;impactStatement&quot;:&quot;No Impact&quot;,&quot;notifyBeforeInDays&quot;:15} such scenario so far&quot;,&quot;notifyBeforeInDays&quot;:30}&quot;,&quot;notifyBeforeInDays&quot;:60}Bamboo+SOPs&quot;,&quot;notifyBeforeInDays&quot;:30}\r\n    *****\r\n    {&quot;name&quot;:&quot;Root\r\n\r\nI want to parse the apps array and get each value inside that node.\r\n\r\n  [1]: https://stackoverflow.com/questions/47775462/jq-not-parsing-json-with-spaces",
        "link": "https://stackoverflow.com/questions/65014334/parse-json-array-with-spaces-in-bash",
        "title": "parse JSON Array with spaces in bash"
    },
    {
        "tags": [
            "json",
            "shell",
            "escaping",
            "jq",
            "glob"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606388067,
                "creation_date": 1606388067,
                "answer_id": 65020622,
                "question_id": 65020149,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To stop wildcard expansion in your bash shell, you can:\r\n\r\n    set -o noglob\r\n\r\nThen to add it back in:\r\n\r\n    set +o noglob",
                "title": "Build JSON using JQ - escaping the asterix character"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1606388978,
                "last_edit_date": 1606388978,
                "creation_date": 1606388378,
                "answer_id": 65020707,
                "question_id": 65020149,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is not with your invocation of jq, but with the way you examined jq&#39;s output.  When confronted with this type of puzzle, you can usually figure out the problem by examining intermediate results.  So consider:\r\n```\r\n\r\n$ Test1=&quot;*/15 * * * *&quot;\r\n\r\n$ echo &quot;$Test1&quot;\r\n*/15 * * * *\r\n\r\n$ jq -n --arg bob &quot;$Test1&quot; &#39;{ Kate: $bob}&#39;\r\n{\r\n  &quot;Kate&quot;: &quot;*/15 * * * *&quot;\r\n}\r\n\r\n$ json=$(jq -n --arg bob &quot;$Test1&quot; &#39;{ Kate: $bob}&#39;)\r\n\r\n$ echo &quot;$json&quot;\r\n{\r\n  &quot;Kate&quot;: &quot;*/15 * * * *&quot;\r\n}\r\n```\r\n## Trailing asterisk\r\n\r\nSimilarly, for the second question about the trailing asterisk:\r\n```\r\n$ echo &quot;$Test1&quot;\r\n*/15 * * * *\r\n\r\n$ echo $Test1\r\n*/15 test test test test\r\n\r\n$ echo \\&quot;$Test1\\&quot;\r\n&quot;*/15 test test test *&quot;\r\n\r\n```",
                "title": "Build JSON using JQ - escaping the asterix character"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1606393266,
        "creation_date": 1606386466,
        "last_edit_date": 1606393266,
        "question_id": 65020149,
        "body_markdown": "Question:\r\n\r\nHow do I build JSON using JQ in bash using something like the following? (The output is not as expected - explanation below)\r\n\r\n```\r\nTest1=&quot;*/15 * * * *&quot;\r\njson=$( jq -n --arg bob &quot;$Test1&quot; &#39;{ Kate: $bob}&#39; )\r\n```\r\n\r\nProblem:  \r\n\r\nBash tries to be helpful when echoing the content of the string. In this case, the `*` character is interpreted as the contents of the current directory.\r\n\r\nAn example of the problem:\r\nIf I have a subfolder called `test` in the current directory and I do the following:\r\n\r\n```bash\r\n:$ Test1=&quot;*/15 * * * *&quot;\r\n:$ echo $Test1\r\n:$ */15 test test test test\r\n```\r\n\r\nObviously, I don&#39;t want the folder name substituted for the asterix. I can get around this by putting the variable in quotes - this outputs the correct string.\r\n\r\n```bash\r\n:$ Test1=&quot;*/15 * * * *&quot;\r\n:$ echo &quot;$Test1&quot;\r\n:$ */15 * * * *\r\n```\r\n\r\nHowever, when I attempt to [build a JSON object using this string with JQ][1], I get the following:\r\n\r\n```bash\r\n:$ Test1=&quot;*/15 * * * *&quot;\r\n:$ json=$( jq -n --arg bob &quot;$Test1&quot; &#39;{ Kate: $bob}&#39; )\r\n:$ echo $json\r\n:$ { &quot;Kate&quot;: &quot;*/15 test test test *&quot; }\r\n```\r\n\r\nI want the output to be \r\n\r\n```bash\r\n{ &quot;Kate&quot;: &quot;*/15 * * * *&quot; }\r\n```\r\n\r\nHow can I achieve this using JQ?  \r\nAlso - why is the last star not interpreted in the JSON object? I would have expected to see four instances of the folder name, but I see three, followed by an asterix.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/48470227/685341",
        "link": "https://stackoverflow.com/questions/65020149/build-json-using-jq-escaping-the-asterix-character",
        "title": "Build JSON using JQ - escaping the asterix character"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606444084,
                "post_id": 65031256,
                "comment_id": 114970113,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606444028,
                "creation_date": 1606444028,
                "answer_id": 65031363,
                "question_id": 65031256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your problem is that the API response is not JSON; it looks like a javascript call.\r\n\r\nPerhaps the API has a parameter which you can use to insist that the response be valid JSON.  Otherwise, you might find it easiest to strip off the leading `APIResponse(` and the trailing `)`, though it should be noted that the posted response argument is not quite valid JSON ....",
                "title": "python api response to json object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606845950,
                "last_edit_date": 1606845950,
                "creation_date": 1606778551,
                "answer_id": 65082581,
                "question_id": 65031256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The api is returning an object, rather than JSON as expected. You might be able to modify your request but in any case you can pull out the json object. By way of example, I do this for a stock api I hit.\r\n\r\n    a = api.get_asset(&#39;NFLX&#39;)\r\n\r\nand this returns:\r\n\r\n    Asset({   &#39;class&#39;: &#39;us_equity&#39;,\r\n        &#39;easy_to_borrow&#39;: True,\r\n        &#39;exchange&#39;: &#39;NASDAQ&#39;,\r\n        &#39;id&#39;: &#39;bb2a26c0-4c77-4801-8afc-82e8142ac7b8&#39;,\r\n        &#39;marginable&#39;: True,\r\n        &#39;name&#39;: &#39;Netflix, Inc. Common Stock&#39;,\r\n        &#39;shortable&#39;: True,\r\n        &#39;status&#39;: &#39;active&#39;,\r\n        &#39;symbol&#39;: &#39;NFLX&#39;,\r\n        &#39;tradable&#39;: True})\r\n\r\nTo retrieve the elements I use the following methods:\r\n\r\n    getattr(a, &#39;symbol&#39;)  or  a.symbol\r\n\r\n\r\nIf you do dir(a), you see this:\r\n\r\n\r\n    In [21]: dir(a)\r\n    Out[21]:\r\n    [&#39;__class__&#39;,\r\n     &#39;__delattr__&#39;,\r\n     &#39;__dict__&#39;,\r\n     &#39;__dir__&#39;,\r\n     &#39;__doc__&#39;,\r\n     &#39;__eq__&#39;,\r\n     &#39;__format__&#39;,\r\n     &#39;__ge__&#39;,\r\n     &#39;__getattr__&#39;,\r\n     &#39;__getattribute__&#39;,\r\n     &#39;__gt__&#39;,\r\n     &#39;__hash__&#39;,\r\n     &#39;__init__&#39;,\r\n     &#39;__init_subclass__&#39;,\r\n     &#39;__le__&#39;,\r\n     &#39;__lt__&#39;,\r\n     &#39;__module__&#39;,\r\n     &#39;__ne__&#39;,\r\n     &#39;__new__&#39;,\r\n     &#39;__reduce__&#39;,\r\n     &#39;__reduce_ex__&#39;,\r\n     &#39;__repr__&#39;,\r\n     &#39;__setattr__&#39;,\r\n     &#39;__sizeof__&#39;,\r\n     &#39;__str__&#39;,\r\n     &#39;__subclasshook__&#39;,\r\n     &#39;__weakref__&#39;,\r\n     &#39;_raw&#39;]\r\n\r\na._raw outputs this:\r\n\r\n    In [23]: a._raw\r\n    Out[23]:\r\n    {&#39;id&#39;: &#39;bb2a26c0-4c77-4801-8afc-82e8142ac7b8&#39;,\r\n     &#39;class&#39;: &#39;us_equity&#39;,\r\n     &#39;exchange&#39;: &#39;NASDAQ&#39;,\r\n     &#39;symbol&#39;: &#39;NFLX&#39;,\r\n     &#39;name&#39;: &#39;Netflix, Inc. Common Stock&#39;,\r\n     &#39;status&#39;: &#39;active&#39;,\r\n     &#39;tradable&#39;: True,\r\n     &#39;marginable&#39;: True,\r\n     &#39;shortable&#39;: True,\r\n     &#39;easy_to_borrow&#39;: True}\r\n\r\nYou can get the JSON this way:\r\n\r\n    In [25]: a.__dict__\r\n    Out[25]:\r\n    {&#39;_raw&#39;: {&#39;id&#39;: &#39;bb2a26c0-4c77-4801-8afc-82e8142ac7b8&#39;,\r\n      &#39;class&#39;: &#39;us_equity&#39;,\r\n      &#39;exchange&#39;: &#39;NASDAQ&#39;,\r\n      &#39;symbol&#39;: &#39;NFLX&#39;,\r\n      &#39;name&#39;: &#39;Netflix, Inc. Common Stock&#39;,\r\n      &#39;status&#39;: &#39;active&#39;,\r\n      &#39;tradable&#39;: True,\r\n      &#39;marginable&#39;: True,\r\n      &#39;shortable&#39;: True,\r\n      &#39;easy_to_borrow&#39;: True}}\r\n\r\nalso, \r\n\r\n    In [26]: a.__class__\r\n    Out[26]: alpaca_trade_api.entity.Asset\r\n\r\nDepending on what you want to do, you can call any of these methods to get the json and work with it directly.\r\n",
                "title": "python api response to json object"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1606845950,
        "creation_date": 1606442666,
        "last_edit_date": 1606482167,
        "question_id": 65031256,
        "body_markdown": "I am trying to write a script to parse over an api response using jq. I can get it to work using bash and the cli, but i want to script it in python so i can put a lot more logic into it. The problem i am having is that i can get the api response but when i try load it using the json.loads() or json.dump() i keep getting the following error:\r\n\r\n    TypeError: the JSON object must be str, bytes or bytearray, not APIResponse\r\n\r\nHere is the response i get from the api\r\n\r\n    APIResponse({\r\n        &quot;data&quot;: {\r\n            &quot;color&quot;: &quot;red&quot;,\r\n            &quot;comments&quot;: &quot;&quot;,\r\n            &quot;domain&quot;: {\r\n                &quot;domain-type&quot;: &quot;domain&quot;,\r\n                &quot;name&quot;: &quot;SMC User&quot;,\r\n                &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-0900211d9fde&quot;\r\n            },\r\n            &quot;groups&quot;: [\r\n                {\r\n                    &quot;domain&quot;: {\r\n                        &quot;domain-type&quot;: &quot;domain&quot;,\r\n                        &quot;name&quot;: &quot;SMC User&quot;,\r\n                        &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-0800211d9fde&quot;\r\n                    },\r\n                    &quot;name&quot;: &quot;NET_MGMT&quot;,\r\n                    &quot;type&quot;: &quot;group&quot;,\r\n                    &quot;uid&quot;: &quot;c0516cd9-d2a7-48a0-967e-5f455b9b0980&quot;\r\n                }\r\n                \r\n            ],\r\n            &quot;icon&quot;: &quot;General/group&quot;,\r\n            &quot;members&quot;: [\r\n                {\r\n                    &quot;domain&quot;: {\r\n                        &quot;domain-type&quot;: &quot;domain&quot;,\r\n                        &quot;name&quot;: &quot;SMC User&quot;,\r\n                        &quot;uid&quot;: &quot;41e821a0-3720-11e3-ba6e-0800200c8fde&quot;\r\n                    },\r\n                    &quot;ipv4-address&quot;: &quot;10.10.10.63&quot;,\r\n                    &quot;name&quot;: &quot;WS3&quot;,\r\n                    &quot;type&quot;: &quot;host&quot;,\r\n                    &quot;uid&quot;: &quot;f7e298dc-9817-4786-8ce0-c6f7dd607034&quot;\r\n                },\r\n                {\r\n                    &quot;domain&quot;: {\r\n                        &quot;domain-type&quot;: &quot;domain&quot;,\r\n                        &quot;name&quot;: &quot;SMC User&quot;,\r\n                        &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;\r\n                    },\r\n                    &quot;ipv4-address&quot;: &quot;10.10.10.62&quot;,\r\n                    &quot;name&quot;: &quot;WS2&quot;,\r\n                    &quot;type&quot;: &quot;host&quot;,\r\n                    &quot;uid&quot;: &quot;665163a1-319d-48c9-aa25-e7beecfa3456&quot;\r\n                },\r\n                {\r\n                    &quot;domain&quot;: {\r\n                        &quot;domain-type&quot;: &quot;domain&quot;,\r\n                        &quot;name&quot;: &quot;SMC User&quot;,\r\n                        &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-1900200c9fde&quot;\r\n                    },\r\n                    &quot;ipv4-address&quot;: &quot;10.10.10.58&quot;,\r\n                    &quot;name&quot;: &quot;host_01&quot;,\r\n                    &quot;type&quot;: &quot;host&quot;,\r\n                    &quot;uid&quot;: &quot;73eded3f-9dee-49d5-84c8-4c9e03b36766&quot;\r\n                }\r\n                \r\n            ],\r\n            &quot;meta-info&quot;: {\r\n                &quot;creation-time&quot;: {\r\n                    &quot;iso-8601&quot;: &quot;2017-04-23T16:31-0400&quot;,\r\n                    &quot;posix&quot;: 1492979419853\r\n                },\r\n                &quot;creator&quot;: &quot;System&quot;,\r\n                &quot;last-modifier&quot;: &quot;test123&quot;,\r\n                &quot;last-modify-time&quot;: {\r\n                    &quot;iso-8601&quot;: &quot;2020-10-07T13:24-0500&quot;,\r\n                    &quot;posix&quot;: 1602091445514\r\n                },\r\n                &quot;lock&quot;: &quot;unlocked&quot;,\r\n                &quot;validation-state&quot;: &quot;ok&quot;\r\n            },\r\n            &quot;name&quot;: &quot;NetworkMgmt&quot;,\r\n            &quot;read-only&quot;: false,\r\n            &quot;tags&quot;: [],\r\n            &quot;type&quot;: &quot;group&quot;,\r\n            &quot;uid&quot;: &quot;254434c7-01a3-4f1d-96b9-b14fc90d9449&quot;\r\n        },\r\n        &quot;res_obj&quot;: {\r\n            &quot;data&quot;: {\r\n                &quot;color&quot;: &quot;red&quot;,\r\n                &quot;comments&quot;: &quot;&quot;,\r\n                &quot;domain&quot;: {\r\n                    &quot;domain-type&quot;: &quot;domain&quot;,\r\n                    &quot;name&quot;: &quot;SMC User&quot;,\r\n                    &quot;uid&quot;: &quot;41e821a0-3620-11e3-aa6e-0800200c8cde&quot;\r\n                },\r\n                &quot;groups&quot;: [\r\n                    {\r\n                        &quot;domain&quot;: {\r\n                            &quot;domain-type&quot;: &quot;domain&quot;,\r\n                            &quot;name&quot;: &quot;SMC User&quot;,\r\n                            &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-1900200c8ffa&quot;\r\n                        },\r\n                        &quot;name&quot;: &quot;NET_MGMT&quot;,\r\n                        &quot;type&quot;: &quot;group&quot;,\r\n                        &quot;uid&quot;: &quot;c0516cd9-d2a7-48a0-967e-5f466b9b0986&quot;\r\n                    },\r\n                    {\r\n                        &quot;domain&quot;: {\r\n                            &quot;domain-type&quot;: &quot;domain&quot;,\r\n                            &quot;name&quot;: &quot;SMC User&quot;,\r\n                            &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-1800200d7fde&quot;\r\n                        },\r\n                        &quot;name&quot;: &quot;NET_MGMT&quot;,\r\n                        &quot;type&quot;: &quot;group&quot;,\r\n                        &quot;uid&quot;: &quot;0861a249-716d-4590-9091-774b6400ab36&quot;\r\n                    }\r\n                ],\r\n                &quot;icon&quot;: &quot;General/group&quot;,\r\n                &quot;members&quot;: [\r\n                    {\r\n                        &quot;domain&quot;: {\r\n                            &quot;domain-type&quot;: &quot;domain&quot;,\r\n                            &quot;name&quot;: &quot;SMC User&quot;,\r\n                            &quot;uid&quot;: &quot;41e821a0-3720-11e3-aa6e-0800200d8fde&quot;\r\n                        },\r\n                        &quot;ipv4-address&quot;: &quot;10.10.10.63&quot;,\r\n                        &quot;name&quot;: &quot;WS1&quot;,\r\n                        &quot;type&quot;: &quot;host&quot;,\r\n                        &quot;uid&quot;: &quot;f7e298dc-9817-4786-8ce0-c6f7dd607034&quot;\r\n                    }\r\n                    {\r\n                        &quot;domain&quot;: {\r\n                            &quot;domain-type&quot;: &quot;domain&quot;,\r\n                            &quot;name&quot;: &quot;SMC User&quot;,\r\n                            &quot;uid&quot;: &quot;41e821a0-3720-21e3-aa6e-1800200c91de&quot;\r\n                        },\r\n                        &quot;mask-length4&quot;: 28,\r\n                        &quot;name&quot;: &quot;Net1&quot;,\r\n                        &quot;subnet-mask&quot;: &quot;255.255.255.0&quot;,\r\n                        &quot;subnet4&quot;: &quot;10.10.10.0&quot;,\r\n                        &quot;type&quot;: &quot;network&quot;,\r\n                        &quot;uid&quot;: &quot;6a1b1187-01d7-430e-b7dc-321efcf49220&quot;\r\n                    }\r\n                ],\r\n                &quot;meta-info&quot;: {\r\n                    &quot;creation-time&quot;: {\r\n                        &quot;iso-8601&quot;: &quot;2017-04-23T16:40-0400&quot;,\r\n                        &quot;posix&quot;: 1492979419853\r\n                    },\r\n                    &quot;creator&quot;: &quot;System&quot;,\r\n                    &quot;last-modifier&quot;: &quot;test123&quot;,\r\n                    &quot;last-modify-time&quot;: {\r\n                        &quot;iso-8601&quot;: &quot;2020-10-07T13:24-0400&quot;,\r\n                        &quot;posix&quot;: 1602091445514\r\n                    },\r\n                    &quot;lock&quot;: &quot;unlocked&quot;,\r\n                    &quot;validation-state&quot;: &quot;ok&quot;\r\n                },\r\n                &quot;name&quot;: &quot;NetworkMgmt&quot;,\r\n                &quot;read-only&quot;: false,\r\n                &quot;tags&quot;: [],\r\n                &quot;type&quot;: &quot;group&quot;,\r\n                &quot;uid&quot;: &quot;254434c7-01a3-4f1d-96c8-b14f290d9440&quot;\r\n            },\r\n            &quot;status_code&quot;: 200\r\n        },\r\n        &quot;status_code&quot;: 200,\r\n        &quot;success&quot;: true\r\n    })",
        "link": "https://stackoverflow.com/questions/65031256/python-api-response-to-json-object",
        "title": "python api response to json object"
    },
    {
        "tags": [
            "json",
            "stream",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606495882,
                "last_edit_date": 1606495882,
                "creation_date": 1606491059,
                "answer_id": 65039877,
                "question_id": 65039429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is covered in the jq Cookbook. Here is an extract, omitting two defs that are unnecessary for defining `uniques/1`:\r\n\r\n\r\n## Using bag to implement a sort-free version of unique\r\n\r\njq&#39;s `unique` built-in involves a sort, which in practice is usually fast enough, but may not be desirable for very large arrays or especially if processing a very long stream of entities, or if the order of first-occurrence is important. One solution is to use &quot;bags&quot;, that is, multisets in the sense of sets-with-multiplicities. Here is a stream-oriented implementation that preserves generality and takes advantage of jq&#39;s implementation of lookups in JSON objects:\r\n\r\n```\r\n\r\n# bag(stream) uses a two-level dictionary: .[type][tostring]\r\n# So given a bag, $b, to recover a count for an entity, $e, use\r\n# $e | $b[type][tostring]\r\ndef bag(stream):\r\n  reduce stream as $x ({}; .[$x|type][$x|tostring] += 1 );\r\n\r\n```\r\nIt is now a simple matter to define uniques(stream), the &quot;s&quot; being appropriate here because the filter produces a stream:\r\n```\r\n\r\n# Produce a stream of the distinct elements in the given stream\r\ndef uniques(stream):\r\n  bag(stream)\r\n  | to_entries[]\r\n  | .key as $type\r\n  | .value\r\n  | to_entries[]\r\n  | if $type == &quot;string&quot; then .key else .key|fromjson end ;\r\n```",
                "title": "How to remove duplicate objects from a json stream with jq without reordering?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1606726697,
        "creation_date": 1606489035,
        "last_edit_date": 1606726697,
        "question_id": 65039429,
        "body_markdown": "Here&#39;s your input data: `&quot;3&quot;&quot;5&quot;&quot;2&quot;&quot;2&quot;`.  \r\nFigure out a `jq` query to return `&quot;3&quot;&quot;5&quot;&quot;2&quot;`.  \r\nMy usecase: polling JSON objects of a third party service state, which changes less often than I&#39;m polling.\r\n\r\nI tried `jq -n &#39;[inputs] | unique[]&#39;`, but this reorders results.",
        "link": "https://stackoverflow.com/questions/65039429/how-to-remove-duplicate-objects-from-a-json-stream-with-jq-without-reordering",
        "title": "How to remove duplicate objects from a json stream with jq without reordering?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1606496362,
                "creation_date": 1606496362,
                "answer_id": 65041082,
                "question_id": 65040990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nto_entries | map(join(&quot;=&quot;)) | join(&quot;, &quot;)\r\n```\r\n\r\n1. `to_entries` produces a list of key/value pairs e.g, `[[&quot;foo&quot;,&quot;bar&quot;], ...]`\r\n2. join each pair with `&quot;=&quot;` e.g. `[&quot;foo=bar&quot;, ...]`\r\n3. join each pair again with `&quot;, &quot;` e.g. `&quot;foo=bar, ...`",
                "title": "How to format a JSON string as a &quot;key=value&quot; format using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606496362,
        "creation_date": 1606495873,
        "last_edit_date": 1606496189,
        "question_id": 65040990,
        "body_markdown": "I would like to convert JSON string into &quot;key=value&quot; format separated by commas.\r\n\r\n    {&quot;foo&quot;: &quot;bar&quot;, &quot;number&quot;: 123}\r\n\r\nShould be converted into\r\n\r\n    foo=bar, number=123\r\n\r\nI&#39;ve been looking for jq documentation and searching for a simple solution but I&#39;m having a hard time to achieve this dynamically, without knowing the names of the fields before hand.\r\n\r\nThis is furthest I&#39;ve gotten to but I&#39;m not sure how to fix the escaping issue and the code is pretty ugly.\r\n\r\n    04:52:32 root@raspberrypi ~ → echo $json\r\n    {&quot;time_utc&quot;:1606488980,&quot;Temperature&quot;:-0.3,&quot;Humidity&quot;:100,&quot;min_temp&quot;:-1.4,&quot;max_temp&quot;:-0.2,&quot;date_max_temp&quot;:1606476880,&quot;date_min_temp&quot;:1606428232,&quot;temp_trend&quot;:&quot;stable&quot;}\r\n    04:52:34 root@raspberrypi ~ → keys=$(echo $json | jq keys | jq -r .[] | awk &#39;{printf $1&quot;=\\(.&quot;$1&quot;) &quot;}&#39;)\r\n    04:52:41 root@raspberrypi ~ → echo $keys\r\n    Humidity=\\(.Humidity) Temperature=\\(.Temperature) date_max_temp=\\(.date_max_temp) date_min_temp=\\(.date_min_temp) max_temp=\\(.max_temp) min_temp=\\(.min_temp) temp_trend=\\(.temp_trend) time_utc=\\(.time_utc)\r\n    04:52:45 root@raspberrypi ~ → echo $json | jq -r &quot;$keys&quot;\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    Humidity=\\(.Humidity) Temperature=\\(.Temperature) date_max_temp=\\(.date_max_temp) date_min_temp=\\(.date_min_temp) max_temp=\\(.max_temp) min_temp=\\(.min_temp) temp_trend=\\(.temp_trend) time_utc=\\(.time_utc)          \r\n    jq: 1 compile error\r\n    04:53:17 root@raspberrypi ~ → echo $json | jq -r &#39;&quot;Humidity=\\(.Humidity) Temperature=\\(.Temperature) date_max_temp=\\(.date_max_temp) date_min_temp=\\(.date_min_temp) max_temp=\\(.max_temp) min_temp=\\(.min_temp) temp_trend=\\(.temp_trend) time_utc=\\(.time_utc)&quot;&#39;\r\n    Humidity=100 Temperature=-0.3 date_max_temp=1606476880 date_min_temp=1606428232 max_temp=-0.2 min_temp=-1.4 temp_trend=stable time_utc=1606488980",
        "link": "https://stackoverflow.com/questions/65040990/how-to-format-a-json-string-as-a-key-value-format-using-jq",
        "title": "How to format a JSON string as a &quot;key=value&quot; format using jq?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606567124,
                "post_id": 65046497,
                "comment_id": 115001546,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606600729,
                "creation_date": 1606600729,
                "answer_id": 65054878,
                "question_id": 65046497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The kind of programming you seem to aspire to is possible but usually not worth the effort, if only because of the way you typically get tangled in your own web.  If you want to go down this path, then consider this attempt of yours:\r\n\r\n&gt; export test=&quot;jq &#39;(.metadata.labels.istio, .spec.selector.istio)|=&quot;internal-ingressgateway&quot;&#39;&quot;\r\n\r\nTo make this work, you&#39;ll have to escape the inner double-quotation marks:\r\n```\r\nexport test=&quot;jq &#39;(.metadata.labels.istio, .spec.selector.istio)|=\\&quot;internal-ingressgateway\\&quot;&#39;&quot;\r\n```\r\nFor further inspiration, see\r\nhttps://stackoverflow.com/questions/64937500/jq-1-5-multiple-bash-variables-as-argument\r\n\r\n",
                "title": "Assign jq command to a variable and process the variable in later variables"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606600729,
        "creation_date": 1606538854,
        "last_edit_date": 1606538948,
        "question_id": 65046497,
        "body_markdown": "```\r\nkubectl get service boss-gateway -n boss-system -o json \\\r\n| jq &#39; (.metadata.labels.boss, .spec.selector.boss)|=&quot;internal-gateway&quot;\r\n| (.metadata.annotations[&quot;service.beta.kubernetes.io/aws-load-balancer-internal&quot;]) |= &quot;true&quot; &#39; \\\r\n| kubectl apply -f - --dry-run=client -o yaml\r\n```\r\n\r\nI have other queries as well, which use this snippet\r\n\r\n| jq &#39; (.metadata.labels.boss, .spec.selector.boss)|=&quot;internal-gateway&quot;\r\n| (.metadata.annotations[&quot;service.beta.kubernetes.io/aws-load-balancer-internal&quot;]) |= &quot;true&quot; &#39;\r\n\r\ncan i assign to a variable and use back in my bash script?\r\n\r\nI tried like this\r\n\r\nexport test=&quot;jq &#39; (.metadata.labels.istio, .spec.selector.istio)|=\\&quot;internal-ingressgateway\\&quot;&#39;&quot;\r\n\r\nkubectl get service boss-gateway -n boss-system -o json \\\r\n| ${test} \\\r\n| kubectl apply -f - --dry-run=client -o yaml\r\nwhen i echoed, it is showing correctly and i am able to execute that query\r\nbut when i try to run it in the script, it is not working. any idea, where am i missing?",
        "link": "https://stackoverflow.com/questions/65046497/assign-jq-command-to-a-variable-and-process-the-variable-in-later-variables",
        "title": "Assign jq command to a variable and process the variable in later variables"
    },
    {
        "tags": [
            "mongodb",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1606576279,
                "post_id": 65050988,
                "comment_id": 115004227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6952818,
                    "reputation": 935,
                    "user_id": 5334903,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/f1PdS.jpg?s=256",
                    "display_name": "Bloodbee",
                    "link": "https://stackoverflow.com/users/5334903/bloodbee"
                },
                "reply_to_user": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606576362,
                "post_id": 65050988,
                "comment_id": 115004251,
                "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": 1606576593,
                "post_id": 65050988,
                "comment_id": 115004351,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1606582062,
                "last_edit_date": 1606582062,
                "creation_date": 1606581459,
                "answer_id": 65051980,
                "question_id": 65050988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the output from jq is a single line, why not just:\r\n\r\n    echo &quot;$documents&quot;\r\n\r\nOr, if the result of the call to jq is a stream that might have more than one item, and if you want each item in the stream to be available as a bash variable, then if your bash is sufficiently up-to-date, you could use `mapfile` (aka `readarray`); otherwise, you could consider using a bash `while` loop, e.g. along the lines of:\r\n\r\n    declare -a document\r\n    while read -r item ; do\r\n      document+=(&quot;$item&quot;)\r\n    done &lt; &lt;(jq -c ....)\r\n\r\nThe idea here is that invoking jq with the -c option ensures that the only raw newlines that jq emits will be the ones demarking the items in the stream.",
                "title": "Iterating over output of jq with a for loop in bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1606582901,
        "creation_date": 1606575797,
        "last_edit_date": 1606582901,
        "question_id": 65050988,
        "body_markdown": "Hello fellow developers !\r\n\r\nI&#39;m quite having a hard time on this one, so your help would be good :)\r\n\r\nI&#39;m creating a script shell that will periodically (thanks to cron) do a synchronisation between an offline mongodb to firebase.\r\n\r\nI use [jq][1] to treat the export of my mongodb, but this one is acting strangely on strings values containing whitespaces.\r\n\r\nFor example, I&#39;ve got this exported document from a mongodb collection named users (using --jsonArray as mongoexport option), file named mycollectionexported.json:\r\n\r\n    [{&quot;_id&quot;:{&quot;$oid&quot;:&quot;5fc253c493b9f7363c8d1011&quot;},&quot;emailVerified&quot;:true,&quot;disabled&quot;:false,&quot;isKickstarter&quot;:false,&quot;isPremiun&quot;:false,&quot;gender&quot;:&quot;Male&quot;,&quot;nationality&quot;:&quot;None&quot;,&quot;type&quot;:&quot;admin&quot;,&quot;optMarketing&quot;:false,&quot;optNewsletter&quot;:false,&quot;cguValidated&quot;:true,&quot;providers&quot;:[],&quot;email&quot;:&quot;test@reflect.com&quot;,&quot;displayName&quot;:&quot;John Doe&quot;,&quot;phoneNumber&quot;:&quot;0644080050&quot;,&quot;homeAddress&quot;:{&quot;street&quot;:&quot;rue Pasteur&quot;,&quot;number&quot;:24,&quot;zipcode&quot;:94270,&quot;city&quot;:&quot;Le Kremlin-Bic&#234;tre&quot;,&quot;country&quot;:&quot;France&quot;},&quot;familyId&quot;:{&quot;$oid&quot;:&quot;5fc253c493b9f7363c8d1010&quot;},&quot;createdAt&quot;:{&quot;$date&quot;:&quot;2020-11-28T13:42:28.51Z&quot;},&quot;updatedAt&quot;:{&quot;$date&quot;:&quot;2020-11-28T13:42:28.51Z&quot;},&quot;__v&quot;:0}]\r\n\r\nYou can see that for keys like &quot;displayName&quot;, &quot;homeAddress.street&quot; or &quot;homeAddress.city&quot;, I&#39;ve got whitespaces in the values.\r\n\r\nWhen I try to store my newly exported collection into a classic variable using jq, and display it on the stdout, jq is acting quite strangely.\r\n\r\nScript executed:\r\n\r\n    #!/bin/bash\r\n    \r\n    documents=$(jq -c &quot;.[]&quot; ./mycollectionexported.json)\r\n    for document in $documents; do\r\n      echo &quot;&quot;\r\n      echo $document\r\n    done\r\n\r\nOutput:\r\n\r\n    {&quot;_id&quot;:{&quot;$oid&quot;:&quot;5fc253c493b9f7363c8d1011&quot;},&quot;emailVerified&quot;:true,&quot;disabled&quot;:false,&quot;isKickstarter&quot;:false,&quot;isPremiun&quot;:false,&quot;gender&quot;:&quot;Male&quot;,&quot;nationality&quot;:&quot;None&quot;,&quot;type&quot;:&quot;admin&quot;,&quot;optMarketing&quot;:false,&quot;optNewsletter&quot;:false,&quot;cguValidated&quot;:true,&quot;providers&quot;:[],&quot;email&quot;:&quot;test@reflect.com&quot;,&quot;displayName&quot;:&quot;John\r\n    \r\n    Doe&quot;,&quot;phoneNumber&quot;:&quot;0644080050&quot;,&quot;homeAddress&quot;:{&quot;street&quot;:&quot;rue\r\n    \r\n    Pasteur&quot;,&quot;number&quot;:24,&quot;zipcode&quot;:94270,&quot;city&quot;:&quot;Le\r\n    \r\n    Kremlin-Bic&#234;tre&quot;,&quot;country&quot;:&quot;France&quot;},&quot;familyId&quot;:{&quot;$oid&quot;:&quot;5fc253c493b9f7363c8d1010&quot;},&quot;createdAt&quot;:{&quot;$date&quot;:&quot;2020-11-28T13:42:28.51Z&quot;},&quot;updatedAt&quot;:{&quot;$date&quot;:&quot;2020-11-28T13:42:28.51Z&quot;},&quot;__v&quot;:0}\r\n\r\nExpected (no newlines):\r\n\r\n    {&quot;_id&quot;:{&quot;$oid&quot;:&quot;5fc253c493b9f7363c8d1011&quot;},&quot;emailVerified&quot;:true,&quot;disabled&quot;:false,&quot;isKickstarter&quot;:false,&quot;isPremiun&quot;:false,&quot;gender&quot;:&quot;Male&quot;,&quot;nationality&quot;:&quot;None&quot;,&quot;type&quot;:&quot;admin&quot;,&quot;optMarketing&quot;:false,&quot;optNewsletter&quot;:false,&quot;cguValidated&quot;:true,&quot;providers&quot;:[],&quot;email&quot;:&quot;test@reflect.com&quot;,&quot;displayName&quot;:&quot;John Doe&quot;,&quot;phoneNumber&quot;:&quot;0644080050&quot;,&quot;homeAddress&quot;:{&quot;street&quot;:&quot;rue Pasteur&quot;,&quot;number&quot;:24,&quot;zipcode&quot;:94270,&quot;city&quot;:&quot;Le Kremlin-Bic&#234;tre&quot;,&quot;country&quot;:&quot;France&quot;},&quot;familyId&quot;:{&quot;$oid&quot;:&quot;5fc253c493b9f7363c8d1010&quot;},&quot;createdAt&quot;:{&quot;$date&quot;:&quot;2020-11-28T13:42:28.51Z&quot;},&quot;updatedAt&quot;:{&quot;$date&quot;:&quot;2020-11-28T13:42:28.51Z&quot;},&quot;__v&quot;:0}\r\n\r\nHow is that possible ? \r\nThere is no such informations about that in the jq documentation.\r\nWhen I do it with a json file containing no whitespaces in string values, it works as expected...\r\n\r\nThank you for your help and futures answers :)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/65050988/iterating-over-output-of-jq-with-a-for-loop-in-bash",
        "title": "Iterating over output of jq with a for loop in bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "merge",
            "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": 1606619863,
                "post_id": 65055484,
                "comment_id": 115014497,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606680653,
                "last_edit_date": 1606680653,
                "creation_date": 1606619786,
                "answer_id": 65056687,
                "question_id": 65055484,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You haven&#39;t specified how the merge is to be performed, but one option would be to let the key-value pairs in the second file dominate.  In that case, you could write:\r\n```\r\njq -n &#39;\r\n  input as $one\r\n  | input as $two\r\n  | ($one + $two)\r\n  | .loggedTimes.steamids = ($one.loggedTimes.steamids + $two.loggedTimes.steamids)\r\n&#39;  1.json 2.json\r\n\r\n```\r\n\r\nWith your input, this produces output from which the following is an extract:\r\n```\r\n{\r\n  &quot;loggedTimes&quot;: {\r\n    &quot;steamids&quot;: {\r\n      &quot;76561197960277005&quot;: &quot;[DECOCO]koker_SZ&quot;,\r\n      &quot;76561197960436395&quot;: &quot;JOJO&quot;,\r\n      ...\r\n    },\r\n    &quot;vehicles&quot;: {\r\n      &quot;-1142039519&quot;: {\r\n        &quot;lapTimes&quot;: {}\r\n      },\r\n      &quot;-1201605905&quot;: {\r\n        &quot;lapTimes&quot;: {\r\n          &quot;76561197984026143&quot;: {\r\n            &quot;lapTime&quot;: 609101,\r\n            &quot;logtime&quot;: 1606516985,\r\n            &quot;name&quot;: &quot;Night Dick&quot;,\r\n            &quot;rank&quot;: 1,\r\n            &quot;refId&quot;: 36032,\r\n            &quot;vehicleId&quot;: -1201605905,\r\n            &quot;wet&quot;: 0\r\n          }\r\n        }\r\n      }\r\n     ...\r\n    }\r\n  }\r\n}\r\n```\r\n",
                "title": "Merging 2 json files into new json with no duplicates"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1606680653,
        "creation_date": 1606606221,
        "last_edit_date": 1606650914,
        "question_id": 65055484,
        "body_markdown": "My dedicated servers are generating 2 laptime arrays and I would like to use a script to merge them into a single, new json file, with duplicate &quot;steamids&quot; removed (and kept grouped together as they still are) and both arrays under a single loggedTimes {} (so I can feed it to a html script that produces laptimes and a leaderboard). In other words, I want the structure to remain.\r\nThe [first laptime file][1] and the [second laptime file][2] go through the following command\r\n```\r\njq &#39;reduce . as $item ({}; . * $item)&#39; laptimes_data_ams.json laptimes_data_kow.json &gt; laptimes.json\r\n```\r\nto then generate the (badly) [merged laptime file][3].\r\n I can get a file reduced but can&#39;t get any further than that. I checked threads by other around here and whenever I try their suggestions the script just refuses to work. Anybody available to lend me a hand in generating a working script to keep this final structure post-merge?\r\n```\r\n{\r\n&quot;loggedTimes&quot; : {\r\n    steamids&quot; : {\r\n        &quot;idnumber1&quot; : &quot;name1&quot;,\r\n        &quot;idnumber2&quot; : &quot;name2&quot;\r\n    },\r\n    &quot;vehicles&quot; : {\r\n        &quot;vehiclenumber1&quot; : {\r\n            &quot;laptimes&quot; : {\r\n                &quot;idnumber1&quot; : {\r\n                    &quot;lapTime&quot; : time1,\r\n                    &quot;logtime&quot; : log1,\r\n                    &quot;name&quot; : &quot;name 1&quot;,\r\n                    &quot;rank&quot; : rank1,\r\n                    &quot;refId&quot; : id1,\r\n                    &quot;vehicleid&quot; : vehiclenumber1,\r\n                    &quot;wet&quot; : 0\r\n                },\r\n                &quot;idnumber2&quot; : {\r\n                    &quot;lapTime&quot; : time2,\r\n                    &quot;logtime&quot; : log2,\r\n                    &quot;name&quot; : &quot;name 2&quot;,\r\n                    &quot;rank&quot; : rank2,\r\n                    &quot;refId&quot; : id2,\r\n                    &quot;vehicleid&quot; : vehiclenumber1,\r\n                    &quot;wet&quot; : 0                \r\n                }\r\n            }\r\n        }\r\n        &quot;vehiclesnumber2&quot; : {\r\n        //you get the idea by now\r\n        }\r\n    }\r\n}\r\n\r\n```\r\n  [1]: https://touristenfahrten.duckdns.org/laptimes_data_ams.json\r\n  [2]: https://touristenfahrten.duckdns.org/laptimes_data_kow.json\r\n  [3]: https://touristenfahrten.duckdns.org/laptimes.json",
        "link": "https://stackoverflow.com/questions/65055484/merging-2-json-files-into-new-json-with-no-duplicates",
        "title": "Merging 2 json files into new json with no duplicates"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1606741968,
                "post_id": 65073609,
                "comment_id": 115044579,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1606743122,
                "post_id": 65073609,
                "comment_id": 115045094,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606741641,
                "creation_date": 1606741641,
                "answer_id": 65074185,
                "question_id": 65073609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    aws rds ... | jq &#39;.PendingMaintenanceActions[].ResourceIdentifier + &quot;,&quot; + .PendingMaintenanceActions[].PendingMaintenanceActionDetails[].Action + &quot;,&quot; + .PendingMaintenanceActions[].PendingMaintenanceActionDetails[].CurrentApplyDate + &quot;,&quot; + .PendingMaintenanceActions[].PendingMaintenanceActionDetails[].Description&#39;\r\n\r\nNot sure which date is required but CurrentApplyDate can be changed if necessary",
                "title": "I am writing a bash script and I got stuck at a place where I am piping using the `jq` command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1606813670,
        "creation_date": 1606739318,
        "last_edit_date": 1606813670,
        "question_id": 65073609,
        "body_markdown": "My Input JSON:\r\n\r\n```\r\n{\r\n    &quot;PendingMaintenanceActions&quot;: [\r\n        {\r\n            &quot;ResourceIdentifier&quot;: &quot;arn:aws:rds:xxxxxx1230000345&quot;,\r\n            &quot;PendingMaintenanceActionDetails&quot;: [\r\n                {\r\n                    &quot;Action&quot;: &quot;hardware-maintenance&quot;,\r\n                    &quot;AutoAppliedAfterDate&quot;: &quot;2020-12-17T08:00:00Z&quot;,\r\n                    &quot;ForcedApplyDate&quot;: &quot;2020-12-18T13:00:00Z&quot;,\r\n                    &quot;CurrentApplyDate&quot;: &quot;2020-12-17T08:00:00Z&quot;,\r\n                    &quot;Description&quot;: &quot;Maintenance on the underlying hardware&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nRequired output:\r\n```\r\narn:aws:rds:xxxxxx1230000345,hardware-maintenance,2020-12-17T08:00:00Z,Maintenance on the underlying hardware\r\n```\r\n\r\nI tried a lot but no luck. Can someone help me to get the required output.\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/65073609/i-am-writing-a-bash-script-and-i-got-stuck-at-a-place-where-i-am-piping-using-th",
        "title": "I am writing a bash script and I got stuck at a place where I am piping using the `jq` command"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606743607,
                "creation_date": 1606743607,
                "answer_id": 65074669,
                "question_id": 65074442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n```\r\njq &#39;map(.Attributes |= map(if .Name == &quot;email&quot; then \r\n                             .Value = &quot;yahoo@gmail.com&quot;\r\n                           else \r\n                              .\r\n                           end))&#39; input.json\r\n```",
                "title": "using JQ to recursively replace a value for a specific name on a file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606753836,
                "creation_date": 1606753836,
                "answer_id": 65077416,
                "question_id": 65074442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I am trying to use JQ to recursively replace a value for a specific name on a file\r\n\r\nIf the emphasis is on *recursively*, you might wish to consider using `walk`:\r\n\r\n    walk(if type == &quot;object&quot;\r\n         and .Name == &quot;Email&quot; \r\n         and .Value == &quot;tpcohen45342@gmail.com&quot;\r\n         then .Value = &quot;yahoo@gmail.com&quot; else . end)\r\n",
                "title": "using JQ to recursively replace a value for a specific name on a file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1606753836,
        "creation_date": 1606742664,
        "question_id": 65074442,
        "body_markdown": "I am trying to use **JQ** to recursively  replace a value for a specific name on a file,\r\nI used JQ before to replaces values in a file but the current JSON file I have is not something that I am familiar with so I couldn&#39;t get it to work.\r\n\r\nWhat I need is to replace the value \r\n\r\n&gt; (&quot;Value&quot;: &quot;tpcohen45342@gmail.com&quot;)\r\n\r\n of every email with a dummy email (let&#39;s say *&quot;yahoo@gmail.com&quot;*),\r\non a JSON file looks like that:\r\n\r\n\r\n    [{\r\n    \t\t&quot;Username&quot;: &quot;a+123@zzz.com&quot;,\r\n    \t\t&quot;Attributes&quot;: [{\r\n    \t\t\t&quot;Name&quot;: &quot;sub&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;fa97fbc3-5916-4eca-bfed-e4b3468ad51c&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email_verified&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;true&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;name&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;NA reg&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;preferred_username&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;18796&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;a+123@zzz.com&quot;\r\n    \t\t}],\r\n    \t\t&quot;UserCreateDate&quot;: &quot;2020-07-01T09:23:33.586Z&quot;,\r\n    \t\t&quot;UserLastModifiedDate&quot;: &quot;2020-07-01T09:23:33.586Z&quot;,\r\n    \t\t&quot;Enabled&quot;: true,\r\n    \t\t&quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Username&quot;: &quot;thos.wsdalkiers@restorem.com&quot;,\r\n    \t\t&quot;Attributes&quot;: [{\r\n    \t\t\t&quot;Name&quot;: &quot;sub&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;5fd921e4-e3d8-4b34-b742-41006159e6b2&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email_verified&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;true&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;name&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;Thomas Walkiers (prod)&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;preferred_username&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;8375&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;thos.wsdalkiers@restorem.com&quot;\r\n    \t\t}],\r\n    \t\t&quot;UserCreateDate&quot;: &quot;2020-07-10T15:14:39.724Z&quot;,\r\n    \t\t&quot;UserLastModifiedDate&quot;: &quot;2020-07-10T15:14:39.724Z&quot;,\r\n    \t\t&quot;Enabled&quot;: true,\r\n    \t\t&quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Username&quot;: &quot;tpcohen4551@gmail.com&quot;,\r\n    \t\t&quot;Attributes&quot;: [{\r\n    \t\t\t&quot;Name&quot;: &quot;sub&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;5d6ff6d2-0ab8-4903-9a87-18f0c69c2282&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email_verified&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;true&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;name&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;Tal tal&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;preferred_username&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;24982&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;tpcohen4551@gmail.com&quot;\r\n    \t\t}],\r\n    \t\t&quot;UserCreateDate&quot;: &quot;2020-10-04T12:54:09.688Z&quot;,\r\n    \t\t&quot;UserLastModifiedDate&quot;: &quot;2020-11-23T14:03:06.034Z&quot;,\r\n    \t\t&quot;Enabled&quot;: true,\r\n    \t\t&quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Username&quot;: &quot;tpcohen45342@gmail.com&quot;,\r\n    \t\t&quot;Attributes&quot;: [{\r\n    \t\t\t&quot;Name&quot;: &quot;sub&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;216ec955-004f-4b5e-b978-0386f22b0029&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email_verified&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;true&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;name&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;Tal Yartal&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;preferred_username&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;27550&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;tpcohen45342@gmail.com&quot;\r\n    \t\t}],\r\n    \t\t&quot;UserCreateDate&quot;: &quot;2020-11-26T07:25:11.645Z&quot;,\r\n    \t\t&quot;UserLastModifiedDate&quot;: &quot;2020-11-26T07:27:59.648Z&quot;,\r\n    \t\t&quot;Enabled&quot;: true,\r\n    \t\t&quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Username&quot;: &quot;user.rndmgt@restorem.com&quot;,\r\n    \t\t&quot;Attributes&quot;: [{\r\n    \t\t\t&quot;Name&quot;: &quot;sub&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;d0b62a0d-2bc7-447a-af06-bebd68544307&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email_verified&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;true&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;name&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;c 1&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;preferred_username&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;13109&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;Name&quot;: &quot;email&quot;,\r\n    \t\t\t&quot;Value&quot;: &quot;user.rndmgt@restorem.com&quot;\r\n    \t\t}],\r\n    \t\t&quot;UserCreateDate&quot;: &quot;2020-06-22T15:59:50.944Z&quot;,\r\n    \t\t&quot;UserLastModifiedDate&quot;: &quot;2020-06-22T15:59:50.944Z&quot;,\r\n    \t\t&quot;Enabled&quot;: true,\r\n    \t\t&quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n    \t}\r\n    ]\r\n\r\nSo I will get a result of something looking like that:\r\n\r\n\r\n    [{\r\n    \r\n    \t&quot;Username&quot;: &quot;user.rndmgt@restorem.com&quot;,\r\n    \t&quot;Attributes&quot;: [{\r\n    \t\t&quot;Name&quot;: &quot;sub&quot;,\r\n    \t\t&quot;Value&quot;: &quot;d0b62a0d-2bc7-447a-af06-bebd68544307&quot;\r\n    \t}, {\r\n    \t\t&quot;Name&quot;: &quot;email_verified&quot;,\r\n    \t\t&quot;Value&quot;: &quot;true&quot;\r\n    \t}, {\r\n    \t\t&quot;Name&quot;: &quot;name&quot;,\r\n    \t\t&quot;Value&quot;: &quot;c 1&quot;\r\n    \t}, {\r\n    \t\t&quot;Name&quot;: &quot;preferred_username&quot;,\r\n    \t\t&quot;Value&quot;: &quot;13109&quot;\r\n    \t}, {\r\n    \t\t&quot;Name&quot;: &quot;email&quot;,\r\n    \t\t&quot;Value&quot;: &quot;yahoo@gmail.com&quot;\r\n    \t}],\r\n    \t&quot;UserCreateDate&quot;: &quot;2020-06-22T15:59:50.944Z&quot;,\r\n    \t&quot;UserLastModifiedDate&quot;: &quot;2020-06-22T15:59:50.944Z&quot;,\r\n    \t&quot;Enabled&quot;: true,\r\n    \t&quot;UserStatus&quot;: &quot;CONFIRMED&quot;\r\n    }]\r\n\r\nI appreciate the help, and sorry for not showing what I&#39;ve tried so far I mainly got JQ index errors",
        "link": "https://stackoverflow.com/questions/65074442/using-jq-to-recursively-replace-a-value-for-a-specific-name-on-a-file",
        "title": "using JQ to recursively replace a value for a specific name on a file"
    },
    {
        "tags": [
            "python",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606744309,
                "post_id": 65074812,
                "comment_id": 115045674,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19738075,
                    "reputation": 79,
                    "user_id": 14452078,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-zYrOyF_3YR8/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnlCCOpXVPxGULq_vomDB9OSM0Q_Q/s96-c/s256-rj/photo.jpg",
                    "display_name": "Stanley LEsniak",
                    "link": "https://stackoverflow.com/users/14452078/stanley-lesniak"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606744380,
                "post_id": 65074812,
                "comment_id": 115045712,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606744517,
                "post_id": 65074812,
                "comment_id": 115045781,
                "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": 1606754189,
                "post_id": 65074812,
                "comment_id": 115050547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19738075,
                    "reputation": 79,
                    "user_id": 14452078,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-zYrOyF_3YR8/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnlCCOpXVPxGULq_vomDB9OSM0Q_Q/s96-c/s256-rj/photo.jpg",
                    "display_name": "Stanley LEsniak",
                    "link": "https://stackoverflow.com/users/14452078/stanley-lesniak"
                },
                "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": 1606755344,
                "post_id": 65074812,
                "comment_id": 115051145,
                "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": 1606759612,
                "post_id": 65074812,
                "comment_id": 115053105,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606744628,
                "creation_date": 1606744628,
                "answer_id": 65074920,
                "question_id": 65074812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `subprocess` module:\r\n```\r\nimport subprocess\r\n\r\ncmd=[&quot;cat&quot;, &quot;json.txt&quot;, &quot;|&quot;, &quot;jq&quot;, &quot;&#39;.members[]&quot;, &quot;|&quot;, &quot;[.name]&quot;]\r\nresult = subprocess.check_output(cmd, shell=True)\r\n\r\nprint(result)",
                "title": "Using JQ in python like using it through cli"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1606759488,
                "creation_date": 1606759488,
                "answer_id": 65078827,
                "question_id": 65074812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After: `pip3 install pyjq`\r\n\r\nthe following runs without problems:\r\n```\r\nimport pyjq\r\nprint(pyjq.all( &quot;.members[] | [.name]&quot;, {&quot;members&quot;: [ {&quot;name&quot;: &quot;foo&quot;} ]} ))\r\n```\r\n\r\n## Output:\r\n    [[&#39;foo&#39;]]\r\n\r\n## Documentation\r\nThe documentation for pyjq is at https://pypi.org/project/pyjq/\r\n\r\nNote in particular the `url` optional argument. ",
                "title": "Using JQ in python like using it through cli"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653323294,
                "last_edit_date": 1653323294,
                "creation_date": 1653322754,
                "answer_id": 72351778,
                "question_id": 65074812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    import os\r\n    \r\n    sd = os.system(&#39;cat json.txt | jq &quot;.members[] | [.name]&quot;&#39;)\r\n    \r\n    print(sd)",
                "title": "Using JQ in python like using it through cli"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1703071430,
                "creation_date": 1703071430,
                "answer_id": 77691194,
                "question_id": 65074812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**There is an alternative JQ Python binding called [JQpy][1].** This one does not require user to compile anything hence simply works on Linux/Windows/e.t.c.\r\n\r\nInstallation\r\n------------\r\nLinux:\r\n```bash\r\nsudo apt-get update &amp;&amp; sudo apt-get install jq\r\npip install jqpy\r\n```\r\n\r\n[Windows][2]:\r\n```shell\r\nchoco install jq\r\npip install jqpy\r\n```\r\n\r\nExample\r\n-------\r\n\r\n```ipython\r\n&gt;&gt;&gt; from jqpy import jq\r\n&gt;&gt;&gt; jq(&#39;.results[] | {age, city}&#39;, {\r\n                &quot;timestamp&quot;: 1234567890,\r\n                &quot;report&quot;: &quot;Age Report&quot;,\r\n                &quot;results&quot;: [\r\n                        { &quot;name&quot;: &quot;John&quot;, &quot;age&quot;: 43, &quot;city&quot;: &quot;TownA&quot; },\r\n                        { &quot;name&quot;: &quot;Joe&quot;,  &quot;age&quot;: 10, &quot;city&quot;: &quot;TownB&quot; }\r\n                ]\r\n        })\r\n[{&#39;age&#39;: 43, &#39;city&#39;: &#39;TownA&#39;}, {&#39;age&#39;: 10, &#39;city&#39;: &#39;TownB&#39;}]\r\n```\r\n\r\n\r\n  [1]: https://baterflyrity.github.io/jqpy/\r\n  [2]: https://baterflyrity.github.io/jqpy/installation.html#installation",
                "title": "Using JQ in python like using it through cli"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 5,
        "last_activity_date": 1703071430,
        "creation_date": 1606744228,
        "last_edit_date": 1606764103,
        "question_id": 65074812,
        "body_markdown": "I have some cli commands that run through an api and then pass to jq like so\r\n\r\n```bash\r\ncat json.txt | jq &#39;.members[] | [.name] \r\n```\r\n\r\nBut now i am trying to do some logic in python and then pipe it out to jq, but i can&#39;t figure out how to do it even in a similar way to the above.\r\n\r\nI read through the documentation for jq module in python, but i just can&#39;t get it to work, can someone please help me out with this?",
        "link": "https://stackoverflow.com/questions/65074812/using-jq-in-python-like-using-it-through-cli",
        "title": "Using JQ in python like using it through cli"
    },
    {
        "tags": [
            "powershell",
            "escaping",
            "jq",
            "quoting"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606746015,
                "creation_date": 1606746015,
                "answer_id": 65075295,
                "question_id": 65074916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Powershell might want you to escape the double-quotes inside the `&#39;..&#39;` expression. Try\r\n\r\n```bash\r\njq --null-input &#39;{ &quot;key&quot;: \\&quot;val\\&quot; }&#39;\r\n```\r\n\r\nor just below as the key names in `jq` don&#39;t need an explicit quote\r\n\r\n```bash\r\njq --null-input &#39;{ key: \\&quot;val\\&quot; }&#39;\r\n```\r\n\r\nFrom the `jq` manual under - [Invoking jq][1]\r\n\r\n&gt; When using the Windows command shell (`cmd.exe`) it&#39;s best to use double quotes around your jq program when given on the command-line (instead of the `-f program-file` option), but then double-quotes in the jq program need backslash escaping.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "String literals in JQ using PowerShell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1606757508,
        "creation_date": 1606744612,
        "last_edit_date": 1606757452,
        "question_id": 65074916,
        "body_markdown": "I cannot get JQ string literals to work from Powershell.\r\nFor example, this outputs a pretty JSON object in Bash, but fails in Powershell:\r\n``` lang-none\r\nPS C:\\temp&gt; jq --null-input &#39;{&quot;key&quot;:&quot;val&quot;}&#39;\r\n\r\njq: error: val/0 is not defined at &lt;top-level&gt;, line 1:\r\n{key:val}\r\njq: 1 compile error\r\n```\r\nAt first I suspected incorrect quoting, but ```Write-Output &#39;{&quot;key&quot;:&quot;val&quot;}&#39;``` outputs ```{&quot;key&quot;:&quot;val&quot;}``` as I would expect.\r\n\r\nI can work around it by writing my JQ filter into a file. Using .NET ```WriteAllText``` ensures the file gets encoded as UTF-8 without BOM.\r\n``` lang-none\r\nPS C:\\temp&gt; [System.IO.File]::WriteAllText(&#39;basic.jq&#39;, &#39;{&quot;key&quot;:&quot;val&quot;}&#39;)\r\nPS C:\\temp&gt; jq --null-input --from-file basic.jq\r\n{\r\n  &quot;key&quot;: &quot;val&quot;\r\n}\r\n```\r\nI am looking for a more nimble approach for prototyping JQ filters and integrating them in PowerShell scripts.\r\n\r\nVersions: JQ 1.6 for win64, PSVersion 5.1.18362.1171",
        "link": "https://stackoverflow.com/questions/65074916/string-literals-in-jq-using-powershell",
        "title": "String literals in JQ using PowerShell"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "append",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607005076,
                "last_edit_date": 1607005076,
                "creation_date": 1606830208,
                "answer_id": 65091652,
                "question_id": 65090702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To append the object, you can use the idiom:\r\n\r\n    .profiles += [...]\r\n\r\nBecause of the friendly way jq handles `null`, the above will also work initially.\r\n\r\nIncidentally, you can abbreviate key-value pairs such as\r\n\r\n    &quot;name&quot;: $name\r\n\r\nto just the variable name: \r\n\r\n    $name\r\n\r\n\r\n## Example\r\nFor the sake of uniformity, it might make sense to prepopulate model.json with `null`, e.g.\r\n\r\n    echo null &gt; model.json\r\n\r\nThen you can invoke jq uniformly (without the -n option), e.g.\r\n\r\n```\r\njq --arg name &quot;$name&quot; --arg car &quot;$car&quot; --arg colour &quot;$colour&quot; &#39;\r\n  .profiles += [{ $name, $car, $colour}]\r\n&#39; model.json | sponge model.json\r\n```\r\n\r\nCaveat: overwriting the input file using `sponge` without taking precautions has its risks, though in this case they would seem to be small.\r\n",
                "title": "Adding/appending objects to a newly created json array with same keys via jq in bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606860181,
                "last_edit_date": 1606860181,
                "creation_date": 1606842377,
                "answer_id": 65095098,
                "question_id": 65090702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Utilised the method above and still does not append:\r\nie.\r\n```\r\nEnter name:\r\nJoe\r\nEnter Car Model:\r\nBMW\r\nEnter Colour:\r\nBlue\r\n\r\nAdd a new entry? (y/n):  y\r\nEnter name:  \r\nPaul\r\nEnter Car Model:  \r\nNissan\r\nEnter Colour:  \r\nBlack\r\n\r\nAdd a new entry? (y/n):  n\r\n\r\n\r\n\r\n{\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Paul&quot;,\r\n      &quot;car&quot;: &quot;Nissan&quot;,\r\n      &quot;colour&quot;: &quot;Black&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "Adding/appending objects to a newly created json array with same keys via jq in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1607005076,
        "creation_date": 1606826545,
        "last_edit_date": 1606827743,
        "question_id": 65090702,
        "body_markdown": "I am having a real hard time in attempting to iteratively append new values over a newly created JSON array/file from the same bash script.\r\nConsider the following simple script snippet:\r\n\r\n```\r\necho &quot;Enter name: &quot;\r\nread name\r\necho &quot;Enter Car Model: &quot;\r\nread car\r\necho &quot;Enter Colour: &quot;\r\nread colour\r\n\r\necho\r\njq -n --arg name &quot;$name&quot; --arg car &quot;$car&quot; --arg colour &quot;$colour&quot; &#39;{&quot;profiles&quot;:[{&quot;name&quot;: $name, &quot;car&quot;: $car, &quot;colour&quot;: $colour}]}&#39; &gt; model.json\r\necho\r\ncat model.json | jq .\r\n```\r\nThis outputs:\r\n```\r\nEnter name:\r\nJoe\r\nEnter Car Model:\r\nBMW\r\nEnter Colour:\r\nRed\r\n\r\n{\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;car&quot;: &quot;BMW&quot;,\r\n      &quot;colour&quot;: &quot;Red&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nWhat I want it to eventually do is something like this, dynamically:\r\n```\r\nEnter name:\r\nJoe\r\nEnter Car Model:\r\nBMW\r\nEnter Colour:\r\nRed\r\n\r\n{\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;car&quot;: &quot;BMW&quot;,\r\n      &quot;colour&quot;: &quot;Red&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Peter&quot;,\r\n      &quot;car&quot;: &quot;Nissan&quot;,\r\n      &quot;colour&quot;: &quot;White&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\netc...\r\n\r\nI understand I&#39;ll need to utilise a loop after the first set of key:value entries, but then how would I append to the newly created model.json file as opposed to overriding the initial values via jq in a bash script?\r\n\r\n\r\nMany Thanks",
        "link": "https://stackoverflow.com/questions/65090702/adding-appending-objects-to-a-newly-created-json-array-with-same-keys-via-jq-in",
        "title": "Adding/appending objects to a newly created json array with same keys via jq in bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606845561,
                "post_id": 65095500,
                "comment_id": 115083669,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1606847476,
                "last_edit_date": 1606847476,
                "creation_date": 1606846688,
                "answer_id": 65096228,
                "question_id": 65095500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to make such a flat object JSON to a TSV format, using the `@tsv` function would be to do\r\n\r\n```jq\r\njq -n &#39; [&quot;location&quot;, &quot;timestamp&quot;, &quot;src_ip&quot;, &quot;dest_ip&quot;, &quot;dest_port&quot;] as $hdr | \r\n        $hdr, ( inputs | [ .[ $hdr[] ] ] ) | @tsv&#39;\r\n```\r\n\r\nThis works, by reusing the key fields as in the header, `.[ $hdr[] ]` is a simple trick to expand values of each of the literal fields in the `hdr` array to their corresponding values in the object (see [Generic Object Index][1]). By surrounding it in the brackets, you get the selected field values in an array. With this array collected and the header array, apply the `@tsv` function to get the tabular form.\r\n\r\n[jq play snippet - Demo][2]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#GenericObjectIndex:.[%3Cstring%3E]\r\n  [2]: https://jqplay.org/s/x3eHtqM1M-",
                "title": "Convert a flat JSON to a TSV file with column headers"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1606847587,
        "creation_date": 1606843912,
        "last_edit_date": 1606847587,
        "question_id": 65095500,
        "body_markdown": "I am reformatting some JSON with JQ into a TSV file.  I am able to create a TSV with the values only, but I cannot figure out how to include a single row with the key values as column headers?\r\n\r\nSample input:\r\n\r\n    {\r\n\t&quot;id&quot;:&quot;1234&quot;,\r\n\t&quot;host&quot;:&quot;6789&quot;,\r\n\t&quot;proto&quot;:&quot;UDP&quot;,\r\n\t&quot;location&quot;:&quot;Boston&quot;,\r\n\t&quot;timestamp&quot;:&quot;2020-12-01T14:18:45.717Z&quot;,\r\n\t&quot;src_ip&quot;:&quot;192.168.3.70&quot;,\r\n\t&quot;dest_ip&quot;:&quot;8.8.8.8&quot;,\r\n\t&quot;dest_port&quot;:53,\r\n\t&quot;message&quot;:&quot;Some Information&quot;,\r\n\t&quot;severity&quot;:1,\r\n\t&quot;details&quot;:&quot;Some Details&quot;,\r\n\t&quot;categories&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n    }\r\n\r\nDesired output:\r\n\r\n    &quot;location\\ttimestamp\\tsrc_ip\\tdest_ip\\tdest_port&quot;\r\n    &quot;Boston\\t2020-12-01T15:13:16.242Z\\t10.8.25.63\\t10.8.1.3\\t445&quot;\r\n    &quot;Atlanta\\t2020-12-01T15:11:15.929Z\\t10.8.25.63\\t10.80.1.3\\t445&quot;\r\n    &quot;Chicago\\t2020-12-01T15:09:45.271Z\\t10.34.196.12\\t10.8.1.3\\t445&quot;\r\n\r\n\r\n\r\nThis statement gets me close:\r\n\r\n    cat input.json | jq  &#39;. | to_entries \r\n    | map(select(.key==&quot;timestamp&quot;), select(.key==&quot;location&quot;), select(.key==&quot;src_ip&quot;), select(.key==&quot;dest_ip&quot;), select(.key==&quot;dest_port&quot;))\r\n    | map(.key), map(.value) \r\n    | @tsv&#39;\r\n\r\nBut the header line is repeated in the output:\r\n\r\n    &quot;location\\ttimestamp\\tsrc_ip\\tdest_ip\\tdest_port&quot;\r\n    &quot;Boston\\t2020-12-01T15:13:16.242Z\\t10.8.25.63\\t10.8.1.3\\t445&quot;\r\n    &quot;location\\ttimestamp\\tsrc_ip\\tdest_ip\\tdest_port&quot;\r\n    &quot;Atlanta\\t2020-12-01T15:11:15.929Z\\t10.8.25.63\\t10.80.1.3\\t445&quot;\r\n\r\nIs there a way to print the keys on the first row only, and then print only the values on the remaining rows, using only JQ?\r\n",
        "link": "https://stackoverflow.com/questions/65095500/convert-a-flat-json-to-a-tsv-file-with-column-headers",
        "title": "Convert a flat JSON to a TSV file with column headers"
    },
    {
        "tags": [
            "arrays",
            "json",
            "list",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606892157,
                "creation_date": 1606892157,
                "answer_id": 65103506,
                "question_id": 65103269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `select(expr)` to find the object with a key-value `&quot;k&quot;:&quot;bar&quot;` and then you can extract the value of the `&quot;v&quot;` key.\r\n\r\n```bash\r\n$ jq . test.json \r\n[\r\n  {\r\n    &quot;k&quot;: &quot;foo&quot;,\r\n    &quot;v&quot;: 1\r\n  },\r\n  {\r\n    &quot;k&quot;: &quot;bar&quot;,\r\n    &quot;v&quot;: 2\r\n  }\r\n]\r\n\r\n$ jq -r &#39;.[] | select(.k == &quot;bar&quot;) | .v&#39; test.json\r\n2\r\n```",
                "title": "How to get value for key in JSON list of {&quot;k&quot;:foo, &quot;v&quot;:bar} items using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1606892776,
        "creation_date": 1606890667,
        "question_id": 65103269,
        "body_markdown": "Suppose I have this JSON:\r\n```\r\n[\r\n    {\r\n        &quot;k&quot;: foo,\r\n        &quot;v&quot;: 1\r\n    },\r\n    {\r\n        &quot;k&quot;: bar,\r\n        &quot;v&quot;: 2\r\n    }\r\n]\r\n```\r\n\r\nHow to get the value for the `&quot;bar&quot;` key?\r\n",
        "link": "https://stackoverflow.com/questions/65103269/how-to-get-value-for-key-in-json-list-of-kfoo-vbar-items-using-jq",
        "title": "How to get value for key in JSON list of {&quot;k&quot;:foo, &quot;v&quot;:bar} items using jq?"
    },
    {
        "tags": [
            "json",
            "slice",
            "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": 1606917601,
                "post_id": 65109169,
                "comment_id": 115107963,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19763508,
                    "reputation": 5,
                    "user_id": 14749318,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb89fee8eb57e4223897c94b0e0c2a7d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abhinav Gupta",
                    "link": "https://stackoverflow.com/users/14749318/abhinav-gupta"
                },
                "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": 1606991205,
                "post_id": 65109169,
                "comment_id": 115133839,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1606917922,
                "creation_date": 1606917922,
                "answer_id": 65109666,
                "question_id": 65109169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.reference_data[0:5]` produces a slice, i.e. an array, so in your query, you would need to itemize it, e.g. by appending []:\r\n\r\n    .reference_data[0:5][]",
                "title": "not able to successfully slice a json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1606917922,
        "creation_date": 1606916161,
        "question_id": 65109169,
        "body_markdown": "I try to slice the json file but it&#39;s giving me the error:\r\n\r\n**jq: error (at result2.json:0): Cannot index array with string &quot;url&quot;**\r\n\r\nI am trying to parse the following json file\r\n\r\n[code ss][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/z54AJ.png\r\n\r\nI want to access six reference links from this list. I tried using the following code but it&#39;s giving me an error.\r\n\r\n\r\n**jq -r .result.CVE_Items[].cve.references.reference_data[0:5].url result2.json**\r\n\r\nI am fairly new to json parsing so i am having a tough time overcoming these issues :(",
        "link": "https://stackoverflow.com/questions/65109169/not-able-to-successfully-slice-a-json-file-with-jq",
        "title": "not able to successfully slice a json file with jq"
    },
    {
        "tags": [
            "regex",
            "jq",
            "pcre"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1882525,
                    "reputation": 455,
                    "user_id": 1702373,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/6d6cef487cffcea43b289858858a608f?s=256&d=identicon&r=PG",
                    "display_name": "Jon Cohen",
                    "link": "https://stackoverflow.com/users/1702373/jon-cohen"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606927733,
                "post_id": 65111840,
                "comment_id": 115113284,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1606932484,
                "last_edit_date": 1606932484,
                "creation_date": 1606930400,
                "answer_id": 65113223,
                "question_id": 65111840,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a basic JQ. Haven&#39;t tried with complex inputs, and haven&#39;t accommodated for `$`. I guess you can build on top of this -\r\n\r\n```\r\nto_entries | map(. as $kv | { &quot;\\($kv.key)&quot;: $kv.value.placeholders | to_entries | map(. as $p | $kv.value.message | sub(&quot;\\\\$\\($p.key)\\\\$&quot;; $p.value.content))[0]}) | add \r\n```\r\n\r\n\r\noutput -\r\n\r\n\r\n```\r\n{\r\n  &quot;some_label&quot;: &quot;a string in English with a {variable}&quot;\r\n}\r\n```",
                "title": "How to use a capture variable as a field name in JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606932792,
                "last_edit_date": 1606932792,
                "creation_date": 1606932469,
                "answer_id": 65113738,
                "question_id": 65111840,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way of achieving the desired result. It could be simplified further too. At the top level it removes the usage of `to_entries`/`from_entries` by enclosing the whole filter under `with_entries()` and modifying the `.value` field as required\r\n\r\n```jq\r\nwith_entries(\r\n  .key |= ( gsub(&quot;_&quot;;&quot;-&quot;) )  |\r\n  .value.placeholders as $p  |\r\n  .value.message as $m       |\r\n  ( $m | match(&quot;.*\\\\$(.*)\\\\$&quot;) | .captures[0].string ) as $c |\r\n  ( $p | .[$c].content ) as $v |\r\n  ( &quot;\\\\$&quot; + $c + &quot;\\\\$&quot; ) as $t     |\r\n  .value = ( $m | sub($t; $v) )\r\n)\r\n```\r\nMy view of the key parts of the expression are \r\n\r\n 1. The part `$m | match(&quot;.*\\\\$(.*)\\\\$&quot;) | .captures[0].string` makes a regex match to extract the part within the `$..$` in the `.message`\r\n 2. The part `$p | .[$c].content` does a generic object index fetch using the dynamic value of `$c`\r\n 3. Since the first argument of `sub()`/`gsub()` functions are a regex, the value captured `$c` needs to be created as `\\\\$VARIABLE\\\\$`\r\n\r\n[jqplay - Demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/JCQVo3IMB1",
                "title": "How to use a capture variable as a field name in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1606934876,
        "creation_date": 1606925450,
        "last_edit_date": 1606934876,
        "question_id": 65111840,
        "body_markdown": "I&#39;m trying to use `jq` to automate changing i18n string files from the format taken by one library to another.\r\n\r\nI have a json file which has looks like this:\r\n\r\n```\r\n{\r\n  &quot;some_label&quot;: {\r\n    &quot;message&quot;: &quot;a string in English with a $VARIABLE$&quot;,\r\n    &quot;description&quot;: &quot;directions to translators&quot;,\r\n    &quot;placeholders&quot;: {\r\n      &quot;VARIABLE&quot;: {\r\n        &quot;content&quot;: &quot;{variable}&quot;\r\n      }\r\n    }\r\n  },\r\n  // more of the same...\r\n}\r\n```\r\n\r\nAnd I need that to turn in to `&quot;some-label&quot;: &quot;a string in English with a {variable}&quot;`\r\n\r\nI am pretty close to getting it.  Currently, I&#39;m using\r\n```\r\njq &#39;[.                                                                                                                                                                            \r\n    | to_entries \r\n    | .[] \r\n    | .key |= (gsub(&quot;_&quot;;&quot;-&quot;)) \r\n    |  .value.placeholders as $p \r\n    | .value.message |= (sub(&quot;\\\\$KEY_NAME\\\\$&quot;;$p.KEY_NAME.content)) \r\n    | .value = .value.message\r\n   ] | from_entries&#39;\r\n```\r\n\r\nThe next step is to use a capture group in the `sub` call so I can programmatically get variables with different names, but I&#39;m not sure how to use the capture group to index into `$p`.\r\n\r\nI&#39;ve tried `sub(&quot;\\\\$(?&lt;id&gt;VARIABLE)\\\\$&quot;;$p.(.id).content)` which gave a compiler error, and I&#39;m pretty much stuck on what to try next.",
        "link": "https://stackoverflow.com/questions/65111840/how-to-use-a-capture-variable-as-a-field-name-in-jq",
        "title": "How to use a capture variable as a field name in JQ?"
    },
    {
        "tags": [
            "json",
            "string",
            "replace",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1606954246,
                "last_edit_date": 1606954246,
                "creation_date": 1606929002,
                "answer_id": 65112851,
                "question_id": 65112659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.DATA |= map(\r\n            if .DOMAIN == &quot;domain1.com&quot;\r\n            then .DOMAIN_DISABLE = true\r\n            else .\r\n            end)&#39; file.json",
                "title": "JQ: replace an array element, based on subelement value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1606945555,
                "last_edit_date": 1606945555,
                "creation_date": 1606942484,
                "answer_id": 65115995,
                "question_id": 65112659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.DATA |= map((.DOMAIN == &quot;domain1.com&quot;) as $disable | .DOMAIN_DISABLE |= $disable)\r\n```\r\n\r\nThis will change `.DATA` whilst keeping everything else in place. Same for each `.DOMAIN_DISABLE` to which we assign the result of  `.DOMAIN==&quot;domain1.com&quot;`.",
                "title": "JQ: replace an array element, based on subelement value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644183209,
                "creation_date": 1644183209,
                "answer_id": 71011877,
                "question_id": 65112659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach that simply assigns `true` to a `select`ed set of targets. This works (the original object remains in context) because the selection (on the left-hand side) happens in a subcontext (in parentheses) while the assignment itself is still part of the top-level context.\r\n~~~sh\r\njq &#39;(.DATA[] | select(.DOMAIN == &quot;domain1.com&quot;)).DOMAIN_DISABLE = true&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/ig4NgYQDcT)",
                "title": "JQ: replace an array element, based on subelement value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1644183209,
        "creation_date": 1606928281,
        "last_edit_date": 1606941713,
        "question_id": 65112659,
        "body_markdown": "I want to modify the value of `DOMAIN_DISABLE` to true if `DOMAIN` equals `domain1.com`\r\n\r\n```bash\r\njq &#39;if .DATA[].DOMAIN == &quot;domain1.com&quot; then .DATA[].DOMAIN_DISABLE = true else . end&#39; &quot;${Json}&quot;\r\n```\r\n\r\nJson Array:\r\n\r\n```json\r\n{\r\n    &quot;ACTION&quot;: &quot;domain.list&quot;,\r\n    &quot;DATA&quot;: [\r\n        {\r\n            &quot;TYPE&quot;: &quot;slave&quot;,\r\n            &quot;AXFR_IPS&quot;: &quot;none&quot;,\r\n            &quot;DOMAIN&quot;: &quot;domain1.com&quot;,\r\n            &quot;TTL_SEC&quot;: 0,\r\n            &quot;SOA_EMAIL&quot;: &quot;&quot;,\r\n            &quot;DOMAINID&quot;: 11111,\r\n            &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n            &quot;EXPIRE_SEC&quot;: 0,\r\n            &quot;RETRY_SEC&quot;: 0,\r\n            &quot;STATUS&quot;: 1,\r\n            &quot;DOMAIN_DISABLE&quot;: false,\r\n            &quot;LPM_DISPLAYGROUP&quot;: &quot;&quot;,\r\n            &quot;REFRESH_SEC&quot;: 0\r\n        },\r\n        {\r\n            &quot;TYPE&quot;: &quot;slave&quot;,\r\n            &quot;AXFR_IPS&quot;: &quot;none&quot;,\r\n            &quot;DOMAIN&quot;: &quot;domain2.net&quot;,\r\n            &quot;TTL_SEC&quot;: 0,\r\n            &quot;SOA_EMAIL&quot;: &quot;&quot;,\r\n            &quot;DOMAINID&quot;: 22222,\r\n            &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n            &quot;EXPIRE_SEC&quot;: 0,\r\n            &quot;RETRY_SEC&quot;: 0,\r\n            &quot;STATUS&quot;: 1,\r\n            &quot;DOMAIN_DISABLE&quot;: false,\r\n            &quot;LPM_DISPLAYGROUP&quot;: &quot;&quot;,\r\n            &quot;REFRESH_SEC&quot;: 0\r\n        },\r\n        {\r\n            &quot;TYPE&quot;: &quot;slave&quot;,\r\n            &quot;AXFR_IPS&quot;: &quot;none&quot;,\r\n            &quot;DOMAIN&quot;: &quot;domain3.edu&quot;,\r\n            &quot;TTL_SEC&quot;: 0,\r\n            &quot;SOA_EMAIL&quot;: &quot;&quot;,\r\n            &quot;DOMAINID&quot;: 33333,\r\n            &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n            &quot;EXPIRE_SEC&quot;: 0,\r\n            &quot;RETRY_SEC&quot;: 0,\r\n            &quot;STATUS&quot;: 1,\r\n            &quot;DOMAIN_DISABLE&quot;: true,\r\n            &quot;LPM_DISPLAYGROUP&quot;: &quot;&quot;,\r\n            &quot;REFRESH_SEC&quot;: 0\r\n        }\r\n    ],\r\n    &quot;ERRORARRAY&quot;: []\r\n}\r\n```\r\n\r\nDesired output:\r\n\r\n```json\r\n{\r\n    &quot;ACTION&quot;: &quot;domain.list&quot;,\r\n    &quot;DATA&quot;: [\r\n        {\r\n            &quot;TYPE&quot;: &quot;slave&quot;,\r\n            &quot;AXFR_IPS&quot;: &quot;none&quot;,\r\n            &quot;DOMAIN&quot;: &quot;domain1.com&quot;,\r\n            &quot;TTL_SEC&quot;: 0,\r\n            &quot;SOA_EMAIL&quot;: &quot;&quot;,\r\n            &quot;DOMAINID&quot;: 11111,\r\n            &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n            &quot;EXPIRE_SEC&quot;: 0,\r\n            &quot;RETRY_SEC&quot;: 0,\r\n            &quot;STATUS&quot;: 1,\r\n            &quot;DOMAIN_DISABLE&quot;: true,\r\n            &quot;LPM_DISPLAYGROUP&quot;: &quot;&quot;,\r\n            &quot;REFRESH_SEC&quot;: 0\r\n        },\r\n        {\r\n            &quot;TYPE&quot;: &quot;slave&quot;,\r\n            &quot;AXFR_IPS&quot;: &quot;none&quot;,\r\n            &quot;DOMAIN&quot;: &quot;domain2.net&quot;,\r\n            &quot;TTL_SEC&quot;: 0,\r\n            &quot;SOA_EMAIL&quot;: &quot;&quot;,\r\n            &quot;DOMAINID&quot;: 22222,\r\n            &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n            &quot;EXPIRE_SEC&quot;: 0,\r\n            &quot;RETRY_SEC&quot;: 0,\r\n            &quot;STATUS&quot;: 1,\r\n            &quot;DOMAIN_DISABLE&quot;: false,\r\n            &quot;LPM_DISPLAYGROUP&quot;: &quot;&quot;,\r\n            &quot;REFRESH_SEC&quot;: 0\r\n        },\r\n        {\r\n            &quot;TYPE&quot;: &quot;slave&quot;,\r\n            &quot;AXFR_IPS&quot;: &quot;none&quot;,\r\n            &quot;DOMAIN&quot;: &quot;domain3.edu&quot;,\r\n            &quot;TTL_SEC&quot;: 0,\r\n            &quot;SOA_EMAIL&quot;: &quot;&quot;,\r\n            &quot;DOMAINID&quot;: 33333,\r\n            &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n            &quot;EXPIRE_SEC&quot;: 0,\r\n            &quot;RETRY_SEC&quot;: 0,\r\n            &quot;STATUS&quot;: 1,\r\n            &quot;DOMAIN_DISABLE&quot;: true,\r\n            &quot;LPM_DISPLAYGROUP&quot;: &quot;&quot;,\r\n            &quot;REFRESH_SEC&quot;: 0\r\n        }\r\n    ],\r\n    &quot;ERRORARRAY&quot;: []\r\n}\r\n```\r\n\r\nwhat should I change in my jq command?\r\n",
        "link": "https://stackoverflow.com/questions/65112659/jq-replace-an-array-element-based-on-subelement-value",
        "title": "JQ: replace an array element, based on subelement value"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606981368,
                "post_id": 65121675,
                "comment_id": 115129542,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5703721,
                    "reputation": 881,
                    "user_id": 4507949,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/PruDR.png?s=256",
                    "display_name": "rathindu_w",
                    "link": "https://stackoverflow.com/users/4507949/rathindu-w"
                },
                "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": 1606981673,
                "post_id": 65121675,
                "comment_id": 115129655,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5703721,
                    "reputation": 881,
                    "user_id": 4507949,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/PruDR.png?s=256",
                    "display_name": "rathindu_w",
                    "link": "https://stackoverflow.com/users/4507949/rathindu-w"
                },
                "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": 1606981689,
                "post_id": 65121675,
                "comment_id": 115129662,
                "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": 1606981952,
                "post_id": 65121675,
                "comment_id": 115129762,
                "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": 1606981966,
                "post_id": 65121675,
                "comment_id": 115129770,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5703721,
                    "reputation": 881,
                    "user_id": 4507949,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/PruDR.png?s=256",
                    "display_name": "rathindu_w",
                    "link": "https://stackoverflow.com/users/4507949/rathindu-w"
                },
                "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": 1606984891,
                "post_id": 65121675,
                "comment_id": 115130922,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 182974,
                    "reputation": 6375,
                    "user_id": 418066,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/38yuw.png?s=256",
                    "display_name": "Biffen",
                    "link": "https://stackoverflow.com/users/418066/biffen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1606986405,
                "post_id": 65121675,
                "comment_id": 115131595,
                "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": 1607012115,
                "post_id": 65121675,
                "comment_id": 115144093,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1606991157,
                "last_edit_date": 1606991157,
                "creation_date": 1606986704,
                "answer_id": 65122885,
                "question_id": 65121675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "  Convert the field value from integer to number with tonumber and so:  \r\n\r\n    readarray data &lt;&lt;&lt; &quot;$(jq -r &#39;.bestMatches[] | select(.&quot;9. matchScore&quot; | tonumber &gt; 0.5) | .&quot;1. symbol&quot;&#39; jq)&quot;\r\n\r\nRedirect the output of the jq command into readarray to create an array.",
                "title": "Shell Script Assigning json object to an variable for iteration"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1606991157,
        "creation_date": 1606981156,
        "last_edit_date": 1606984847,
        "question_id": 65121675,
        "body_markdown": "```\r\nDATA=&quot;$(curl &quot;https://www.alphavantage.co/query?function=SYMBOL_SEARCH&amp;keywords=BA&amp;apikey=demo&quot; | jq &#39;.bestMatches&#39; | jq &#39;.[] | .&quot;1. symbol&quot;&#39;)&quot;\r\n```\r\nI want to iterate over DATA variable which would ideally be an array. What I want to do here is two fold.\r\n1. I need a way to select the &quot;1. symbol&quot; attribute of all the records which have a &quot;matchScore&quot; greater than 0.5. This is a problematic thing for me to do since the matchScore contains a string, not a number.\r\n2. I want to store the selected &quot;1. Symbol&quot; attributes in a variable which I can iterate over later to do more operations.  \r\n\r\n```\r\n{\r\n  &quot;bestMatches&quot;: [\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BA&quot;,\r\n      &quot;2. name&quot;: &quot;The Boeing Company&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;1.0000&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BAC&quot;,\r\n      &quot;2. name&quot;: &quot;Bank of America Corporation&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.8000&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BABA&quot;,\r\n      &quot;2. name&quot;: &quot;Alibaba Group Holding Limited&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.6667&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;GOLD&quot;,\r\n      &quot;2. name&quot;: &quot;Barrick Gold Corporation&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.5714&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BIDU&quot;,\r\n      &quot;2. name&quot;: &quot;Baidu Inc.&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.5000&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BAYRY&quot;,\r\n      &quot;2. name&quot;: &quot;Bayer Aktiengesellschaft&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.4000&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BLDP&quot;,\r\n      &quot;2. name&quot;: &quot;Ballard Power Systems Inc.&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.3333&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BHC&quot;,\r\n      &quot;2. name&quot;: &quot;Bausch Health Companies Inc.&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.3333&quot;\r\n    },\r\n    {\r\n      &quot;1. symbol&quot;: &quot;BK&quot;,\r\n      &quot;2. name&quot;: &quot;The Bank of New York Mellon Corporation&quot;,\r\n      &quot;3. type&quot;: &quot;Equity&quot;,\r\n      &quot;4. region&quot;: &quot;United States&quot;,\r\n      &quot;5. marketOpen&quot;: &quot;09:30&quot;,\r\n      &quot;6. marketClose&quot;: &quot;16:00&quot;,\r\n      &quot;7. timezone&quot;: &quot;UTC-05&quot;,\r\n      &quot;8. currency&quot;: &quot;USD&quot;,\r\n      &quot;9. matchScore&quot;: &quot;0.1538&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nThe above is the json object I get.",
        "link": "https://stackoverflow.com/questions/65121675/shell-script-assigning-json-object-to-an-variable-for-iteration",
        "title": "Shell Script Assigning json object to an variable for iteration"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607005240,
                "post_id": 65127096,
                "comment_id": 115140341,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20122048,
                    "reputation": 3,
                    "user_id": 14756372,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiedSRCemUoADv5IGrMDi4t7Jbwa43-mHuLGrJd6Q=k-s256",
                    "display_name": "Blažej Farkaš",
                    "link": "https://stackoverflow.com/users/14756372/bla%c5%beej-farka%c5%a1"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607006046,
                "post_id": 65127096,
                "comment_id": 115140755,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1607005445,
                "creation_date": 1607005445,
                "answer_id": 65127826,
                "question_id": 65127096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure what output you expect. Does this work for you?\r\n\r\n    jq -r &#39;[\r\n        .report.moduleReports.COMPLIANCE.items[]\r\n        | select(.requirementSourceType==&quot;CIS&quot;)\r\n        | [.complianceId, .title, .status]\r\n    ] | unique | .[] | @csv&#39; report.json",
                "title": "jq: error (at report.json:32): Cannot index string with string &quot;complianceId&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607005726,
        "creation_date": 1607002734,
        "last_edit_date": 1607005726,
        "question_id": 65127096,
        "body_markdown": "I am trying to parse CSV output from json file through jq.\r\n\r\nJson looks like this:\r\n\r\n```json\r\n{\r\n\t&quot;report&quot;: {\r\n\t\t&quot;id&quot;: &quot;xxx-xxxxx-xxxx&quot;,\r\n\t\t&quot;machineId&quot;: &quot;xxx-xxxxx-xxxx&quot;,\r\n\t\t&quot;scanDate&quot;: &quot;2020-12-03T09:11:28Z&quot;,\r\n\t\t&quot;moduleReports&quot;: {\r\n\t\t\t&quot;COMPLIANCE&quot;: {\r\n\t\t\t\t&quot;complianceCheckVersion&quot;: &quot;1.3.1&quot;,\r\n\t\t\t\t&quot;items&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;complianceId&quot;: &quot;Report_ID1&quot;,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Title of Report ID1&quot;,\r\n\t\t\t\t\t\t&quot;status&quot;: &quot;FULFILLED&quot;,\r\n\t\t\t\t\t\t&quot;requirementSourceType&quot;: &quot;ABC&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;complianceId&quot;: &quot;Report_ID2&quot;,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Title of Report ID2&quot;,\r\n\t\t\t\t\t\t&quot;status&quot;: &quot;FULFILLED&quot;,\r\n\t\t\t\t\t\t&quot;requirementSourceType&quot;: &quot;ABC&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;complianceId&quot;: &quot;Report_ID3&quot;,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Title of Report ID3&quot;,\r\n\t\t\t\t\t\t&quot;status&quot;: &quot;FULFILLED&quot;,\r\n\t\t\t\t\t\t&quot;requirementSourceType&quot;: &quot;DEF&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nI would like to parse so only results with **key** *requirementSourceType* and **value** is only *ABC*. *DEF* should be filtered out.\r\n\r\nWith filtering there is not a problem, currently it is done with this command:\r\n\r\n```bash\r\njq -r &#39;.report | .moduleReports | .COMPLIANCE | .items[] | select(.requirementSourceType==&quot;CIS&quot;)&#39; report.json\r\n```\r\n\r\nBut, when I am trying to do an unique columns for CSV report, output with following command:\r\n\r\n```bash\r\njq -r &#39;.report | .moduleReports | .COMPLIANCE | .items[] | select(.requirementSourceType==&quot;CIS&quot;) | map({complianceId, title, status}) | (map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39; report.json\r\n```\r\n\r\n... I am getting this error:\r\n\r\n&gt; jq: error (at report.json:32): Cannot index string with string &quot;complianceId&quot;\r\n\r\nIs there any way to fix this error please?\r\n\r\nI&#39;ve tried to research such a solution, but wasn&#39;t able to find simmilar case.\r\n\r\nThank you.\r\n\r\n**EDIT**\r\n----------------\r\n\r\nExpected CSV output:\r\n\r\n```csv\r\n&quot;complianceId&quot;,&quot;status&quot;,&quot;title&quot;\r\n&quot;Report_ID1&quot;,&quot;FULFILLED&quot;,&quot;Title of Report ID1&quot;\r\n&quot;Report_ID2&quot;,&quot;FULFILLED&quot;,&quot;Title of Report ID2&quot;\r\n&quot;Report_ID3&quot;,&quot;FULFILLED&quot;,&quot;Title of Report ID3&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/65127096/jq-error-at-report-json32-cannot-index-string-with-string-complianceid",
        "title": "jq: error (at report.json:32): Cannot index string with string &quot;complianceId&quot;"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "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": 0,
                "creation_date": 1607007958,
                "post_id": 65128519,
                "comment_id": 115141759,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5703721,
                    "reputation": 881,
                    "user_id": 4507949,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/PruDR.png?s=256",
                    "display_name": "rathindu_w",
                    "link": "https://stackoverflow.com/users/4507949/rathindu-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607008396,
                "post_id": 65128519,
                "comment_id": 115142018,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5703721,
                    "reputation": 881,
                    "user_id": 4507949,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/PruDR.png?s=256",
                    "display_name": "rathindu_w",
                    "link": "https://stackoverflow.com/users/4507949/rathindu-w"
                },
                "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": 1607008450,
                "post_id": 65128519,
                "comment_id": 115142045,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607012176,
                "post_id": 65128519,
                "comment_id": 115144124,
                "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": 1607012258,
                "post_id": 65128519,
                "comment_id": 115144171,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607012303,
                "post_id": 65128519,
                "comment_id": 115144210,
                "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": 1607185822,
                "post_id": 65128519,
                "comment_id": 115195283,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607019896,
                "last_edit_date": 1607019896,
                "creation_date": 1607009007,
                "answer_id": 65128877,
                "question_id": 65128519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `| .[$key] |` to get the key from your `$key` variable;\r\n```bash\r\nkey=&quot;2020-12-02&quot;\r\njq -r --arg key &quot;$key&quot;  &#39;.&quot;Time Series (Daily)&quot; | .[$key] | .&quot;1. open&quot;&#39; newdata.json\r\n# output: 32.6700\r\n```\r\n\r\nOr, combined with the `for()` (hardcoded keys, since we&#39;re not sure how you get those)\r\n```\r\nkeys=(&quot;2020-12-02&quot; &quot;2020-12-01&quot; &quot;2020-11-30&quot;)\r\nfor key in &quot;${keys[@]}&quot;; do\r\n    jq -r --arg key &quot;$key&quot;  &#39;.&quot;Time Series (Daily)&quot; | .[$key] | .&quot;1. open&quot;&#39; newdata.json\r\ndone\r\n```\r\n&gt; 32.6700\r\n&gt;\r\n&gt; 32.1500\r\n&gt;\r\n&gt; 32.3800",
                "title": "Pass keys from array from bash into jq -- output all nulls"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607185740,
                "last_edit_date": 1607185740,
                "creation_date": 1607010908,
                "answer_id": 65129438,
                "question_id": 65128519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Focusing On The Immediate Issue\r\n\r\nThe problem isn&#39;t how you&#39;re passing `key` to jq; the problem is *how you&#39;re populating the `key` variable in the first place*.\r\n\r\nChange:\r\n\r\n```\r\nreadarray keys &lt;&lt;&lt; &quot;$(jq  &#39;.&quot;Time Series (Daily)&quot; |  keys[]&#39; newdata.json)&quot;\r\n```\r\n\r\n...to:\r\n\r\n```\r\nreadarray -t keys &lt;&lt;&lt; &quot;$(jq -r &#39;.&quot;Time Series (Daily)&quot; |  keys[]&#39; newdata.json)&quot;\r\n```\r\n\r\nThere are two changes here:\r\n\r\n1. We added the `-t` argument to `readarray`, so it no longer includes the newline ending each line in the variable itself.\r\n2. We added the `-r` argument to `jq`, so it no longer adds literal quotes around the strings.\r\n\r\n---\r\n\r\n### Sidebar: Retrieving both keys and values at the same time\r\n\r\nThere&#39;s no reason to do one pass to retrieve keys and another to retrieve values -- better to just get them all at once:\r\n\r\n```\r\ndates=( )\r\nopening_prices=( )\r\nwhile IFS=$&#39;\\t&#39; read -r date opening_price; do\r\n  dates+=( &quot;$date&quot; )\r\n  opening_prices+=( &quot;$opening_price&quot; )\r\ndone &lt; &lt;(\r\n  jq -r &#39;\r\n    .&quot;Time Series (Daily)&quot; | to_entries[] | [.key, .value.&quot;1. open&quot;] | @tsv\r\n  &#39; &lt;newdata.json\r\n)\r\n```\r\n\r\n...after which, `declare -p dates opening_prices` emits:\r\n\r\n```\r\ndeclare -a dates=([0]=&quot;2020-12-02&quot; [1]=&quot;2020-12-01&quot; [2]=&quot;2020-11-30&quot;)\r\ndeclare -a opening_prices=([0]=&quot;32.6700&quot; [1]=&quot;32.1500&quot; [2]=&quot;32.3800&quot;)\r\n```\r\n\r\n---\r\n\r\n### Original response (before population of keys was shown)\r\n\r\nHere&#39;s a different approach that only calls `jq` _once_, instead of once per item, while still getting your keys from an array. It does this by using `-R` to read raw strings as input; `.` is then used to address those inputs (which we rename to `$key` to make it clear how this lines up with the old code).\r\n\r\n```\r\nkeys=(&quot;2020-12-02&quot; &quot;2020-12-01&quot; &quot;2020-11-30&quot;)\r\nreadarray -t openingPrices &lt; &lt;(\r\n  jq -Rr --slurpfile indatas newdata.json &#39;\r\n    $indatas[0] as $indata | . as $key |\r\n    $indata.&quot;Time Series (Daily)&quot;[$key][&quot;1. open&quot;]\r\n  &#39; &lt; &lt;(printf &#39;%s\\n&#39; &quot;${keys[@]}&quot;)\r\n)\r\n```\r\n\r\nAfter running that, `declare -p keys openingPrices` (to show how both arrays are defined) emits:\r\n\r\n```\r\ndeclare -a keys=([0]=&quot;2020-12-02&quot; [1]=&quot;2020-12-01&quot; [2]=&quot;2020-11-30&quot;)\r\ndeclare -a openingPrices=([0]=&quot;32.6700&quot; [1]=&quot;32.1500&quot; [2]=&quot;32.3800&quot;)\r\n```\r\n\r\n...so you have an output array that lines up with your input array (so long as the latter isn&#39;t sparse).",
                "title": "Pass keys from array from bash into jq -- output all nulls"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1607185971,
        "creation_date": 1607007791,
        "last_edit_date": 1607185971,
        "question_id": 65128519,
        "body_markdown": "I&#39;m trying to do something akin to this:\r\n\r\n```\r\njq -r  &#39;. | .&quot;Time Series (Daily)&quot;.&quot;2020-12-02&quot; | .&quot;1. open&quot;&#39; newdata.json\r\n```\r\n\r\n...but with the key coming from a variable, as in:\r\n\r\n```\r\njq -r --arg key &quot;$key&quot; &#39;. | .&quot;Time Series (Daily)&quot;.&quot;[$key]&quot; | .&quot;1. open&quot;&#39; newdata.json\r\n```\r\nThe first one works just fine, but when I assign the date to a variable called key and then try to get the data, it fails.\r\n\r\nI tried [This answer][1] and [This answer][2]. But did not work for me.\r\n\r\n```\r\n{\r\n    &quot;Meta Data&quot;: {\r\n        &quot;1. Information&quot;: &quot;Daily Prices (open, high, low, close) and Volumes&quot;,\r\n        &quot;2. Symbol&quot;: &quot;AB&quot;,\r\n        &quot;3. Last Refreshed&quot;: &quot;2020-12-02&quot;,\r\n        &quot;4. Output Size&quot;: &quot;Compact&quot;,\r\n        &quot;5. Time Zone&quot;: &quot;US/Eastern&quot;\r\n    },\r\n    &quot;Time Series (Daily)&quot;: {\r\n        &quot;2020-12-02&quot;: {\r\n            &quot;1. open&quot;: &quot;32.6700&quot;,\r\n            &quot;2. high&quot;: &quot;33.3300&quot;,\r\n            &quot;3. low&quot;: &quot;32.5000&quot;,\r\n            &quot;4. close&quot;: &quot;33.1200&quot;,\r\n            &quot;5. volume&quot;: &quot;273799&quot;\r\n        },\r\n        &quot;2020-12-01&quot;: {\r\n            &quot;1. open&quot;: &quot;32.1500&quot;,\r\n            &quot;2. high&quot;: &quot;32.8000&quot;,\r\n            &quot;3. low&quot;: &quot;32.0000&quot;,\r\n            &quot;4. close&quot;: &quot;32.6000&quot;,\r\n            &quot;5. volume&quot;: &quot;265086&quot;\r\n        },\r\n        &quot;2020-11-30&quot;: {\r\n            &quot;1. open&quot;: &quot;32.3800&quot;,\r\n            &quot;2. high&quot;: &quot;32.4900&quot;,\r\n            &quot;3. low&quot;: &quot;31.7500&quot;,\r\n            &quot;4. close&quot;: &quot;31.8700&quot;,\r\n            &quot;5. volume&quot;: &quot;251970&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nThe above is the newdata.json file.\r\nWhat I want to get is the &quot;1. open&quot; value.\r\nI am using a for loop to iterate over all the keys of &quot;Time Series (Daily)&quot; and the keys are generated correctly. There is no issue with that. I then want to use the $key variable in each iteration to \r\nget the data I need.\r\n\r\n```\r\nreadarray keys &lt;&lt;&lt; &quot;$(jq  &#39;.&quot;Time Series (Daily)&quot; |  keys[]&#39; newdata.json)&quot;\r\nfor key in &quot;${keys[@]}&quot;; do\r\n  jq -r --arg key &quot;$key&quot;  &#39;. | .&quot;Time Series (Daily)&quot; | .[$key] | .&quot;1. open&quot;&#39; newdata.json\r\ndone\r\n```\r\n\r\n  [1]: https://stackoverflow.com/questions/40027395/passing-bash-variable-to-jq\r\n  [2]: https://stackoverflow.com/questions/34745451/passing-arguments-to-jq-filter",
        "link": "https://stackoverflow.com/questions/65128519/pass-keys-from-array-from-bash-into-jq-output-all-nulls",
        "title": "Pass keys from array from bash into jq -- output all nulls"
    },
    {
        "tags": [
            "json",
            "csv",
            "boolean",
            "jq",
            "indicator"
        ],
        "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": 1607031942,
                "post_id": 65131942,
                "comment_id": 115152870,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1607040406,
                "last_edit_date": 1607040406,
                "creation_date": 1607020956,
                "answer_id": 65132141,
                "question_id": 65131942,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the invocation:\r\n```\r\njq -r --argjson whitelist &#39;[&quot;role1&quot;, &quot;role3&quot;, &quot;role4&quot;]&#39; &#39;\r\n  ([&quot;username&quot;] + $whitelist),\r\n  [.username, ($whitelist[] as $w | .roles | index([$w]) != null)]\r\n  | @csv\r\n&#39;\r\n```\r\nproduces:\r\n\r\n```\r\n&quot;username&quot;,&quot;role1&quot;,&quot;role3&quot;,&quot;role4&quot;\r\n&quot;janedoe&quot;,true,false,true\r\n\r\n```\r\n\r\n### Notes:\r\n1. The second last line of the jq filter above could be shortened to:\r\n\r\n      `[.username, (.roles | index($whitelist[]) != null)]`\r\n\r\n2. Presumably if there were more than one user, you&#39;d only want\r\nthe header row once, in which case the above solution \r\nwould need to be tweaked.\r\n\r\n## Using IN/1\r\nBecause `index/1` is not as efficient as it might be,\r\nyou might like to consider this alternative:\r\n\r\n```\r\n  ([&quot;username&quot;] + $whitelist),\r\n  (.roles as $roles | [.username, ($whitelist[] | IN($roles[]) )])\r\n  | @csv\r\n```\r\n\r\n## Using a JSON dictionary\r\n\r\nIf the number of roles was very large, then it would probably be more\r\nefficient to construct a JSON dictionary to avoid repeated linear lookups:\r\n```\r\n  (reduce .roles[] as $r ({}; .[$r]=true)) as $roles\r\n  | ([&quot;username&quot;] + $whitelist),\r\n    [.username, ($roles[$whitelist[]] != null)]\r\n  | @csv\r\n```\r\n## With ndjson as input\r\nFor efficiency, and to ensure there&#39;s just one header, you could use `inputs` with the -n command-line option.  Adding the extra fields mentioned in the revised Q, you might end up with:\r\n\r\n```\r\njq -nr --argjson whitelist &#39;[&quot;role1&quot;, &quot;role2&quot;]&#39; &#39;\r\n  [&quot;email&quot;, &quot;username&quot;, &quot;given_name&quot;, &quot;family_name&quot;] as $greenlist\r\n  | ($greenlist + $whitelist),\r\n    (inputs \r\n     | select(has(&quot;roles&quot;) and any(.roles[] == $whitelist[]; true))\r\n     | (reduce .&quot;roles&quot;[] as $r ({}; .[$r]=true)) as $roles\r\n     | [ .[$greenlist[]], ($roles[$whitelist[]] != null) ])\r\n  | @csv\r\n&#39; users.json\r\n\r\n```\r\n",
                "title": "Can I output boolean based on values in a list?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607396686,
        "creation_date": 1607020045,
        "last_edit_date": 1607396686,
        "question_id": 65131942,
        "body_markdown": "Edit: I used the solution provided by @peak to do the following:\r\n\r\n```\r\n$ jq -r --argjson whitelist &#39;[&quot;role1&quot;, &quot;role2&quot;]&#39; &#39;\r\nselect(has(&quot;roles&quot;) and any(.roles[]; . == &quot;role1&quot; or . == &quot;role2&quot;))\r\n| (reduce .&quot;roles&quot;[] as $r ({}; .[$r]=true)) as $roles\r\n| [.email, .username, .given_name, .family_name, ($roles[$whitelist[]]\r\n| . != null)]\r\n| @csv\r\n&#39; users.json\r\n```\r\n\r\nAdded the `select()` to filter out users who haven&#39;t onboarded yet and don&#39;t have any roles, and to ensure the users included in the output have at least one of the target roles.\r\n\r\n\r\n\r\nScenario: user profiles as JSON docs, where each profile has a list object with their assigned roles. Example:\r\n\r\n```\r\n{\r\n  &quot;username&quot;: &quot;janedoe&quot;,\r\n  &quot;roles&quot;: [\r\n    &quot;role1&quot;,\r\n    &quot;role4&quot;,\r\n    &quot;role5&quot;\r\n  ]\r\n}\r\n```\r\n\r\nThe actual data file is an ndjson file, one user object as above per line.\r\n\r\nI am only interested in specific roles, say `role1`, `role3`, and `role4`. I want to produce a CSV formatted as:\r\n\r\n```\r\nusername,role1?,role3?,role4?\r\n```\r\n\r\ne.g.,\r\n\r\n```\r\njanedoe,true,false,true\r\n```\r\n\r\nThe part I haven&#39;t figured out is how to output booleans or Y / N in response to the values in the list object. Is this something I can do in `jq` itself?",
        "link": "https://stackoverflow.com/questions/65131942/can-i-output-boolean-based-on-values-in-a-list",
        "title": "Can I output boolean based on values in a list?"
    }
]