[
    {
        "tags": [
            "awk",
            "jq",
            "zeek"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 23298398,
                    "reputation": 20,
                    "user_id": 17379464,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08c669fab9d383c4a8d90c6aaef4838e?s=256&d=identicon&r=PG",
                    "display_name": "net_solv",
                    "link": "https://stackoverflow.com/users/17379464/net-solv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636566086,
                "post_id": 69917808,
                "comment_id": 123593526,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1636569314,
                "post_id": 69917808,
                "comment_id": 123594780,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1636572290,
                "post_id": 69917808,
                "comment_id": 123595910,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1636572324,
                "post_id": 69917808,
                "comment_id": 123595921,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1636572414,
                "post_id": 69917808,
                "comment_id": 123595958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1636572869,
                "post_id": 69917808,
                "comment_id": 123596133,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1636572926,
                "post_id": 69917808,
                "comment_id": 123596146,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23298398,
                    "reputation": 20,
                    "user_id": 17379464,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08c669fab9d383c4a8d90c6aaef4838e?s=256&d=identicon&r=PG",
                    "display_name": "net_solv",
                    "link": "https://stackoverflow.com/users/17379464/net-solv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636573356,
                "post_id": 69917808,
                "comment_id": 123596300,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23298398,
                    "reputation": 20,
                    "user_id": 17379464,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08c669fab9d383c4a8d90c6aaef4838e?s=256&d=identicon&r=PG",
                    "display_name": "net_solv",
                    "link": "https://stackoverflow.com/users/17379464/net-solv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636573894,
                "post_id": 69917808,
                "comment_id": 123596470,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636577907,
                "last_edit_date": 1636577907,
                "creation_date": 1636574211,
                "answer_id": 69919463,
                "question_id": 69917808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As far as I understand what you are trying to accomplish, this might go in your direction:\r\n\r\n```sh\r\njq -sr &#39;\r\n  group_by([.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;])[]\r\n  | [(first|.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;), (map(.duration)|add)]\r\n  | @csv\r\n&#39; extract.json\r\n``` \r\n\r\nExplanation: Your input is a stream of objects. Reading them in using `-s` (or `--slurp`) turns the stream into an array. With `group_by` we transform it into an array of arrays, separating equal values, here given as an array of the two IP fields. Next, for each element of the outer array (the group members) we construct an array of the two IP fields of the first member only (this suffices as all others are equal to this regard), and as third value we `add` up the values of each group members `.duration` field. Lastly, the constructed array is transformed to a line of CSV using `@csv`, which is printed raw thanks to the initial `-r` (`--raw-output`) parameter.\r\n\r\nNote: I treated field values like `&quot;ts&quot;: 1636xxxxx.41xxx34` as obfuscation of an actual number. If, however, it&#39;s rather a string containing some `x` characters, then the string literal needs to be quoted (`&quot;ts&quot;: &quot;1636xxxxx.41xxx34&quot;`) for being proper JSON.\r\n\r\n---\r\n\r\nAnswering a [follow-up question](https://stackoverflow.com/questions/69917808/trying-to-reproduce-awk-in-jq/69919463#comment123597096_69919463), how to filter out durations equal to 0 and sort the remaining lines by duration from highest to lowest\r\n\r\n```sh\r\njq -sr &#39;\r\n  group_by([.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;]) | map(\r\n    [(first|.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;), (map(.duration)|add)]\r\n    | select(.[2] &gt; 0)\r\n  )\r\n  | sort_by(-.[2])[]\r\n  | @csv\r\n&#39; extract.json\r\n``` \r\n\r\n\r\n",
                "title": "Trying to reproduce awk in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636577907,
        "creation_date": 1636565938,
        "last_edit_date": 1636573975,
        "question_id": 69917808,
        "body_markdown": "Preamble: Enterprise Network Engineer/Architect (Non-Programmer).  \r\nSynopsis: Logs moving from txt output to json   \r\nIssue: Not successfully trying to migrate from a functioning awk data extraction to using jq against json using one-liner.  \r\nActive awk:  \r\n\r\n```sh\r\nawk &#39;\r\n   BEGIN{ FS=&quot;\\t&quot; }\r\n  { arr[$1 FS $2] += $3; count[$1 FS $2] += 1 }\r\n  END{ for (key in arr) printf &quot;%s%s%s%s%s\\n&quot;, key, FS, count[key], FS, arr[key] }\r\n&#39; | sort -nrk 4 | head -1 | awk &#39;{ print $1&quot; | &quot;$2&quot; | &quot;$4/60/60 }&#39;\r\n```\r\n\r\nEnd Result: using jq to count duplicate entries for src/dst ip address and dst port and ADD the cumulative duration of the connections.\r\n\r\nSAMPLE JSON INPUT\r\n```\r\n{\r\n  &quot;ts&quot;: 1636xxxxx.41xxx34,\r\n  &quot;uid&quot;: &quot;hex_code&quot;,\r\n  &quot;id.orig_h&quot;: &quot;10.x.x.11&quot;,\r\n  &quot;id.orig_p&quot;: 42996,\r\n  &quot;id.resp_h&quot;: &quot;10.x.x.123&quot;,\r\n  &quot;id.resp_p&quot;: 53,\r\n  &quot;proto&quot;: &quot;udp&quot;,\r\n  &quot;service&quot;: &quot;dns&quot;,\r\n  &quot;duration&quot;: 0.01117664844,\r\n  &quot;conn_state&quot;: &quot;SF&quot;,\r\n  &quot;local_orig&quot;: true,\r\n  &quot;local_resp&quot;: true,\r\n  &quot;missed_bytes&quot;: 0,\r\n  &quot;history&quot;: &quot;Dd&quot;,\r\n  &quot;orig_pkts&quot;: 1,\r\n  &quot;orig_ip_bytes&quot;: 71,\r\n  &quot;resp_pkts&quot;: 1,\r\n  &quot;resp_ip_bytes&quot;: 71\r\n}\r\n{\r\n  &quot;ts&quot;: 1xxxx0501.5xxx47,\r\n  &quot;uid&quot;: &quot;hex_code&quot;,\r\n  &quot;id.orig_h&quot;: &quot;10.x.x.11&quot;,\r\n  &quot;id.orig_p&quot;: 36299,\r\n  &quot;id.resp_h&quot;: &quot;10.x.x.123&quot;,\r\n  &quot;id.resp_p&quot;: 53,\r\n  &quot;proto&quot;: &quot;udp&quot;,\r\n  &quot;service&quot;: &quot;dns&quot;,\r\n  &quot;duration&quot;: 0.00857415966797,\r\n  &quot;conn_state&quot;: &quot;SF&quot;,\r\n  &quot;local_orig&quot;: true,\r\n  &quot;local_resp&quot;: true,\r\n  &quot;missed_bytes&quot;: 0,\r\n  &quot;history&quot;: &quot;Dd&quot;,\r\n  &quot;orig_pkts&quot;: 1,\r\n  &quot;orig_ip_bytes&quot;: 74,\r\n  &quot;resp_pkts&quot;: 1,\r\n  &quot;resp_ip_bytes&quot;: 74\r\n}\r\n```\r\n```\r\ntargeted jq output...\r\n10.xxx.xxx.21 | 18.xx1.xx1.158 | 45.6606 &lt;--time is shown cumulative duration",
        "link": "https://stackoverflow.com/questions/69917808/trying-to-reproduce-awk-in-jq",
        "title": "Trying to reproduce awk in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636583972,
                "last_edit_date": 1636583972,
                "creation_date": 1636571112,
                "answer_id": 69918893,
                "question_id": 69918777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure if I totally understand what you are trying to explain to us here, but if you are trying to extract/export it from your file to a command or a retrieval command, then you would need to specify which files need to be included, along with where you want to post that text to.\r\n\r\nWith any files you can extract data. For example, if you were using Sqlite:\r\n\r\n```\r\ndb.fetch(`data_specified_here`)\r\n```\r\n\r\n&gt; **Note:** This would fetch the data from the database—or for you db file— then what you would want to do is either log or print out the data.\r\n\r\nSince you have things like &quot;time&quot; and &quot;Number&quot;&#39;s, you&#39;d want to specify that that (meaning &quot;time&quot;:**2021-10-01**, and so on) you need to specify that it is the string, or input you with to take out from your file.\r\n\r\nIf this didn&#39;t help, please re-ask your question with a little more detail and I can help more. I just gave a general rundown on how to fetch something from the DB, or in your case &quot;JSON&quot;.",
                "title": "Export unique JSON values from two files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636571346,
                "creation_date": 1636571346,
                "answer_id": 69918933,
                "question_id": 69918777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Choose a field that will be compared (e.g. `.signature`) and filter by that using `unique_by` in the comprehensive array obtained by using the option `--slurp` or `-s`:\r\n\r\n```sh\r\njq -s &#39;unique_by(.signature)[]&#39; file*.txt\r\n```",
                "title": "Export unique JSON values from two files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1636583972,
        "creation_date": 1636570561,
        "question_id": 69918777,
        "body_markdown": "I am trying to extract unique values between two JSON files. I see many jq posts on how to filter unique values within the same file, but not compare two. \r\n\r\nBoth of my files are in the same format: \r\n```\r\n{\r\n&quot;time&quot;:&quot;2021-10-01T04:00:38.161Z&quot;,\r\n&quot;Number&quot;:2,\r\n&quot;signature&quot;:&quot;e03756fa67a30d52837d3743d4d87e9a810c5e2ddf11061a976c386a742fa&quot;\r\n}\r\n{\r\n&quot;time&quot;:&quot;2021-10-01T04:01:38.164Z&quot;,\r\n&quot;Number&quot;:2,\r\n&quot;signature&quot;:&quot;3b4d746ac2da2543047d8cc981db2464d4993065993449b321fc15d7f0aa6&quot;\r\n}\r\n```\r\n\r\nI would like to create a 3rd file which contains only unique values. If I must choose a single value to declare as unique, then I would select &#39;signature.&#39;",
        "link": "https://stackoverflow.com/questions/69918777/export-unique-json-values-from-two-files",
        "title": "Export unique JSON values from two files"
    },
    {
        "tags": [
            "jenkins-pipeline",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636579972,
                "creation_date": 1636579972,
                "answer_id": 69920482,
                "question_id": 69920097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You passed `true` as the argument for the `returnStdout` argument to the shell step method for `stageTwoList`, but then forgot to use the same argument for the JSON parsed returns to the next two variable assignments:\r\n\r\n    def lines = stageOneList.readLines()\r\n    lines.each { line -&gt; println line\r\n                        \r\n      stageTwoList = sh(script: &quot;curl -u $apptoken&quot; + &quot; -X GET --url &quot; + &#39;&quot;&#39; + &quot;$appurl&quot; + &quot;components/tree?component=&quot; + line + &#39;&quot;&#39;, returnStdout: true)                                \r\n      pfName = sh(script: &quot;jq -r &#39;.component.name&#39; &lt;&lt;&lt; &#39;${stageTwoList}&#39; &quot;, returnStdout: true)\r\n      pfKey = sh(script: &quot;jq -r &#39;.component.key&#39; &lt;&lt;&lt; &#39;${stageTwoList}&#39; &quot;, returnStdout: true)\r\n      echo &quot;Component Names and Keys\\n | $pfName | $pfKey |&quot;\r\n    }\r\n\r\nNote you can also make this much easier on yourself by doing the JSON parsing natively in Groovy and with Jenkins Pipeline step methods:\r\n\r\n    String stageTwoList = sh(script: &quot;curl -u $apptoken&quot; + &quot; -X GET --url &quot; + &#39;&quot;&#39; + &quot;$appurl&quot; + &quot;components/tree?component=&quot; + line + &#39;&quot;&#39;, returnStdout: true)\r\n    Map stageTwoListData = readJSON(text: stageTwoList)\r\n    pfName = stageTwoListData[&#39;component&#39;][&#39;name&#39;]\r\n    pfKey = stageTwoListData[&#39;component&#39;][&#39;key&#39;]",
                "title": "jq in a Jenkins pipeline not saving output to variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636579972,
        "creation_date": 1636577601,
        "question_id": 69920097,
        "body_markdown": "So in my Jenkins pipeline I run a couple of curl commands across different stages. I store the ouput of Stage1 into a file and for every item in that list I run another curl command and use the output of that to extract some values using jq. \r\n\r\nHowever from the second stage I can&#39;t seem to store the jq extracted values into variables to echo them later. What am I doing wrong?\r\n\r\n```\r\n{Stage1}\r\n.\r\n.\r\n.\r\n{Stage2}\r\ndef lines = stageOneList.readLines()\r\nlines.each { line -&gt; println line\r\n                        \r\nstageTwoList = sh (script: &quot;curl -u $apptoken&quot; + &quot; -X GET --url &quot; + &#39;&quot;&#39; + &quot;$appurl&quot; + &quot;components/tree?component=&quot; + line + &#39;&quot;&#39;, returnStdout: true)                                \r\npfName = sh (script: &quot;jq -r &#39;.component.name&#39; &lt;&lt;&lt; &#39;${stageTwoList}&#39; &quot;)\r\npfKey = sh (script: &quot;jq -r &#39;.component.key&#39; &lt;&lt;&lt; &#39;${stageTwoList}&#39; &quot;)\r\necho &quot;Component Names and Keys\\n | $pfName | $pfKey |&quot;\r\n}\r\n```\r\nreturns in the end for Stage2\r\n```\r\n[Pipeline] sh\r\n+ jq -r .component.name\r\ndigital-hot-wallet-gateway\r\n[Pipeline] sh\r\n+ jq -r .component.key\r\ndhwg\r\n[Pipeline] echo\r\nComponent Names and Keys\r\n | null | null |\r\n```\r\n\r\nAny help in the right direction appreciated!\r\n                                ",
        "link": "https://stackoverflow.com/questions/69920097/jq-in-a-jenkins-pipeline-not-saving-output-to-variable",
        "title": "jq in a Jenkins pipeline not saving output to variable"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1636585629,
                "creation_date": 1636585629,
                "answer_id": 69921278,
                "question_id": 69921044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To keep things simple, since you indicated the intent is that json-data.json\r\ncontain JSON, let&#39;s suppose that it contains valid JSON.\r\n\r\nIt would probably be simpler also if the template were valid JSON, but\r\nin case you&#39;re stuck with templates like the one you showed, let&#39;s go with that.\r\n\r\nSince the template shown is not valid JSON but is valid as a jq object specification,\r\nlet&#39;s start by supposing we can make it part of a jq program, e.g.\r\nby\r\n\r\n```\r\ndef template:\r\n{\r\n  key1: &quot;value1&quot;,\r\n  key2: &quot;value2&quot;,\r\n  name: &quot;XXX&quot;,\r\n  familyName: &quot;YYY&quot;\r\n}\r\n;\r\n```\r\n\r\nWe have now only to write a filter for converting an input object to the form specified by the template:\r\n```\r\ndef fillin($template):\r\n  . as $in\r\n  | reduce ($template|keys_unsorted[]) as $k ($template; if $in|has($k) then .[$k] = $in[$k] else . end);\r\n```\r\n\r\nWith your input, we have then only to call:\r\n```\r\nmap(fillin(template))\r\n```\r\n\r\nPutting all the jq code in a single file, the invocation would then look like this:\r\n```\r\njq -f populate-template.jq json-data.json\r\n```",
                "title": "jq: populate template json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636586721,
                "creation_date": 1636586721,
                "answer_id": 69921397,
                "question_id": 69921044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the template is potentially invalid as JSON and if you want to keep it in a separate file, then, assuming a bash or bash-like shell, you could write:\r\n```\r\n&lt; json-data.json jq --argfile t &lt;(jq -n -f template.txt) &#39;\r\n\r\n  def fillin($template):\r\n    . as $in\r\n    | reduce ($template|keys_unsorted[]) as $k ($template; if $in|has($k) then .[$k] = $in[$k] else . end);\r\n\r\n  map(fillin($t))\r\n&#39; \r\n```",
                "title": "jq: populate template json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1636586721,
        "creation_date": 1636583811,
        "question_id": 69921044,
        "body_markdown": "I&#39;d like to populate a `json-data.json` json data objects using a `json-template.json`.\r\n\r\nExample:\r\n\r\n`json-data.json`:\r\n```lang-json\r\n[\r\n  {name: &quot;John&quot;, familyName: &quot;Smith&quot;},\r\n  {name: &quot;Samuel&quot;, familyName: &quot;Schnaider&quot;}\r\n]\r\n```\r\nAnd my `json-template.json`:\r\n```lang-json\r\n{\r\n  key1: &quot;value1&quot;,\r\n  key2: &quot;value2&quot;,\r\n  name: &quot;XXX&quot;,\r\n  familyName: &quot;YYY&quot;\r\n}\r\n```\r\n\r\nMy desired result would be:\r\n\r\n```lang-java\r\n[\r\n  {\r\n    key1: &quot;value1&quot;,\r\n    key2: &quot;value2&quot;,\r\n    name: &quot;John&quot;,\r\n    familyName: &quot;Smith&quot;\r\n  },\r\n  {\r\n    key1: &quot;value1&quot;,\r\n    key2: &quot;value2&quot;,\r\n    name: &quot;Samuel&quot;,\r\n    familyName: &quot;Schnaider&quot;    \r\n  }\r\n]\r\n```\r\n\r\nAny ideas about how to get it using `jq`?",
        "link": "https://stackoverflow.com/questions/69921044/jq-populate-template-json",
        "title": "jq: populate template json"
    },
    {
        "tags": [
            "bash",
            "loops",
            "for-loop",
            "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": 1,
                "creation_date": 1636590690,
                "post_id": 69921626,
                "comment_id": 123601141,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636601247,
                "last_edit_date": 1636601247,
                "creation_date": 1636598184,
                "answer_id": 69922563,
                "question_id": 69921626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of the dubious:\r\n\r\n    echo $(_jq &#39;.dependencies[].name&#39;)\r\n\r\nwrite:\r\n\r\n    _jq &#39;.dependencies[].name&#39;\r\n\r\nIOW, KIS.\r\n\r\n----\r\n\r\nAnd speaking of KIS, have you considered using `@base64d`?  As in:\r\n\r\n    printf &quot;%s&quot; &quot;${row}&quot; | jq -Rr &quot;@base64d | fromjson | ${1}&quot;",
                "title": "jq loop on items in new lines"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636601247,
        "creation_date": 1636588607,
        "question_id": 69921626,
        "body_markdown": "I could read all of the entries it was set to, but they are put in one line instead of appending on new line.\r\n\r\nSource:\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nfor row in $(jq -r &#39;. | @base64&#39; recipe.json); do\r\n    _jq() {\r\n     echo ${row} | base64 --decode | jq -r ${1}\r\n    }\r\n   #echo $(_jq &#39;.dependencies[].name&#39;)\r\n   echo $(_jq &#39;.dependencies[].name&#39;) &gt;&gt; file.log\r\ndone\r\n```\r\n\r\nrecipe.json:\r\n```json\r\n{\r\n\t&quot;florecipe-v&quot;: &quot;1.0&quot;,\r\n\t&quot;name&quot;: &quot;web3updater&quot;,\r\n\t&quot;dependencies&quot;: [{\r\n\t\t\t&quot;name&quot;: &quot;ethereal&quot;,\r\n\t\t\t&quot;version&quot;: &quot;2.6.0&quot;,\r\n\t\t\t&quot;source&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;QmWmxakbb7msHFaD9QmGXBAmLpUHTdZG64BWhQg8dyx8gM&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;https://github.com/wealdtech/ethereal.git&quot;\r\n\t\t\t},\r\n\t\t\t&quot;linux-amd64&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;QmbwABiXz4U5MrmJLisfxaHEG7CyJKEnNECRjXogS7eAFw&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;https://github.com/wealdtech/ethereal/releases/download/v2.6.0/ethereal-2.6.0-linux-amd64.tar.gz&quot;\r\n\t\t\t},\r\n\t\t\t&quot;linux-arm64&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;QmV9agwSZuVXMJNYV1NhU8SY8TRg73z8RgTw4QaYrVxtrr&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;https://github.com/wealdtech/ethereal/releases/download/v2.6.0/ethereal-2.6.0-linux-arm64.tar.gz&quot;\r\n\t\t\t},\r\n\t\t\t&quot;windows-i386&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;new&quot;,\r\n\t\t\t&quot;version&quot;: &quot;&quot;,\r\n\t\t\t&quot;source&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;linux-amd64&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;linux-arm64&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;windows-i386&quot;: {\r\n\t\t\t\t&quot;ipfs&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;github&quot;: &quot;&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\nfile.log properly contains ethereal and new, but they are on the same line instead of appending.",
        "link": "https://stackoverflow.com/questions/69921626/jq-loop-on-items-in-new-lines",
        "title": "jq loop on items in new lines"
    },
    {
        "tags": [
            "json",
            "performance",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636605415,
                "post_id": 69922985,
                "comment_id": 123603743,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3378634,
                    "reputation": 385,
                    "user_id": 2836235,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/daf0ff0aefbb8617d568ef49ac6a18c3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nick Hatfield",
                    "link": "https://stackoverflow.com/users/2836235/nick-hatfield"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636605662,
                "post_id": 69922985,
                "comment_id": 123603793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636606485,
                "post_id": 69922985,
                "comment_id": 123603926,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3378634,
                    "reputation": 385,
                    "user_id": 2836235,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/daf0ff0aefbb8617d568ef49ac6a18c3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nick Hatfield",
                    "link": "https://stackoverflow.com/users/2836235/nick-hatfield"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636606810,
                "post_id": 69922985,
                "comment_id": 123603973,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636607117,
                "post_id": 69922985,
                "comment_id": 123604021,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3378634,
                    "reputation": 385,
                    "user_id": 2836235,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/daf0ff0aefbb8617d568ef49ac6a18c3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nick Hatfield",
                    "link": "https://stackoverflow.com/users/2836235/nick-hatfield"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636607501,
                "post_id": 69922985,
                "comment_id": 123604095,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1636607434,
                "last_edit_date": 1636607434,
                "creation_date": 1636604619,
                "answer_id": 69923156,
                "question_id": 69922985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you either get rid of the commas between the objects or enclose the whole input with array brackets (in order to get proper JSON), then you can do (use the `-s` option for `{}{}{}` style, or drop it for `[{],{},{}]` style):\r\n\r\n```sh\r\njq -s --argjson delta $((15*60)) --argjson addvalue 10 &#39;\r\n\r\n (now - $delta) as $pivot\r\n | map(select(.timestamp &gt;= $pivot))\r\n | group_by(.uniqueId)\r\n | map({\r\n    name: first.uniqueId,\r\n    value_total: map(.value) | (add + $addvalue),\r\n    uniqueId_count: length\r\n  })\r\n\r\n&#39; ",
                "title": "Advanced JQ techniques"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636727299,
        "creation_date": 1636602674,
        "last_edit_date": 1636727299,
        "question_id": 69922985,
        "body_markdown": "I&#39;m looking for some help to increase my jq-foo, and could use a little guidance. I have some etl jobs that I script using JQ and I want to see if there is a way to make the runs more efficient in terms of CPU utilization and or speed. \r\n\r\nHeres a sample payload:\r\n\r\n```\r\n{\r\n  &quot;timestamp&quot;: 1636601959,\r\n  &quot;uniqueId&quot;: &quot;Foo&quot;,\r\n  &quot;value&quot;: 10\r\n},\r\n{\r\n  &quot;timestamp&quot;: 1636601859,\r\n  &quot;uniqueId&quot;: &quot;Bar&quot;,\r\n  &quot;value&quot;: 13\r\n}\r\n```\r\n\r\nand I want to do something like (pseudo-code):\r\n\r\n```\r\nif [ (epoch 15 minutes ago) -le timestamp ]; then \r\n   name=uniqueId; value_total=value(total); uniqueId_count=(uniqueId(count_total))\r\nfi\r\n```\r\n\r\nRight now I do something like (pseudo-code):\r\n\r\n```\r\nfor jq[timestamps] in $(json); do\r\n  if [ (epoch 15 minutes ago)  -le timestamp ]; then \r\n    name=uniqueId; value_total=(value_total + value); uniqueId_count=(uniqueId_count + 1). \r\n  fi\r\ndone\r\n```\r\n\r\nIs there a way to simplify this without using a for loop to iterate over each object by calling `jq &#39;select() ...&#39;` over and over?",
        "link": "https://stackoverflow.com/questions/69922985/advanced-jq-techniques",
        "title": "Advanced JQ techniques"
    },
    {
        "tags": [
            "python",
            "powershell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1636607020,
                "last_edit_date": 1636607020,
                "creation_date": 1636606009,
                "answer_id": 69923316,
                "question_id": 69923050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: sh --&gt;\r\n\r\nAs long as *each line*&lt;sup&gt;[1]&lt;/sup&gt; that your `python` script outputs is a _complete_ JSON object by itself, you can use a [`ForEach-Object`](https://learn.microsoft.com/powershell/module/microsoft.powershell.core/foreach-object) call to process each output line as it is being received by PowerShell and call [`ConvertFrom-Json`](https://learn.microsoft.com/powershell/module/microsoft.powershell.utility/convertfrom-json) for _each_:\r\n\r\n```\r\npython .\\dir_json.py | ForEach-Object { ConvertFrom-JSON $_ }\r\n```\r\n\r\nA simplified example that demonstrates that _streaming_ occurs, pausing between lines processed (waiting for a keypress):\r\n\r\n```\r\n# Prompts for a keystroke after each line emitted by the Python command.\r\npython -c &#39;from json import dumps; print(dumps({&#39;&#39;name&#39;&#39;: &#39;&#39;foo&#39;&#39;})); print(dumps({&#39;&#39;name&#39;&#39;: &#39;&#39;bar&#39;&#39;}))&#39; | \r\n  ForEach-Object { ConvertFrom-Json $_ | Out-Host; pause }\r\n```\r\n\r\nNote: The [`Out-Host`](https://learn.microsoft.com/powershell/module/microsoft.powershell.core/out-host) call is only used to work around a _display bug_ in PowerShell, still present as of PowerShell 7.2: `Out-Host` forces _synchronous_ printing of the implicit table-formatting that is applied - see [this answer](https://stackoverflow.com/a/43691123/45375).\r\n\r\n---\r\n\r\n`ConvertFrom-Json` - atypically for PowerShell cmdlets - _collects all input up front_ before emitting the object(s) that the JSON input has been parsed into, which can be demonstrated as follows:\r\n\r\n```\r\n# Prompts for a keystroke first, and only after *both*\r\n# strings have been emitted does ConvertFrom-Json produce output.\r\n&amp; { &#39;{ &quot;name&quot;: &quot;foo&quot; }&#39;; pause; &#39;{ &quot;name&quot;: &quot;bar&quot; }&#39; } |\r\n  ConvertFrom-Json | Out-Host\r\n```\r\n\r\n---\r\n\r\n&lt;sup&gt;[1] PowerShell relays output _from external programs_ such as Python invariably _line by line_. By contrast, a _PowerShell-native command_ is free to emit any object to the pipeline, including _multiline_ strings.&lt;/sup&gt;",
                "title": "Streaming objects from Python to PowerShell?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1636607020,
        "creation_date": 1636603379,
        "question_id": 69923050,
        "body_markdown": "After some searching and checking previous answers like here https://stackoverflow.com/questions/28980250/passing-objects-from-python-to-powershell, apparently the best way to send objects from a Python script to PowerShell script or command is going to be as JSON.\r\n\r\nHowever, with something like this (`dir_json.py`):\r\n```python\r\nfrom json import dumps\r\nfrom pathlib import Path\r\n\r\nfor fn in Path(&#39;.&#39;).glob(&#39;**/*&#39;):\r\n    print(dumps({&#39;name&#39;: str(fn)}))\r\n```\r\nYou can do this:\r\n```none\r\npython .\\dir_json.py | ConvertFrom-JSON\r\n```\r\nAnd the result is OK, but the problem I&#39;m hoping to solve is that `ConvertFrom-JSON` seems to wait until the script has completed before reading any of the JSON, even though the invidual JSON objects end on each line. This can easily be verified by adding a line like `time.sleep(1)` after the print.\r\n\r\nIs there a better way to send objects from Python to PowerShell than using JSON objects? And is there a way to actually stream them as they are written, instead of passing the entire output of the Python script after the script completes?\r\n\r\nI ran into `jq`, which was recommended by &quot;people on the internet&quot; as a solution to my type of problem, stating that `ConvertFrom-JSON` doesn&#39;t allow streaming, but `jq` does. However, this did nothing to improve my situation:\r\n```none\r\npython .\\dir_json_slow.py | jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; | ConvertFrom-JSON\r\n```\r\nTo make `jq` play nice, I did change the script to write a list of objects instead of separate objects:\r\n```python\r\nfrom sys import stdout\r\nfrom time import sleep\r\nfrom json import dumps\r\nfrom pathlib import Path\r\n\r\nfirst = True\r\nstdout.write(&#39;[\\n&#39;)\r\nfor fn in Path(&#39;.&#39;).glob(&#39;**/*&#39;):\r\n    if first:\r\n        stdout.write(dumps({&#39;name&#39;: str(fn)}))\r\n        first = False\r\n    else:\r\n        stdout.write(&#39;,\\n&#39;+dumps({&#39;name&#39;: str(fn)}))\r\n    stdout.flush()\r\n    sleep(.1)\r\nstdout.write(&#39;\\n]&#39;)\r\n```\r\n(note that the problem isn&#39;t `ConvertFrom-JSON` holding things up at the end, `jq` itself only starts writing output once the Python script completes)",
        "link": "https://stackoverflow.com/questions/69923050/streaming-objects-from-python-to-powershell",
        "title": "Streaming objects from Python to PowerShell?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636618535,
                "post_id": 69924653,
                "comment_id": 123606703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636619032,
                "post_id": 69924653,
                "comment_id": 123606860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636619453,
                "post_id": 69924653,
                "comment_id": 123606980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636619592,
                "post_id": 69924653,
                "comment_id": 123607016,
                "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": 1636619759,
                "post_id": 69924653,
                "comment_id": 123607088,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636620339,
                "post_id": 69924653,
                "comment_id": 123607303,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636621735,
                "last_edit_date": 1636621735,
                "creation_date": 1636619849,
                "answer_id": 69925314,
                "question_id": 69924653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Disregarding your template, why not simply calling\r\n\r\n```sh\r\njq &#39;map(\r\n  .patient = {name: .patientName, familyName: .patientFamilyName}\r\n  | del(.patientName, .patientFamilyName)\r\n)&#39; data.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/4lH1g9HaLO) (For this, I corrected your input JSON according to a presumed typo described in my [comment](https://stackoverflow.com/questions/69924653/jq-populate-json-data-using-a-json-template#comment123607303_69924653) above)\r\n",
                "title": "JQ: Populate json data using a json template"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636620780,
                "creation_date": 1636620780,
                "answer_id": 69925509,
                "question_id": 69924653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;query-by-example&quot; approach you envision in the question is do-able, though it is error-prone (and indeed as @pmf pointed out, your example contains an error).  This is how to realize the &quot;QBE&quot; approach based on matching &quot;$-names&quot; with key names:\r\n\r\n```\r\ndef matchName($name):\r\n   first(.. | objects | to_entries[] | select(.key == $name) | .value) // null ;\r\n\r\ndef fillin($t):\r\n  . as $in\r\n  | $t\r\n  | walk(if type == &quot;string&quot; and startswith(&quot;$&quot;)\r\n         then .[1:] as $s | $in | matchName($s)\r\n         else . end);\r\n\t \r\nmap(fillin(template))\r\n```\r\n  ",
                "title": "JQ: Populate json data using a json template"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1636621735,
        "creation_date": 1636616119,
        "last_edit_date": 1636619374,
        "question_id": 69924653,
        "body_markdown": "I&#39;d like to transform a &quot;raw&quot; json data transforming to other json structure.\r\n\r\nFor example:\r\n\r\n```\r\ndef template:\r\n{\r\n  &quot;id&quot;: &quot;$id&quot;,\r\n  &quot;practitioner&quot;: &quot;$practitioner&quot;,\r\n  &quot;patient&quot;: {\r\n    &quot;name&quot;: &quot;$patientName&quot;,\r\n    &quot;familyName&quot;: &quot;$patientFamilyName&quot;\r\n  }\r\n}\r\n;\r\n```\r\n\r\nMy data.json is:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;practitioner&quot;: {\r\n      &quot;practitionerKey1&quot;: &quot;practitionerValue1&quot;,\r\n      &quot;practitionerKey2&quot;: &quot;practitionerValue2&quot;\r\n    },\r\n    &quot;name&quot;: &quot;John&quot;,\r\n    &quot;familyName&quot;: &quot;Smith&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;practitioner&quot;: {\r\n      &quot;practitionerKey1&quot;: &quot;practitionerValue1&quot;,\r\n      &quot;practitionerKey2&quot;: &quot;practitionerValue2&quot;\r\n    },\r\n    &quot;patientName&quot;: &quot;Samuel&quot;,\r\n    &quot;patientFamilyName&quot;: &quot;Schnaider&quot;    \r\n  }\r\n]\r\n```\r\n\r\nMy desired result would be:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;practitioner&quot;: {\r\n      &quot;practitionerKey1&quot;: &quot;practitionerValue1&quot;,\r\n      &quot;practitionerKey2&quot;: &quot;practitionerValue2&quot;\r\n    },\r\n    &quot;patient&quot;: {\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;familyName&quot;: &quot;Smith&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;practitioner&quot;: {\r\n      &quot;practitionerKey1&quot;: &quot;practitionerValue1&quot;,\r\n      &quot;practitionerKey2&quot;: &quot;practitionerValue2&quot;\r\n    },\r\n    &quot;patient&quot;: {\r\n      &quot;name&quot;: &quot;Samuel&quot;,\r\n      &quot;familyName&quot;: &quot;Schnaider&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nAny ideas about how to map above data json and populate it using a json template with JQ?",
        "link": "https://stackoverflow.com/questions/69924653/jq-populate-json-data-using-a-json-template",
        "title": "JQ: Populate json data using a json template"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1636633471,
                "last_edit_date": 1636633471,
                "creation_date": 1636633044,
                "answer_id": 69928186,
                "question_id": 69927048,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n\r\n1) Use string manipulation to insert a newline (`\\n`) between each value, each line will now contain the value you&#39;re trying to catch\r\n2) Quote the `jq` command since it may contain spaces &lt;sup&gt;[\\[info\\]](https://stackoverflow.com/a/10067297/5625547)&lt;/sup&gt;\r\n3) Set `IFS` to a newline &lt;sup&gt;[\\[info\\]](&lt;https://unix.stackexchange.com/questions/184863/what-is-the-meaning-of-ifs-n-in-bash-scripting&gt;)&lt;/sup&gt;\r\n3) Use `read -d &#39;&#39;` &lt;sup&gt;[\\[docs\\]][1]&lt;/sup&gt;\r\n    &gt;  `-d delim`\r\n    &gt;\r\n    &gt;   continue until the first character of DELIM is read, rather\r\n                than newline\r\n\r\n\r\n----------\r\n\r\n\r\nApplying those fixes, the script will look like:\r\n```bash\r\nIFS=$&#39;\\n&#39;\r\nread -r -d &#39;&#39; totalIssues facetsArr issuesArr &lt;&lt;&lt; &quot;$( jq -r &#39;&quot;\\(.total)\\n\\(.facets[].values)\\n\\(.issues[])&quot;&#39; input)&quot;\r\necho &quot;total      : $totalIssues&quot;\r\necho &quot;facetsArr  : $facetsArr&quot;\r\necho &quot;issuesArr  : $issuesArr&quot;\r\n```\r\n&lt;sup&gt;**Note**: I&#39;ve replaced the curl command with an actual file called `input` containing OP&#39;s JSON&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\n\r\nThe output will be:\r\n```\r\ntotal      : 10057\r\nfacetsArr  : [{&quot;val&quot;:&quot;CRITICAL&quot;,&quot;count&quot;:5818},{&quot;val&quot;:&quot;MAJOR&quot;,&quot;count&quot;:1459},{&quot;val&quot;:&quot;BLOCKER&quot;,&quot;count&quot;:1286},{&quot;val&quot;:&quot;MINOR&quot;,&quot;count&quot;:1163},{&quot;val&quot;:&quot;INFO&quot;,&quot;count&quot;:331}]\r\nissuesArr  : {&quot;key&quot;:&quot;AX0NVCNfENszTAxEgX5e&quot;,&quot;rule&quot;:&quot;java:S122&quot;,&quot;severity&quot;:&quot;MINOR&quot;,&quot;component&quot;:&quot;my_project:SomeFile.java&quot;,&quot;project&quot;:&quot;my_project&quot;,&quot;line&quot;:241,&quot;hash&quot;:&quot;1111111111&quot;,&quot;textRange&quot;:{&quot;startLine&quot;:241,&quot;endLine&quot;:241,&quot;startOffset&quot;:0,&quot;endOffset&quot;:46},&quot;flows&quot;:[],&quot;status&quot;:&quot;OPEN&quot;,&quot;message&quot;:&quot;At most one statement is allowed per line, but 2 statements were found on this line.&quot;,&quot;effort&quot;:&quot;1min&quot;,&quot;debt&quot;:&quot;1min&quot;,&quot;author&quot;:&quot;eugeniur&quot;,&quot;tags&quot;:[&quot;convention&quot;],&quot;creationDate&quot;:&quot;2021-11-11T06:40:05+0200&quot;,&quot;updateDate&quot;:&quot;2021-11-11T06:40:05+0200&quot;,&quot;type&quot;:&quot;CODE_SMELL&quot;,&quot;scope&quot;:&quot;MAIN&quot;}\r\n```\r\n\r\n\r\n  [1]: https://linuxcommand.org/lc3_man_pages/readh.html",
                "title": "Can&#39;t assign multiple values to 3 variables"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1636637659,
                "creation_date": 1636637659,
                "answer_id": 69929194,
                "question_id": 69927048,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slightly inefficient, but it would be much simpler to just parse the (small) response 3 times.\r\n\r\n    #!/bin/bash\r\n    readonly BASE_URL=http://my_host:9111/api\r\n    readonly PROJECT_KEY=my_project\r\n    \r\n    response=$(curl -XGET &quot;$BASE_URL/issues/search?componentKeys=$PROJECT_KEY&amp;facets=severities&amp;p=1&amp;ps=1&quot;)\r\n    \r\n    total=$(jq &#39;.total&#39; &lt;&lt;&lt; &quot;$response&quot;)\r\n    issues=$(jq &#39;.issues&#39; &lt;&lt;&lt; &quot;$response&quot;)\r\n    facets=$(jq &#39;.facets[].values&#39; &lt;&lt;&lt; &quot;$response&quot;)\r\n    \r\n    # ...\r\n\r\nThen you don&#39;t have to worry about constructing a single output with `jq` that `bash` must parse anyway.\r\n\r\n(I&#39;ve intentionally left the value of `issues` a JSON array, rather than a stream of `issues`, in the event that there is more than a single object in the array.)",
                "title": "Can&#39;t assign multiple values to 3 variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1636637659,
        "creation_date": 1636627898,
        "question_id": 69927048,
        "body_markdown": "Request\r\n\r\n    curl -XGET http\\://my_host\\:9111/api/issues/search\\?componentKeys\\=my_poject\\&amp;facets\\=severities\\&amp;p\\=1\\&amp;ps\\=1\r\n\r\nHere response:\r\n\r\n    {\r\n      &quot;total&quot;: 10057,\r\n      &quot;p&quot;: 1,\r\n      &quot;ps&quot;: 1,\r\n      &quot;paging&quot;: {\r\n        &quot;pageIndex&quot;: 1,\r\n        &quot;pageSize&quot;: 1,\r\n        &quot;total&quot;: 10057\r\n      },\r\n      &quot;effortTotal&quot;: 51031,\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;AX0NVCNfENszTAxEgX5e&quot;,\r\n          &quot;rule&quot;: &quot;java:S122&quot;,\r\n          &quot;severity&quot;: &quot;MINOR&quot;,\r\n          &quot;component&quot;: &quot;my_project:SomeFile.java&quot;,\r\n          &quot;project&quot;: &quot;my_project&quot;,\r\n          &quot;line&quot;: 241,\r\n          &quot;hash&quot;: &quot;1111111111&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 241,\r\n            &quot;endLine&quot;: 241,\r\n            &quot;startOffset&quot;: 0,\r\n            &quot;endOffset&quot;: 46\r\n          },\r\n          &quot;flows&quot;: [],\r\n          &quot;status&quot;: &quot;OPEN&quot;,\r\n          &quot;message&quot;: &quot;At most one statement is allowed per line, but 2 statements were found on this line.&quot;,\r\n          &quot;effort&quot;: &quot;1min&quot;,\r\n          &quot;debt&quot;: &quot;1min&quot;,\r\n          &quot;author&quot;: &quot;eugeniur&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;convention&quot;\r\n          ],\r\n          &quot;creationDate&quot;: &quot;2021-11-11T06:40:05+0200&quot;,\r\n          &quot;updateDate&quot;: &quot;2021-11-11T06:40:05+0200&quot;,\r\n          &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n          &quot;scope&quot;: &quot;MAIN&quot;\r\n        }\r\n      ],\r\n      &quot;components&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;my_project&quot;,\r\n          &quot;enabled&quot;: true,\r\n          &quot;qualifier&quot;: &quot;TRK&quot;,\r\n          &quot;name&quot;: &quot;Parent&quot;,\r\n          &quot;longName&quot;: &quot;Parent&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;my_project:MyFile.java&quot;,\r\n          &quot;enabled&quot;: true,\r\n          &quot;qualifier&quot;: &quot;FIL&quot;,\r\n          &quot;name&quot;: &quot;XStartDServerComponent.java&quot;,\r\n          &quot;longName&quot;: &quot;MyFile.java&quot;,\r\n          &quot;path&quot;: &quot;MyFile.java&quot;\r\n        }\r\n      ],\r\n      &quot;facets&quot;: [\r\n        {\r\n          &quot;property&quot;: &quot;severities&quot;,\r\n          &quot;values&quot;: [\r\n            {\r\n              &quot;val&quot;: &quot;CRITICAL&quot;,\r\n              &quot;count&quot;: 5818\r\n            },\r\n            {\r\n              &quot;val&quot;: &quot;MAJOR&quot;,\r\n              &quot;count&quot;: 1459\r\n            },\r\n            {\r\n              &quot;val&quot;: &quot;BLOCKER&quot;,\r\n              &quot;count&quot;: 1286\r\n            },\r\n            {\r\n              &quot;val&quot;: &quot;MINOR&quot;,\r\n              &quot;count&quot;: 1163\r\n            },\r\n            {\r\n              &quot;val&quot;: &quot;INFO&quot;,\r\n              &quot;count&quot;: 331\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\nNow I want to extract keys: `&quot;total&quot;, &quot;issues&quot;, &quot;facets.values&quot;`.\r\n\r\nSo I try this in my bash script:\r\n\r\n    #!/bin/bash\r\n    readonly BASE_URL=http://my_host:9111/api\r\n    readonly PROJECT_KEY=my_project\r\n    \r\n    read totalIssues facetsArr issuesArr &lt; &lt;(echo $(curl -XGET $BASE_URL/issues/search\\?componentKeys\\=$PROJECT_KEY\\&amp;facets\\=severities\\&amp;p\\=1\\&amp;ps\\=1 |\r\n    \t\t\t\t\t   jq -r &#39;.total, .issues[], .facets[].values&#39;))\r\n    echo &quot;total      : $totalIssues&quot;\r\n    echo &quot;facetsArr     : $facetsArr&quot;\r\n    echo &quot;issuesArr  : $issuesArr&quot;\r\n\r\nBut result is:\r\n\r\n    total      : 10057\r\n    facetsArr  : {\r\n    issuesArr  : &quot;key&quot;: &quot;AX0NVCNfENszTAxEgX5e&quot;, &quot;rule&quot;: &quot;java:S122&quot;, &quot;severity&quot;: &quot;MINOR&quot;, &quot;component&quot;: &quot;MyFile.java&quot;, &quot;project&quot;: &quot;myProject&quot;, &quot;line&quot;: 241, &quot;hash&quot;: &quot;b68d3b4b390c81e2714d263b31acdd08&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 241, &quot;endLine&quot;: 241, &quot;startOffset&quot;: 0, &quot;endOffset&quot;: 46 }, &quot;flows&quot;: [], &quot;status&quot;: &quot;OPEN&quot;, &quot;message&quot;: &quot;At most one statement is allowed per line, but 2 statements were found on this line.&quot;, &quot;effort&quot;: &quot;1min&quot;, &quot;debt&quot;: &quot;1min&quot;, &quot;author&quot;: &quot;eugeniur&quot;, &quot;tags&quot;: [ &quot;convention&quot; ], &quot;creationDate&quot;: &quot;2021-11-11T06:40:05+0200&quot;, &quot;updateDate&quot;: &quot;2021-11-11T06:40:05+0200&quot;, &quot;type&quot;: &quot;CODE_SMELL&quot;, &quot;scope&quot;: &quot;MAIN&quot; } [ { &quot;val&quot;: &quot;CRITICAL&quot;, &quot;count&quot;: 5818 }, { &quot;val&quot;: &quot;MAJOR&quot;, &quot;count&quot;: 1459 }, { &quot;val&quot;: &quot;BLOCKER&quot;, &quot;count&quot;: 1286 }, { &quot;val&quot;: &quot;MINOR&quot;, &quot;count&quot;: 1163 }, { &quot;val&quot;: &quot;INFO&quot;, &quot;count&quot;: 331 } ]\r\n\r\n\r\nWhy &quot;**facetsArr**&quot; get incorrect value?\r\n\r\nThe &quot;**facetsArr**&quot; must be:\r\n\r\n    facetsArr  : [ { &quot;val&quot;: &quot;CRITICAL&quot;, &quot;count&quot;: 5818 }, { &quot;val&quot;: &quot;MAJOR&quot;, &quot;count&quot;: 1459 }, { &quot;val&quot;: &quot;BLOCKER&quot;, &quot;count&quot;: 1286 }, { &quot;val&quot;: &quot;MINOR&quot;, &quot;count&quot;: 1163 }, { &quot;val&quot;: &quot;INFO&quot;, &quot;count&quot;: 331 } ]\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69927048/cant-assign-multiple-values-to-3-variables",
        "title": "Can&#39;t assign multiple values to 3 variables"
    },
    {
        "tags": [
            "post",
            "terminal",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1636637648,
                "post_id": 69928771,
                "comment_id": 123614052,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660469335,
                "creation_date": 1660469335,
                "answer_id": 73350512,
                "question_id": 69928771,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`data` is a function invocation and there is no such function in jq. If you are trying to access the `&quot;data&quot;` property of an object, you need to use an [Object Identifier-Index filter](https://github.com/api/v3/repos/Myrepo/test/latest). These filters always start with a `.`:\r\n\r\n    jq &#39;.data.attributes.bearerToken&#39;\r\n\r\n* `jq &#39;data&#39;` tries to invoke the parameterless function &quot;data&quot;\r\n* `jq &#39;.data&#39;` filters for and returns the value of the &quot;data&quot; property in an object, e.g. `42` for input `{&quot;data&quot;: 42}`",
                "title": "POST request with terminal - jq error: data/0 is not defined at &lt;top-level&gt;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660469335,
        "creation_date": 1636635874,
        "question_id": 69928771,
        "body_markdown": "I am trying to do a POST request through a terminal command:\r\n\r\n    curl --request POST -H &#39;Content-type: application/vnd.myapp.api+json&#39; \\\r\n        -H &#39;Authorization: Bearer $77777uTlmlHRfyoUj.$3333DZpH0XB0ER6W3Y.22227WYZZ6xSTQd/J5AvOqA1&#39; \\\r\n        -d &#39;{&quot;data&quot;:{&quot;id&quot;:&quot;mytoken&quot;,&quot;type&quot;:&quot;jwtToken&quot;}}&#39; \\\r\n        https://app.com/api/entities/users/apiTokens | \\\r\n          jq data.attributes.bearerToken\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n      0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0jq: \r\n\r\nBut, I get an error:\r\n\r\n    error: data/0 is not defined at &lt;top-level&gt;, line 1:\r\n        data.attributes.bearerToken\r\n        jq: 1 compile error\r\n\r\n\r\nWhat am I doing wrong here?",
        "link": "https://stackoverflow.com/questions/69928771/post-request-with-terminal-jq-error-data-0-is-not-defined-at-top-level",
        "title": "POST request with terminal - jq error: data/0 is not defined at &lt;top-level&gt;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1636651280,
                "last_edit_date": 1636651280,
                "creation_date": 1636644435,
                "answer_id": 69930847,
                "question_id": 69930540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq --arg ad 192.168.5.5 -r &#39;.name = &quot;Addr &quot; + $ad&#39; address.tmpl\r\n\r\n`$ad` will be expanded by the shell if it is not not hard quoted. In `jq`, you can use string interpolation `&quot;Addr \\($ad)&quot;`, or concatenation (as above), which I find slightly more readable.",
                "title": "jq not writing value of variable but the actual text of the variable name"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1636644520,
                "creation_date": 1636644520,
                "answer_id": 69930865,
                "question_id": 69930540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In [the `jq` manual](https://stedolan.github.io/jq/manual), search for &quot;String interpolation&quot;\r\n```sh\r\njq --arg ad &quot;192.168.5.5&quot; -r &#39;.name = &quot;Addr \\($ad)&quot;&#39;\r\n```",
                "title": "jq not writing value of variable but the actual text of the variable name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1636651280,
        "creation_date": 1636643111,
        "last_edit_date": 1636644047,
        "question_id": 69930540,
        "body_markdown": "I&#39;m scripting in bash to edit a json template to replace some field values with arguments to my script, and trying to use jq to do the editing. My code is not replacing the --arg with the value of the argument, but the literal text of the argument name.\r\n\r\nMy template contains:\r\n\r\n    {\r\n    &quot;name&quot;:&quot;&quot;\r\n    }\r\n\r\nMy jq code:\r\n\r\n    jq --arg ad &quot;192.168.5.5&quot; -r &#39;.name = &quot;Addr $ad&quot;&#39; address.tmpl\r\n\r\nThis outputs:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Addr $ad&quot;\r\n    }\r\n\r\nOr, if I remove the double-quotes\r\n\r\n    jq --arg ad &quot;192.168.5.5&quot; -r &#39;.name = Addr $ad&#39; address.tmpl\r\n\r\nI get\r\n\r\n    jq: error: syntax error, unexpected &#39;$&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .name = Addr $ad\r\n    jq: 1 compile error\r\n\r\nAccording to all that I have read, this should work. What am I doing wrong/how do I fix this????\r\n\r\nOS = debian 10",
        "link": "https://stackoverflow.com/questions/69930540/jq-not-writing-value-of-variable-but-the-actual-text-of-the-variable-name",
        "title": "jq not writing value of variable but the actual text of the variable name"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 23298398,
                    "reputation": 20,
                    "user_id": 17379464,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08c669fab9d383c4a8d90c6aaef4838e?s=256&d=identicon&r=PG",
                    "display_name": "net_solv",
                    "link": "https://stackoverflow.com/users/17379464/net-solv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636659073,
                "post_id": 69931773,
                "comment_id": 123622787,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636660299,
                "last_edit_date": 1636660299,
                "creation_date": 1636649105,
                "answer_id": 69931939,
                "question_id": 69931773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this\r\n\r\n```sh\r\njq --slurp --raw-output &#39;\r\n  map(select(.resp_ip_bytes &gt; 0 ... your conditions here ...))\r\n  | group_by([.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;])\r\n  | map(length as $count | .[] | .count = $count)\r\n  | sort_by([-.count, -.resp_ip_bytes]) | first\r\n  | [.&quot;id.orig_h&quot;, &quot;-&gt;&quot;, .&quot;id.resp_h&quot;, &quot;|&quot;, .count]\r\n  | join(&quot; &quot;)\r\n&#39;\r\n```\r\n\r\nThis inserts another field value `count` with the number of connections, then sorts first by the highest `count`, then by the highest `resp_ip_bytes`, takes the first match an formats the output as desired.\r\n",
                "title": "Consolidate stream of json objects with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636665115,
                "last_edit_date": 1636665115,
                "creation_date": 1636664574,
                "answer_id": 69934885,
                "question_id": 69931773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although the built-in `group_by` is convenient, it can be very inefficient with respect to both space and time, and the following alternative may be especially appropriate in the context of very long log files.\r\n\r\nNotice that `inputs` is used with the -n command-line option:\r\n```\r\n&lt; log.json jq -nr &#39;\r\n# Emit a stream of arrays, each array being a group defined by a value of f,\r\n# which can be any jq filter that produces exactly one value for each item in `stream`.\r\ndef GROUPS_BY(stream; f): \r\n   reduce stream as $x ({};\r\n     ($x|f) as $s\r\n     | ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s else ($s|tojson) end) as $y\r\n     | .[$t][$y] += [$x] )\r\n   | .[][] ;\r\n\r\nGROUPS_BY(inputs\r\n          | select(.resp_ip_bytes &gt; 0 and\r\n                   .orig_ip_bytes &gt; 0 and\r\n                   .duration &gt; 0 and .orig_bytes &gt; 0 and\r\n                   .resp_bytes &gt;0);\r\n          [.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;] ) \r\n| (first | &quot;\\(.&quot;id.orig_h&quot;) -&gt; \\(.&quot;id.resp_h&quot;)&quot; ) +\r\n  ( .[]  | &quot; | \\(length)&quot; )\r\n&#39;\r\n```\r\n\r\n---\r\nNotes:\r\n\r\na) `GROUPS_BY` as defined above is stream-oriented, both with respect to its input and its output.  Apart from that, the main functional difference between `GROUPS_BY` and `group_by` is that the latter involves a sort.\r\n\r\nb) `GROUPS_BY/2` as defined above is relatively complex because it is designed to have the full generality of `group_by`, for which it is almost a plug-in alternative. Specifically, `E | group_by(F)` is functionally equivalent to:\r\n```\r\n[GROUPS_BY(E[]; F)] | sort_by(F)\r\n```\r\n",
                "title": "Consolidate stream of json objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1636665115,
        "creation_date": 1636648317,
        "last_edit_date": 1636662269,
        "question_id": 69931773,
        "body_markdown": "Premise: Looking to parse stream of objects from a json log file and output the total number of times &quot;id.orig_h&quot; connects to &quot;id.resp_h&quot; based on certain conditions and show the total count. \r\n\r\nSample json input:\r\n```\r\njq --slurp --raw-output . \r\n   \r\n  {\r\n    &quot;ts&quot;: 1636606.998991,\r\n    &quot;uid&quot;: &quot;CgbTrLvhqHAa&quot;,\r\n    &quot;id.orig_h&quot;: &quot;10.8.21.11&quot;,\r\n    &quot;id.orig_p&quot;: 54858,\r\n    &quot;id.resp_h&quot;: &quot;10.8.21.66&quot;,\r\n    &quot;id.resp_p&quot;: 5044,\r\n    &quot;proto&quot;: &quot;tcp&quot;,\r\n    &quot;conn_state&quot;: &quot;S0&quot;,\r\n    &quot;local_orig&quot;: true,\r\n    &quot;local_resp&quot;: true,\r\n    &quot;missed_bytes&quot;: 0,\r\n    &quot;history&quot;: &quot;S&quot;,\r\n    &quot;orig_pkts&quot;: 1,\r\n    &quot;orig_ip_bytes&quot;: 60,\r\n    &quot;resp_pkts&quot;: 0,\r\n    &quot;resp_ip_bytes&quot;: 0\r\n  },\r\n  {\r\n    &quot;ts&quot;: 1636638.028568,\r\n    &quot;uid&quot;: &quot;CFNumGx3XYWW7&quot;,\r\n    &quot;id.orig_h&quot;: &quot;fe80::ba:61:fe3f:80&quot;,\r\n    &quot;id.orig_p&quot;: 130,\r\n    &quot;id.resp_h&quot;: &quot;ff02::1&quot;,\r\n    &quot;id.resp_p&quot;: 131,\r\n    &quot;proto&quot;: &quot;icmp&quot;,\r\n    &quot;duration&quot;: 3420.447889374,\r\n    &quot;orig_bytes&quot;: 2608,\r\n    &quot;resp_bytes&quot;: 0,\r\n    &quot;conn_state&quot;: &quot;OTH&quot;,\r\n    &quot;local_orig&quot;: false,\r\n    &quot;local_resp&quot;: false,\r\n    &quot;missed_bytes&quot;: 0,\r\n    &quot;orig_pkts&quot;: 163,\r\n    &quot;orig_ip_bytes&quot;: 11736,\r\n    &quot;resp_pkts&quot;: 0,\r\n    &quot;resp_ip_bytes&quot;: 0\r\n  },\r\n  {\r\n    &quot;ts&quot;: 1636526872.598889,\r\n    &quot;uid&quot;: &quot;Cq9JTE1OweOW6mi&quot;,\r\n    &quot;id.orig_h&quot;: &quot;fe::63:88:14f5:b5&quot;,\r\n    &quot;id.orig_p&quot;: 131,\r\n    &quot;id.resp_h&quot;: &quot;ff02::fb&quot;,\r\n    &quot;id.resp_p&quot;: 130,\r\n    &quot;proto&quot;: &quot;icmp&quot;,\r\n    &quot;duration&quot;: 81086.88094513,\r\n    &quot;orig_bytes&quot;: 64000,\r\n    &quot;resp_bytes&quot;: 0,\r\n    &quot;conn_state&quot;: &quot;OTH&quot;,\r\n    &quot;local_orig&quot;: false,\r\n    &quot;local_resp&quot;: false,\r\n    &quot;missed_bytes&quot;: 0,\r\n    &quot;orig_pkts&quot;: 4000,\r\n    &quot;orig_ip_bytes&quot;: 288000,\r\n    &quot;resp_pkts&quot;: 0,\r\n    &quot;resp_ip_bytes&quot;: 0\r\n  },\r\n  {\r\n    &quot;ts&quot;: 1636604547.798971,\r\n    &quot;uid&quot;: &quot;Cs41IjaZTAdF7f&quot;,\r\n    &quot;id.orig_h&quot;: &quot;fe::63:88:14f5:b5&quot;,\r\n    &quot;id.orig_p&quot;: 131,\r\n    &quot;id.resp_h&quot;: &quot;ff02::1:ff:b5&quot;,\r\n    &quot;id.resp_p&quot;: 130,\r\n    &quot;proto&quot;: &quot;icmp&quot;,\r\n    &quot;duration&quot;: 3414.3990546265,\r\n    &quot;orig_bytes&quot;: 2608,\r\n    &quot;resp_bytes&quot;: 0,\r\n    &quot;conn_state&quot;: &quot;OTH&quot;,\r\n    &quot;local_orig&quot;: false,\r\n    &quot;local_resp&quot;: false,\r\n    &quot;missed_bytes&quot;: 0,\r\n    &quot;orig_pkts&quot;: 163,\r\n    &quot;orig_ip_bytes&quot;: 11736,\r\n    &quot;resp_pkts&quot;: 0,\r\n    &quot;resp_ip_bytes&quot;: 0\r\n   }\r\n```\r\nI believe the conditions part is good\r\n```\r\n    jq -r &#39;. | select(.resp_ip_bytes &gt; 0 and .orig_ip_bytes &gt; 0 and .duration &gt; 0 and .orig_bytes &gt; 0 and .resp_bytes &gt;0)&#39;\r\n```\r\n\r\nHowever every time I try a \r\n```\r\n    group_by([.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;]), \r\n```\r\ngetting --&gt; Cannot index number with string &quot;id.orig_h&quot;\r\n\r\nDesired Output:\r\n```\r\n1.1.1.1 -&gt; 2.2.2.2 | XXXX &lt;- # of times\r\n```\r\nHere is the output without the join(&quot; &quot;)\r\n```\r\njq -sr &#39;map(select(.resp_ip_bytes &gt; 0 and .orig_ip_bytes &gt; 0 and .duration &gt; 0 and .orig_bytes &gt; 0 and .resp_bytes &gt;0)) | group_by([.&quot;id.orig_h&quot;, .&quot;id.resp_h&quot;]) | map(length as $count | .[] | .count = $count) | sort_by([-.count, -.resp_ip_bytes]) | first | [.&quot;id.orig_h&quot;, &quot;-&gt;&quot;, .&quot;id.resp_h&quot;, &quot;|&quot;, .count]&#39;\r\n[\r\n  &quot;10.8.21.11&quot;,\r\n  &quot;-&gt;&quot;,\r\n  &quot;10.8.21.123&quot;,\r\n  &quot;|&quot;,\r\n  225 &lt;--(not sure it matters but output on .count is yellow, all other output is green)\r\n]\r\n```\r\n\r\nWith the join(&quot; &quot;) \r\n```\r\nstring (&quot; &quot;) and number (225) cannot be added\r\n```",
        "link": "https://stackoverflow.com/questions/69931773/consolidate-stream-of-json-objects-with-jq",
        "title": "Consolidate stream of json objects with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636671560,
                "post_id": 69935407,
                "comment_id": 123626337,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636708418,
                "last_edit_date": 1636708418,
                "creation_date": 1636668138,
                "answer_id": 69935454,
                "question_id": 69935407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Explicitly\r\n```sh\r\njq -s &#39;[map(.[0][]),map(.[1][])]&#39;  file1.json file2.json\r\n```\r\n\r\nImplicitly\r\n```sh\r\njq -s &#39;transpose | map(flatten)&#39;  file*.json\r\n```\r\n\r\nOr as suggested by @peak\r\n```sh\r\njq -s &#39;transpose | map(add)&#39; file*.json\r\n```",
                "title": "Using jq is there an easy way to combine json objects into an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1636708418,
        "creation_date": 1636667821,
        "question_id": 69935407,
        "body_markdown": "I have two simple jsons that I want to combine into one. I am trying to bake this into some automation so that I will not need to manually combine the two each time. Is there a way with jq to combine file1.json with file2.json so that the output looks like desired.json?\r\n\r\n\r\nfile1.json\r\n\r\n    [\r\n      [\r\n        &quot;1&quot;,\r\n        &quot;2&quot;\r\n      ],\r\n      [\r\n        &quot;a&quot;,\r\n        &quot;b&quot;\r\n      ]\r\n    ]\r\n\r\nfile2.json\r\n\r\n    [\r\n      [\r\n        &quot;3&quot;\r\n      ],\r\n      [\r\n        &quot;c&quot;\r\n      ]\r\n    ]\r\n\r\n\r\ndesired.json\r\n\r\n    [\r\n      [\r\n        &quot;1&quot;,\r\n        &quot;2&quot;,\r\n        &quot;3&quot;\r\n      ],\r\n      [\r\n        &quot;a&quot;,\r\n        &quot;b&quot;,\r\n        &quot;c&quot;\r\n      ]\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69935407/using-jq-is-there-an-easy-way-to-combine-json-objects-into-an-array",
        "title": "Using jq is there an easy way to combine json objects into an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636689180,
                "creation_date": 1636689180,
                "answer_id": 69937759,
                "question_id": 69936884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For &quot;in-place&quot; deletion of a key, you might find `walk` quite congenial:\r\n```\r\nwalk(if type == &quot;object&quot; and .__typename == &quot;MyType&quot; \r\n     then del(.delete_me) else . end)\r\n```",
                "title": "Traverse JSON object/array and delete field of selected objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636692358,
        "creation_date": 1636680143,
        "last_edit_date": 1636692358,
        "question_id": 69936884,
        "body_markdown": "I have a bunch of JSON files (fixtures) from which I need to delete a field if the &quot;current&quot; object happens to match a `select` filter. \r\n\r\nI&#39;m able to match the desired objects but I&#39;m not sure how to perform the deletion of the field so that the object is modified in-place. \r\n\r\nSo far this is the closest I&#39;ve gotten to:\r\n\r\n```bash\r\njq &#39;..|objects|select(.__typename == &quot;MyType&quot;) | del(.delete_me)&#39; fixture.json\r\n```\r\nBut doesn&#39;t seem to work correctly, assignment of the field is straight forward I&#39;m thinking I could probably try and use `path as $paths` and `getpath` to set the &quot;parent&quot; value with the output of `del` but I&#39;m stuck and don&#39;t quite fully understand the functions.\r\n\r\nAny help is really appreciated!",
        "link": "https://stackoverflow.com/questions/69936884/traverse-json-object-array-and-delete-field-of-selected-objects",
        "title": "Traverse JSON object/array and delete field of selected objects"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1636688962,
                "creation_date": 1636688962,
                "answer_id": 69937735,
                "question_id": 69937562,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing a very small technical problem with your JSON, the following produces the required result:\r\n```\r\nmap( {id,\r\n      assigneeId: .assignee.id,\r\n      assigneeName: (.assignee | .firstName + &quot; &quot; + .lastName),\r\n      epicsid: .epics[0].id,\r\n      location } )\r\n```\r\n\r\nYou might wish to modify this if the &quot;epics&quot; array has more than one item in it.\r\n",
                "title": "Parsing nested JSON and creating new keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636688962,
        "creation_date": 1636687294,
        "question_id": 69937562,
        "body_markdown": "I have a JSON file that has hundreds of objects. Each object has 2 keys with nested object\\arrays one for assignee and another for epics.  \r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1111111111,\r\n        &quot;assignee&quot;: {\r\n          &quot;id&quot;: 1234,\r\n          &quot;firstName&quot;: &quot;John&quot;,\r\n          &quot;lastName&quot;: &quot;Doe&quot;,\r\n          &quot;email&quot;: &quot;Doe@doe.com&quot;,   \r\n        },\r\n        &quot;epics&quot;: [\r\n          {\r\n            &quot;id&quot;: 111,\r\n            &quot;title&quot;: &quot;Big Code Issues&quot;,\r\n            &quot;version&quot;: 16\r\n          }\r\n        ],\r\n        &quot;location&quot;: &quot;Nerdville&quot;\r\n      }\r\n    ]\r\n\r\nfrom the current assignee key.  I want to create a two new keys assigneeId and assigneeName.  Where the assigneeName is the firstName and lastName combined.  The original nested assignee key can be discarded.\r\n\r\nfrom the epics key I would like to create and epicsID key with a value of id from epics.  The rest of the keys in the nested key can be discarded.\r\n\r\n     \r\nI am very new to jq but i would like to create following output.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1111111111,\r\n        &quot;assigneeId&quot;: 1234,\r\n        &quot;assingeeName&quot;: &quot;John Doe&quot;,\r\n        &quot;epicsid&quot;: 111,\r\n        &quot;location&quot;: &quot;Nerdville&quot;\r\n      }\r\n    ]\r\n\r\nI can create and remove keys with JQ but I am have not been able to iterate the JSON file to grab values from with the nested keys and put into new keys. I have been getting errors based on different command I been running but the main one is &quot;Cannot index array with string &quot;epics&quot;&quot;. \r\n\r\nAny help would be greatly appreciated\r\n",
        "link": "https://stackoverflow.com/questions/69937562/parsing-nested-json-and-creating-new-keys-with-jq",
        "title": "Parsing nested JSON and creating new keys with jq"
    },
    {
        "tags": [
            "bash",
            "docker",
            "jq",
            "traefik"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636702302,
                "creation_date": 1636702302,
                "answer_id": 69939324,
                "question_id": 69939211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the option `--arg` to pass arguments to `jq`.\r\n\r\n    jq --arg url http://172.18.0.17:3000 -r &#39;.serverStatus[$url]&#39;\r\n\r\nAlways use this option to avoid security problems by injections.",
                "title": "Bash getting escaped variable key value with script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1636702410,
                "creation_date": 1636702410,
                "answer_id": 69939344,
                "question_id": 69939211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of the preferred ways to pass specific environment variables into jq is using the `--arg` command-line option; in your case:\r\n\r\n```\r\njq -r --arg url &quot;${NEW_ENV_URL}&quot;  &#39;.serverStatus[$url]&#39;\r\n```",
                "title": "Bash getting escaped variable key value with script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1636702410,
        "creation_date": 1636701516,
        "question_id": 69939211,
        "body_markdown": "I want to use jq to get value&#39;s out of a the Traefik API service. The output of the service looks like this:\r\n\r\n```\r\n{\r\n  &quot;loadBalancer&quot;: {\r\n    &quot;servers&quot;: [\r\n      {\r\n        &quot;url&quot;: &quot;http://172.18.0.19:3000&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;http://172.18.0.17:3000&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;http://172.20.0.3:3000&quot;\r\n      }\r\n    ],\r\n    &quot;healthCheck&quot;: {\r\n      &quot;path&quot;: &quot;/health&quot;,\r\n      &quot;interval&quot;: &quot;10s&quot;,\r\n      &quot;timeout&quot;: &quot;10s&quot;,\r\n      &quot;followRedirects&quot;: true\r\n    },\r\n    &quot;passHostHeader&quot;: true\r\n  },\r\n  &quot;status&quot;: &quot;enabled&quot;,\r\n  &quot;serverStatus&quot;: {\r\n    &quot;http://172.18.0.17:3000&quot;: &quot;UP&quot;,\r\n    &quot;http://172.18.0.19:3000&quot;: &quot;UP&quot;,\r\n    &quot;http://172.20.0.3:3000&quot;: &quot;DOWN&quot;\r\n  },\r\n  &quot;provider&quot;: &quot;docker&quot;,\r\n  &quot;type&quot;: &quot;loadbalancer&quot;\r\n}\r\n```\r\n\r\nI want to get the value of the `serverStatus` dynamically. First assigning a variable with the correct IP address from docker inspect. I&#39;m using `curl` with `jq` to check if the container is being serviced.\r\n\r\nThe problem is when getting it with a variable I cannot seem to escape the special characters in the url key. **Nothing is returned**.\r\n\r\nThis is the command I use is:\r\n\r\n```\r\nTRAEFIK_URL=&quot;http://someurl.com/&quot;\r\nTRAEFIK_URL=&quot;&#39;Authorization: Basic hashkey&quot;\r\nNEW_IPADDRESS=$(docker container inspect some_container_name | jq -r .[].NetworkSettings.Networks.proxy.IPAddress)\r\nNEW_ENV_URL=&quot;http://${NEW_IPADDRESS}:3000&quot;\r\n\r\ncurl --location --request GET &quot;$TRAEFIK_URL&quot; --header &quot;$TRAEFIK_AUTH_HEADER&quot; | jq -r &#39;.serverStatus[&quot;${NEW_ENV_URL}&quot;]&#39;\r\n```\r\n\r\nI&#39;ve tried using this command and some other obvious options but all didn&#39;t work.\r\n```\r\njq -r .serverStatus[$NEW_ENV_URL]\r\n``` \r\n\r\n\r\nI do get the correct value when I&#39;m not using a variable to get the status using:\r\n\r\n```\r\n jq -r &#39;.serverStatus[&quot;http://172.18.0.17:3000&quot;]&#39;\r\n```\r\n\r\nAny help is welcome.",
        "link": "https://stackoverflow.com/questions/69939211/bash-getting-escaped-variable-key-value-with-script",
        "title": "Bash getting escaped variable key value with script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1636717751,
                "last_edit_date": 1636717751,
                "creation_date": 1636715227,
                "answer_id": 69941941,
                "question_id": 69941773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the ID in a variable and add it as a new field to each array member.\r\n```sh\r\n jq &#39;map(.id as $sId | .tasks[] += {$sId})&#39; file.json\r\n```\r\n[Demo](https://jqplay.org/s/jKtaM9Lv82)\r\n\r\nNote #1: Get rid of the final `,` within each object (see the Demo), as it&#39;s not proper JSON.\r\n\r\nNote #2: Object fields generally have no order, but if you want to have the propagated ID shown first, as seen in your expected output, you could try to replace `+= {$sId}` (which by itself is shorthand for `|= . + {$sId}`) with `|= {$sId} + .` to flip the order of generation ([Demo](https://jqplay.org/s/tc2XmjlD4a)). Although there is no guarantee that it stays that way with further processing.\r\n",
                "title": "Updating Nested JSON Array with new key and value from another key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636746739,
        "creation_date": 1636714515,
        "last_edit_date": 1636746739,
        "question_id": 69941773,
        "body_markdown": "I have have a JSON file where I have IDs with tasks.  Some tasks can be empty.  I want to put the ID into the tasks where tasks are not empty.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1961126,\r\n        &quot;tasks&quot;: [\r\n          {\r\n            &quot;id&quot;: 70340700,\r\n            &quot;title&quot;: &quot;Test1&quot;,\r\n          },\r\n          {\r\n            &quot;id&quot;: 69801130,\r\n            &quot;title&quot;: &quot;Test15A&quot;,\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 1961126,\r\n        &quot;tasks&quot;: []\r\n      }           \r\n    ]  \r\n\r\nI would like to get the tasks array updated to look like\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1961126,\r\n        &quot;tasks&quot;: [\r\n          {\r\n            **&quot;sId&quot;:1961126,**\r\n            &quot;id&quot;: 70340700,\r\n            &quot;title&quot;: &quot;Test1&quot;,\r\n          },\r\n          {\r\n            **&quot;sId&quot;:1961126,**\r\n            &quot;id&quot;: 69801130,\r\n            &quot;title&quot;: &quot;Test15A&quot;,\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 1961126,\r\n        &quot;tasks&quot;: []\r\n      }           \r\n    ] \r\n\r\nI can&#39;t figure out how to get the id from the object into the nested array.  Here is what I have come up with\r\n\r\n    jq &#39;map(.tasks[0]|select( . != null )|.sId = .id)&#39; file.json\r\n\r\nThis is only pulling in the same id.  I have tired to put in `[].id` but I get a error `Cannot index number with string &quot;id&quot;.`  I am still learning how to deal with nested arrays and objects.\r\n",
        "link": "https://stackoverflow.com/questions/69941773/updating-nested-json-array-with-new-key-and-value-from-another-key",
        "title": "Updating Nested JSON Array with new key and value from another key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1636719146,
                "last_edit_date": 1636719146,
                "creation_date": 1636718069,
                "answer_id": 69942545,
                "question_id": 69942402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n[ paths(scalars) as $p | { &quot;key&quot;: $p | join(&quot;_&quot;), &quot;value&quot;: getpath($p) } ] | from_entries\r\n```\r\n\r\nWill generate\r\n```json\r\n{\r\n  &quot;welcome_title&quot;: &quot;Hello World&quot;,\r\n  &quot;block1_header&quot;: &quot;My Header&quot;,\r\n  &quot;block1_body&quot;: &quot;My BODY of block 1&quot;,\r\n  &quot;block1_footer&quot;: &quot;My Footer&quot;,\r\n  &quot;multi_level-01-A_head&quot;: &quot;Head Section&quot;,\r\n  &quot;multi_level-01-A_foot&quot;: &quot;Foot Section&quot;,\r\n  &quot;multi_level-01-A_level-02-A_head&quot;: &quot;Head Section Level 2 A&quot;,\r\n  &quot;multi_level-01-A_level-02-A_fead&quot;: &quot;Foot Section Level 2 A&quot;,\r\n  &quot;multi_level-01-A_level-02-B_head&quot;: &quot;Head Section Level 2 B&quot;,\r\n  &quot;multi_level-01-A_level-02-B_fead&quot;: &quot;Foot Section Level 2 B&quot;,\r\n  &quot;multi_level-01-B_head&quot;: &quot;Head Section&quot;,\r\n  &quot;multi_level-01-B_foot&quot;: &quot;Foot Section&quot;,\r\n  &quot;multi_no-level&quot;: &quot;Foo Bar&quot;\r\n}\r\n```\r\n\r\nAs you can test [in this online demo](https://jqplay.org/s/bPOxbPKyFc)\r\n\r\n----------\r\n\r\n&gt; `paths` &lt;sup&gt;[\\[docs\\]](https://stedolan.github.io/jq/manual/#example22)&lt;/sup&gt;\r\n&gt;\r\n&gt; paths outputs the paths to all the elements in its input (except it does not output the empty list, representing . itself).\r\n&gt; &lt;hr&gt;\r\n&gt;\r\n&gt; `getpath` &lt;sup&gt;[\\[docs\\]][1]&lt;/sup&gt;\r\n&gt;\r\n&gt; The builtin function getpath outputs the values in . found at each path in PATHS.\r\n&gt;\r\n&gt; &lt;hr&gt;\r\n&gt; \r\n&gt; `from_entries` &lt;sup&gt;[\\[docs\\]](https://stedolan.github.io/jq/manual/#example27)&lt;/sup&gt;\r\n&gt;\r\n&gt; These functions convert between an object and an array of key-value pairs. If to_entries is passed an object, then for each k: v entry in the input, the output array includes {&quot;key&quot;: k, &quot;value&quot;: v}.\r\n\r\n----------\r\n\r\nSo the steps I took are:\r\n\r\n1) Get every available (nested) path and hold it in a variable\r\n    ```\r\n    paths(scalars) as $p\r\n    ```\r\n2) Create an object holding the `key` and `value`. We can retreive the value by using `getpath`\r\n    ```\r\n    { &quot;key&quot;: $p | join(&quot;_&quot;), &quot;value&quot;: getpath($p) }\r\n    ```\r\n3) Use `from_entries` to convert to a single object\r\n    ```\r\n    | from_entries\r\n    ```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example24\r\n  [2]: https://stedolan.github.io/jq/manual/#paths,paths(node_filter),leaf_paths",
                "title": "JSON, key-value-pairs in groups to &quot;flat&quot; key-value-pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1745692317,
        "creation_date": 1636717405,
        "last_edit_date": 1745692317,
        "question_id": 69942402,
        "body_markdown": "Each key of a JSON should be combined with `_` (or any valid JSON symbol). To have a simple key-value list.\r\n\r\nI have the following structure. A few JSON groups (no arrays), inside the groups there are key-value pairs. I need to flat them to a single key-value-list. I tried `jq` but there is only something &quot;nested&quot; / &quot;unnested&quot;. I do not find something about flatten or compaine the keys.\r\n\r\nSo it should be `&quot;key_subkey_subsubkey&quot;: &quot;value&quot;`\r\n\r\n```json\r\n{\r\n    &quot;welcome&quot;: {\r\n        &quot;title&quot; : &quot;Hello World&quot;\r\n    },\r\n    &quot;block1&quot;: {\r\n        &quot;header&quot;: &quot;My Header&quot;,\r\n\t\t&quot;body&quot;: &quot;My BODY of block 1&quot;,\r\n\t\t&quot;footer&quot;: &quot;My Footer&quot;\r\n    },\r\n    &quot;multi&quot;: {\r\n        &quot;level-01-A&quot;: {\r\n\t\t\t&quot;head&quot;: &quot;Head Section&quot;,\r\n\t\t\t&quot;foot&quot;: &quot;Foot Section&quot;\r\n\t\t\t&quot;level-02-A&quot;: {\r\n\t\t\t\t&quot;head&quot;: &quot;Head Section Level 2 A&quot;,\r\n\t\t\t\t&quot;fead&quot;: &quot;Foot Section Level 2 A&quot;\r\n\t\t\t},\r\n\t\t\t&quot;level-02-B&quot;: {\r\n\t\t\t\t&quot;head&quot;: &quot;Head Section Level 2 B&quot;,\r\n\t\t\t\t&quot;fead&quot;: &quot;Foot Section Level 2 B&quot;\r\n\t\t\t},\r\n\t\t},\r\n\t\t&quot;level-01-B&quot;: {\r\n\t\t\t&quot;head&quot;: &quot;Head Section&quot;,\r\n\t\t\t&quot;foot&quot;: &quot;Foot Section&quot;\r\n\t\t}\r\n        &quot;no-level&quot; : &quot;Foo Bar&quot;,\t\t\r\n    }\r\n}\r\n```\r\n\r\nand I want to have\r\n\r\n```json\r\n{\r\n    &quot;welcome_title&quot; : &quot;Hello World&quot;,\r\n\r\n\t&quot;block1_header&quot;: &quot;My Header&quot;,\r\n\t&quot;block1_body&quot;: &quot;My BODY of block 1&quot;,\r\n\t&quot;block1_footer&quot;: &quot;My Footer&quot;,\r\n\r\n\t&quot;multi_level-01-A_head&quot;: &quot;Head Section&quot;,\r\n\t&quot;multi_level-01-A_foot&quot;: &quot;Foot Section&quot;,\r\n\t\t\r\n\t&quot;multi_level-01-A_level-02-A_head&quot;: &quot;Head Section Level 1 A&quot;,\r\n\t&quot;multi_level-01-A_level-02-A_fead&quot;: &quot;Foot Section Level 1 A&quot;,\r\n\r\n\t&quot;multi_level-01-A_level-02-B_head&quot;: &quot;Head Section Level 1 B&quot;,\r\n\t&quot;multi_level-01-A_level-02-B_fead&quot;: &quot;Foot Section Level 1 B&quot;,\r\n\r\n\t&quot;multi_level-01-B_head&quot;: &quot;Head Section&quot;,\r\n\t&quot;multi_level-01-B_foot&quot;: &quot;Foot Section&quot;,\r\n\r\n\t&quot;multi_no-level&quot; : &quot;Foo Bar&quot;\r\n}\r\n```\r\n\r\nAny idea, what tool I can use?",
        "link": "https://stackoverflow.com/questions/69942402/json-key-value-pairs-in-groups-to-flat-key-value-pair",
        "title": "JSON, key-value-pairs in groups to &quot;flat&quot; key-value-pair"
    },
    {
        "tags": [
            "bash",
            "curl",
            "syntax",
            "jq",
            "command-substitution"
        ],
        "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": 1636884423,
                "post_id": 69961877,
                "comment_id": 123671838,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16644876,
                    "reputation": 29,
                    "user_id": 12109373,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1cafda87c4ebaabbc7df1c967d546b12?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vivern202",
                    "link": "https://stackoverflow.com/users/12109373/vivern202"
                },
                "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": 1636885351,
                "post_id": 69961877,
                "comment_id": 123672008,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636885738,
                "post_id": 69961877,
                "comment_id": 123672088,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1636922317,
                "last_edit_date": 1636922317,
                "creation_date": 1636887601,
                "answer_id": 69962339,
                "question_id": 69961877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `jq --arg ...` option to pass values and build a valid `jq` request like this:\r\n\r\n```bash\r\ncurl -s \\\r\n  -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n  --url &quot;https://api.github.com/repos/datamove/linux-git2/pulls?state=all&amp;per_page=100&quot; \\\r\n| jq \\\r\n  --arg user_login &quot;$1&quot; \\\r\n  &#39;.[] | select(.user.login==$user_login) | .user.login&#39; \\\r\n| wc -l\r\n```\r\n\r\n**UPDATE**\r\n\r\nFull `jq` solution:\r\n```bash\r\ncurl \\\r\n  -s \\\r\n  -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n  --url &quot;https://api.github.com/repos/datamove/linux-git2/pulls?state=all&amp;per_page=100&quot; \\\r\n| jq \\\r\n  --arg user_login &quot;$1&quot; \\\r\n  &#39;[select(.[].user.login == $user_login)] | length&#39;\r\n```",
                "title": "How to count amount of pull request made by user?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636922317,
        "creation_date": 1636883067,
        "last_edit_date": 1636885831,
        "question_id": 69961877,
        "body_markdown": "I have bash sript pull.sh with one argument is github nickname of a person. And I want to count amount of all pull request which was made with this nickname. I select pr this way in command line:\r\n\r\n    curl -s https://api.github.com/repos/owner/repo/pulls?&quot;state=all&amp;per_page=100&quot; | jq &#39;.[] | select(.user.login==&quot;nickname&quot;) | .user.login&#39;\r\n\r\nAnd this work well.\r\nBut how can I count how much values was selected? \r\n\r\nIn bash I am trying this:\r\n\r\n    amount_of_pr=$(curl -s https://api.github.com/repos/owner/repo/pulls?&quot;state=all&amp;per_page=100&quot; | jq &#39;.[] | select(.user.login==&quot;$1&quot;) | .user.login&#39;)\r\n    echo &quot;$amount_of_pr&quot;\r\n\r\nBut it doesnt print anything.\r\n\r\nAnother problem is that amount of pull requests in repo is much bigger than 100. And I need to search through all of them. How can I do it?\r\n\r\nExample of curl output\r\n\r\n    [\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/datamove/linux-git2/pulls/315&quot;,\r\n        &quot;id&quot;: 771895341,\r\n        &quot;node_id&quot;: &quot;PR_kwDOEh6nts4uAjAt&quot;,\r\n        &quot;html_url&quot;: &quot;https://github.com/datamove/linux-git2/pull/315&quot;,\r\n        &quot;diff_url&quot;: &quot;https://github.com/datamove/linux-git2/pull/315.diff&quot;,\r\n        &quot;patch_url&quot;: &quot;https://github.com/datamove/linux-git2/pull/315.patch&quot;,\r\n        &quot;issue_url&quot;: &quot;https://api.github.com/repos/datamove/linux-git2/issues/315&quot;,\r\n        &quot;number&quot;: 315,\r\n        &quot;state&quot;: &quot;open&quot;,\r\n        &quot;locked&quot;: false,\r\n        &quot;title&quot;: &quot;hw git2 nicknazarov&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;login&quot;: &quot;nicknazarov&quot;,\r\n          &quot;id&quot;: 16031089,\r\n          &quot;node_id&quot;: &quot;MDQ6VXNlcjE2MDMxMDg5&quot;,\r\n          &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/16031089?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/nicknazarov&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/nicknazarov&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/nicknazarov/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/nicknazarov/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/nicknazarov/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/nicknazarov/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/nicknazarov/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/nicknazarov/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/nicknazarov/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/nicknazarov/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/nicknazarov/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        }\r\n    ]",
        "link": "https://stackoverflow.com/questions/69961877/how-to-count-amount-of-pull-request-made-by-user",
        "title": "How to count amount of pull request made by user?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636946567,
                "last_edit_date": 1636946567,
                "creation_date": 1636914555,
                "answer_id": 69965980,
                "question_id": 69965595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that the string with the space in it does not in fact occur in the given JSON.  It&#39;s not too clear what you are trying to do but please note that `contains` is not symmetric:\r\n\r\n    &quot;a&quot; | contains(&quot;a b&quot;)\r\n\r\nevaluates to `false`. \r\n\r\nIf you intended to write a boolean search criterion, you could use a boolean expression, or use jq&#39;s regular expression machinery, e.g.\r\n\r\n    test(&quot;10.32.0.4:8055|10.32.0.7:8055&quot;)\r\n\r\nor probably even better:\r\n\r\n    test(&quot;\\&quot;(10[.]32[.]0[.]4:8055|10[.]32[.]0[.]7:8055)\\&quot;&quot;)\r\n\r\n",
                "title": "jq bash issue with filtering with CONTAINS"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1636973850,
                "last_edit_date": 1636973850,
                "creation_date": 1636919154,
                "answer_id": 69966577,
                "question_id": 69965595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "None of your data contains `&quot;10.32.0.4:8055 10.32.0.7:8055&quot;`.\r\n\r\nYou could pass multiple strings to `contains()`, using a bash array:\r\n\r\n    strings=(&quot;10.32.0.4:8055&quot; &quot;10.32.0.7:8055&quot;)\r\n\r\n    echo &quot;${_metadatadashjson}&quot; |\r\n    jq -r --args &#39;.dashboard.panels[] | select(.targets[].expr | contains($ARGS.positional[])) | .targets[].expr&#39; &quot;${strings[@]}&quot;\r\n\r\nBut `contains` will evaluate to true for each match. Ie. if one `expr` contained both strings, it would be selected (and printed) twice.\r\n\r\nWith `test`, that won&#39;t happen. Here&#39;s how you can add the `|`s between multiple strings, and pass them in a single jq variable (as well as escape all the dots):\r\n\r\n    strings=(&quot;10.32.0.4:8055&quot; &quot;10.32.0.7:8055&quot;)\r\n    IFS=\\|\r\n    echo &quot;${_metadatadashjson}&quot; |\r\n    jq -r --arg str &quot;${strings[*]//./\\\\.}&quot; &#39;.dashboard.panels[] | select(.targets[].expr | test($str)) | .targets[].expr&#39;\r\n\r\nBoth examples print this:\r\n\r\n    jvm_threads_current{instance=&quot;10.32.0.4:8055&quot;,job=&quot;prometheus_gyrex&quot;}\r\n    jvm_threads_current{instance=&quot;10.32.0.7:8055&quot;,job=&quot;prometheus_gyrex&quot;}\r\n\r\nUpdate: I forgot to escape the dots for `test`. I edited the `test` example so that all the dots get escaped (with a single backslash). It&#39;s regex, so (unescaped) dots will match any character. The `contains` example matches the strings literally (not regex).",
                "title": "jq bash issue with filtering with CONTAINS"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1636973850,
        "creation_date": 1636911624,
        "question_id": 69965595,
        "body_markdown": "I have an issue where I am trying to filter records with a CONTAINS, but it won&#39;t accept a variable that has spaces in it. I am including the JSON and the calls. I explain what works and the last one that does not work. I have looked High and Low but I can&#39;t make it work. I have seen and tried many (hundreds of ways taking into account the double quotes, escaped, not escaped, with, without, but no luck) can someone take a look and point me to something that might help.\r\n\r\n**JSON used to test**\r\n\r\n    _metadatadashjson=&#39;{  &quot;meta&quot;: {    &quot;provisionedExternalId&quot;: &quot;&quot;  },  &quot;dashboard&quot;: {    &quot;liveNow&quot;: false,    &quot;panels&quot;: [      {        &quot;collapsed&quot;: false,        &quot;title&quot;: &quot;Gyrex Thread Count Gauges&quot;,        &quot;type&quot;: &quot;row&quot;, &quot;targets&quot;: [          {            &quot;expr&quot;: &quot;jvm_threads_current{instance=\\&quot;192.1.50.22:8055\\&quot;,job=\\&quot;prometheus_gyrex\\&quot;}&quot;,            &quot;refId&quot;: &quot;B&quot;          }        ]      },      {        &quot;datasource&quot;: &quot;Prometheus_16_Docker&quot;,        &quot;targets&quot;: [          {            &quot;exemplar&quot;: true,            &quot;expr&quot;: &quot;jvm_threads_current{instance=\\&quot;10.32.0.4:8055\\&quot;,job=\\&quot;prometheus_gyrex\\&quot;}&quot;          }        ],        &quot;title&quot;: &quot;.16 : 3279&quot;,        &quot;type&quot;: &quot;gauge&quot;      },      {        &quot;description&quot;: &quot;&quot;,        &quot;targets&quot;: [          {            &quot;expr&quot;: &quot;jvm_threads_current{instance=\\&quot;10.32.0.7:8055\\&quot;,job=\\&quot;prometheus_gyrex\\&quot;}&quot;,            &quot;refId&quot;: &quot;B&quot;          }        ],        &quot;title&quot;: &quot;.16 : 3288&quot;,        &quot;type&quot;: &quot;graph&quot;      },      {        &quot;description&quot;: &quot;&quot;,        &quot;targets&quot;: [          {            &quot;expr&quot;: &quot;jvm_threads_current{instance=\\&quot;192.168.2.16:3288\\&quot;,job=\\&quot;prometheus_gyrex\\&quot;}&quot;,            &quot;refId&quot;: &quot;C&quot;          }        ],        &quot;title&quot;: &quot;.16 : 3288&quot;,        &quot;type&quot;: &quot;graph&quot;      }    ],    &quot;version&quot;: 55  }}&#39;\r\n\r\n**Set the string to search for in key &quot;expr&quot;**\r\n\r\n    exprStrSearch=&quot;10.32.0.4:8055&quot;\r\n\r\n**This works returns one record**\r\n\r\n    echo &quot;${_metadatadashjson}&quot; | jq -r --arg EXPRSTRSEARCH &quot;$exprStrSearch&quot; &#39;.dashboard.panels[] | select(.targets[].expr | contains($EXPRSTRSEARCH)) | .targets[].expr&#39;\r\n**This works no problem returns two records.**\r\n\r\n    echo &quot;${_metadatadashjson}&quot; | jq -r --arg EXPRSTRSEARCH &quot;$exprStrSearch&quot; &#39;.dashboard.panels[] | select(.targets[].expr | contains(&quot;10.32.0.4:8055&quot;, &quot;10.32.0.7:8055&quot;)) | .targets[].expr&#39;\r\n**Change the value to include a space and another string**\r\n\r\n    exprStrSearch=&quot;10.32.0.4:8055 10.32.0.7:8055&quot;\r\n**Does not work.**\r\n\r\n    echo &quot;${_metadatadashjson}&quot; | jq -r --arg EXPRSTRSEARCH &quot;$exprStrSearch&quot; &#39;.dashboard.panels[] | select(.targets[].expr | contains($EXPRSTRSEARCH)) | .targets[].expr&#39;\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69965595/jq-bash-issue-with-filtering-with-contains",
        "title": "jq bash issue with filtering with CONTAINS"
    },
    {
        "tags": [
            "batch-file",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636963694,
                "last_edit_date": 1636963694,
                "creation_date": 1636931911,
                "answer_id": 69967975,
                "question_id": 69966355,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are running into problems because you&#39;re not following the quoting rules for the Windows/DOS command line.  You would probably find things simpler if you used jq&#39;s -f command-line option, which makes all those problems vanish.  You&#39;re running into these problems because your jq program includes double quotation marks.\r\n\r\nPlease also note:\r\n\r\n1. jq&#39;s filter names are case sensitive, so that `INDEX` and `index` are quite different;\r\n2. If you are going to use `index`, it would be better to use it just once, perhaps storing it as a jq variable;\r\n3. Your jq program can be greatly simplified by &quot;lifting&quot; `.RequestToUploadFileList[0]`:\r\n```\r\n{ReferenceNumber:.ReferenceNumber}\r\n + (.RequestToUploadFileList[0]\r\n    | (.Url|index(&quot;?sv=&quot;)) as $ix\r\n    | {URI:.Url,\r\n        URI_ABS: .Url[0:$ix],\r\n        URI_SAS: .Url[$ix:],\r\n        FILE: .FileName,\r\n        Key: .HeaderList[0].Value } )\r\n```\r\n4. For robustness, you might want to deal with the case when $ix is null.\r\n\r\n5. Instead of using `index`, you might wish to consider using `capture`:\r\n```\r\n(.Url|capture( &quot;(?&lt;head&gt;.*)(?&lt;tail&gt;\\\\?sv=.*)&quot; )) as $url ...\r\n```",
                "title": "Why does the processing of |INDEX(&quot;__string__&quot;) filter fail on calling the executable jq-win32.exe from Windows commmand line?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636963694,
        "creation_date": 1636917379,
        "last_edit_date": 1636961403,
        "question_id": 69966355,
        "body_markdown": "If it&#39;s possible, I couldn&#39;t find the solution in the Internet.  \r\nI have JSON file:\r\n\r\n```\r\n{\r\n\t&quot;ReferenceNumber&quot;: &quot;d4fd41850323d2f6000000b013016327&quot;,\r\n\t&quot;TimeoutInSec&quot;: 900,\r\n\t&quot;RequestToUploadFileList&quot;: [\r\n\t\t{\r\n\t\t\t&quot;BlobName&quot;: &quot;8377ed3d-1b05-4c76-b718-6fddd46fd298&quot;,\r\n\t\t\t&quot;FileName&quot;: &quot;jpk_vat_100-01.xml.zip.aes&quot;,\r\n\t\t\t&quot;Url&quot;: &quot;https://taxdocumentstorage09tst.blob.core.windows.net/d4fd41850323d2f6000000b013016327/8377ed3d-1b05-4c76-b718-6fddd46fd298?sv=2015-07-08&amp;sr=b&amp;si=d4fd41850323d2f6000000b013016327&amp;sig=yFXyJdsPPkbE0iQwVs5ccLEYEU0lxQHldbVyPfPciXw%3D&quot;,\r\n\t\t\t&quot;Method&quot;: &quot;PUT&quot;,\r\n\t\t\t&quot;HeaderList&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;Content-MD5&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;eXkPLHMM+dHB5GCFoeAvsA==&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;x-ms-blob-type&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;BlockBlob&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;BlobName&quot;: &quot;0a80a089-bc10-41e1-a74d-70fd45f27aa3&quot;,\r\n\t\t\t&quot;FileName&quot;: &quot;jpk_vat_100-02.xml.zip.aes&quot;,\r\n\t\t\t&quot;Url&quot;: &quot;https://taxdocumentstorage09tst.blob.core.windows.net/d4fd41850323d2f6000000b013016327/0a80a089-bc10-41e1-a74d-70fd45f27aa3?sv=2015-07-08&amp;sr=b&amp;si=d4fd41850323d2f6000000b013016327&amp;sig=Fj%2BGjn7hCKIM6hSvMBGWBxSOyV7V%2FLMM9pnenbaoxks%3D&quot;,\r\n\t\t\t&quot;Method&quot;: &quot;PUT&quot;,\r\n\t\t\t&quot;HeaderList&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;Content-MD5&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;NZew85QTb16mFLzx9cyKzA==&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;x-ms-blob-type&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;BlockBlob&quot;\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 want to split `RequestToUploadFileList[0].Url` into two parts: before `?sv=` and the remaining string.\r\n\r\nI am trying to convert it into other JSON using Windows command line\r\n\r\n    c:\\EJPK\\exe&gt;type &quot;c:\\TEMP\\jpk1012\\out\\JPK_VAT.xml.sig.resp&quot;| d:\\curl\\send\\bin\\jq-win32.exe -r &quot;{ReferenceNumber:.ReferenceNumber} + {URI:(.RequestToUploadFileList[0].Url)} + {URI_ABS:.RequestToUploadFileList[0].Url[0:.RequestToUploadFileList[0].Url|index(&quot;?sv=&quot;)] } +{URI_SAS:.RequestToUploadFileList[0].Url[.RequestToUploadFileList[0].Url|index(&quot;?sv=&quot;):] } + {FILE:.RequestToUploadFileList[0].FileName} + {Key:.RequestToUploadFileList[0].HeaderList[0].Value}&quot;\r\n\r\nI am using a formula tested on [jqplay.org](https://jqplay.org/s/YCMm9F0tnE).\r\n\r\nClearly the problem is in the filter concatenation or putting string into INDEX filter:\r\n\r\n    .RequestToUploadFileList[0].Url|index(&quot;?sv=&quot;)\r\n\r\nThe source/original formula build with jqplay.org:\r\n\r\n```\r\njq &#39;{ReferenceNumber:.ReferenceNumber}\r\n    + {URI:(.RequestToUploadFileList[0].Url)}\r\n    + {URI_ABS:.RequestToUploadFileList[0].Url[0:.RequestToUploadFileList[0].Url|index(&quot;?sv=&quot;)] }\r\n    + {URI_SAS:.RequestToUploadFileList[0].Url[.RequestToUploadFileList[0].Url|index(&quot;?sv=&quot;):] }\r\n    + {FILE:.RequestToUploadFileList[0].FileName} \r\n    + {Key:.RequestToUploadFileList[0].HeaderList[0].Value}&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69966355/why-does-the-processing-of-index-string-filter-fail-on-calling-the-execu",
        "title": "Why does the processing of |INDEX(&quot;__string__&quot;) filter fail on calling the executable jq-win32.exe from Windows commmand line?"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636947003,
                "post_id": 69968773,
                "comment_id": 123685353,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636949074,
                "creation_date": 1636949074,
                "answer_id": 69969381,
                "question_id": 69968773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using jq&#39;s --stream option:\r\n```\r\njq -n --stream &#39;\r\n  def stream:\r\n    foreach ((inputs | select(length==2)), null) as $kv (null;\r\n      if $kv == null then .emit = .value\r\n      else .emit = null\r\n      | $kv[0][0] as $k\r\n      | if .k and ($k != .k) \r\n        then .emit = .value | .value = null \r\n        else . \r\n        end\r\n      | .value |= setpath($kv[0]; $kv[1])\r\n      | .k = $k\r\n      end;\r\n    select(.emit).emit);\r\n\r\n  [stream] | add\r\n&#39; input.json\r\n```",
                "title": "How to Group By within Object in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636969865,
        "creation_date": 1636942248,
        "last_edit_date": 1636969865,
        "question_id": 69968773,
        "body_markdown": "I have this JSON Object\r\n```\r\n{\r\n    &quot;id_1&quot;: {\r\n        &quot;day_1&quot;: {\r\n            &quot;loc_sec&quot;: 886,\r\n            &quot;int_sec&quot;: null\r\n        }\r\n    },\r\n    &quot;id_1&quot;: {\r\n        &quot;day_2&quot;: {\r\n            &quot;loc_sec&quot;: 575,\r\n            &quot;int_sec&quot;: null\r\n        }\r\n    },\r\n    &quot;id_2&quot;: {\r\n        &quot;day_1&quot;: {\r\n            &quot;loc_sec&quot;: 140,\r\n            &quot;int_sec&quot;: null\r\n        }\r\n    },\r\n    &quot;id_2&quot;: {\r\n        &quot;day_2&quot;: {\r\n            &quot;loc_sec&quot;: 138,\r\n            &quot;int_sec&quot;: null\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nAnd I want an output like this\r\n```\r\n{\r\n    &quot;id_1&quot;: {\r\n        &quot;day_1&quot;: {\r\n            &quot;loc_sec&quot;: 886,\r\n            &quot;int_sec&quot;: null\r\n        },\r\n        &quot;day_2&quot;: {\r\n            &quot;loc_sec&quot;: 575,\r\n            &quot;int_sec&quot;: null\r\n        }\r\n    },\r\n    &quot;id_2&quot;: {\r\n        &quot;day_1&quot;: {\r\n            &quot;loc_sec&quot;: 140,\r\n            &quot;int_sec&quot;: null\r\n        },\r\n        &quot;day_2&quot;: {\r\n            &quot;loc_sec&quot;: 138,\r\n            &quot;int_sec&quot;: null\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nHow do I achieve this with bash script and jq?\r\nThis seems to be like a group by functionality, but I&#39;m unable to figure it out.",
        "link": "https://stackoverflow.com/questions/69968773/how-to-group-by-within-object-in-jq",
        "title": "How to Group By within Object in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636971422,
                "post_id": 69972477,
                "comment_id": 123691095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14754800,
                    "reputation": 2261,
                    "user_id": 10655742,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Xd1vU.png?s=256",
                    "display_name": "KargWare",
                    "link": "https://stackoverflow.com/users/10655742/kargware"
                },
                "reply_to_user": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636971686,
                "post_id": 69972477,
                "comment_id": 123691196,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636972120,
                "creation_date": 1636972120,
                "answer_id": 69972905,
                "question_id": 69972477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;to_entries | map(.key |= split(&quot;___&quot;)) | reduce .[] as $obj({}; setpath($obj.key; $obj.value))&#39;\r\n```\r\n\r\nThe `reduce` builds up the object by applying `setpath` with input element&#39;s key/value in turn",
                "title": "JSON from flat key-value pair to nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636972120,
        "creation_date": 1636970371,
        "last_edit_date": 1636971200,
        "question_id": 69972477,
        "body_markdown": "How can I change a flat key-value pair (with concatenated key) to a nested group. I want to split a key at the `___` and use the new sub-key as key of the nested object.\r\n\r\nI have tried `map` and `split(&quot;___&quot;)` and the operator `|=` but was not able to get it, with `jq`\r\n\r\nSource (Input) file, with flat key-value pair\r\n\r\n```json\r\n{\r\n  &quot;key1___subkey1-2-foo&quot;: &quot;Value 1a&quot;,\r\n  &quot;key1___subkey1-2-bar&quot;: &quot;Value 1b&quot;,\r\n  &quot;key2___subkey2-2___subkey2-3&quot;: &quot;Value 2, Level 3&quot;,\r\n  &quot;key3&quot;: &quot;Value 3&quot;\r\n}\r\n```\r\n\r\nTarget format, as nested object\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: {\r\n      &quot;subkey1-2-foo&quot;: &quot;Value 1a&quot;,\r\n      &quot;subkey1-2-bar&quot;: &quot;Value 1b&quot;\r\n  },\r\n  &quot;key2&quot;: {\r\n      &quot;subkey2-2&quot;: {\r\n        &quot;subkey2-3&quot;: &quot;Value 2, Level 3&quot;\r\n      }\r\n  },\r\n  &quot;key3&quot;: &quot;Value 3&quot;\r\n}\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/69972477/json-from-flat-key-value-pair-to-nested-object",
        "title": "JSON from flat key-value pair to nested object"
    },
    {
        "tags": [
            "json",
            "jq",
            "cross-product"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1636977236,
                "creation_date": 1636977236,
                "answer_id": 69974013,
                "question_id": 69973010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you are looking for:\r\n\r\n```\r\n.Products[] | {sku: .SKU, desc: .Description} + (\r\n  .Images[] | {img_url: .FullUrl, img_angle: .Angle}\r\n)\r\n```\r\n\r\n[Fiddle](https://jqplay.org/s/nRHCkn0we_)",
                "title": "How do I avoid creating a cross product when extracting multiple sub-elements from a list in JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1637073794,
                "last_edit_date": 1637073794,
                "creation_date": 1637073156,
                "answer_id": 69991026,
                "question_id": 69973010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can see `STREAM as $var` as creating a foreach loop.\r\n\r\n```jq\r\n.Products[] |\r\n.Images[] as $img |\r\n{ sku: .SKU, desc: .Description, img_url: $img.FullUrl, img_angle: $img.Angle }\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/ufjQz207JY)\r\n\r\n--- \r\n\r\nWe can show this is equivalent to other answer.\r\n\r\nLet&#39;s start by factoring out `$img`.\r\n\r\n```jq\r\n.Products[] |\r\n.Images[] as $img |\r\n{ sku: .SKU, desc: .Description } +\r\n( $img | { img_url: .FullUrl, img_angle: .Angle } )\r\n```\r\n\r\nNow we can inline the variable because 1) it&#39;s only used once and 2) the topic (`.`) is the same.\r\n\r\n```jq\r\n.Products[] |\r\n{ sku: .SKU, desc: .Description } +\r\n( .Images[] | { img_url: .FullUrl, img_angle: .Angle } )\r\n```\r\n\r\nAnd we&#39;re already there.\r\n\r\n",
                "title": "How do I avoid creating a cross product when extracting multiple sub-elements from a list in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1637073794,
        "creation_date": 1636972606,
        "last_edit_date": 1637000821,
        "question_id": 69973010,
        "body_markdown": "I&#39;m getting product information from a vendor. It&#39;s got a bajillion fields in it, but I have this trimmed down to just relevant fields. I&#39;m anticipating the solution has something to do with `map()`, but I just haven&#39;t been able to wrap my head around it.\r\n\r\nWhen I try and get multiple fields out of a sub-dictionary, it does a cross product. I&#39;m expecting 2 lines back in this example, but I get 4.\r\n\r\n[Fiddle](https://jqplay.org/s/i-H4zXDGvY)    \r\nExpected output:\r\n```\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_A&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewA&quot;\r\n}\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_B&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewB&quot;\r\n}\r\n```\r\n----------\r\n\r\nStarting data:\r\n```\r\n{\r\n  &quot;Products&quot;: [\r\n    {\r\n      &quot;SKU&quot;: &quot;1234&quot;,\r\n      &quot;Description&quot;: &quot;Pink Ring&quot;,\r\n      &quot;RingSize&quot;: 7,\r\n      &quot;Images&quot;: [\r\n        {\r\n          &quot;FullUrl&quot;: &quot;https://provider.com/rings/1234_A&quot;,\r\n          &quot;SortOrder&quot;: 1,\r\n          &quot;Angle&quot;: &quot;ViewA&quot;\r\n        },\r\n        {\r\n          &quot;FullUrl&quot;: &quot;https://provider.com/rings/1234_B&quot;,\r\n          &quot;SortOrder&quot;: 2,\r\n          &quot;Angle&quot;: &quot;ViewB&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nI then pass it through this filter:\r\n```\r\n.Products[] | { sku: .SKU, desc: .Description, img_url: .Images[].FullUrl, img_angle: .Images[].Angle }\r\n```\r\nThis gives me the following data:\r\n```\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_A&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewA&quot;\r\n}\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_A&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewB&quot;\r\n}\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_B&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewA&quot;\r\n}\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_B&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewB&quot;\r\n}\r\n```\r\nThis is what I&#39;m hoping for. You can see URL_A and ANGLE_A don&#39;t cross multiply with URL_B and ANGLE_B.\r\n```\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_A&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewA&quot;\r\n}\r\n{\r\n  &quot;sku&quot;: &quot;1234&quot;,\r\n  &quot;desc&quot;: &quot;Pink Ring&quot;,\r\n  &quot;img_url&quot;: &quot;https://provider.com/rings/1234_B&quot;,\r\n  &quot;img_angle&quot;: &quot;ViewB&quot;\r\n}\r\n```\r\nPlease don&#39;t assume that you can trust `img_url` and `img_angle` to have values that reference each other - you definitely can&#39;t, that&#39;s only here for illustration purposes.\r\n\r\nI&#39;ve tried several things that keep giving me a cross product and don&#39;t actually change the output, like `{ sku: .SKU, desc: .Description } + { img_url: .Images[].FullUrl } + { img_angle: .Images[].Angle }`.\r\n\r\nI&#39;ve also tried adapting recipes from [this recipe book](https://remysharp.com/drafts/jq-recipes) and [this cheat sheet](https://lzone.de/cheat-sheet/jq). I haven&#39;t been able to get anything useful that doesn&#39;t puke at runtime.",
        "link": "https://stackoverflow.com/questions/69973010/how-do-i-avoid-creating-a-cross-product-when-extracting-multiple-sub-elements-fr",
        "title": "How do I avoid creating a cross product when extracting multiple sub-elements from a list in JQ?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3595907,
                    "reputation": 5832,
                    "user_id": 3000629,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fd7f5c9cce7faba20cc43901b5d03ffd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Poshi",
                    "link": "https://stackoverflow.com/users/3000629/poshi"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1636983943,
                "post_id": 69975333,
                "comment_id": 123695891,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636986371,
                "post_id": 69975333,
                "comment_id": 123696884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636991154,
                "post_id": 69975333,
                "comment_id": 123699067,
                "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": 1637001103,
                "post_id": 69975333,
                "comment_id": 123703009,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637070184,
                "last_edit_date": 1637070184,
                "creation_date": 1636995138,
                "answer_id": 69978036,
                "question_id": 69975333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You set the shell&#39;s `currentIssuesArr` but not `jq`&#39;s. Use:\r\n\r\n```sh\r\njq --argjson currentIssuesArr &quot;$currentIssuesArr&quot; &#39;...&#39;\r\n```\r\n\r\nYou could also export `currentIssuesArr` and use `env.currentIssuesArr` in `jq`.\r\n\r\nIf we cleanup the program, we get\r\n\r\n```jq\r\njq --argjson currentIssuesArr &quot;$currentIssuesArr&quot; &#39;.issues += [ $currentIssuesArr ]&#39;\r\n```\r\n\r\n(You call the variable an &quot;issues array&quot;, but your working code shows an object. If it is an array, remove the square brackets.)",
                "title": "Can&#39;t add item to array via variable: is not defined at &lt;top-level&gt;,"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637070184,
        "creation_date": 1636983757,
        "question_id": 69975333,
        "body_markdown": "In bash script:\r\n\r\n    for (( pageNumber=$page; pageNumber&lt;=$countPages; pageNumber++ ))\t\t  \r\n    do\r\n        read -r currentIssuesArr &lt; &lt;(echo $(curl -s -XGET $BASE_URL/issues/search\\?componentKeys\\=$PROJECT_KEY\\&amp;p\\=$pageNumber\\&amp;ps\\=$PAGE_SIZE | jq -r &#39;.issues[]&#39;))\r\n        jq &#39;.issues[.issues| length] |= . + {&quot;aaaaaaaaaaaa&quot;: &quot;2010-01-07T19:55:99.999Z&quot;}&#39; $FILE_REPORT_RESULT &gt;test.json\r\n    done\r\n\r\nThis work fine. And add json to last array&#39;s item. Nice.\r\n\r\nBut now I want do the same but via variable `currentIssuesArr`\r\n\r\nLike this:\r\n\r\n    for (( pageNumber=$page; pageNumber&lt;=$countPages; pageNumber++ ))\t\t  \r\n    do\r\n        read -r currentIssuesArr &lt; &lt;(echo $(curl -s -XGET $BASE_URL/issues/search\\?componentKeys\\=$PROJECT_KEY\\&amp;p\\=$pageNumber\\&amp;ps\\=$PAGE_SIZE | jq -r &#39;.issues[]&#39;))\r\n        jq &#39;.issues[.issues| length] |= . + $currentIssuesArr&#39; $FILE_REPORT_RESULT &gt;test.json\r\n    done\r\n\r\n\r\nBut now I get error:\r\n\r\n    jq: error: $currentIssuesArr is not defined at &lt;top-level&gt;, line 1:\r\n    .issues[.issues| length] |= . + $currentIssuesArr                                \r\n    jq: 1 compile error\r\n    jq: error: $currentIssuesArr is not defined at &lt;top-level&gt;, line 1:\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69975333/cant-add-item-to-array-via-variable-is-not-defined-at-top-level",
        "title": "Can&#39;t add item to array via variable: is not defined at &lt;top-level&gt;,"
    },
    {
        "tags": [
            "bash",
            "zsh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1637042776,
                "post_id": 69984441,
                "comment_id": 123712594,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1637046143,
                "post_id": 69984441,
                "comment_id": 123713487,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11291259,
                    "reputation": 339,
                    "user_id": 8280263,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/92514f2dd8c76deddb99efe9bef189ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beweeted",
                    "link": "https://stackoverflow.com/users/8280263/beweeted"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637046477,
                "post_id": 69984441,
                "comment_id": 123713597,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11291259,
                    "reputation": 339,
                    "user_id": 8280263,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/92514f2dd8c76deddb99efe9bef189ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beweeted",
                    "link": "https://stackoverflow.com/users/8280263/beweeted"
                },
                "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": 1637046578,
                "post_id": 69984441,
                "comment_id": 123713627,
                "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"
                },
                "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": 1637046629,
                "post_id": 69984441,
                "comment_id": 123713641,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "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": 1637047475,
                "post_id": 69984441,
                "comment_id": 123713912,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637048349,
                "post_id": 69984441,
                "comment_id": 123714213,
                "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"
                },
                "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": 1637048381,
                "post_id": 69984441,
                "comment_id": 123714227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "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": 1637053078,
                "post_id": 69984441,
                "comment_id": 123715875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637086265,
                "last_edit_date": 1637086265,
                "creation_date": 1637051829,
                "answer_id": 69986005,
                "question_id": 69984441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The escaping of the quotes inside your example data is valid JSON throughout. Depending on what you intend to do inside your loop, maybe it can be accomplished by `jq` itself, which automatically iterates over each object for you. You can even use it to unescape a given string using the `--raw-output` option like so:\r\n```sh\r\n jq --raw-output &#39;.desc&#39; input.txt\r\n```\r\n```lang-none\r\nNecklace 18&quot; long\r\nNecklace 18&quot; long\r\n```\r\nAgain, all depends on what is your actual goal is inside the loop. The following example even encodes for HTML using the `@html` builtin:\r\n```sh\r\njq --raw-output &#39;@html &quot;&lt;h1&gt;\\(.desc)&lt;/h1&gt;\\n&lt;img src=\\&quot;\\(.img)\\&quot;/&gt;\\n&quot;&#39; input.txt\r\n```\r\n```html\r\n&lt;h1&gt;Necklace 18&amp;quot; long&lt;/h1&gt;\r\n&lt;img src=&quot;https://provider.com/12345.jpg&quot;/&gt;\r\n\r\n&lt;h1&gt;Necklace 18&amp;quot; long&lt;/h1&gt;\r\n&lt;img src=&quot;https://provider.com/12346.jpg&quot;/&gt;\r\n```",
                "title": "How do you capture escaped quotes from a file when using &quot;while read line&quot; loops?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637086265,
        "creation_date": 1637042666,
        "question_id": 69984441,
        "body_markdown": "I&#39;m trying to access data from a file full of JSON objects, where the string fields may or may not have escaped quotes in them.\r\n\r\nWhen I try to process it using `while read line ; do echo ; done &lt; input.txt`, it pukes because of the unbalanced number of quotes.\r\n\r\nI have this input file:\r\n```\r\n$ cat input.txt \r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18\\&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12345.jpg&quot;, &quot;imgView&quot;:&quot;A&quot;}\r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18\\&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12346.jpg&quot;, &quot;imgView&quot;:&quot;B&quot;}\r\n```\r\nWhen I use `read` to capture it on the way in, I lose the backslash.\r\n```\r\n$ while read line ; do echo &quot;${line}&quot; ; done &lt; input.txt\r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12345.jpg&quot;, &quot;imgView&quot;:&quot;A&quot;}\r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12346.jpg&quot;, &quot;imgView&quot;:&quot;B&quot;}\r\n\r\n$ while read line ; do echo &quot;${line}&quot; | sed &#39;s/\\\\/\\\\\\\\/g&#39; ; done &lt; input.txt\r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12345.jpg&quot;, &quot;imgView&quot;:&quot;A&quot;}\r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12346.jpg&quot;, &quot;imgView&quot;:&quot;B&quot;}\r\n```\r\nI have this workaround that I&#39;ll use for now to unblock myself. But it&#39;s ugly and verbose.\r\n\r\n```\r\n#Showing that it&#39;s preserving the escape\r\n$ input=input.txt ; counter=1; length=$(cat ${input} | wc -l)\r\n$ while [ ${counter} -le ${length} ] ; do data=$(tail -n +${counter} ${input} | head -n 1 ) ; echo ${data} ; counter=$(( counter + 1)) ; done \r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18\\&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12345.jpg&quot;, &quot;imgView&quot;:&quot;A&quot;}\r\n{&quot;sku&quot;:&quot;1234&quot;, &quot;desc&quot;:&quot;Necklace 18\\&quot; long&quot;, &quot;img&quot;:&quot;https://provider.com/12346.jpg&quot;, &quot;imgView&quot;:&quot;B&quot;}\r\n\r\n#Showing that jq can actually process the data now\r\n$ input=input.txt ; counter=1; length=$(cat ${input} | wc -l)\r\n$ while [ ${counter} -le ${length} ] ; do desc=$(tail -n +${counter} ${input} | head -n 1 | jq &#39;.desc&#39; -r) ; echo ${desc} ; counter=$(( counter + 1)) ; done \r\nNecklace 18&quot; long\r\nNecklace 18&quot; long\r\n```\r\nI feel like I have to get way too low level into how the shell is handling the input. There has to be an easier way, or a flag or something that I&#39;m missing.",
        "link": "https://stackoverflow.com/questions/69984441/how-do-you-capture-escaped-quotes-from-a-file-when-using-while-read-line-loops",
        "title": "How do you capture escaped quotes from a file when using &quot;while read line&quot; loops?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637069833,
                "creation_date": 1637069833,
                "answer_id": 69990154,
                "question_id": 69988561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This lists all triplets and a header row formatted as CSV:\r\n\r\n```sh\r\njq --raw-output &#39;\r\n  [ &quot;SerialNumber&quot;, &quot;EnrollmentUserName&quot;, &quot;os_vers&quot; ], # header\r\n  ( .Devices[]\r\n    | [ .SerialNumber, .EnrollmentUserName,\r\n        (.CustomAttributes[] | select(.Name == &quot;os_vers&quot;).Value)\r\n      ]\r\n  )\r\n  | @csv\r\n&#39; input.json\r\n```\r\n```csv\r\n&quot;SerialNumber&quot;,&quot;EnrollmentUserName&quot;,&quot;os_vers&quot;\r\n&quot;aaabbbccc&quot;,&quot;Donald&quot;,&quot;10.15.7&quot;\r\n&quot;CCCBBBAAA&quot;,&quot;Mickey&quot;,&quot;11.5.2&quot;\r\n```\r\n[Demo](https://jqplay.org/s/gHFAkrOfBP)\r\n\r\nIf you only need one specific line, leave out the header (marked with `#header`) and apply another `select` after `.Devices[]` according to your criterion (e.g. `.EnrollmentUserName == &quot;Donald&quot;`).",
                "title": "JQ: Extract value from object in nested array based on object name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637585243,
        "creation_date": 1637063173,
        "last_edit_date": 1637585243,
        "question_id": 69988561,
        "body_markdown": "I have tried learning jq, but I can&#39;t really seem to wrap my head properly around it. (JSON and jq Newb here) \r\n\r\nI need to extract some values from &quot;Devices&quot;, and I need to get one value from the &quot;CustomAttributes&quot; array. The big problem is that the position of the data I need isn&#39;t fixed within this array, so I have to find the right object based on the name. \r\n\r\nI need to export this as a CSV. \r\n\r\nThe expected output is :\r\n\r\n    SerialNumber: &quot;aaabbbccc&quot; \r\n    \r\n    EnrollmentUserName:&quot;Donald&quot;\r\n     \r\n    os_vers: &quot;10.15.7&quot;\r\n\r\nDoes anyone have a recipe for this? \r\n\r\n``` json\r\n{\r\n  &quot;Devices&quot;: [\r\n    {\r\n      &quot;DeviceId&quot;: 111,\r\n      &quot;Udid&quot;: &quot;a813bf407aa55ed686f3d3ade3e6d3c4&quot;,\r\n      &quot;SerialNumber&quot;: &quot;aaabbbccc&quot;,\r\n      &quot;EnrollmentUserName&quot;: &quot;Donald&quot;,\r\n      &quot;AssetNumber&quot;: &quot;A813BF407AA55ED686F3D3ADE3E6D3C4&quot;,\r\n      &quot;CustomAttributes&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;reinstall&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;reinstall_keys&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;msc_version&quot;,\r\n          &quot;Value&quot;: &quot;4.1.4.3949&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;reinstall_ssh_log&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;cert_date&quot;,\r\n          &quot;Value&quot;: &quot;20210422&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;model_id&quot;,\r\n          &quot;Value&quot;: &quot;iMac14,2&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;cfengine&quot;,\r\n          &quot;Value&quot;: &quot;disabled&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;os_vers&quot;,\r\n          &quot;Value&quot;: &quot;10.15.7&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;xprotect_vers&quot;,\r\n          &quot;Value&quot;: &quot;2149&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;powerpoint&quot;,\r\n          &quot;Value&quot;: &quot;true&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;DeviceId&quot;: 178,\r\n      &quot;Udid&quot;: &quot;72893dbe48755ac99641ab2a3b8a5228&quot;,\r\n      &quot;SerialNumber&quot;: &quot;CCCBBBAAA&quot;,\r\n      &quot;EnrollmentUserName&quot;: &quot;Mickey&quot;,\r\n      &quot;AssetNumber&quot;: &quot;&quot;,\r\n      &quot;CustomAttributes&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;MobileAccount&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;reinstall&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;reinstall_keys&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;reinstall_ssh_log&quot;,\r\n          &quot;Value&quot;: &quot;false&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;cert_date&quot;,\r\n          &quot;Value&quot;: &quot;20210422&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;model_id&quot;,\r\n          &quot;Value&quot;: &quot;MacBookPro12,1&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;dep_check&quot;,\r\n          &quot;Value&quot;: &quot;checked&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;cfengine&quot;,\r\n          &quot;Value&quot;: &quot;disabled&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;os_vers&quot;,\r\n          &quot;Value&quot;: &quot;11.5.2&quot;,\r\n          &quot;Source&quot;: &quot;Device Sourced&quot;,\r\n          &quot;Application&quot;: &quot;AirWatchAgent&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;Page&quot;: 0,\r\n  &quot;PageSize&quot;: 5,\r\n  &quot;Total&quot;: 1831\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69988561/jq-extract-value-from-object-in-nested-array-based-on-object-name",
        "title": "JQ: Extract value from object in nested array based on object name"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1637137916,
                "last_edit_date": 1637137916,
                "creation_date": 1637136535,
                "answer_id": 70000790,
                "question_id": 69999734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you are looking for:\r\n```sh\r\njq -r &#39;\r\n  [.id, .description] + (.project[] | [.id, .description, .url])\r\n  | @csv\r\n&#39; \r\n```\r\n```csv\r\n15,&quot;package&quot;,1762,&quot;This Red Hat Server 7 is built from the Redhat Official&quot;,&quot;some url&quot;\r\n15,&quot;package&quot;,1663,&quot;This Ubuntu 20.04 is built from the Ubuntu Official&quot;,&quot;some url&quot;\r\n15,&quot;package&quot;,1557,&quot;This Centos 7 is built from the Centos Official&quot;,&quot;some url&quot;\r\n22,&quot;exe&quot;,1332,&quot;This Windows 7 is developed from the Windows Official&quot;,&quot;some url&quot;\r\n22,&quot;exe&quot;,1563,&quot;This Windows 11 is developed from the Windows Official&quot;,&quot;some url&quot;\r\n\r\n```\r\n[Demo](https://jqplay.org/s/B1zZJQ8BCY)\r\n\r\n---\r\nYou can also adopt @ikegami&#39;s [solution](https://stackoverflow.com/questions/69973010/how-do-i-avoid-creating-a-cross-product-when-extracting-multiple-sub-elements-fr/69991026#69991026) to a (technically) very similar problem:\r\n```sh\r\njq -r &#39;\r\n  .project[] as $p\r\n  | [.id, .description, $p.id, $p.description, $p.url]\r\n  | @csv\r\n&#39; \r\n```\r\n[Demo](https://jqplay.org/s/T-3SGYpWd1)",
                "title": "Parsing json values and converting them to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637151776,
        "creation_date": 1637130104,
        "last_edit_date": 1637151776,
        "question_id": 69999734,
        "body_markdown": "I need your help for parsing below json file and converting them to csv using jq command.\r\n\r\n      {\r\n        \t&quot;id&quot;: 15,\r\n        \t&quot;description&quot;: &quot;package&quot;,\r\n        \t&quot;active&quot;: true,\r\n        \t&quot;name&quot;: &quot;linux&quot;,\r\n        \t&quot;project&quot;: [\r\n        \t{\r\n        \t\t&quot;id&quot;: 1762,\r\n        \t\t&quot;description&quot;: &quot;This Red Hat Server 7 is built from the Redhat Official&quot;,\r\n        \t\t&quot;path&quot;: &quot;x86_24&quot;,\r\n        \t\t&quot;url&quot;: &quot;some url&quot;\r\n        \t},\r\n        \t{\r\n        \t\t&quot;id&quot;: 1663,\r\n        \t\t&quot;description&quot;: &quot;This Ubuntu 20.04 is built from the Ubuntu Official&quot;,\r\n        \t\t&quot;path&quot;: &quot;x86_24&quot;,\r\n        \t\t&quot;url&quot;: &quot;some url&quot;\r\n        \t},\r\n\t        {\r\n\t\t        &quot;id&quot;: 1557,\r\n\t\t        &quot;description&quot;: &quot;This Centos 7 is built from the Centos Official&quot;,\r\n\t\t        &quot;path&quot;: &quot;x86_24&quot;,\r\n\t\t        &quot;url&quot;: &quot;some url&quot;\r\n\t        }\r\n        ]\r\n        }\r\n        {\r\n        \t&quot;id&quot;: 22,\r\n        \t&quot;description&quot;: &quot;exe&quot;,\r\n        \t&quot;active&quot;: true,\r\n        \t&quot;name&quot;: &quot;windows&quot;,\r\n        \t&quot;project&quot;: []\r\n        }\r\n        {\r\n        \t&quot;id&quot;: 34,\r\n        \t&quot;description&quot;: &quot;brew&quot;,\r\n        \t&quot;active&quot;: true,\r\n        \t&quot;name&quot;: &quot;mac&quot;,\r\n        \t&quot;project&quot;: []\r\n        }\r\n\r\n\r\nThe values which I need from this json is: id, description, project.id, project.description, project.url. I tried doing with jq cmd, but at last my csv is getting messed up. Here id holds project, project has multiple ids. I need to separate them and generate my csv like below. I&#39;m stuck up here. Any solution for this ? Thanks in Advance !\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/oEnW9.png",
        "link": "https://stackoverflow.com/questions/69999734/parsing-json-values-and-converting-them-to-csv-using-jq",
        "title": "Parsing json values and converting them to csv using jq"
    },
    {
        "tags": [
            "arrays",
            "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": 2,
                "creation_date": 1637155885,
                "post_id": 70004565,
                "comment_id": 123749617,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1637155708,
                "last_edit_date": 1637155708,
                "creation_date": 1637153738,
                "answer_id": 70004800,
                "question_id": 70004565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why are you mangling JSON with sed if you already have jq?\r\n\r\nI would simplify the loop to:\r\n```sh\r\ncurrentReportContent=`cat &quot;$FILE_REPORT&quot;`\r\nfor (( pageNumber=1; pageNumber&lt;=$COUNT_PAGES; pageNumber++ ))        \r\ndo\r\n    read -r resultIssues &lt; &lt;(curl -s -XGET &quot;$BASE_URL/issues/search?componentKeys=$PROJECT_KEY&amp;p=$pageNumber&amp;ps=$PAGE_SIZE&quot; | jq &#39;.issues&#39;)\r\n    currentReportContent=$(jq --argjson resultIssues &quot;$resultIssues&quot; &#39;.issues |= . + $resultIssues&#39; &lt;&lt;&lt; &quot;$currentReportContent&quot;) \r\n    echo &quot;$currentReportContent&quot; &gt; &quot;$FILE_REPORT&quot;\r\ndone\r\n```\r\n\r\nand if you don&#39;t mind a few temporary files it becomes massively simpler yet:\r\n```sh\r\nallPages=$(mktemp allPages.XXXXXX)\r\n\r\nfor (( pageNumber=1; pageNumber&lt;=$COUNT_PAGES; pageNumber++ ))        \r\ndo\r\n    curl -s -XGET &quot;$BASE_URL/issues/search?componentKeys=$PROJECT_KEY&amp;p=$pageNumber&amp;ps=$PAGE_SIZE&quot; | jq &#39;.issues[]&#39; &gt;&gt; $allPages\r\ndone\r\n\r\njq --slurpfile resultIssues $allPages &#39;.issues |= . + $resultIssues&#39; &quot;$FILE_REPORT&quot; | sponge &quot;$FILE_REPORT&quot;\r\n```",
                "title": "Can&#39;t add json items to the end of json array. Out of array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637179695,
        "creation_date": 1637152688,
        "last_edit_date": 1637179695,
        "question_id": 70004565,
        "body_markdown": "I wan to to add json items to the end of current array &quot;**issues**&quot;.\r\n\r\nI try this in bash:\r\n\r\n    #!/bin/bash\r\n    currentReportContent=`cat $FILE_REPORT`\r\n    for (( pageNumber=1; pageNumber&lt;=$COUNT_PAGES; pageNumber++ ))\t\t  \r\n    do\r\n        read -r currentIssuesArr &lt; &lt;(echo $(curl -s -XGET $BASE_URL/issues/search\\?componentKeys\\=$PROJECT_KEY\\&amp;p\\=$pageNumber\\&amp;ps\\=$PAGE_SIZE | jq &#39;.issues&#39;))\r\n        echo  &quot;before_currentIssuesArr = $currentIssuesArr&quot;\r\n        # remove first [ and last ]\r\n        resultIssues=${currentIssuesArr:1:${#currentIssuesArr}-2}\r\n        echo &quot;resultIssues = $resultIssues&quot;\r\n        currentReportContent=$(jq -r &quot;.issues[.issues| length] |= . + $resultIssues&quot; &lt;&lt;&lt; $currentReportContent) \r\n        echo &quot;$currentReportContent&quot; &gt; &quot;$FILE_REPORT&quot;\r\n        done\r\n\r\nHere output\r\n   \r\n\r\n     before_currentIssuesArr = [ { &quot;key&quot;: &quot;AX0h7PXHENszTAxEiB7V&quot;, &quot;rule&quot;: &quot;java:S1871&quot;, &quot;severity&quot;: &quot;MAJOR&quot;, &quot;component&quot;: &quot;myProject&quot;, &quot;project&quot;: &quot;some_component&quot;, &quot;line&quot;: 390, &quot;hash&quot;: &quot;129a49831e0f7ba156e0f3e4e4508a8c&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 390, &quot;endLine&quot;: 393, &quot;startOffset&quot;: 2, &quot;endOffset&quot;: 9 }, &quot;flows&quot;: [ { &quot;locations&quot;: [ { &quot;component&quot;: &quot;myProject/server-services/services-cfg/cfg-impl/src/&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 386, &quot;endLine&quot;: 389, &quot;startOffset&quot;: 2, &quot;endOffset&quot;: 9 }, &quot;msg&quot;: &quot;Original&quot; } ] } ], &quot;status&quot;: &quot;OPEN&quot;, &quot;message&quot;: &quot;This case&#39;s code block is the same as the block for the case on line 386.&quot;, &quot;effort&quot;: &quot;10min&quot;, &quot;debt&quot;: &quot;10min&quot;, &quot;author&quot;: &quot;eugeniur&quot;, &quot;tags&quot;: [ &quot;design&quot;, &quot;suspicious&quot; ], &quot;creationDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;updateDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;type&quot;: &quot;CODE_SMELL&quot;, &quot;scope&quot;: &quot;MAIN&quot; }, { &quot;key&quot;: &quot;AX0h7PXvENszTAxEiB7W&quot;, &quot;rule&quot;: &quot;java:S122&quot;, &quot;severity&quot;: &quot;MINOR&quot;, &quot;component&quot;: &quot;myProject/server-services&quot;, &quot;project&quot;: &quot;some_component&quot;, &quot;line&quot;: 238, &quot;hash&quot;: &quot;e88a41c67f42388448824393203574dd&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 238, &quot;endLine&quot;: 238, &quot;startOffset&quot;: 0, &quot;endOffset&quot;: 87 }, &quot;flows&quot;: [], &quot;status&quot;: &quot;OPEN&quot;, &quot;message&quot;: &quot;At most one statement is allowed per line, but 2 statements were found on this line.&quot;, &quot;effort&quot;: &quot;1min&quot;, &quot;debt&quot;: &quot;1min&quot;, &quot;author&quot;: &quot;eugeniur&quot;, &quot;tags&quot;: [ &quot;convention&quot; ], &quot;creationDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;updateDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;type&quot;: &quot;CODE_SMELL&quot;, &quot;scope&quot;: &quot;MAIN&quot; } ]\r\n        \r\n        resultIssues =  { &quot;key&quot;: &quot;AX0h7PXHENszTAxEiB7V&quot;, &quot;rule&quot;: &quot;java:S1871&quot;, &quot;severity&quot;: &quot;MAJOR&quot;, &quot;component&quot;: &quot;myProject/server-services/services-cfg/cfg-impl/src/&quot;, &quot;project&quot;: &quot;some_component&quot;, &quot;line&quot;: 390, &quot;hash&quot;: &quot;129a49831e0f7ba156e0f3e4e4508a8c&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 390, &quot;endLine&quot;: 393, &quot;startOffset&quot;: 2, &quot;endOffset&quot;: 9 }, &quot;flows&quot;: [ { &quot;locations&quot;: [ { &quot;component&quot;: &quot;myProject/server-services/services-cfg/cfg-impl/src/&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 386, &quot;endLine&quot;: 389, &quot;startOffset&quot;: 2, &quot;endOffset&quot;: 9 }, &quot;msg&quot;: &quot;Original&quot; } ] } ], &quot;status&quot;: &quot;OPEN&quot;, &quot;message&quot;: &quot;This case&#39;s code block is the same as the block for the case on line 386.&quot;, &quot;effort&quot;: &quot;10min&quot;, &quot;debt&quot;: &quot;10min&quot;, &quot;author&quot;: &quot;eugeniur&quot;, &quot;tags&quot;: [ &quot;design&quot;, &quot;suspicious&quot; ], &quot;creationDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;updateDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;type&quot;: &quot;CODE_SMELL&quot;, &quot;scope&quot;: &quot;MAIN&quot; }, { &quot;key&quot;: &quot;AX0h7PXvENszTAxEiB7W&quot;, &quot;rule&quot;: &quot;java:S122&quot;, &quot;severity&quot;: &quot;MINOR&quot;, &quot;component&quot;: &quot;myProject/server-service&quot;, &quot;project&quot;: &quot;some_component&quot;, &quot;line&quot;: 238, &quot;hash&quot;: &quot;e88a41c67f42388448824393203574dd&quot;, &quot;textRange&quot;: { &quot;startLine&quot;: 238, &quot;endLine&quot;: 238, &quot;startOffset&quot;: 0, &quot;endOffset&quot;: 87 }, &quot;flows&quot;: [], &quot;status&quot;: &quot;OPEN&quot;, &quot;message&quot;: &quot;At most one statement is allowed per line, but 2 statements were found on this line.&quot;, &quot;effort&quot;: &quot;1min&quot;, &quot;debt&quot;: &quot;1min&quot;, &quot;author&quot;: &quot;eugeniur&quot;, &quot;tags&quot;: [ &quot;convention&quot; ], &quot;creationDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;updateDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;, &quot;type&quot;: &quot;CODE_SMELL&quot;, &quot;scope&quot;: &quot;MAIN&quot; } \r\n\r\n\r\nAs you can see it successfully removes the first `[` and last `]`.\r\n\r\nNice.\r\n\r\nNow I try to add **resultIssues** to the end of array **issues**.\r\n\r\nBut here output in the file:\r\n\r\n\r\n \r\n\r\n     &quot;issues&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;AX0h7PXHENszTAxEiB7V&quot;,\r\n          &quot;rule&quot;: &quot;java:S1871&quot;,\r\n          &quot;severity&quot;: &quot;MAJOR&quot;,\r\n          &quot;component&quot;: &quot;myProject&quot;,\r\n          &quot;project&quot;: &quot;some_project&quot;,\r\n          &quot;line&quot;: 390,\r\n          &quot;hash&quot;: &quot;129a49831e0f7ba156e0f3e4e4508a8c&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 390,\r\n            &quot;endLine&quot;: 393,\r\n            &quot;startOffset&quot;: 2,\r\n            &quot;endOffset&quot;: 9\r\n          },\r\n          &quot;flows&quot;: [\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;myProject&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 386,\r\n                    &quot;endLine&quot;: 389,\r\n                    &quot;startOffset&quot;: 2,\r\n                    &quot;endOffset&quot;: 9\r\n                  },\r\n                  &quot;msg&quot;: &quot;Original&quot;\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;status&quot;: &quot;OPEN&quot;,\r\n          &quot;message&quot;: &quot;This case&#39;s code block is the same as the block for the case on line 386.&quot;,\r\n          &quot;effort&quot;: &quot;10min&quot;,\r\n          &quot;debt&quot;: &quot;10min&quot;,\r\n          &quot;author&quot;: &quot;eugeniur&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;design&quot;,\r\n            &quot;suspicious&quot;\r\n          ],\r\n          &quot;creationDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;,\r\n          &quot;updateDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;,\r\n          &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n          &quot;scope&quot;: &quot;MAIN&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;AX0h7PXvENszTAxEiB7W&quot;,\r\n      &quot;rule&quot;: &quot;java:S122&quot;,\r\n      &quot;severity&quot;: &quot;MINOR&quot;,\r\n      &quot;component&quot;: &quot;some_&quot;,\r\n      &quot;project&quot;: &quot;some_project&quot;,\r\n      &quot;line&quot;: 238,\r\n      &quot;hash&quot;: &quot;e88a41c67f42388448824393203574dd&quot;,\r\n      &quot;textRange&quot;: {\r\n        &quot;startLine&quot;: 238,\r\n        &quot;endLine&quot;: 238,\r\n        &quot;startOffset&quot;: 0,\r\n        &quot;endOffset&quot;: 87\r\n      },\r\n      &quot;flows&quot;: [],\r\n      &quot;status&quot;: &quot;OPEN&quot;,\r\n      &quot;message&quot;: &quot;At most one statement is allowed per line, but 2 statements were found on this line.&quot;,\r\n      &quot;effort&quot;: &quot;1min&quot;,\r\n      &quot;debt&quot;: &quot;1min&quot;,\r\n      &quot;author&quot;: &quot;eugeniur&quot;,\r\n      &quot;tags&quot;: [\r\n        &quot;convention&quot;\r\n      ],\r\n      &quot;creationDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;,\r\n      &quot;updateDate&quot;: &quot;2021-11-15T06:40:16+0200&quot;,\r\n      &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n      &quot;scope&quot;: &quot;MAIN&quot;\r\n    }\r\n\r\nWhy some json items  **out of** array &quot;**issues**&quot;?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70004565/cant-add-json-items-to-the-end-of-json-array-out-of-array",
        "title": "Can&#39;t add json items to the end of json array. Out of array"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1637160042,
                "creation_date": 1637160042,
                "answer_id": 70006406,
                "question_id": 70006317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Enclose the whole selector on the LHS within parentheses:\r\n\r\n```\r\n(.myValues[] | select(.filterableValue == &quot;y&quot;)).this = &quot;has been added&quot;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/ApdfbDXDU7)",
                "title": "JQ: Modify object that is the result of a filter while keeping the original structure"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637161107,
                "last_edit_date": 1637161107,
                "creation_date": 1637160807,
                "answer_id": 70006642,
                "question_id": 70006317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, let&#39;s cleanup \r\n\r\n```jq\r\n.myValues | map(select(.filterableValue==&quot;y&quot;))[0]\r\n```\r\n\r\nIt&#39;s better written as\r\n\r\n```jq\r\n.myValues[] | select(.filterableValue==&quot;y&quot;)\r\n```\r\n\r\nNot only is it shorter, it handles the case where there are 0 or 2+ matches better.\r\n\r\n---\r\n\r\nThen, you just need to change `... |` to `( ... ) |=`.\r\n\r\n```jq\r\n( .myValues[] | select(.filterableValue==&quot;y&quot;) ) |= ( .this = &quot;has been added&quot; )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/DA2V5Dz8bu)\r\n",
                "title": "JQ: Modify object that is the result of a filter while keeping the original structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1637173898,
        "creation_date": 1637159715,
        "last_edit_date": 1637173898,
        "question_id": 70006317,
        "body_markdown": "I have the following JSON\r\n## Original Data\r\n```json\r\n{\r\n  &quot;myValues&quot;: [\r\n    {\r\n      &quot;filterableValue&quot;: &quot;x&quot;,\r\n      &quot;something&quot;: &quot;else&quot;\r\n    },\r\n    {\r\n      &quot;filterableValue&quot;: &quot;y&quot;,\r\n      &quot;another key&quot;: &quot;another value&quot;\r\n    },\r\n    {\r\n      &quot;filterableValue&quot;: &quot;z&quot;\r\n    }\r\n  ],\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\nUsing JQ I want to add a key value pair to the first (or all) entries in the `myValues` array, that have the `filterableValue==&quot;y&quot;`. The position/index of these entries inside the `myValues` array is arbitrary.\r\n\r\n## Expected Output\r\nThe result should have the same structure (still contain both `foo` and `myValues`) but have a modified entry where `filterableValue==&quot;y&quot;`.\r\n\r\n```json\r\n{\r\n  &quot;myValues&quot;: [\r\n    {\r\n      &quot;filterableValue&quot;: &quot;x&quot;,\r\n      &quot;something&quot;: &quot;else&quot;\r\n    },\r\n    {\r\n      &quot;filterableValue&quot;: &quot;y&quot;,\r\n      &quot;another key&quot;: &quot;another value&quot;,\r\n      &quot;this&quot;: &quot;has been added&quot; // &lt;-- this is the only thing that changed\r\n    },\r\n    {\r\n      &quot;filterableValue&quot;: &quot;z&quot;\r\n    }\r\n  ],\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\n## What I tried and why it failed\r\nSo far I managed to filter the respective array entry and set the value on the filtered output but didn&#39;t manage to keep the original structure AND modifiy a filtered entry.\r\nMy JQ that adds the `&quot;this&quot;:&quot;has been added&quot;` pair but does _not_ contain the original structure is:\r\n\r\n`.myValues|map(select(.filterableValue==&quot;y&quot;))[0]|.this=&quot;has been added&quot;`\r\n[jqplay mwe](https://jqplay.org/s/M-030I0lr0)\r\n\r\n## Question\r\nHow can I modify a filtered entry as above _and_ contain the original structure?",
        "link": "https://stackoverflow.com/questions/70006317/jq-modify-object-that-is-the-result-of-a-filter-while-keeping-the-original-stru",
        "title": "JQ: Modify object that is the result of a filter while keeping the original structure"
    },
    {
        "tags": [
            "python",
            "json",
            "csv",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17067994,
                    "reputation": 23,
                    "user_id": 12349538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QKFz9.png?s=256",
                    "display_name": "Brandon",
                    "link": "https://stackoverflow.com/users/12349538/brandon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637185373,
                "post_id": 70011869,
                "comment_id": 123761941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14170934,
                    "reputation": 11918,
                    "user_id": 10237506,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Gqq2VGl.jpg?s=256",
                    "display_name": "Wizard.Ritvik",
                    "link": "https://stackoverflow.com/users/10237506/wizard-ritvik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637188107,
                "post_id": 70011869,
                "comment_id": 123762873,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17067994,
                    "reputation": 23,
                    "user_id": 12349538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QKFz9.png?s=256",
                    "display_name": "Brandon",
                    "link": "https://stackoverflow.com/users/12349538/brandon"
                },
                "reply_to_user": {
                    "account_id": 14170934,
                    "reputation": 11918,
                    "user_id": 10237506,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Gqq2VGl.jpg?s=256",
                    "display_name": "Wizard.Ritvik",
                    "link": "https://stackoverflow.com/users/10237506/wizard-ritvik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637188387,
                "post_id": 70011869,
                "comment_id": 123762958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14170934,
                    "reputation": 11918,
                    "user_id": 10237506,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Gqq2VGl.jpg?s=256",
                    "display_name": "Wizard.Ritvik",
                    "link": "https://stackoverflow.com/users/10237506/wizard-ritvik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637188447,
                "post_id": 70011869,
                "comment_id": 123762979,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17067994,
                    "reputation": 23,
                    "user_id": 12349538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QKFz9.png?s=256",
                    "display_name": "Brandon",
                    "link": "https://stackoverflow.com/users/12349538/brandon"
                },
                "reply_to_user": {
                    "account_id": 14170934,
                    "reputation": 11918,
                    "user_id": 10237506,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Gqq2VGl.jpg?s=256",
                    "display_name": "Wizard.Ritvik",
                    "link": "https://stackoverflow.com/users/10237506/wizard-ritvik"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1637189065,
                "post_id": 70011869,
                "comment_id": 123763118,
                "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": 1637193889,
                "post_id": 70011869,
                "comment_id": 123764100,
                "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": 1637195116,
                "post_id": 70011869,
                "comment_id": 123764344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637314550,
                "last_edit_date": 1637314550,
                "creation_date": 1637191717,
                "answer_id": 70012823,
                "question_id": 70011869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a fast solution using jq.  It requires hardly any memory, but there is general caveat and one potential complication.\r\n\r\nThe caveat is that it has been assumed that the &quot;joined_by&quot; array can be flattened into a string using &quot;; &quot; as a separator.\r\n\r\nThe complication is that some CSV parsers require a &quot;rectangular&quot; structure.  In the first potential solution below, the header that is generated will only take into account the length of the \r\n&quot;opinions_cited&quot; array in the first file that is presented.  If later JSON files contain more\r\n&quot;opinions_cited&quot;, the rows will still be correct, but the header will not take them into account.\r\n\r\nIf the header is an issue, then you might wish to consider a two-pass solution to avoid memory issues.  As shown in Part 2 of this answer, the first pass would be responsible for\r\ndetermining the maximum array length,\r\nand in the second pass, this value would be used to determine the appropriate headers.\r\n\r\nYou might also wish to consider a post-processing &quot;fixup&quot;.\r\n\r\nFor testing, I&#39;d suggest using a truncated version of `topKeys`, e.g.\r\n```jq\r\ndef topKeys: {resource_url, opinions_cited};\r\n```\r\n## Part 1 - a one-pass approach\r\n\r\nThe following has been tested with this invocation of jq in the directory in which all the .json files reside:\r\n```bash\r\njq -Mnrf combine.jq *.json &gt; wash.csv\r\n```\r\n\r\n### combine.jq\r\n```jq\r\ndef topKeys: {\r\n  resource_url,\r\n  id,\r\n  absolute_url,\r\n  cluster,\r\n  author,\r\n  joined_by,\r\n  author_str,\r\n  per_curiam,\r\n  date_created,\r\n  date_modified,\r\n  type,\r\n  sha1,\r\n  page_count,\r\n  download_url,\r\n  local_path,\r\n  plain_text,\r\n  html,\r\n  html_lawbox,\r\n  html_columbia,\r\n  html_with_citations,\r\n  extracted_by_ocr\r\n}\r\n  | .joined_by |= (if type == &quot;array&quot; then join(&quot;; &quot;) else . end)\r\n;\r\n\r\ndef header:\r\n (topKeys|keys_unsorted) + [range(1; 1 + (.opinions_cited | length)) ];\r\n\r\ndef row:\r\n  [topKeys[]] + .opinions_cited;\r\n\r\n# s should be a stream of arrays\r\n# For each item in the stream, a counter (starting at 1) is inserted before the other items\r\ndef insert_counter(s): foreach s as $x (0; .+1; [.] + $x);\r\n\r\n# Read the first file for the headers\r\ninput\r\n| ([&quot;record&quot;] + header),\r\n   insert_counter( (., inputs) | row )\r\n| @csv\r\n```\r\n\r\n## Part 2 - a two-pass solution\r\n\r\n(a) Change the def of `header` above to:\r\n```\r\ndef header:\r\n (topKeys|keys_unsorted) + [range(1; 1 + $n) ];\r\n```\r\n(b) Use or adapt the following script:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nn=$(jq &#39;def max(s): reduce s as $x (null; if . == null or $x &gt; . then $x else . end); max(.opinions_cited|length)&#39; *.json )\r\n\r\njq -Mnr --argjson n $n -f combine.jq *.json &gt; wash.csv\r\n\r\n```\r\n\r\n### For the record...\r\n\r\nThere are many post-processing alternatives.  One is to use [csvq][1], e.g.:\r\n```\r\ncsvq --allow-uneven-fields -f CSV &#39;select *&#39; &lt; wash.csv | sponge wash.csv\r\n```\r\n\r\n\r\n  [1]: https://github.com/mithrandie/csvq",
                "title": "How do I use python or jq to merge multiple JSON files with uniform columns into one CSV?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637314550,
        "creation_date": 1637184983,
        "last_edit_date": 1637193970,
        "question_id": 70011869,
        "body_markdown": "I am trying to make Primary Source American Law more American with Disabilities Act (ADA), more compliant for my Study.\r\n\r\nThe technical question is in the topic.\r\n\r\nThe source files I am using are found here: [https://www.courtlistener.com/api/bulk-data/opinions/wash.tar.gz][1]\r\n\r\nA sample JSON file within that archive (which contains 52,565 Washington State Supreme Court Judicial Opinions),\r\n\r\n987095.json is an example with the following &quot;elements&quot; (I want to carry the element names over as column names while providing a new id for record count; rather than source database id column):\r\n\r\nUsing [Dadroit Viewer 1.5 Build 1935.appimage][2] to view the JSON data easiest for me.\r\n\r\nI extracted the following data (the bottom opinions_cited has [] brackets with 0 - 28 in them; and I expect each JSON to have different numbers of opinions_cited ; anyone from 0 to 1000 or more perhaps); I don&#39;t know the most cases cited in a Judicial Opinion.\r\n\r\n**Extracted from JSON**:\r\n\r\n```none\r\nresource_url \r\nid \r\nabsolute_url \r\ncluster \r\nauthor \r\njoined_by \r\nauthor_str\r\nper_curiam \r\ndate_created \r\ndate_modified \r\ntype \r\nsha1 \r\npage_count\r\ndownload_url \r\nlocal_path \r\nplain_text \r\nhtml \r\nhtml_lawbox \r\nhtml_columbia\r\nhtml_with_citations \r\nextracted_by_ocr\r\n   \r\nopinions_cited  (sub nodes) [0] - [28]\r\n\r\n```\r\n\r\nI need assistance in merging the directory (I tried various solutions found on google and stackoverflow for merging; none that I put against my cpu, memory or time has proven to work without taking for hours to error or produce nothing in the end).\r\n\r\nHow to I create 1 large CSV for every folder of JSONs (containing tens of thousands; in this example 54k) 1 JSON for every row in the CSV using JSON element names to create column&#39;s.\r\n\r\nThe StackOverFlow script I was using (code can be seen here to the error I posted in comments):\r\n\r\n```python\r\nimport glob\r\nimport json\r\n\r\nfile_names = glob.glob(&#39;*.json&#39;)\r\n\r\njson_list = []\r\n\r\nfor curr_f_name in file_names:\r\n    with open(curr_f_name) as curr_f_obj:\r\n        json_list.append(json.load(curr_f_obj))\r\n\r\nwith open(&#39;json_merge_out.json&#39;, &#39;w&#39;) as out_file:\r\n    json.dump(json_list, out_file, indent=4)\r\n```\r\n\r\nThe above attempt remedy outputs the following error:\r\n\r\n```none\r\n/Wash/json# ./json.merge.python.1.py\r\n./json.merge.python.1.py: line 4: syntax error near unexpected token `(&#39;\r\n./json.merge.python.1.py: line 4: `file_names = glob.glob(&#39;*.json&#39;)&#39;\r\n```\r\n\r\n  [1]: https://www.courtlistener.com/api/bulk-data/opinions/wash.tar.gz\r\n  [2]: https://dadroit.com/download\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70011869/how-do-i-use-python-or-jq-to-merge-multiple-json-files-with-uniform-columns-into",
        "title": "How do I use python or jq to merge multiple JSON files with uniform columns into one CSV?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1637221556,
                "creation_date": 1637221556,
                "answer_id": 70016167,
                "question_id": 70015029,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What I would like to do is get the objects that are unique by their .hash\r\n\r\nOne way to remove the duplicates would be to use `unique_by/1` in conjunction with the -s command-line option.  \r\n\r\nAssuming you want all the items in all the .data arrays\r\nyou could start your pipeline with:\r\n```\r\njq -s &#39;map(.data[]) | unique_by(.hash) ...&#39; \r\n```\r\n\r\nHowever, since you are really only interested in the .timestamp and .amount fields, it would be more efficient to proceed along the following lines:\r\n```\r\njq -s --arg this &quot;$(date +%Y-%m-%dT%H:%M:%S)&quot; &#39;\r\n  map(.data[] | select(.timestamp &gt;= $this) | {hash, amount})\r\n  | unique_by(.hash)[]\r\n  | .amount\r\n&#39; input.json\r\n\r\n\r\n",
                "title": "Get unique objects and arrays based on key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1747639007,
        "creation_date": 1637213698,
        "last_edit_date": 1747639007,
        "question_id": 70015029,
        "body_markdown": "Is there a way to return a unique object/array when duplicates exist? Here&#39;s what I&#39;m trying to do. \r\n\r\nI have a payload like this:\r\n\r\n```lang-json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;amount&quot;: 7885016,\r\n      &quot;block&quot;: 470788,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-28T01:29:46.000000Z&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;amount&quot;: 7885016,\r\n      &quot;block&quot;: 470788,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-28T01:29:46.000000Z&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;amount&quot;: 8623955,\r\n      &quot;block&quot;: 470509,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;5fQJY9MprH9b3IstVU1SdfBteUWoF_sdsVuiARPBtTY&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-27T19:01:48.000000Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAs you can see, the first 2 payloads are identical and the last one is unique. I need to get the unique objects and then sum up the .amount when they fall below a certain time period. Here&#39;s what I have so far\r\n\r\n```lang-bash\r\njq --arg this &quot;$(date +%Y-%m-%dT%H:%M:%S)&quot; &#39;.data[] | select(.timestamp &gt;= $this) | .amount&#39;\r\n```\r\n\r\nWhich gives me the amounts so I can sum them up but, it also contains the duplicates. What I would like to do is get the objects that are unique by their `.hash` The idea is to sum up the total amounts that fall within the given date\r\n",
        "link": "https://stackoverflow.com/questions/70015029/get-unique-objects-and-arrays-based-on-key-value",
        "title": "Get unique objects and arrays based on key value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1637237150,
                "creation_date": 1637237150,
                "answer_id": 70019532,
                "question_id": 70019429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this\r\n```sh\r\njq &#39;.[] | select(.name == &quot;foo&quot;)&#39; \r\n```\r\n[Demo](https://jqplay.org/s/Lfb2eF6Xvp)",
                "title": "How to filter an list by the value of an inner dict with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1637262047,
        "creation_date": 1637236678,
        "last_edit_date": 1637262047,
        "question_id": 70019429,
        "body_markdown": "Giving the input JSON:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;value&quot;: 1\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;value&quot;: 1\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;value&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m trying to get the dicts with the name `foo`, so the expecting output is:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;value&quot;: 1\r\n},\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;value&quot;: 2\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70019429/how-to-filter-an-list-by-the-value-of-an-inner-dict-with-jq",
        "title": "How to filter an list by the value of an inner dict with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637249143,
                "last_edit_date": 1637249143,
                "creation_date": 1637247069,
                "answer_id": 70021929,
                "question_id": 70021792,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can split up a string into an array using the `/` operator and a separator, `&quot;/&quot;` in your case:\r\n\r\n```\r\n.spec.rules[0].match.resources.kinds / &quot;/&quot;\r\n```\r\n```json\r\n[\r\n  &quot;networking.k8s.io&quot;,\r\n  &quot;v1&quot;,\r\n  &quot;NetworkPolicy&quot;\r\n]\r\n```\r\nThen, rearrange according to the presence of the elements:\r\n```\r\n... | [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n```\r\nFinally, assign the array elements to multiple variables at once:\r\n```\r\n... as [$version,$group,$kind]\r\n```\r\n\r\nCombined:\r\n```\r\n(.spec.rules[0].match.resources.kinds / &quot;/&quot;)\r\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n  as [$version,$group,$kind]\r\n| {$version,$group,$kind}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/vAgo6WI-44)",
                "title": "Split &quot;/&quot; with complex conditions in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1637249143,
        "creation_date": 1637246494,
        "question_id": 70021792,
        "body_markdown": "I have json:\r\n```json\r\n    &quot;spec&quot;: {\r\n        &quot;background&quot;: true,\r\n        &quot;failurePolicy&quot;: &quot;Fail&quot;,\r\n        &quot;rules&quot;: [\r\n            {\r\n                &quot;exclude&quot;: {\r\n                    &quot;resources&quot;: {}\r\n                },\r\n                &quot;generate&quot;: {\r\n                    &quot;clone&quot;: {}\r\n                },\r\n                &quot;match&quot;: {\r\n                    &quot;resources&quot;: {\r\n                        &quot;kinds&quot;: [\r\n                            &quot;networking.k8s.io/v1/NetworkPolicy&quot;\r\n                        ]\r\n                    }\r\n                },\r\n                &quot;mutate&quot;: {},\r\n                &quot;name&quot;: &quot;validate-nodeport&quot;,\r\n                &quot;validate&quot;: {\r\n                    &quot;message&quot;: &quot;Services of type NodePort are not allowed.&quot;,\r\n                    &quot;pattern&quot;: {\r\n                        &quot;spec&quot;: {\r\n                            &quot;type&quot;: &quot;!NodePort&quot;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        ],\r\n        &quot;validationFailureAction&quot;: &quot;audit&quot;\r\n    },\r\n    &quot;status&quot;: {\r\n        &quot;ready&quot;: true\r\n    }\r\n}\r\n```\r\nI need to parse this string ```&quot;networking.k8s.io/v1/NetworkPolicy&quot;```, BUT its can be looks like ```Kind``` or ```Version/Kind``` or ```Version/Group/Kind```. I have jq command only for ```Kind``` case: ```.spec.rules[0].match.resources.kinds[] as $kind```\r\n\r\nI need more universal command for split string to &quot;/&quot;, but in some cases there may be one &quot;/&quot; and in some cases two. I need to parse it correctly and write a command with the condition",
        "link": "https://stackoverflow.com/questions/70021792/split-with-complex-conditions-in-jq",
        "title": "Split &quot;/&quot; with complex conditions in JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637250152,
                "creation_date": 1637250152,
                "answer_id": 70022750,
                "question_id": 70022570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t need to use _entries function, a simple key/value lookup and string interpolation should suffice\r\n\r\n```\r\nkeys_unsorted[] as $k | &quot;\\($k);\\( .[$k][])&quot;\r\n```\r\n\r\nThe construct `.[$k][]` is an expression that first expands the value associated with each key, i.e. `.foo` and then with [object construction][1], produces multiple results for each key identified and stored in `$k` variable.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/#ObjectConstruction:%7B%7D",
                "title": "JQ: Convert Dictionary with List as Values to flat CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637255176,
        "creation_date": 1637249500,
        "last_edit_date": 1637255176,
        "question_id": 70022570,
        "body_markdown": "### Original Data\r\nI have the following JSON:\r\n\r\n```json\r\n{\r\n    &quot;foo&quot;:[\r\n        &quot;asd&quot;,\r\n        &quot;fgh&quot;\r\n    ],\r\n    &quot;bar&quot;:[\r\n        &quot;abc&quot;,\r\n        &quot;xyz&quot;,\r\n        &quot;ert&quot;\r\n    ],\r\n    &quot;baz&quot;:[\r\n        &quot;something&quot;\r\n    ]\r\n}\r\n```\r\n\r\nNow I want to transform it to a &quot;flat&quot; CSV, such that for every key in my object the list in the value is expanded to `n` rows with `n` being the number of entries in the respective list.\r\n\r\n### Expected Output\r\n```csv\r\nfoo;asd\r\nfoo;fgh\r\nbar;abc\r\nbar;xyz\r\nbar;ert\r\nbaz;something\r\n```\r\n## Approaches\r\nI guess I need to use `to_entries` and then **for each** `.value` repeat the same `.key` for the first column. The [jq docs state](https://stedolan.github.io/jq/manual/#Advancedfeatures) that:\r\n&gt; Thus `as` functions as something of a foreach loop.\r\n\r\nSo I tried combining \r\n* `to_entries`to give the keys and values from my dictionary an accessible name\r\n* then build kind of a foreach loop around the `.value`s\r\n* and pass the result to `@csv`\r\n\r\n`to_entries|map(.value) as $v|what goes here?|@csv`\r\n\r\nI prepared something that at least compiles [here](https://jqplay.org/s/xZ_FCxVD5H)",
        "link": "https://stackoverflow.com/questions/70022570/jq-convert-dictionary-with-list-as-values-to-flat-csv",
        "title": "JQ: Convert Dictionary with List as Values to flat CSV"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "subtraction",
            "blacklist"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1637270647,
                "last_edit_date": 1637270647,
                "creation_date": 1637267981,
                "answer_id": 70026453,
                "question_id": 70026357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Suppose you have:\r\n\r\n```json\r\n[10, 10, 20, 10, 20, 10, 30]\r\n```\r\n\r\n…and you want to remove all the `20` and all the `30`. Here&#39;s one way:\r\n\r\n```none\r\n. - [20, 30]\r\n```\r\n\r\n&gt; As well as normal arithmetic subtraction on numbers, the `-` operator can be used on arrays to remove all occurrences of the second array&#39;s elements from the first array.\r\n\r\nSee https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions\r\n\r\nIn your case you could do:\r\n\r\n```none\r\n.vars.instances -= [&quot;three&quot;, &quot;five&quot;]\r\n```\r\n\r\n…which returns:\r\n\r\n```json\r\n{\r\n  &quot;address&quot;: &quot;localhost&quot;,\r\n  &quot;name&quot;: &quot;local&quot;,\r\n  &quot;vars&quot;: {\r\n    &quot;instances&quot;: [\r\n      &quot;one&quot;,\r\n      &quot;two&quot;,\r\n      &quot;four&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n",
                "title": "JQ — Remove elements by value not index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637270694,
        "creation_date": 1637267522,
        "last_edit_date": 1637270694,
        "question_id": 70026357,
        "body_markdown": "I need to delete all elements of `instances` that are either set to &quot;three&quot; or &quot;five&quot;. Their index is not always the same:\r\n\r\n```json\r\n{\r\n&quot;address&quot;: &quot;localhost&quot;,\r\n&quot;name&quot;: &quot;local&quot;,\r\n&quot;vars&quot;: {\r\n    &quot;instances&quot;: [\r\n        &quot;one&quot;,\r\n        &quot;two&quot;,\r\n        &quot;three&quot;,\r\n        &quot;four&quot;,\r\n        &quot;five&quot;\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70026357/jq-remove-elements-by-value-not-index",
        "title": "JQ — Remove elements by value not index"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637310460,
                "creation_date": 1637310460,
                "answer_id": 70031850,
                "question_id": 70031566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are feeding `.[]` into `map(.field)` as well as `map(.value)`.\r\n\r\nUse `map(.field)` only on the `first` item, and `map(.value)` on all items `.[]`:\r\n\r\n```sh\r\njq -r &#39;.results | (first | map(.field)), (.[] | map(.value)) | @csv&#39; input.json \r\n```\r\n[Demo](https://jqplay.org/s/Rc7sqqMpmu)",
                "title": "How to convert a hash of an array of array of hashes JSON input into CSV using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637311199,
        "creation_date": 1637308812,
        "last_edit_date": 1637311199,
        "question_id": 70031566,
        "body_markdown": "I want to convert the following JSON content stored in a file input.json\r\n\r\n```\r\n{\r\n    &quot;results&quot;: [\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value1-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value1-2&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field3&quot;,\r\n               &quot;value&quot;: &quot;value1-3&quot;\r\n           }\r\n        ],\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value2-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value2-2&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field3&quot;,\r\n               &quot;value&quot;: &quot;value2-3&quot;\r\n           }\r\n        ],\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value3-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value3-2&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field3&quot;,\r\n               &quot;value&quot;: &quot;value3-3&quot;\r\n           }\r\n        ]\r\n    ]\r\n}\r\n```\r\n\r\ninto a CSV output\r\n\r\n```\r\n&quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;\r\n&quot;value1-1&quot;,&quot;value1-2&quot;,&quot;value1-3&quot;\r\n&quot;value2-1&quot;,&quot;value2-2&quot;,&quot;value2-3&quot;\r\n&quot;value3-1&quot;,&quot;value3-2&quot;,&quot;value3-3&quot;\r\n```\r\n\r\nThe closest jq expression I&#39;ve come up with is this:\r\n\r\n```\r\n$ cat input.json | jq -r &#39;.results | .[] | map(.field), map(.value) | @csv&#39;\r\n&quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;\r\n&quot;value1-1&quot;,&quot;value1-2&quot;,&quot;value1-3&quot;\r\n&quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;\r\n&quot;value2-1&quot;,&quot;value2-2&quot;,&quot;value2-3&quot;\r\n&quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;\r\n&quot;value3-1&quot;,&quot;value3-2&quot;,&quot;value3-3&quot;\r\n```\r\n\r\nwhich is still not correct. How should I write the jq expression to get the desired CSV output?\r\n",
        "link": "https://stackoverflow.com/questions/70031566/how-to-convert-a-hash-of-an-array-of-array-of-hashes-json-input-into-csv-using-j",
        "title": "How to convert a hash of an array of array of hashes JSON input into CSV using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1637323889,
                "post_id": 70034146,
                "comment_id": 123802032,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1637323658,
                "creation_date": 1637323658,
                "answer_id": 70034604,
                "question_id": 70034146,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can construct an array and then use `@csv` directly:\r\n\r\n    $ jq -r &#39;[.id,.meta.lastUpdated,.identifier[0].value,.identifier[1].value,.identifier[2].value,.code[0].coding[0].code] | @csv&#39; file.txt\r\n    &quot;2261026&quot;,&quot;2021-11-08T15:13:39.318+01:00&quot;,&quot;6209&quot;,&quot;00042&quot;,&quot;UAB2&quot;,&quot;MG&quot;\r\n    &quot;2261027&quot;,&quot;2021-11-08T15:13:39.140+01:00&quot;,&quot;6734&quot;,&quot;01785&quot;,&quot;IN013&quot;,&quot;INF&quot;",
                "title": "Jq: map fields to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637350228,
        "creation_date": 1637321328,
        "last_edit_date": 1637350228,
        "question_id": 70034146,
        "body_markdown": "I need to map and convert a json file to csv.\r\n\r\nThis is my file. Take in mind, it&#39;s not an array. Each element is in a row.\r\n\r\n```\r\n{\r\n   &quot;resourceType&quot;:&quot;PractitionerRole&quot;,\r\n   &quot;id&quot;:&quot;2261026&quot;,\r\n   &quot;meta&quot;:{\r\n      &quot;versionId&quot;:&quot;1&quot;,\r\n      &quot;lastUpdated&quot;:&quot;2021-11-08T15:13:39.318+01:00&quot;,\r\n      &quot;source&quot;:&quot;#wcktDPNPRW67Ths4&quot;\r\n   },\r\n   &quot;identifier&quot;:[\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.93&quot;,\r\n         &quot;value&quot;:&quot;6209&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.2&quot;,\r\n         &quot;value&quot;:&quot;00042&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.90&quot;,\r\n         &quot;value&quot;:&quot;UAB2&quot;\r\n      }\r\n   ],\r\n   &quot;active&quot;:true,\r\n   &quot;practitioner&quot;:{\r\n      &quot;reference&quot;:&quot;Practitioner/1046220&quot;\r\n   },\r\n   &quot;code&quot;:[\r\n      {\r\n         &quot;coding&quot;:[\r\n            {\r\n               &quot;system&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rol-professional&quot;,\r\n               &quot;code&quot;:&quot;MG&quot;\r\n            }\r\n         ]\r\n      }\r\n   ]\r\n}\r\n{\r\n   &quot;resourceType&quot;:&quot;PractitionerRole&quot;,\r\n   &quot;id&quot;:&quot;2261027&quot;,\r\n   &quot;meta&quot;:{\r\n      &quot;versionId&quot;:&quot;1&quot;,\r\n      &quot;lastUpdated&quot;:&quot;2021-11-08T15:13:39.140+01:00&quot;,\r\n      &quot;source&quot;:&quot;#l6DwTkxasiJQmfBJ&quot;\r\n   },\r\n   &quot;identifier&quot;:[\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.93&quot;,\r\n         &quot;value&quot;:&quot;6734&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.2&quot;,\r\n         &quot;value&quot;:&quot;01785&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.91&quot;,\r\n         &quot;value&quot;:&quot;IN013&quot;\r\n      }\r\n   ],\r\n   &quot;active&quot;:true,\r\n   &quot;practitioner&quot;:{\r\n      &quot;reference&quot;:&quot;Practitioner/1045804&quot;\r\n   },\r\n   &quot;code&quot;:[\r\n      {\r\n         &quot;coding&quot;:[\r\n            {\r\n               &quot;system&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rol-professional&quot;,\r\n               &quot;code&quot;:&quot;INF&quot;\r\n            }\r\n         ]\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI need to get those fields:\r\n\r\n```\r\n.id, .meta.lastUpdated, .identifier[0].value, .identifier[1].value, .identifier[2].value, .code[0].coding[0].code\r\n```\r\n\r\nAnd extract them as `id, lastUpdated, identifier1, identifier2, identifier3, code` in csv format.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70034146/jq-map-fields-to-csv",
        "title": "Jq: map fields to csv"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637326848,
                "creation_date": 1637326848,
                "answer_id": 70035254,
                "question_id": 70034818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Enclose your expression in brackets and add `| [&quot;test&amp;foo&amp;bar&quot;] + . | .[]` at the end.\r\n\r\n```\r\n[group_by(.type)[][] | &quot;\\(if &quot;type&quot; == &quot;foo&quot; then &quot;oof&quot; else &quot;rab&quot; end)&amp;\\(.name)&quot;] | [&quot;test&amp;foo&amp;bar&quot;] + . | .[]\r\n```\r\n\r\nNot sure why you need `columns`. Seems like you can just replace `&amp;` with `\\t`.",
                "title": "JQ Add (static) header before filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1637326848,
        "creation_date": 1637324733,
        "last_edit_date": 1637325421,
        "question_id": 70034818,
        "body_markdown": "Consider the following (simplified) JSON:\r\n```json\r\n[\r\n    {\r\n        &quot;type&quot;: &quot;foo&quot;,\r\n        &quot;name&quot;: &quot;test_1&quot;\r\n    },\r\n    {\r\n        &quot;type&quot;: &quot;bar&quot;,\r\n        &quot;name&quot;: &quot;test_2&quot;\r\n    },\r\n    {\r\n        &quot;type&quot;: &quot;bar&quot;,\r\n        &quot;name&quot;: &quot;test_3&quot;\r\n    }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\nI&#39;m using the following filter to generate my output:\r\n```none\r\ngroup_by(.type)[][] | &quot;\\(if &quot;type&quot; == &quot;foo&quot; then &quot;oof&quot; else &quot;rab&quot; end)&amp;\\(.name)&quot;\r\n```\r\n\r\nThis produces\r\n```none\r\nrab&amp;test_2\r\nrab&amp;test_3\r\nrab&amp;test_1\r\n```\r\n&lt;sup&gt;[Demo][1]&lt;/sup&gt;\r\n\r\nUsing `column -ts &#39;&amp;&#39;` this gets converted to:\r\n```none\r\nrab  test_2\r\nrab  test_3\r\nrab  test_1\r\n```\r\n\r\n----------\r\n\r\nMy *problem*; I need to add a custom header line, so that the output becomes:\r\n```json\r\ntest&amp;foo&amp;bar\r\nrab&amp;test_2\r\nrab&amp;test_3\r\nrab&amp;test_1\r\n```\r\n\r\n\r\n----------\r\n\r\nThere are many questions how to add (a static) set of header lines, like:\r\n* &lt;https://stackoverflow.com/questions/30015555/how-to-add-a-header-to-csv-export-in-jq&gt;\r\n* &lt;https://stackoverflow.com/questions/65897260/column-name-in-the-csv-file-after-converting-from-json-using-jq&gt;\r\n\r\nBut I&#39;m unable to combine it so I can leave the `group_by` intact and let `column` handle the spacing\r\n\r\n(I&#39;d rather let `column` handle the spacing)\r\n\r\n----------\r\n\r\n&lt;sup&gt;***tl;dr***;&lt;/sup&gt;  \r\nHow can I add a custom header array, something like:\r\n```none\r\n[ &quot;test&quot;, &quot;foo&quot;, &quot;bar&quot; ] | join(&quot;&amp;&quot;)\r\n```\r\n\r\nSo that\r\n * The `group_by` and everything behind it isn&#39;t changed\r\n * `column` can parse the output\r\n\r\n\r\n----------\r\n\r\n**Edit**, of course I can pull off the `column` from the `jq` command, and &#39;abuse&#39; `echo` like so:\r\n```bash\r\nugly=$(curl --silent &lt;URI&gt; \\\r\n        | jq -r &#39;group_by(.type)[][] | &quot;\\(if &quot;type&quot; == &quot;foo&quot; then &quot;oof&quot; else &quot;rab&quot; end)&amp;\\(.name)&quot;&#39; \\\r\n        | egrep --color -E &quot;FooBar|$&quot;)\r\nheaders=&quot;foo#bar#foorbar&quot;\r\necho &quot;$headers\\n$ugly&quot; | column -ts &#39;#&#39; \\\r\n```\r\n\r\nBut I&#39;d rather keep the `| column` on the `jq` part so that `echo` and `$ugly` aren&#39;t needed.\r\n\r\n  [1]: https://jqplay.org/s/5EswrYDxhW",
        "link": "https://stackoverflow.com/questions/70034818/jq-add-static-header-before-filter",
        "title": "JQ Add (static) header before filter"
    },
    {
        "tags": [
            "json",
            "foreach",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637327047,
                "creation_date": 1637327047,
                "answer_id": 70035305,
                "question_id": 70034893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your structure is so rigid, you can cheat and use the built-in `from_entries`, which takes a list of `{key, value}` pairs and constructs an object:\r\n```\r\n.main[] |\r\n{firstKey, id} +\r\n  (.data | map({key: &quot;data.name.\\(.name)&quot;, value}) |\r\n   from_entries)\r\n```",
                "title": "Combining all key value pairs in one using jq filter or jq play"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637327047,
        "creation_date": 1637325136,
        "question_id": 70034893,
        "body_markdown": "I want to transform JSON data using jq filter\r\n\r\nJson data: \r\n```\r\n{\r\n &quot;main&quot;: [\r\n  {\r\n   &quot;firstKey&quot;: &quot;ABCD&quot;,\r\n   &quot;id&quot;: &quot;12345&quot;,\r\n   &quot;data&quot;: [\r\n    {\r\n     &quot;name&quot;: &quot;first_id&quot;,\r\n     &quot;value&quot;: &quot;first_id_value&quot;\r\n    },\r\n    {\r\n     &quot;name&quot;: &quot;second_id&quot;,\r\n     &quot;value&quot;: &quot;second_id_value&quot;\r\n    },\r\n    {\r\n     &quot;name&quot;: &quot;third_id&quot;,\r\n     &quot;value&quot;: &quot;third_id_value&quot;\r\n    }\r\n   ]\r\n  }\r\n ]\r\n}\r\n```\r\n\r\n**Expected OUTPUT**:\r\n```\r\n{\r\n &quot;firstKey&quot;: &quot;ABCD&quot;,\r\n &quot;id&quot;: &quot;12345&quot;,\r\n &quot;data.name.first_id&quot;: &quot;first_id_value&quot;,\r\n &quot;data.name.second_id&quot;: &quot;second_id_value&quot;,\r\n &quot;data.name.third_id&quot;: &quot;third_id_value&quot;\r\n}\r\n```\r\n\r\nAfter many trials and errors, I was near to expected output using following filter expression\r\n```\r\n[.main[]|{&quot;firstKey&quot;, &quot;id&quot;},foreach .data[] as $item (0; &quot;data.name.\\($item.name)&quot; as $a|$item.value as $b| {($a): $b})][]\r\n```\r\nUsed foreach as **objects under &quot;data&quot; are dynamic**. the number of objects can differ.\r\nThe output for the above expression is:\r\n```\r\n{\r\n  &quot;firstKey&quot;: &quot;ABCD&quot;,\r\n  &quot;id&quot;: &quot;12345&quot;\r\n}\r\n{\r\n  &quot;data.name.first_id&quot;: &quot;first_id_value&quot;\r\n}\r\n{\r\n  &quot;data.name.second_id&quot;: &quot;second_id_value&quot;\r\n}\r\n{\r\n  &quot;data.name.third_id&quot;: &quot;third_id_value&quot;\r\n}\r\n```\r\n\r\nBut I want the **objects of data to be under the same braces** as &#39;firstKey&#39; and &#39;id&#39;.\r\n\r\n[LINK to JqPlay][1]\r\n\r\nAny suggestions will be helpful.\r\n\r\n\r\n  [1]: https://jqplay.org/#",
        "link": "https://stackoverflow.com/questions/70034893/combining-all-key-value-pairs-in-one-using-jq-filter-or-jq-play",
        "title": "Combining all key value pairs in one using jq filter or jq play"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1637327054,
                "post_id": 70035232,
                "comment_id": 123803112,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 113180,
                    "reputation": 5570,
                    "user_id": 298209,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/08fa936794810c7e9fbf3cc2e1916ff3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Milad",
                    "link": "https://stackoverflow.com/users/298209/milad"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639137969,
                "post_id": 70035232,
                "comment_id": 124277822,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639143029,
                "post_id": 70035232,
                "comment_id": 124279552,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637328421,
                "creation_date": 1637328421,
                "answer_id": 70035596,
                "question_id": 70035232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n[ recurse(.nodes[]?) | select(has(&quot;nodes&quot;)|not) ]\r\n```\r\n\r\nThis walks the tree and retains all nodes that do not have a `nodes` key themselves.",
                "title": "flatten and filter a tree json object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647309891,
                "creation_date": 1647309891,
                "answer_id": 71476216,
                "question_id": 70035232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "demo\r\nhttps://jqplay.org/s/Xrgqos4W-M\r\n\r\n```\r\nfilter:\r\n[recurse(.nodes[]?) | select(has(&quot;nodes&quot;) | not) | {name:.name}]\r\n\r\ninput:\r\n{\r\n    &quot;name&quot;: &quot;root&quot;,\r\n    &quot;nodes&quot;: [\r\n        {&quot;name&quot;: &quot;foo1&quot;},\r\n        {&quot;name&quot;: &quot;foo2&quot;, \r\n        &quot;nodes&quot;: [\r\n            {&quot;name&quot;: &quot;bar&quot;}\r\n        ]}\r\n    ]\r\n}\r\n\r\nouput:\r\n[{&quot;name&quot;:&quot;foo1&quot;},{&quot;name&quot;:&quot;bar&quot;}]\r\n```",
                "title": "flatten and filter a tree json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1647309891,
        "creation_date": 1637326773,
        "question_id": 70035232,
        "body_markdown": "How can I filter and flatten a tree-like json object using `jq` so that it&#39;s only applied to leaves of the tree? In the example below I&#39;d like jq to return something like `[{&quot;name&quot;: &quot;foo1&quot;}, {&quot;name&quot;: &quot;bar&quot;}]`\r\n\r\n```\r\nobj = {\r\n    &quot;name&quot;: &quot;root&quot;,\r\n    &quot;nodes&quot;: [\r\n        {&quot;name&quot;: &quot;foo1&quot;},\r\n        {&quot;name&quot;: &quot;foo2&quot;, nodes = [\r\n            {&quot;name&quot;: &quot;bar&quot;}\r\n        ]}\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70035232/flatten-and-filter-a-tree-json-object-using-jq",
        "title": "flatten and filter a tree json object using jq"
    },
    {
        "tags": [
            "json",
            "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": 1637328702,
                "post_id": 70035615,
                "comment_id": 123803719,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3006560,
                    "reputation": 1073,
                    "user_id": 2550985,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/acKrd.jpg?s=256",
                    "display_name": "rmsys",
                    "link": "https://stackoverflow.com/users/2550985/rmsys"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637328999,
                "post_id": 70035615,
                "comment_id": 123803855,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1637329063,
                "post_id": 70035615,
                "comment_id": 123803893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3006560,
                    "reputation": 1073,
                    "user_id": 2550985,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/acKrd.jpg?s=256",
                    "display_name": "rmsys",
                    "link": "https://stackoverflow.com/users/2550985/rmsys"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637329867,
                "post_id": 70035615,
                "comment_id": 123804218,
                "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": 1637679213,
                "post_id": 70035615,
                "comment_id": 123887333,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3006560,
                    "reputation": 1073,
                    "user_id": 2550985,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/acKrd.jpg?s=256",
                    "display_name": "rmsys",
                    "link": "https://stackoverflow.com/users/2550985/rmsys"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637697251,
                "post_id": 70035615,
                "comment_id": 123894735,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1637328959,
                "creation_date": 1637328959,
                "answer_id": 70035693,
                "question_id": 70035615,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you&#39;re JSON isn&#39;t valid, I&#39;ve converted it into:\r\n```json\r\n{\r\n\t&quot;Job&quot;: {\r\n\t\t&quot;Name&quot;: &quot;sample_job&quot;,\r\n\t\t&quot;Role&quot;: &quot;sample_role_job&quot;\r\n\t},\r\n\t&quot;DefaultArguments&quot;: {\r\n\t\t&quot;--enable-continuous-cloudwatch-log&quot;: &quot;test_1&quot;,\r\n\t\t&quot;--enable-metrics&quot;: &quot;&quot;\r\n\t},\r\n\t&quot;Timeout&quot;: 2880,\r\n\t&quot;NumberOfWorkers&quot;: 10\r\n}\r\n```\r\n\r\nUsing the following filter:\r\n```none\r\n&quot;Name \\(.Job.Name)\\n--enable-continuous-cloudwatch-log \\(.DefaultArguments.&quot;--enable-continuous-cloudwatch-log&quot;)\\n--enable-metrics \\(.DefaultArguments.&quot;--enable-metrics&quot;)&quot;\r\n```\r\n\r\nWe use string interpolation to show the desired output:\r\n```none\r\nName sample_job\r\n--enable-continuous-cloudwatch-log test_1\r\n--enable-metrics \r\n```\r\n\r\n```\r\njq --raw-output &#39;&quot;Name \\(.Job.Name)\\n--enable-continuous-cloudwatch-log \\(.DefaultArguments.&quot;--enable-continuous-cloudwatch-log&quot;)\\n--enable-metrics \\(.DefaultArguments.&quot;--enable-metrics&quot;)&quot;&#39;\r\n```\r\n\r\n#### [Online Demo](https://jqplay.org/s/VuhGbtLK30)",
                "title": "Using jq to fetch and show key value with quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637697470,
        "creation_date": 1637328502,
        "last_edit_date": 1637697470,
        "question_id": 70035615,
        "body_markdown": "I have a file that looks as below:\r\n\r\n\r\n```\r\n{\r\n    &quot;Job&quot;: {\r\n        &quot;Name&quot;: &quot;sample_job&quot;,\r\n        &quot;Description&quot;: &quot;&quot;,\r\n        &quot;Role&quot;: &quot;arn:aws:iam::00000000000:role/sample_role&quot;,\r\n        &quot;CreatedOn&quot;: &quot;2021-10-21T23:35:23.660000-03:00&quot;,\r\n        &quot;LastModifiedOn&quot;: &quot;2021-10-21T23:45:41.771000-03:00&quot;,\r\n        &quot;ExecutionProperty&quot;: {\r\n            &quot;MaxConcurrentRuns&quot;: 1\r\n        },\r\n        &quot;Command&quot;: {\r\n            &quot;Name&quot;: &quot;glueetl&quot;,\r\n            &quot;ScriptLocation&quot;: &quot;s3://aws-sample-s3/scripts/sample.py&quot;,\r\n            &quot;PythonVersion&quot;: &quot;3&quot;\r\n        },\r\n        &quot;DefaultArguments&quot;: {\r\n            &quot;--TempDir&quot;: &quot;s3://aws-sample-s3/temporary/&quot;,\r\n            &quot;--class&quot;: &quot;GlueApp&quot;,\r\n            &quot;--enable-continuous-cloudwatch-log&quot;: &quot;true&quot;,\r\n            &quot;--enable-glue-datacatalog&quot;: &quot;true&quot;,\r\n            &quot;--enable-metrics&quot;: &quot;true&quot;,\r\n            &quot;--enable-spark-ui&quot;: &quot;true&quot;,\r\n            &quot;--job-bookmark-option&quot;: &quot;job-bookmark-enable&quot;,\r\n            &quot;--job-insights-byo-rules&quot;: &quot;&quot;,\r\n            &quot;--job-language&quot;: &quot;python&quot;,\r\n            &quot;--spark-event-logs-path&quot;: &quot;s3://aws-sample-s3/logs&quot;\r\n        },\r\n        &quot;MaxRetries&quot;: 0,\r\n        &quot;AllocatedCapacity&quot;: 100,\r\n        &quot;Timeout&quot;: 2880,\r\n        &quot;MaxCapacity&quot;: 100.0,\r\n        &quot;WorkerType&quot;: &quot;G.1X&quot;,\r\n        &quot;NumberOfWorkers&quot;: 100,\r\n        &quot;GlueVersion&quot;: &quot;2.0&quot;\r\n    }\r\n}\r\n```\r\n\r\nI want to get key/value from `&quot;Name&quot;`, `&quot;--enable-continuous-cloudwatch-log&quot;: &quot;&quot;` and `&quot;--enable-metrics&quot;: &quot;&quot;`. So, I need to show the info like this:\r\n\r\n```\r\n&quot;Name&quot; &quot;sample_job&quot;\r\n&quot;--enable-continuous-cloudwatch-log&quot; &quot;&quot;\r\n&quot;--enable-metrics&quot; &quot;&quot;\r\n```\r\n\r\n`UPDATE`\r\n\r\nFollow the tips from @Inian and @0stone0 I came close to it:\r\n\r\n`jq -r &#39;(.Job ) + (.Job.DefaultArguments | { &quot;--enable-continuous-cloudwatch-log&quot;, &quot;--enable-metrics&quot;}) | to_entries[] | &quot;\\&quot;\\(.key)\\&quot; \\&quot;\\(.value)\\&quot;&quot;&#39;`\r\n\r\nThis extract the values I need but show all another key/values.",
        "link": "https://stackoverflow.com/questions/70035615/using-jq-to-fetch-and-show-key-value-with-quotes",
        "title": "Using jq to fetch and show key value with quotes"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637358212,
                "last_edit_date": 1637358212,
                "creation_date": 1637345095,
                "answer_id": 70039105,
                "question_id": 70039008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this\r\n\r\n```sh\r\njq -r &#39;[\r\n  .id,\r\n  (.meta | .versionId, .lastUpdated),\r\n  (.address | join(&quot;|&quot;)),\r\n  (.identifier[] | .system, .value)\r\n] | @csv&#39;\r\n```\r\n[Demo](https://jqplay.org/s/JIvlj8TdSG)\r\n\r\n---\r\nTo prepend a header row with the number of `identifierX_system` and `identifierX_value` field pairs in it matching the length of the input&#39;s longest `identifier` array, try this\r\n\r\n```sh\r\njq -rs &#39;[\r\n  \r\n  &quot;id&quot;,\r\n  &quot;meta_versionId&quot;, &quot;meta_lastUpdated&quot;,\r\n  &quot;address&quot;,\r\n  (\r\n    range([.[].identifier | length] | max)\r\n    | &quot;identifier\\(.)_system&quot;, &quot;identifier\\(.)_value&quot;\r\n  )\r\n\r\n], (.[] | [\r\n\r\n  .id,\r\n  (.meta | .versionId, .lastUpdated),\r\n  (.address | join(&quot;|&quot;)),\r\n  (.identifier[] | .system, .value)\r\n\r\n]) | @csv&#39;\r\n```\r\n[Demo](https://jqplay.org/s/quifX4aOfQ)",
                "title": "jq: map arrays to csv field headers"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637358212,
        "creation_date": 1637344601,
        "question_id": 70039008,
        "body_markdown": "Is there a way to export a json like this:\r\n\r\n```lang-json\r\n{\r\n   &quot;id&quot;:&quot;2261026&quot;,\r\n   &quot;meta&quot;:{\r\n      &quot;versionId&quot;:&quot;1&quot;,\r\n      &quot;lastUpdated&quot;:&quot;2021-11-08T15:13:39.318+01:00&quot;,\r\n   },\r\n   &quot;address&quot;: [\r\n      &quot;string-value1&quot;,\r\n      &quot;string-value2&quot;\r\n   ],\r\n   &quot;identifier&quot;:[\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.93&quot;,\r\n         &quot;value&quot;:&quot;6209&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.2&quot;,\r\n         &quot;value&quot;:&quot;00042&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.90&quot;,\r\n         &quot;value&quot;:&quot;UAB2&quot;\r\n      }\r\n   ]\r\n}\r\n{\r\n   &quot;id&quot;:&quot;2261027&quot;,\r\n   &quot;meta&quot;:{\r\n      &quot;versionId&quot;:&quot;1&quot;,\r\n      &quot;lastUpdated&quot;:&quot;2021-11-08T15:13:39.318+01:00&quot;,\r\n   },\r\n   &quot;address&quot;: [\r\n      &quot;string-value1&quot;,\r\n      &quot;string-value2&quot;,\r\n      &quot;string-value3&quot;,\r\n      &quot;string-value4&quot;\r\n   ],\r\n   &quot;identifier&quot;:[\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.93&quot;,\r\n         &quot;value&quot;:&quot;6205&quot;\r\n      },\r\n      {\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.20.2&quot;,\r\n         &quot;value&quot;:&quot;05041&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI&#39;d like to get something like this:\r\n\r\n```lang-csv\r\n&quot;id&quot;,&quot;meta_versionId&quot;,&quot;meta_lastUpdated&quot;,&quot;address&quot;,&quot;identifier0_system&quot;,&quot;identifier0_value&quot;,&quot;identifier1_system&quot;,&quot;identifier1_value&quot;,&quot;identifier2_system&quot;,&quot;identifier2_value&quot;\r\n&quot;2261026&quot;,&quot;1&quot;,&quot;2021-11-08T15:13:39.318+01:00&quot;,&quot;string-value1|string-value2&quot;,&quot;urn:oid:2.16.724.4.9.20.93&quot;,&quot;6209&quot;,&quot;urn:oid:2.16.724.4.9.20.2&quot;,&quot;00042&quot;,&quot;urn:oid:2.16.724.4.9.20.90&quot;,&quot;UAB2&quot;\r\n&quot;2261027&quot;,&quot;1&quot;,&quot;2021-11-08T15:13:39.318+01:00&quot;,&quot;string-value1|string-value2|string-value3|string-value4&quot;,&quot;urn:oid:2.16.724.4.9.20.93&quot;,&quot;6205&quot;,&quot;urn:oid:2.16.724.4.9.20.2&quot;,&quot;05041&quot;,,\r\n```\r\n\r\nIn short:\r\n\r\n`address` array field string values has to be mapped joining its values using &quot;|&quot; character. Example: `&quot;string-value1|string-value2&quot;`\r\n\r\n\r\n`identifiers` array field objects have to be mapped to `&quot;n-field-header&quot;`. Example: `&quot;identifier0_system&quot;,&quot;identifier0_value&quot;,&quot;identifier1_system&quot;,&quot;identifier1_value&quot;,&quot;identifier2_system&quot;,&quot;identifier2_value,...&quot;`\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70039008/jq-map-arrays-to-csv-field-headers",
        "title": "jq: map arrays to csv field headers"
    },
    {
        "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": 1637349617,
                "post_id": 70039341,
                "comment_id": 123811668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "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": 1637349791,
                "post_id": 70039341,
                "comment_id": 123811734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637359185,
                "post_id": 70039341,
                "comment_id": 123814402,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637347397,
                "last_edit_date": 1637347397,
                "creation_date": 1637346635,
                "answer_id": 70039383,
                "question_id": 70039341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try \r\n```sh\r\njq &#39;[&quot;&quot;, (paths | join(&quot;/&quot;))]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/1rhPnJJ3yx)",
                "title": "jq function to convert a stream of strings into a single array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637347397,
        "creation_date": 1637346423,
        "question_id": 70039341,
        "body_markdown": "I am trying to get an array of all possible paths in a JSON Document.\r\n\r\nGiven the document:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;bar&quot;,\r\n      &quot;b&quot;: [\r\n       {&quot;c&quot;: 3}, {&quot;d&quot;: 6},\r\n       {&quot;c&quot;: 7}, {&quot;d&quot;: 5}\r\n      ]\r\n    }\r\n\r\nI&#39;d like the output to be:\r\n  [&quot;&quot;,&quot;a&quot;,&quot;b&quot;,&quot;b/0&quot;,&quot;b/0/c&quot;,&quot;b/1&quot;,&quot;b/1/d&quot;,&quot;b/2&quot;,&quot;b/2/c&quot;,&quot;b/3&quot;,&quot;b/3/d&quot;]\r\n\r\nI got pretty close, here is a [snippet](https://jqplay.org/s/b7q_1tfuFv) on the JQ Playground.",
        "link": "https://stackoverflow.com/questions/70039341/jq-function-to-convert-a-stream-of-strings-into-a-single-array",
        "title": "jq function to convert a stream of strings into a single array"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637352108,
                "last_edit_date": 1637352108,
                "creation_date": 1637346810,
                "answer_id": 70039411,
                "question_id": 70039380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try one of these:\r\n```sh\r\njq --slurp &#39;{first_key:.[0], second_key:.[1]}&#39; file1 file2\r\n```\r\n```sh\r\njq --null-input &#39;{first_key:input, second_key:input}&#39; file1 file2\r\n```\r\n```sh\r\njq --null-input &#39;[inputs] | {first_key:.[0], second_key:.[1]}&#39; file1 file2\r\n```\r\n```sh\r\njq --null-input --argfile f1 file1 --argfile f2 file2 &#39;{first_key:$f1, second_key:$f2}&#39;\r\n```\r\n```sh\r\njq --null-input --argjson f1 &quot;$(&lt;file1)&quot; --argjson f2 &quot;$(&lt;file2)&quot; &#39;{first_key:$f1, second_key:$f2}&#39;\r\n```\r\n```sh\r\njq --null-input --slurpfile f1 file1 --slurpfile f2 file2 &#39;{first_key:$f1[0], second_key:$f2[0]}&#39;\r\n```\r\n```sh\r\njq --null-input --slurpfile f &lt;(cat file1 file2) &#39;{first_key:$f[0], second_key:$f[1]}&#39;\r\n```\r\n---\r\nNotes\r\n- `--slurp` can be abbreviated to `-s`\r\n- `--null-input` can be abbreviated to `-n`\r\n- `--argfile` is deprecated in favor of `--slurpfile`\r\n",
                "title": "How to merge two json file with jq with additional key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637352108,
        "creation_date": 1637346618,
        "question_id": 70039380,
        "body_markdown": "I&#39;ve got 2 json files and want to merge them into one unique file, but with additional key, for example &quot;first_key&quot; and &quot;second_key&quot;\r\n\r\nHere the content of files:\r\n\r\nFile 1\r\n\r\n    {\r\n      &quot;timestamp&quot;: 1382461861,\r\n      &quot;value&quot;: {\r\n          &quot;aaa&quot;: {\r\n              &quot;value1&quot;: &quot;v1&quot;,\r\n              &quot;value2&quot;: &quot;v2&quot;\r\n          },\r\n          &quot;bbb&quot;: {\r\n              &quot;value1&quot;: &quot;v1&quot;,\r\n              &quot;value2&quot;: &quot;v2&quot;\r\n          },\r\n          &quot;ccc&quot;: {\r\n              &quot;value1&quot;: &quot;v1&quot;,\r\n              &quot;value2&quot;: &quot;v2&quot;\r\n          }\r\n       }\r\n    }\r\n\r\nFile 2\r\n\r\n    {\r\n      &quot;timestamp&quot;: 138246330,\r\n      &quot;value&quot;: {\r\n          &quot;ddd&quot;: {\r\n              &quot;value1&quot;: &quot;v1&quot;,\r\n              &quot;value2&quot;: &quot;v2&quot;\r\n          },\r\n          &quot;eee&quot;: {\r\n              &quot;value1&quot;: &quot;v1&quot;,\r\n              &quot;value2&quot;: &quot;v2&quot;\r\n          },\r\n          &quot;fff&quot;: {\r\n              &quot;value1&quot;: &quot;v1&quot;,\r\n              &quot;value2&quot;: &quot;v2&quot;\r\n          }\r\n       }\r\n    }\r\n\r\nexpected result :\r\n\r\n    { \r\n      &quot;first_key&quot; : {\r\n        &quot;timestamp&quot;: 1382461861,\r\n        &quot;value&quot;: {\r\n            &quot;aaa&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;bbb&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;ccc&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            }\r\n         }\r\n      },\r\n      &quot;second_key&quot;: {\r\n        &quot;timestamp&quot;: 138246330,\r\n        &quot;value&quot;: {\r\n            &quot;ddd&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;eee&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;fff&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            }\r\n         }\r\n      }\r\n    }\r\n\r\nI try a lot of combinations but none of the result has the additional key as i expected. I&#39;m also new at using jq so i really appreciate it if you could tell me command i should use. thankyou.",
        "link": "https://stackoverflow.com/questions/70039380/how-to-merge-two-json-file-with-jq-with-additional-key",
        "title": "How to merge two json file with jq with additional key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1637376310,
                "post_id": 70042813,
                "comment_id": 123817190,
                "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": 1637621466,
                "post_id": 70042813,
                "comment_id": 123871101,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638186693,
                "last_edit_date": 1638186693,
                "creation_date": 1637377864,
                "answer_id": 70042946,
                "question_id": 70042813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since superfluous leading 0s are not allowed in JSON, a &quot;strict mode&quot; might be nice for jq, but without even invoking [Postel&#39;s Law][1], it is evidently perfectly reasonable for a tool such as jq to accept them (JSON, after all, is supposed to be human-friendly), so long as the output that is supposed to be JSON is valid.\r\n\r\nAnd besides, there are plenty of dour linters.\r\n\r\nBy the way, FWIW, NaN and Infinite are also accepted as input (and interpreted accordingly), so it&#39;s evident that jq&#39;s creators/maintainers intend there to be a &quot;non-strict&quot; mode when reading JSON texts. \r\n\r\nFor some background, see https://stackoverflow.com/questions/27361565/why-is-json-invalid-if-an-integer-begins-with-a-leading-zero\r\n\r\n---\r\n&lt;sub&gt; One argument I&#39;ve seen against allowing superfluous 0s is that since `00` is not valid JSON, a tool that purports to read streams of JSON should recognize `00` as two 0s.  This is indeed the way that gojq&#39;s JSON parser handles leading 0s.&lt;/sub&gt;\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Robustness_principle",
                "title": "Why does JQ accept leading zeros?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1638186693,
        "creation_date": 1637375492,
        "question_id": 70042813,
        "body_markdown": "`{&quot;a&quot; : 01}` or `{&quot;a&quot; : -000.1}` is an invalid, but JQ is fine with it and interprets it as `{&quot;a&quot; : 1}` and `{&quot;a&quot; : -0.1}`.\r\n\r\nIs it by design or a bug?",
        "link": "https://stackoverflow.com/questions/70042813/why-does-jq-accept-leading-zeros",
        "title": "Why does JQ accept leading zeros?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1637522016,
                "creation_date": 1637522016,
                "answer_id": 70057796,
                "question_id": 70057777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can check the input&#39;s `type` directly:\r\n```sh\r\njq &#39;if type == &quot;object&quot; then [.] else . end&#39;\r\n```\r\n[Demo](https://jqplay.org/s/FLmNOB3DNS)\r\n\r\n---\r\nOr use the deconstruction alternative operator `?//` (available since [jq 1.6](https://stedolan.github.io/jq/manual/v1.6)):\r\n```sh\r\njq &#39;. as [$v] ?// $v | [$v]&#39; \r\n```\r\n[Demo](https://jqplay.org/s/ox13HMlbOe)",
                "title": "Converting object to array or keeping an array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637528889,
                "creation_date": 1637528889,
                "answer_id": 70058619,
                "question_id": 70057777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Auxiliary to pmf&#39;s answer, why doesn&#39;t this work?\r\n\r\n`input.jsonl`:\r\n```\r\n[{&quot;version&quot;: &quot;1.0&quot;}]\r\n{&quot;version&quot;: &quot;2.0&quot;}\r\n```\r\nCommand:\r\n```\r\njq -c &#39;if (select(has(&quot;version&quot;)?)) then [.] else . end&#39;\r\n```\r\nActual output:\r\n```\r\n[{&quot;version&quot;: &quot;2.0&quot;}]\r\n```\r\nDesired output:\r\n```\r\n[{&quot;version&quot;: &quot;1.0&quot;}]\r\n[{&quot;version&quot;: &quot;2.0&quot;}]\r\n```\r\n\r\nFirst of all, `select` filters out values. For each value input to `select`, it evaluates the filter you give it on its input, and if that filter evaluates to a true value, the whole input value it emitted unchanged. Otherwise there is no output. Using `select` here is unhelpful, because you want a true or false value for the `if` condition. If the condition part of your `if-then-else` expression emits no output then the whole `if-then-else` expression emits no output.\r\n\r\nA more thorough way to understand `select(expr)` is that every time `expr` emits a true value then the `select(expr)` emits its input value. A more thorough way to understand `if cond then a else b end` is that every time `cond` emits a true value the whole `if-then-else` emits `a` and every time `cond` emits a false value the whole `if-then-else` emits `b`.\r\n\r\nOkay, so forget the `select`... why doesn&#39;t this work?\r\n\r\nCommand:\r\n```\r\njq -c &#39;if (has(&quot;version&quot;)?) then [.] else . end&#39;\r\n```\r\nActual output:\r\n```\r\n[{&quot;version&quot;: &quot;2.0&quot;}]\r\n```\r\n\r\nIn this case, the `?` is the [error suppression operator][1] and is equivalent to `try has(&quot;version&quot;)` which is itself equivalent to `try has(&quot;version&quot;) catch empty`. This means that when an error occurs the expression returns `empty` which means no output. An error does indeed occur when the input is a list instead of an object. When the condition part of the `if-then-else` expression emits no output, you guessed it, the whole expression emits no output.\r\n\r\nYou could make this work by doing this instead:\r\n\r\nCommand:\r\n```\r\njq -c &#39;if (try has(&quot;version&quot;) catch false) then [.] else . end&#39;\r\n```\r\nActual output:\r\n```\r\n[{&quot;version&quot;:&quot;1.0&quot;}]\r\n[{&quot;version&quot;:&quot;2.0&quot;}]\r\n```\r\n\r\nOf course that&#39;s a bit roundabout. You should follow pmf&#39;s answer. But this perhaps helps you understand why your attempt didn&#39;t go as you expected.\r\n\r\nAs a rule of thumb, try to make sure your `select` and `if` conditions always emit exactly one output for each input - that way you will not be surprised. Expressions that can emit zero outputs (e.g. `expr?` or `select(...)`) or multiple outputs (e.g. `.[]`) will make for a confusing time when used as conditions in `select` or `if`.\r\n\r\n[1]: https://stedolan.github.io/jq/manual/#ErrorSuppression%2FOptionalOperator%3A%3F",
                "title": "Converting object to array or keeping an array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637573894,
                "last_edit_date": 1637573894,
                "creation_date": 1637529334,
                "answer_id": 70058662,
                "question_id": 70057777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `arrays` function selects an input if it is an array. Combined with `//` you can handle the case where it isn&#39;t:\r\n\r\n```sh\r\n$ jq -c &#39;arrays // [.]&#39; versions.json \r\n[{&quot;version&quot;:&quot;1.0&quot;}]\r\n[{&quot;version&quot;:&quot;2.0&quot;}]\r\n```\r\n\r\n---\r\n\r\nWhere `versions.json` is:\r\n\r\n```json\r\n[{&quot;version&quot;:&quot;1.0&quot;}]\r\n{&quot;version&quot;:&quot;2.0&quot;}\r\n```",
                "title": "Converting object to array or keeping an array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1637573894,
        "creation_date": 1637521870,
        "question_id": 70057777,
        "body_markdown": "I have an input file which type may vary from array to object, one of the following inputs expected:\r\n\r\n\r\n    [{&quot;version&quot;: &quot;1.0&quot;}]\r\n    {version: &quot;1.0&quot;}\r\n\r\n How can I construct jq expression for the output to be always converted into array. I came up with the following:\r\n\r\n    jq &#39;if (select(has(&quot;version&quot;)?)) then [.] else . end&#39;\r\n\r\nonce `version` key is matched, object is added inside array, but if not matched, that would mean it&#39;s already an array, nothing is printed, and I would it expect it to be printed as it is. Please suggest the right way to achieve it. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/70057777/converting-object-to-array-or-keeping-an-array-with-jq",
        "title": "Converting object to array or keeping an array with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637569064,
                "creation_date": 1637569064,
                "answer_id": 70062732,
                "question_id": 70062602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter you have is already a pretty efficient way to deal with formation of objects, when all the individual fields (version, group and kind) are present and not required to re-write the whole thing to deal with one specific case. \r\n\r\nTo skip the null fields, just pipe your previous filter to below\r\n\r\n```none\r\nwith_entries(select(.value!=null))\r\n```\r\n\r\ni.e. the whole filter being below. See [jqplay][1] demo\r\n\r\n```none\r\n(.spec.rules[0].match.resources.kinds[] / &quot;/&quot;)\r\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n  as [$version,$group,$kind]\r\n| {$version,$group,$kind} \r\n| with_entries(select(.value!=null))\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/6tkmAK1ZzY",
                "title": "Skip printing a field when it is empty in the resulting JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637570481,
                "creation_date": 1637570481,
                "answer_id": 70062993,
                "question_id": 70062602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` filter:\r\n\r\n```bash\r\njq &#39;(.spec.rules[0].match.resources.kinds[] / &quot;/&quot;)\r\n        | [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n            as [$version,$group,$kind]\r\n    | {$version,$group,$kind}\r\n    | select(.version != &quot;&quot;)\r\n    | select(.group != &quot;&quot;)\r\n    &#39; \\\r\n    spec.json\r\n```\r\n\r\nOr if you want to only reduce output:\r\n\r\n```bash\r\njq &#39;(.spec.rules[0].match.resources.kinds[] / &quot;/&quot;)\r\n        | [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n            as [$version,$group,$kind]\r\n    | {$version,$group,$kind}\r\n    | if .version != &quot;&quot; then\r\n        if .group != &quot;&quot; then\r\n            {$version,$group,$kind}\r\n        else\r\n            {$version,$kind}\r\n        end\r\n      else\r\n        if .group != &quot;&quot; then\r\n            {$group,$kind}\r\n        else\r\n            {$kind}\r\n        end\r\n      end\r\n    &#39; \\\r\n    spec.json\r\n``` ",
                "title": "Skip printing a field when it is empty in the resulting JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637571827,
                "creation_date": 1637571827,
                "answer_id": 70063221,
                "question_id": 70062602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `{$version,$group,$kind}` part from [my other answer](https://stackoverflow.com/a/70021929/2158479) was included to show how to make use of the variables you requested to be created. Thus, if you don&#39;t want it to be written, don&#39;t generate it in the first place only to modify it later with `with_entries(select(.value))` or the like. Instead, generate it differently, according to your needs.\r\n\r\nFor instance, instead of unconditionally using all three parts as in `{$version,$group,$kind}` you may pick just the ones that are not null using `[{$version},{$group},{$kind} | select(.[])] | add`: ([Demo](https://jqplay.org/s/zrfBh4WTFx))\r\n```\r\n(.spec.rules[0].match.resources.kinds / &quot;/&quot;)\r\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n  as [$version,$group,$kind]\r\n| [{$version},{$group},{$kind} | select(.[])] | add\r\n```\r\n\r\nBetter yet, modify the `[...] as {...}` part directly to generate what you need, for instance: ([Demo](https://jqplay.org/s/nlPQthipQX))\r\n```\r\n(.spec.rules[0].match.resources.kinds[] / &quot;/&quot;)\r\n| ({version:select(.[1])[0]} // {})\r\n  + ({group:select(.[2])[1]} // {})\r\n  + {kind: last}\r\n```\r\n",
                "title": "Skip printing a field when it is empty in the resulting JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1637571827,
        "creation_date": 1637568221,
        "last_edit_date": 1637569316,
        "question_id": 70062602,
        "body_markdown": "I have json:\r\n```json\r\n    &quot;spec&quot;: {\r\n        &quot;background&quot;: true,\r\n        &quot;failurePolicy&quot;: &quot;Fail&quot;,\r\n        &quot;rules&quot;: [\r\n            {\r\n                &quot;exclude&quot;: {\r\n                    &quot;resources&quot;: {}\r\n                },\r\n                &quot;generate&quot;: {\r\n                    &quot;clone&quot;: {}\r\n                },\r\n                &quot;match&quot;: {\r\n                    &quot;resources&quot;: {\r\n                        &quot;kinds&quot;: [\r\n                            &quot;networking.k8s.io/v1/NetworkPolicy&quot;\r\n                        ]\r\n                    }\r\n                },\r\n                &quot;mutate&quot;: {},\r\n                &quot;name&quot;: &quot;validate-nodeport&quot;,\r\n                &quot;validate&quot;: {\r\n                    &quot;message&quot;: &quot;Services of type NodePort are not allowed.&quot;,\r\n                    &quot;pattern&quot;: {\r\n                        &quot;spec&quot;: {\r\n                            &quot;type&quot;: &quot;!NodePort&quot;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        ],\r\n        &quot;validationFailureAction&quot;: &quot;audit&quot;\r\n    },\r\n    &quot;status&quot;: {\r\n        &quot;ready&quot;: true\r\n    }\r\n}\r\n```\r\nI have jq command:\r\n```\r\n(.spec.rules[0].match.resources.kinds[] / &quot;/&quot;)\r\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\r\n  as [$version,$group,$kind]\r\n| {$version,$group,$kind}\r\n```\r\n\r\nBut sometimes field &quot;version&quot; or &quot;group&quot; maybe empty. I need to write with the following condition - if the string is null, then it is not necessary to write it.",
        "link": "https://stackoverflow.com/questions/70062602/skip-printing-a-field-when-it-is-empty-in-the-resulting-json",
        "title": "Skip printing a field when it is empty in the resulting JSON"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637589825,
                "creation_date": 1637589825,
                "answer_id": 70067028,
                "question_id": 70063816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We could operate one level higher in the nesting hierarchy, and test for `&quot;group&quot;` being a key, then update accordingly `.group = .group[0]` instead of `. = .[0]`\r\n```\r\njq &#39;walk(if type==&quot;object&quot;\r\n          and has(&quot;group&quot;) \r\n          and (.group | type)==&quot;array&quot; \r\n          and (.group | length)==1 \r\n          then .group = .group[0] \r\n          else . end)&#39;\r\n```",
                "title": "jq ~ collapse specific single object arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669471281,
        "creation_date": 1637574682,
        "last_edit_date": 1669471281,
        "question_id": 70063816,
        "body_markdown": "corresponding to https://stackoverflow.com/questions/51157550/jq-is-there-a-better-way-to-collapse-single-object-arrays and https://stackoverflow.com/questions/70016854/r-nested-data-table-to-json\r\nhow do I collapse only specific elements?\r\n\r\nI want to get rid of the &quot;group&quot; arrays in\r\n```\r\n[\r\n  {\r\n    &quot;id2&quot;: &quot;A&quot;,\r\n    &quot;group&quot;: [\r\n      {\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;id1&quot;: 1,\r\n            &quot;group&quot;: [\r\n              {\r\n                &quot;data&quot;: [\r\n                  {\r\n                    &quot;a&quot;: 1,\r\n                    &quot;b&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;a&quot;: 2,\r\n                    &quot;b&quot;: 2\r\n                  }\r\n                ],\r\n                &quot;type&quot;: &quot;test&quot;\r\n              }\r\n            ],\r\n            &quot;type&quot;: &quot;B&quot;\r\n          }\r\n        ],\r\n        &quot;type&quot;: &quot;C&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id2&quot;: &quot;C&quot;,\r\n    &quot;group&quot;: [\r\n      {\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;id1&quot;: 3,\r\n            &quot;group&quot;: [\r\n              {\r\n                &quot;data&quot;: [\r\n                  {\r\n                    &quot;a&quot;: 1,\r\n                    &quot;b&quot;: 1\r\n                  }\r\n                ],\r\n                &quot;type&quot;: &quot;test&quot;\r\n              }\r\n            ],\r\n            &quot;type&quot;: &quot;B&quot;\r\n          }\r\n        ],\r\n        &quot;type&quot;: &quot;C&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\ndesired output\r\n```\r\n[{\r\n\t\t&quot;id2&quot;: &quot;A&quot;,\r\n\t\t&quot;group&quot;: {\r\n\t\t\t&quot;data&quot;: [{\r\n\t\t\t\t&quot;id1&quot;: 1,\r\n\t\t\t\t&quot;group&quot;: {\r\n\t\t\t\t\t&quot;data&quot;: [{\r\n\t\t\t\t\t\t\t&quot;a&quot;: 1,\r\n\t\t\t\t\t\t\t&quot;b&quot;: 1\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;a&quot;: 2,\r\n\t\t\t\t\t\t\t&quot;b&quot;: 2\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t],\r\n\t\t\t\t\t&quot;type&quot;: &quot;test&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;type&quot;: &quot;B&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;type&quot;: &quot;C&quot;\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t&quot;id2&quot;: &quot;C&quot;,\r\n\t\t&quot;group&quot;: {\r\n\t\t\t&quot;data&quot;: [{\r\n\t\t\t\t&quot;id1&quot;: 3,\r\n\t\t\t\t&quot;group&quot;: {\r\n\t\t\t\t\t&quot;data&quot;: [{\r\n\t\t\t\t\t\t&quot;a&quot;: 1,\r\n\t\t\t\t\t\t&quot;b&quot;: 1\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;type&quot;: &quot;test&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;type&quot;: &quot;B&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;type&quot;: &quot;C&quot;\r\n\t\t}\r\n\t}\r\n]\r\n```\r\n\r\nThe line  ```&#39;walk(if type==&quot;array&quot; and length==1  then .[0] else . end)&#39;``` additionally removes the array from the single &quot;data&quot; object. \r\n\r\n\r\n---\r\n\r\nUnfortunately, we are not able to install the jq 1.6 version on our RStudio Server und thereby I&#39;m not able to use the walk function. (Although is working perfectly fine on my local system)\r\n\r\nCan anybody help me out with an alternative solution without walk? Would be highly appreciated.\r\n\r\n*edit*\r\nOk I got it. I can manually add the walk function such as:\r\n\r\n    &#39;def walk(f):\r\n                                       . as $in\r\n                                     | if type == &quot;object&quot; then\r\n                                     reduce keys_unsorted[] as $key\r\n                                     ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n                                     elif type == &quot;array&quot; then map( walk(f) ) | f\r\n                                     else f\r\n                                     end; walk(if type==&quot;object&quot;\r\n                                               and has(&quot;group&quot;)\r\n                                               and (.group | type)==&quot;array&quot;\r\n                                               and (.group | length)==1\r\n                                               then .group = .group[0]\r\n                                               else . end)&#39;",
        "link": "https://stackoverflow.com/questions/70063816/jq-collapse-specific-single-object-arrays",
        "title": "jq ~ collapse specific single object arrays?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637596104,
                "post_id": 70068440,
                "comment_id": 123862180,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3108086,
                    "reputation": 43,
                    "user_id": 2630477,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a730ef1a97c8c9de99b4045a8c403fe5?s=256&d=identicon&r=PG",
                    "display_name": "user2630477",
                    "link": "https://stackoverflow.com/users/2630477/user2630477"
                },
                "reply_to_user": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637597709,
                "post_id": 70068440,
                "comment_id": 123862874,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1637598044,
                "creation_date": 1637598044,
                "answer_id": 70069045,
                "question_id": 70068440,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind, I added a `.` to divide top-level from sub-level headers to make things easier (namely `company.name` and `company.countryCode`):\r\n```sh\r\njq --raw-output &#39;[\r\n  &quot;eventDate&quot;,\r\n  &quot;ruleCode&quot;,\r\n  &quot;ruleName&quot;,\r\n  &quot;summary&quot;,\r\n  &quot;oldValue&quot;,\r\n  &quot;newValue&quot;,\r\n  &quot;company.name&quot;,\r\n  &quot;company.countryCode&quot;\r\n] as $h\r\n| $h, (.data[] | [getpath($h[] / &quot;.&quot;)])\r\n| @csv&#39; \r\n```\r\n```csv\r\n&quot;eventDate&quot;,&quot;ruleCode&quot;,&quot;ruleName&quot;,&quot;summary&quot;,&quot;oldValue&quot;,&quot;newValue&quot;,&quot;company.name&quot;,&quot;company.countryCode&quot;\r\n&quot;2021-11-22T00:00:00&quot;,704,&quot;New Accounts&quot;,&quot;Explanations...&quot;,,,&quot;My_company_name&quot;,&quot;US&quot;\r\n&quot;2021-10-22T00:00:00&quot;,701,&quot;Hello&quot;,&quot;otherExplanations...&quot;,,,&quot;My_company_name 2&quot;,&quot;UK&quot;\r\n```\r\n[Demo](https://jqplay.org/s/rD6j7q6G88)",
                "title": "JQ - Converting json to csv - &quot;Multi-levels&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637612328,
        "creation_date": 1637595644,
        "last_edit_date": 1637612328,
        "question_id": 70068440,
        "body_markdown": "I&#39;m trying to convert a json object into csv via jq. This is the json structure:\r\n\r\n    {\r\n      &quot;totalCount&quot;: 4440,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;company&quot;: {\r\n            &quot;name&quot;: &quot;My_company_name&quot;,\r\n            &quot;countryCode&quot;: &quot;US&quot;,\r\n            &quot;portfolioName&quot;: &quot;My_portfolio&quot;\r\n          },\r\n          &quot;eventDate&quot;: &quot;2021-11-22T00:00:00&quot;,\r\n          &quot;newValue&quot;: null,\r\n          &quot;oldValue&quot;: null,\r\n          &quot;ruleCode&quot;: 704,\r\n          &quot;ruleName&quot;: &quot;New Accounts&quot;,\r\n          &quot;summary&quot;: &quot;Explanations...&quot;\r\n        },\r\n        {\r\n          &quot;company&quot;: {\r\n            &quot;name&quot;: &quot;My_company_name 2&quot;,\r\n            &quot;countryCode&quot;: &quot;UK&quot;,\r\n            &quot;portfolioName&quot;: &quot;My_portfolio&quot;\r\n          },\r\n          &quot;eventDate&quot;: &quot;2021-10-22T00:00:00&quot;,\r\n          &quot;newValue&quot;: null,\r\n          &quot;oldValue&quot;: null,\r\n          &quot;ruleCode&quot;: 701,\r\n          &quot;ruleName&quot;: &quot;Hello&quot;,\r\n          &quot;summary&quot;: &quot;otherExplanations...&quot;    \r\n          }\r\n          ...\r\n        ]\r\n    }\r\n\r\nFor data in &quot;first level&quot;, I&#39;ve no problems:\r\n\r\n    jq -r &#39;.data | map({eventDate, ruleCode, ruleName, summary, oldValue, newValue}) | (first | keys_unsorted) as $keys | map([to_entries[] | .value]) as $rows | $keys,$rows[] | @csv&#39; input.json &gt; output.csv\r\n\r\nBut I&#39;ld like to add the company name and country code for example, and I don&#39;t kown to do this, with this king of data in second &quot;level&quot;.\r\n\r\nI&#39;ld to obtain something like that:\r\n\r\n    &quot;eventDate&quot;,&quot;ruleCode&quot;,&quot;ruleName&quot;,&quot;summary&quot;,&quot;oldValue&quot;,&quot;newValue&quot;,&quot;companyName&quot;, &quot;companyCountryCode&quot;\r\n    &quot;2021-11-22T00:00:00&quot;,704,&quot;New Accounts&quot;,&quot;Explanations...&quot;,,,&quot;My_company_name&quot;, &quot;US&quot;\r\n    &quot;2021-11-22T00:00:00&quot;,701,&quot;Hello&quot;,&quot;otherExplanations...&quot;,,,&quot;My_company_name 2&quot;, &quot;UK&quot;\r\n\r\nCould you help me ?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/70068440/jq-converting-json-to-csv-multi-levels",
        "title": "JQ - Converting json to csv - &quot;Multi-levels&quot;"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1637671370,
                "last_edit_date": 1637671370,
                "creation_date": 1637670436,
                "answer_id": 70080916,
                "question_id": 70074192,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is hard to test this since your input is missing almost all of its fields, but:\r\n```\r\n# header\r\n{providerName: &quot;CrozTest&quot;, language: &quot;en-us&quot;, lastUpdated: (.results[].timestamp | max)} +\r\n# the bit after the | is repeated for every element of results\r\n{shortFormVideos: [.results[] |\r\n  {title, thumbnail, id,\r\n   longDescription: .short_description,\r\n   shortDescription: .short_description,\r\n   releaseDate: .timestamp,\r\n   genres: [&quot;technology&quot;], \r\n   tags: [.branch],\r\n   content:\r\n    {duration,\r\n     dateAdded: .timestamp, \r\n     videos: [{url: .hls_url,\r\n               quality: &quot;HD&quot;,\r\n               videoType: &quot;HLS&quot;,\r\n               dateAdded: .publishdate}]}\r\n}]}\r\n```\r\n\r\nTo clarify what is wrong with your approach: `.results[] | ...` executes the filter once per element of `results`. The result of each filter is output as a separate JSON object – or as you call it – &quot;stripping commas&quot;.\r\n\r\nMy approach embeds the `.results[]` inside the resulting object. If you find it more readable, you can also do `.results | map({...}) | {providerName: ......., shortFormVideos: .}`\r\n",
                "title": "Reshape JSON File with JQ stripping commas from objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1637671370,
        "creation_date": 1637629271,
        "question_id": 70074192,
        "body_markdown": "I&#39;m building a ROKU app and am reformatting a json file pulled from an API to be in the same format as the ROKU Direct Publisher feed. \r\n\r\nThis is what ROKU is expecting...\r\n\r\n    {\r\n        &quot;providerName&quot;: &quot;Acme Productions&quot;,\r\n        &quot;lastUpdated&quot;: &quot;2015-11-11T22:21:37+00:00&quot;,\r\n        &quot;language&quot;: &quot;en&quot;,\r\n        &quot;categories&quot;: [\r\n            ...\r\n        ],\r\n        &quot;playlists&quot;: [\r\n            ...\r\n        ],\r\n        &quot;movies&quot;: [\r\n            ...\r\n        ],\r\n        &quot;liveFeeds&quot;: [\r\n            ...\r\n        ],\r\n        &quot;series&quot;: [\r\n            ...\r\n        ],\r\n        &quot;shortFormVideos&quot;:  [\r\n            ...\r\n        ],\r\n        &quot;tvSpecials&quot;: [\r\n            ...\r\n        ]\r\n    }\r\n\r\nI&#39;m using jq to reshape it and am having an issue.\r\n\r\nMy current json file is basically like this and goes on and on and on (i&#39;ve stripped most of it out as the keys don&#39;t really matter for what I&#39;m asking...)\r\n\r\n    {\r\n    &quot;page_info&quot;:{\r\n        &quot;total_results&quot;:1000,\r\n        &quot;results_per_page&quot;:50\r\n    },\r\n    &quot;results&quot;:[\r\n        {\r\n            &quot;category&quot;:&quot;B-Roll&quot;,\r\n            &quot;aspect_ratio&quot;:&quot;16:9&quot;,\r\n            &quot;duration&quot;:1851,\r\n            &quot;hd&quot;:true,\r\n            &quot;title&quot;:&quot;Title&quot;,\r\n            &quot;id&quot;:&quot;video:822667&quot;,\r\n            &quot;type&quot;:&quot;video&quot;,\r\n            &quot;keywords&quot;:&quot;removed&quot;,\r\n            &quot;credit&quot;:&quot;Removed&quot;,\r\n            &quot;country&quot;:&quot;United States&quot;,\r\n            &quot;city&quot;:&quot;&quot;,\r\n            &quot;hls_url&quot;:&quot;file&quot;\r\n        },\r\n        {\r\n            &quot;category&quot;:&quot;B-Roll&quot;,\r\n            &quot;aspect_ratio&quot;:&quot;16:9&quot;,\r\n            &quot;duration&quot;:1851,\r\n            &quot;hd&quot;:true,\r\n            &quot;title&quot;:&quot;Title&quot;,\r\n            &quot;id&quot;:&quot;video:822667&quot;,\r\n            &quot;type&quot;:&quot;video&quot;,\r\n            &quot;keywords&quot;:&quot;removed&quot;,\r\n            &quot;credit&quot;:&quot;Removed&quot;,\r\n            &quot;country&quot;:&quot;United States&quot;,\r\n            &quot;city&quot;:&quot;&quot;,\r\n            &quot;hls_url&quot;:&quot;file&quot;\r\n        },\r\n        {\r\n             &quot;category&quot;:&quot;B-Roll&quot;,\r\n            &quot;aspect_ratio&quot;:&quot;16:9&quot;,\r\n            &quot;duration&quot;:1851,\r\n            &quot;hd&quot;:true,\r\n            &quot;title&quot;:&quot;Title&quot;,\r\n            &quot;id&quot;:&quot;video:822667&quot;,\r\n            &quot;type&quot;:&quot;video&quot;,\r\n            &quot;keywords&quot;:&quot;removed&quot;,\r\n            &quot;credit&quot;:&quot;Removed&quot;,\r\n            &quot;country&quot;:&quot;United States&quot;,\r\n            &quot;city&quot;:&quot;&quot;,\r\n            &quot;hls_url&quot;:&quot;file&quot;\r\n        }\r\n    ]}\r\n\r\nThis is my jq filter - `.results[] | {&quot;providerName&quot;:&quot;CrozTest&quot; } + {&quot;language&quot;: &quot;en-us&quot;} + {&quot;lastUpdated&quot;: .timestamp} +  {&quot;shortFormVideos&quot;: [{&quot;title&quot;: .title, &quot;thumbnail&quot;: .thumbnail, &quot;longDescription&quot;: .short_description, &quot;shortDescription&quot;: .short_description, &quot;id&quot;: .id, &quot;releaseDate&quot;: .timestamp, &quot;genres&quot;: [&quot;technology&quot;], &quot;tags&quot;: [.branch], &quot;content&quot;: {&quot;duration&quot;: .duration, &quot;dateAdded&quot;: .timestamp, &quot;videos&quot;: [{url: .hls_url, quality: &quot;HD&quot;, videoType: &quot;HLS&quot;, dateAdded: .publishdate,}]}}]}`\r\n\r\nWhen I use this, it drills down to .results[], it displays everything fine, but removes the comma inbetween the objects and adds my &quot;provider name, language, updated and shortformvideos&quot; to every object. Now I need to keep the commas inbetween the objects and only display the provider/language/date/shortform at the top of the file as I continue to manipulate the object to be in the correct format that ROKU wants. \r\n\r\nThis is what is displayed when I run my code... \r\n\r\n    {\r\n      &quot;providerName&quot;: &quot;CrozTest&quot;,\r\n      &quot;language&quot;: &quot;en-us&quot;,\r\n      &quot;lastUpdated&quot;: null,\r\n      &quot;shortFormVideos&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;Title&quot;,\r\n          &quot;thumbnail&quot;: null,\r\n          &quot;longDescription&quot;: null,\r\n          &quot;shortDescription&quot;: null,\r\n          &quot;id&quot;: &quot;video:822667&quot;,\r\n          &quot;releaseDate&quot;: null,\r\n          &quot;genres&quot;: [\r\n            &quot;technology&quot;\r\n          ],\r\n          &quot;tags&quot;: [\r\n            null\r\n          ],\r\n          &quot;content&quot;: {\r\n            &quot;duration&quot;: 1851,\r\n            &quot;dateAdded&quot;: null,\r\n            &quot;videos&quot;: [\r\n              {\r\n                &quot;url&quot;: &quot;file&quot;,\r\n                &quot;quality&quot;: &quot;HD&quot;,\r\n                &quot;videoType&quot;: &quot;HLS&quot;,\r\n                &quot;dateAdded&quot;: null\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;providerName&quot;: &quot;CrozTest&quot;,\r\n      &quot;language&quot;: &quot;en-us&quot;,\r\n      &quot;lastUpdated&quot;: null,\r\n      &quot;shortFormVideos&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;Title&quot;,\r\n          &quot;thumbnail&quot;: null,\r\n          &quot;longDescription&quot;: null,\r\n          &quot;shortDescription&quot;: null,\r\n          &quot;id&quot;: &quot;video:822667&quot;,\r\n          &quot;releaseDate&quot;: null,\r\n          &quot;genres&quot;: [\r\n            &quot;technology&quot;\r\n          ],\r\n          &quot;tags&quot;: [\r\n            null\r\n          ],\r\n          &quot;content&quot;: {\r\n            &quot;duration&quot;: 1851,\r\n            &quot;dateAdded&quot;: null,\r\n            &quot;videos&quot;: [\r\n              {\r\n                &quot;url&quot;: &quot;file&quot;,\r\n                &quot;quality&quot;: &quot;HD&quot;,\r\n                &quot;videoType&quot;: &quot;HLS&quot;,\r\n                &quot;dateAdded&quot;: null\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;providerName&quot;: &quot;CrozTest&quot;,\r\n      &quot;language&quot;: &quot;en-us&quot;,\r\n      &quot;lastUpdated&quot;: null,\r\n      &quot;shortFormVideos&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;Title&quot;,\r\n          &quot;thumbnail&quot;: null,\r\n          &quot;longDescription&quot;: null,\r\n          &quot;shortDescription&quot;: null,\r\n          &quot;id&quot;: &quot;video:822667&quot;,\r\n          &quot;releaseDate&quot;: null,\r\n          &quot;genres&quot;: [\r\n            &quot;technology&quot;\r\n          ],\r\n          &quot;tags&quot;: [\r\n            null\r\n          ],\r\n          &quot;content&quot;: {\r\n            &quot;duration&quot;: 1851,\r\n            &quot;dateAdded&quot;: null,\r\n            &quot;videos&quot;: [\r\n              {\r\n                &quot;url&quot;: &quot;file&quot;,\r\n                &quot;quality&quot;: &quot;HD&quot;,\r\n                &quot;videoType&quot;: &quot;HLS&quot;,\r\n                &quot;dateAdded&quot;: null\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nNow I&#39;m just now starting to noodle around with jq, and this is what I&#39;m trying to get...\r\n\r\n     \r\n\r\n          {\r\n              &quot;providerName&quot;: &quot;CrozTest&quot;,\r\n              &quot;language&quot;: &quot;en-us&quot;,\r\n              &quot;lastUpdated&quot;: &quot;2021-11-21T19:24:03.750Z&quot;,\r\n              &quot;shortFormVideos&quot;: [\r\n            {\r\n                    &quot;category&quot;:&quot;B-Roll&quot;,\r\n                    &quot;aspect_ratio&quot;:&quot;16:9&quot;,\r\n                    &quot;duration&quot;:1851,\r\n                    &quot;hd&quot;:true,\r\n                    &quot;title&quot;:&quot;Title&quot;,\r\n                    &quot;id&quot;:&quot;video:822667&quot;,\r\n                    &quot;type&quot;:&quot;video&quot;,\r\n                    &quot;keywords&quot;:&quot;removed&quot;,\r\n                    &quot;credit&quot;:&quot;Removed&quot;,\r\n                    &quot;country&quot;:&quot;United States&quot;,\r\n                    &quot;city&quot;:&quot;&quot;,\r\n                    &quot;hls_url&quot;:&quot;file&quot;,\r\n              &quot;id&quot;: &quot;video:822412&quot;,\r\n              &quot;releaseDate&quot;: &quot;2021-11-21T18:21:04.353Z&quot;,\r\n              &quot;genres&quot;: [\r\n                &quot;technology&quot;\r\n              ],\r\n              &quot;tags&quot;: [\r\n                &quot;tag&quot;\r\n              ],\r\n              &quot;content&quot;: {\r\n                &quot;duration&quot;: 160,\r\n                &quot;dateAdded&quot;: &quot;2021-11-21T18:21:04.353Z&quot;,\r\n                &quot;videos&quot;: [\r\n                  {\r\n                    &quot;url&quot;: &quot;hls_url&quot;,\r\n                    &quot;quality&quot;: &quot;HD&quot;,\r\n                    &quot;videoType&quot;: &quot;HLS&quot;,\r\n                    &quot;dateAdded&quot;: &quot;2021-11-21T18:19:31Z&quot;\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n                    &quot;category&quot;:&quot;B-Roll&quot;,\r\n                    &quot;aspect_ratio&quot;:&quot;16:9&quot;,\r\n                    &quot;duration&quot;:1851,\r\n                    &quot;hd&quot;:true,\r\n                    &quot;title&quot;:&quot;Title&quot;,\r\n                    &quot;id&quot;:&quot;video:822667&quot;,\r\n                    &quot;type&quot;:&quot;video&quot;,\r\n                    &quot;keywords&quot;:&quot;removed&quot;,\r\n                    &quot;credit&quot;:&quot;Removed&quot;,\r\n                    &quot;country&quot;:&quot;United States&quot;,\r\n                    &quot;city&quot;:&quot;&quot;,\r\n                    &quot;hls_url&quot;:&quot;file&quot;,\r\n              &quot;id&quot;: &quot;video:822412&quot;,\r\n              &quot;releaseDate&quot;: &quot;2021-11-21T18:21:04.353Z&quot;,\r\n              &quot;genres&quot;: [\r\n                &quot;technology&quot;\r\n              ],\r\n              &quot;tags&quot;: [\r\n                &quot;tag&quot;\r\n              ],\r\n              &quot;content&quot;: {\r\n                &quot;duration&quot;: 160,\r\n                &quot;dateAdded&quot;: &quot;2021-11-21T18:21:04.353Z&quot;,\r\n                &quot;videos&quot;: [\r\n                  {\r\n                    &quot;url&quot;: &quot;hls_url&quot;,\r\n                    &quot;quality&quot;: &quot;HD&quot;,\r\n                    &quot;videoType&quot;: &quot;HLS&quot;,\r\n                    &quot;dateAdded&quot;: &quot;2021-11-21T18:19:31Z&quot;\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n    {\r\n                    &quot;category&quot;:&quot;B-Roll&quot;,\r\n                    &quot;aspect_ratio&quot;:&quot;16:9&quot;,\r\n                    &quot;duration&quot;:1851,\r\n                    &quot;hd&quot;:true,\r\n                    &quot;title&quot;:&quot;Title&quot;,\r\n                    &quot;id&quot;:&quot;video:822667&quot;,\r\n                    &quot;type&quot;:&quot;video&quot;,\r\n                    &quot;keywords&quot;:&quot;removed&quot;,\r\n                    &quot;credit&quot;:&quot;Removed&quot;,\r\n                    &quot;country&quot;:&quot;United States&quot;,\r\n                    &quot;city&quot;:&quot;&quot;,\r\n                    &quot;hls_url&quot;:&quot;file&quot;,\r\n              &quot;id&quot;: &quot;video:822412&quot;,\r\n              &quot;releaseDate&quot;: &quot;2021-11-21T18:21:04.353Z&quot;,\r\n              &quot;genres&quot;: [\r\n                &quot;technology&quot;\r\n              ],\r\n              &quot;tags&quot;: [\r\n                &quot;tag&quot;\r\n              ],\r\n              &quot;content&quot;: {\r\n                &quot;duration&quot;: 160,\r\n                &quot;dateAdded&quot;: &quot;2021-11-21T18:21:04.353Z&quot;,\r\n                &quot;videos&quot;: [\r\n                  {\r\n                    &quot;url&quot;: &quot;hls_url&quot;,\r\n                    &quot;quality&quot;: &quot;HD&quot;,\r\n                    &quot;videoType&quot;: &quot;HLS&quot;,\r\n                    &quot;dateAdded&quot;: &quot;2021-11-21T18:19:31Z&quot;\r\n                  }\r\n                ]\r\n              }\r\n            } \r\n              ]\r\n            }",
        "link": "https://stackoverflow.com/questions/70074192/reshape-json-file-with-jq-stripping-commas-from-objects",
        "title": "Reshape JSON File with JQ stripping commas from objects"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637655309,
                "post_id": 70077412,
                "comment_id": 123877646,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637655699,
                "creation_date": 1637655699,
                "answer_id": 70077497,
                "question_id": 70077412,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `?` as the [Optional Object Identifier-Index][1] operator, you could do a select as below\r\n\r\n```none\r\nmap(select(.groups[].name == &quot;G1&quot;)? | .user)\r\n```\r\n\r\nand un-wrap the results from the array by using `[]` at the end of the filter. To combine multiple selection conditions use the [boolean operators][2] with `and/or` inside the `select` statement\r\n\r\n\r\nSee [demo][3] on jqplay\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#OptionalObjectIdentifier-Index:.foo?\r\n  [2]: https://stedolan.github.io/jq/manual/#and/or/not\r\n  [3]: https://jqplay.org/s/AytqH6IOxk",
                "title": "jq: list users belonging to a specific group in array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1637656003,
                "creation_date": 1637656003,
                "answer_id": 70077548,
                "question_id": 70077412,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Better enter your serach data from parameters using `--arg` and use `any` to avoid duplicate outputs if both inputs match:\r\n```\r\njq -r --arg id &quot;&quot; --arg name &quot;G1&quot; &#39;\r\n  .[] | select(.groups | map(.id == $id or .name == $name) | any)? | .user\r\n&#39;\r\n```\r\n```\r\nu2\r\nu3\r\n```\r\n[Demo](https://jqplay.org/s/_e16vHJW3D)",
                "title": "jq: list users belonging to a specific group in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1637672181,
        "creation_date": 1637655264,
        "last_edit_date": 1637672181,
        "question_id": 70077412,
        "body_markdown": "input json:\r\n\r\n    [\r\n      {\r\n        &quot;user&quot;: &quot;u1&quot;\r\n      },\r\n      {\r\n        &quot;user&quot;: &quot;u2&quot;,\r\n        &quot;groups&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;100001&quot;,\r\n            &quot;name&quot;: &quot;G1&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;100002&quot;,\r\n            &quot;name&quot;: &quot;G2&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;user&quot;: &quot;u3&quot;,\r\n        &quot;groups&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;100001&quot;,\r\n            &quot;name&quot;: &quot;G1&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\nI want to find all users belonging to specific group (searching by group `name` or group `id` in the `groups` array)\r\n\r\n    $ jq -r &#39;.[]|select(.groups[].name==&quot;G1&quot; | .user)&#39; json\r\n    jq: error (at json:27): Cannot iterate over null (null)\r\n\r\n\r\nDesired output format when searching of example group *G1* would be:\r\n\r\n    u2\r\n    u3\r\n\r\nAdditional question:\r\nIs it possible to produce comma-separated output *u2,u3* without using external utilities like *tr*?\r\n",
        "link": "https://stackoverflow.com/questions/70077412/jq-list-users-belonging-to-a-specific-group-in-array",
        "title": "jq: list users belonging to a specific group in array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637704611,
                "last_edit_date": 1637704611,
                "creation_date": 1637696092,
                "answer_id": 70086839,
                "question_id": 70085640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if I got all your alignments right, but give this a try:\r\n```\r\n.headerData.methodNames as $header\r\n| .lightValueObjects | map(\r\n  ( [$header, .data]\r\n    | transpose\r\n    | map({(first): last})\r\n    | add\r\n  ) + del(.data)\r\n)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;super&quot;,\r\n    &quot;accessIp&quot;: &quot;192.168.128.222&quot;,\r\n    &quot;deviceType&quot;: &quot;leader&quot;,\r\n    &quot;version&quot;: null,\r\n    &quot;discoverTime&quot;: 1637092568000,\r\n    &quot;discoverMethod&quot;: &quot;LOG&quot;,\r\n    &quot;status&quot;: 1,\r\n    &quot;department&quot;: &quot;Super&quot;,\r\n    &quot;description&quot;: null,\r\n    &quot;perfMonStatus&quot;: &quot;&quot;,\r\n    &quot;eventLogStatus&quot;: &quot;Normal&quot;,\r\n    &quot;maintenance&quot;: &quot;&quot;,\r\n    &quot;location&quot;: null,\r\n    &quot;agentStatus&quot;: &quot;&quot;,\r\n    &quot;policyName&quot;: &quot;&quot;,\r\n    &quot;policyId&quot;: &quot;&quot;,\r\n    &quot;agentType&quot;: null,\r\n    &quot;templateIds&quot;: &quot;&quot;,\r\n    &quot;agentId&quot;: null,\r\n    &quot;decommission&quot;: false,\r\n    &quot;accountId&quot;: &quot;&quot;,\r\n    &quot;instanceId&quot;: &quot;&quot;,\r\n    &quot;agentVersion&quot;: null,\r\n    &quot;parserName&quot;: &quot;&quot;,\r\n    &quot;objectId&quot;: 17657,\r\n    &quot;custId&quot;: 1,\r\n    &quot;parentId&quot;: null,\r\n    &quot;collectorId&quot;: null,\r\n    &quot;extData&quot;: null,\r\n    &quot;naturalId&quot;: &quot;lead%2dsuper&quot;,\r\n    &quot;aoSys&quot;: false\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;fw01&quot;,\r\n    &quot;accessIp&quot;: &quot;192.168.128.1&quot;,\r\n    &quot;deviceType&quot;: &quot;fw&quot;,\r\n    &quot;version&quot;: &quot;ANY&quot;,\r\n    &quot;discoverTime&quot;: 1637098725000,\r\n    &quot;discoverMethod&quot;: &quot;LOG&quot;,\r\n    &quot;status&quot;: 1,\r\n    &quot;department&quot;: &quot;Super&quot;,\r\n    &quot;description&quot;: null,\r\n    &quot;perfMonStatus&quot;: &quot;&quot;,\r\n    &quot;eventLogStatus&quot;: &quot;Normal&quot;,\r\n    &quot;maintenance&quot;: &quot;&quot;,\r\n    &quot;location&quot;: null,\r\n    &quot;agentStatus&quot;: &quot;&quot;,\r\n    &quot;policyName&quot;: &quot;&quot;,\r\n    &quot;policyId&quot;: &quot;&quot;,\r\n    &quot;agentType&quot;: null,\r\n    &quot;templateIds&quot;: &quot;&quot;,\r\n    &quot;agentId&quot;: null,\r\n    &quot;decommission&quot;: false,\r\n    &quot;accountId&quot;: &quot;&quot;,\r\n    &quot;instanceId&quot;: &quot;&quot;,\r\n    &quot;agentVersion&quot;: null,\r\n    &quot;parserName&quot;: &quot;&quot;,\r\n    &quot;objectId&quot;: 883252,\r\n    &quot;custId&quot;: 1,\r\n    &quot;parentId&quot;: null,\r\n    &quot;collectorId&quot;: null,\r\n    &quot;extData&quot;: null,\r\n    &quot;naturalId&quot;: &quot;fw01&quot;,\r\n    &quot;aoSys&quot;: false\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/xtZMyxqxGj)\r\n\r\nEdit: If you want to replace empty strings `&quot;&quot;` with `null`, as you did in your approach, replace `last` from my solution with either `(last | select(. != &quot;&quot;) // null)` or, more explicitly, with  `(last | if . == &quot;&quot; then null else . end)`.",
                "title": "Reshaping loosely structured JSON (field names stored in array)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637704611,
        "creation_date": 1637690167,
        "question_id": 70085640,
        "body_markdown": "I have a unique problem I have been struggling to get my head wrapped around.  I have a bit of JSON from an API.  The field names are actually stored in **.headerData.methodNames** and most of the values are stored in **.lightValueObjects[].data**.\r\n```json\r\n{\r\n  &quot;headerData&quot;: {\r\n    &quot;objectTypeName&quot;: &quot;device&quot;,\r\n    &quot;methodNames&quot;: [\r\n      &quot;name&quot;,\r\n      &quot;accessIp&quot;,\r\n      &quot;deviceType&quot;,\r\n      &quot;version&quot;,\r\n      &quot;discoverTime&quot;,\r\n      &quot;discoverMethod&quot;,\r\n      &quot;status&quot;,\r\n      &quot;department&quot;,\r\n      &quot;description&quot;,\r\n      &quot;perfMonStatus&quot;,\r\n      &quot;eventLogStatus&quot;,\r\n      &quot;maintenance&quot;,\r\n      &quot;location&quot;,\r\n      &quot;agentStatus&quot;,\r\n      &quot;policyName&quot;,\r\n      &quot;policyId&quot;,\r\n      &quot;agentType&quot;,\r\n      &quot;templateIds&quot;,\r\n      &quot;agentId&quot;,\r\n      &quot;decommission&quot;,\r\n      &quot;accountId&quot;,\r\n      &quot;instanceId&quot;,\r\n      &quot;agentVersion&quot;,\r\n      &quot;parserName&quot;\r\n    ]\r\n  },\r\n  &quot;lightValueObjects&quot;: [\r\n    {\r\n      &quot;objectId&quot;: 17657,\r\n      &quot;custId&quot;: 1,\r\n      &quot;parentId&quot;: null,\r\n      &quot;collectorId&quot;: null,\r\n      &quot;data&quot;: [\r\n        &quot;super&quot;,\r\n        &quot;192.168.128.222&quot;,\r\n        &quot;leader&quot;,\r\n        null,\r\n        1637092568000,\r\n        &quot;LOG&quot;,\r\n        1,\r\n        &quot;Super&quot;,\r\n        null,\r\n        &quot;&quot;,\r\n        &quot;Normal&quot;,\r\n        &quot;&quot;,\r\n        null,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        null,\r\n        &quot;&quot;,\r\n        null,\r\n        false,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        null,\r\n        &quot;&quot;\r\n      ],\r\n      &quot;extData&quot;: null,\r\n      &quot;naturalId&quot;: &quot;lead%2dsuper&quot;,\r\n      &quot;aoSys&quot;: false\r\n    },\r\n    {\r\n      &quot;objectId&quot;: 883252,\r\n      &quot;custId&quot;: 1,\r\n      &quot;parentId&quot;: null,\r\n      &quot;collectorId&quot;: null,\r\n      &quot;data&quot;: [\r\n        &quot;fw01&quot;,\r\n        &quot;192.168.128.1&quot;,\r\n        &quot;fw&quot;,\r\n        &quot;ANY&quot;,\r\n        1637098725000,\r\n        &quot;LOG&quot;,\r\n        1,\r\n        &quot;Super&quot;,\r\n        null,\r\n        &quot;&quot;,\r\n        &quot;Normal&quot;,\r\n        &quot;&quot;,\r\n        null,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        null,\r\n        &quot;&quot;,\r\n        null,\r\n        false,\r\n        &quot;&quot;,\r\n        &quot;&quot;,\r\n        null,\r\n        &quot;&quot;\r\n      ],\r\n      &quot;extData&quot;: null,\r\n      &quot;naturalId&quot;: &quot;fw01&quot;,\r\n      &quot;aoSys&quot;: false\r\n    }\r\n  ],\r\n  &quot;errCode&quot;: 0,\r\n  &quot;errObj&quot;: null,\r\n  &quot;dataType&quot;: &quot;Device&quot;,\r\n  &quot;totalCount&quot;: 0\r\n}\r\n```\r\nThe following code produces better output, but it&#39;s not quite perfect.\r\n```\r\n.headerData.methodNames as $header | [.lightValueObjects[].data] | map(\r\n      . as $o |\r\n      reduce .[] as $item({}; ($o | index($item)) as $index |\r\n      .[$header[$index]] = (if $item == &quot;&quot; then null else $item end))\r\n      )\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;super&quot;,\r\n    &quot;accessIp&quot;: &quot;192.168.128.222&quot;,\r\n    &quot;deviceType&quot;: &quot;leader&quot;,\r\n    &quot;version&quot;: null,\r\n    &quot;discoverTime&quot;: 1637092568000,\r\n    &quot;discoverMethod&quot;: &quot;LOG&quot;,\r\n    &quot;status&quot;: 1,\r\n    &quot;department&quot;: &quot;Super&quot;,\r\n    &quot;perfMonStatus&quot;: null,\r\n    &quot;eventLogStatus&quot;: &quot;Normal&quot;,\r\n    &quot;decommission&quot;: false\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;fw01&quot;,\r\n    &quot;accessIp&quot;: &quot;192.168.128.1&quot;,\r\n    &quot;deviceType&quot;: &quot;fw&quot;,\r\n    &quot;version&quot;: &quot;ANY&quot;,\r\n    &quot;discoverTime&quot;: 1637098725000,\r\n    &quot;discoverMethod&quot;: &quot;LOG&quot;,\r\n    &quot;status&quot;: 1,\r\n    &quot;department&quot;: &quot;Super&quot;,\r\n    &quot;description&quot;: null,\r\n    &quot;perfMonStatus&quot;: null,\r\n    &quot;eventLogStatus&quot;: &quot;Normal&quot;,\r\n    &quot;decommission&quot;: false\r\n  }\r\n]\r\n```\r\n\r\n**Current Problems**\r\n1. There should be 24 fields returned per device, but only 11 are being shown.\r\n2. I have not been able to figure out how to merge the named values in .lightValueObjects to the final output.\r\n\r\nHere is an example of what I am trying to make the output show, (To keep things simple, I am only showing 1 device)\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;super&quot;,\r\n    &quot;accessIp&quot;: &quot;192.168.128.222&quot;,\r\n    &quot;deviceType&quot;: &quot;leader&quot;,\r\n    &quot;version&quot;: null,\r\n    &quot;discoverTime&quot;: 1637092568000,\r\n    &quot;discoverMethod&quot;: &quot;LOG&quot;,\r\n    &quot;status&quot;: 1,\r\n    &quot;department&quot;: &quot;Super&quot;,\r\n    &quot;description&quot;: null,\r\n    &quot;perfMonStatus&quot;: null,\r\n    &quot;eventLogStatus&quot;: &quot;Normal&quot;,\r\n    &quot;maintenance&quot;: null,\r\n    &quot;location&quot;: null,\r\n    &quot;agentStatus&quot;: null,\r\n    &quot;policyName&quot;: null,\r\n    &quot;agentType&quot;: null,\r\n    &quot;templateIds&quot;: null,\r\n    &quot;agentId&quot;: null,\r\n    &quot;decommission&quot;: false,\r\n    &quot;accountId&quot;: null,\r\n    &quot;instanceId&quot;: null,\r\n    &quot;agentVersion&quot;: null,\r\n    &quot;parserName&quot;: null,\r\n    &quot;objectId&quot;: 17657,\r\n    &quot;custId&quot;: 1,\r\n    &quot;parentId&quot;: null,\r\n    &quot;collectorId&quot;: null,\r\n    &quot;extData&quot;: null,\r\n    &quot;naturalId&quot;: &quot;lead%2dsuper&quot;,\r\n    &quot;aoSys&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nAny help would be **GREATLY** appreciated!!",
        "link": "https://stackoverflow.com/questions/70085640/reshaping-loosely-structured-json-field-names-stored-in-array",
        "title": "Reshaping loosely structured JSON (field names stored in array)"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637699596,
                "last_edit_date": 1637699596,
                "creation_date": 1637696642,
                "answer_id": 70086940,
                "question_id": 70086757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you get your quoting right in the input JSON, it&#39;s as simple as calling the `from_entries` builtin. It converts an array of objects to a single object with given key/value pairs. It takes the field name from a field called `key`, `Key`, `name` or `Name` and the value from a field called `value` or `Value` (see [Demo](https://jqplay.org/s/Pjp12A-D_5)):\r\n```\r\nfrom_entries\r\n```\r\n```json\r\n{\r\n  &quot;data_file_pattern&quot;: &quot;list_of_orders.csv&quot;,\r\n  &quot;header_count&quot;: &quot;1&quot;\r\n}\r\n```\r\n\r\nNote: I believe the second field name should read `header_count` instead of `delimited_file` as you wanted to take its name from `.name`, not `.object_type`.",
                "title": "Create single dictionary with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637700613,
        "creation_date": 1637695751,
        "last_edit_date": 1637700613,
        "question_id": 70086757,
        "body_markdown": "I have the following input:\r\n\r\n```\r\n[\r\n  {\r\n    constant_id: 5,\r\n    object_id: 2,\r\n    object_type: &#39;delimited_file&#39;,\r\n    name: &#39;data_file_pattern&#39;,\r\n    value: &#39;list_of_orders.csv&#39;,\r\n    insert_date: 2021-11-23T10:24:16.568Z,\r\n    update_date: null\r\n  },\r\n  {\r\n    constant_id: 6,\r\n    object_id: 2,\r\n    object_type: &#39;delimited_file&#39;,\r\n    name: &#39;header_count&#39;,\r\n    value: &#39;1&#39;,\r\n    insert_date: 2021-11-23T10:24:16.568Z,\r\n    update_date: null\r\n  }\r\n]\r\n```\r\n\r\nThat I&#39;d like to combine to get the following result:\r\n\r\n```\r\n{\r\n  data_file_pattern: &#39;list_of_orders.csv&#39;,\r\n  header_count: &#39;1&#39;\r\n}\r\n```\r\n\r\nBasically creating a single dictionary with only the `name` and `value` keys from the input dictionaries. I believe I&#39;ve done this before but for the life of me I can&#39;t figure it out again.",
        "link": "https://stackoverflow.com/questions/70086757/create-single-dictionary-with-jq",
        "title": "Create single dictionary with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "filenames"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637736727,
                "last_edit_date": 1637736727,
                "creation_date": 1637735147,
                "answer_id": 70091550,
                "question_id": 70091006,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`input_filename` evaluates to the input file name of the file currently being read (after it has been opened).  For STDIN, it evaluates to `&quot;&lt;stdin&gt;&quot;`:\r\n\r\n```\r\njq  &#39;input_filename, input_filename&#39; &lt;&lt;&lt; 1\r\n&quot;&lt;stdin&gt;&quot;\r\n&quot;&lt;stdin&gt;&quot;\r\n```\r\nIt works with the -n command-line option, but only after an `input` or `inputs` function has been called:\r\n```\r\njq -n &#39;input_filename, (input | input_filename)&#39; &lt;&lt;&lt; 1\r\nnull\r\n&quot;&lt;stdin&gt;&quot;\r\n```",
                "title": "Parse multiple json files and output the match/hits against the regex with associated file names"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1637745687,
                "creation_date": 1637745687,
                "answer_id": 70093500,
                "question_id": 70091006,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a jq-internal solution use `input_filename` as @peak suggested. Here&#39;s an external solution which iterates over your input files and passes the file name as variable into jq. This approach, however, calls jq once for each input file (as opposed to your `cat *.json | jq ...` approach which has just one call), so you might run into performance issues when applied to a larger number of input files.\r\n```sh\r\nfor f in *.json\r\ndo jq --arg f &quot;$f&quot; &#39;. as $data | ... (use $f here) ...&#39; &quot;$f&quot;\r\ndone\r\n```",
                "title": "Parse multiple json files and output the match/hits against the regex with associated file names"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1641283547,
        "creation_date": 1637730654,
        "last_edit_date": 1641283547,
        "question_id": 70091006,
        "body_markdown": "Currently, the cat command piped to jq helps me to parse multiple JSON files in my working directory and screen against the regex pattern matching email ids available in all in the files. However, am keen to identify the file name also in which the regex pattern is being hit/matched\r\n\r\n```\r\ncat *.json | jq &#39;. as $data | [path(..| select(scalars and (tostring | test(&quot;^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9.-]+$&quot;, &quot;ixn&quot;)))) ] | map({ (.|join(&quot;.&quot;)): (. as $path | .=$data | getpath($path)) }) | reduce .[] as $item ({}; . * $item)&#39; \r\n```\r\n\r\nRequest your kind help tweaking the command to print $filename. thanks!",
        "link": "https://stackoverflow.com/questions/70091006/parse-multiple-json-files-and-output-the-match-hits-against-the-regex-with-assoc",
        "title": "Parse multiple json files and output the match/hits against the regex with associated file names"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7596864,
                    "reputation": 982,
                    "user_id": 5762785,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/9145d71d002c069b979fdda9ee1b7afe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hermit.crab",
                    "link": "https://stackoverflow.com/users/5762785/hermit-crab"
                },
                "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": 1637735134,
                "post_id": 70091433,
                "comment_id": 123902626,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637738672,
                "last_edit_date": 1637738672,
                "creation_date": 1637736126,
                "answer_id": 70091671,
                "question_id": 70091433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If newlines are the only thing you can handle, maybe you can do a string replacement.\r\n```\r\ncat tmp.json | jq -r &#39;.results | (first | map(.field)), (.[] | map(.value) | map(gsub(&quot;\\\\n&quot;; &quot;\\\\n&quot;))) | @csv&#39;\r\n```",
                "title": "How to not let jq interpret the newline character when exporting to CSV"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637737027,
                "last_edit_date": 1637737027,
                "creation_date": 1637736507,
                "answer_id": 70091736,
                "question_id": 70091433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a jq-only solution, you can use `gsub(&quot;\\n&quot;; &quot;\\\\n&quot;)`. I&#39;d go with something like this:\r\n\r\n```\r\n.results\r\n| (.[0] | map(.field)),\r\n  (.[]  | map( .value | gsub(&quot;\\n&quot;; &quot;\\\\n&quot;)))\r\n| @csv\r\n```\r\n\r\nUsing your JSON and invoking this with the -r command line option yields:\r\n```\r\n&quot;field1&quot;,&quot;field2&quot;\r\n&quot;value1-1&quot;,&quot;value1-2\\n&quot;\r\n&quot;value2-1&quot;,&quot;value2-2\\n&quot;\r\n```\r\n\r\n",
                "title": "How to not let jq interpret the newline character when exporting to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1637738672,
        "creation_date": 1637734148,
        "last_edit_date": 1637735990,
        "question_id": 70091433,
        "body_markdown": "I want to convert the following JSON content stored in a file tmp.json\r\n\r\n```\r\n{\r\n    &quot;results&quot;: [\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value1-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value1-2\\n&quot;\r\n           }\r\n        ],\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value2-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value2-2\\n&quot;\r\n           }\r\n        ]\r\n    ]\r\n}\r\n```\r\n\r\ninto a CSV output\r\n\r\n```\r\n&quot;field1&quot;,&quot;field2&quot;\r\n&quot;value1-1&quot;,&quot;value1-2\\n&quot;\r\n&quot;value2-1&quot;,&quot;value2-2\\n&quot;\r\n```\r\n\r\nWhen I use this `jq` command, however,\r\n\r\n```\r\n cat tmp.json | jq -r &#39;.results | (first | map(.field)), (.[] | map(.value)) | @csv&#39;\r\n```\r\n\r\nI get this result:\r\n\r\n```\r\n&quot;field1&quot;,&quot;field2&quot;\r\n&quot;value1-1&quot;,&quot;value1-2\r\n&quot;\r\n&quot;value2-1&quot;,&quot;value2-2\r\n&quot;\r\n```\r\n\r\nHow should the `jq` command be written to get the desired CSV result?\r\n",
        "link": "https://stackoverflow.com/questions/70091433/how-to-not-let-jq-interpret-the-newline-character-when-exporting-to-csv",
        "title": "How to not let jq interpret the newline character when exporting to CSV"
    },
    {
        "tags": [
            "json",
            "bash",
            "time",
            "query-optimization",
            "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": 2,
                "creation_date": 1637738741,
                "post_id": 70092053,
                "comment_id": 123903504,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 70999,
                    "reputation": 515,
                    "user_id": 205420,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/4VM8r.jpg?s=256",
                    "display_name": "Sam P",
                    "link": "https://stackoverflow.com/users/205420/sam-p"
                },
                "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": 1637739331,
                "post_id": 70092053,
                "comment_id": 123903700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 70999,
                    "reputation": 515,
                    "user_id": 205420,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/4VM8r.jpg?s=256",
                    "display_name": "Sam P",
                    "link": "https://stackoverflow.com/users/205420/sam-p"
                },
                "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": 1637739397,
                "post_id": 70092053,
                "comment_id": 123903719,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1637743342,
                "post_id": 70092053,
                "comment_id": 123904967,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637793911,
                "last_edit_date": 1637793911,
                "creation_date": 1637744231,
                "answer_id": 70093166,
                "question_id": 70092053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Regarding the main question (regarding computing time differences), you&#39;re in luck as jq provides the built-in function `fromdateiso8601` for converting ISO times to &quot;the \r\n number of seconds since the Unix epoch (1970-01-01T00:00:00Z)&quot;.\r\n\r\nWith your JSON sample,\r\n```\r\n.trades[]\r\n| [ .orders[1].placedTime, .orders[0].placedTime]\r\n| map(fromdateiso8601)\r\n| .[0] - .[1]\r\n```\r\n\r\nproduces the three differences:\r\n```\r\n79200\r\n900\r\n900\r\n```\r\n\r\nAnd here&#39;s a function for converting seconds to &quot;hh:mm:ss&quot; format:\r\n```\r\ndef hhmmss:\r\n  def l: tostring | if length &lt; 2 then &quot;0\\(.)&quot; else . end;\r\n  (. % 60) as $ss\r\n  | ((. / 60) | floor) as $mm\r\n  | (($mm / 60) | floor) as $hh\r\n  | ($mm % 60) as $mm\r\n  | [$hh, $mm, $ss] | map(l) | join(&quot;:&quot;);\r\n\r\n```\r\n",
                "title": "Bash script with jq wont get date difference from strings, and runs quite slowly on i7 16GB RAM"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638204337,
                "last_edit_date": 1638204337,
                "creation_date": 1637773127,
                "answer_id": 70100071,
                "question_id": 70092053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I prefer using an intermediate structure of the &quot;entry&quot; and &quot;exit&quot; JSON.  This helps with debugging the `jq` commands.  Formatted for readability over performance:\r\n\r\n    #!/usr/bin/env bash\r\n    echo &quot;TradeNo,TradeOpenType,TradeCloseType,TradeOpenSource,TradeCloseSource,TradeOpenTime,TradeCloseTime,PNL,Exposure&quot; &gt; tradelist.csv\r\n    jq -r &#39;\r\n      .trades[]\r\n      |{tradeNo,\r\n        profitPercentage,\r\n        entry:.orders[0],\r\n        exit:.orders[1],\r\n        entryTS:.orders[0].placedTime|fromdate,\r\n        exitTS:.orders[1].placedTime|fromdate}\r\n      |[.tradeNo,\r\n        .entry.side,\r\n        .exit.side,\r\n        .entry.source,\r\n        .exit.source,\r\n        (.entry.placedTime|strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)|strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)),\r\n        (.exit.placedTime|strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)|strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)),\r\n        (.profitPercentage*100),\r\n        (.exitTS-.entryTS|todate|strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)|strftime(&quot;%d:%H:%M&quot;))]|@csv\r\n      &#39; D.json | tr -d &#39;&quot;&#39; &gt;&gt; tradelist.csv\r\nWARNING: This formatting assumes Exposure is *LESS THAN 1 MONTH.*  Good luck with that!",
                "title": "Bash script with jq wont get date difference from strings, and runs quite slowly on i7 16GB RAM"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1638225058,
                "last_edit_date": 1638225058,
                "creation_date": 1637782432,
                "answer_id": 70101942,
                "question_id": 70092053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it all (extracts, conversions and formatting) with one `jq` call:\r\n\r\n```sh\r\n#!/bin/sh\r\n\r\necho &#39;TradeNo,TradeOpenType,TradeCloseType,TradeOpenSource,TradeCloseSource,TradeOpenTime,TradeCloseTime,PNL,Exposure&#39;\r\n\r\nquery=&#39;\r\n  .trades[]\r\n  | [\r\n    .tradeNo,\r\n    .orders[0].side,\r\n    .orders[1].side,\r\n    .orders[0].source,\r\n    .orders[1].source,\r\n    (.orders[0].placedTime | fromdate | strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)),\r\n    (.orders[1].placedTime | fromdate | strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)),\r\n    .profitPercentage * 100,\r\n    (\r\n      (.orders[1].placedTime | fromdate) - (.orders[0].placedTime | fromdate)\r\n      | (. / 86400 | floor | tostring) + (. % 86400 | strftime(&quot;:%H:%M&quot;))\r\n    )\r\n  ]\r\n  |@csv\r\n&#39;\r\n\r\njq -r &quot;$query&quot; &lt; D.json &gt; tradelist.csv\r\n```\r\n\r\nexample of JSON (cleaned of all irrelevant keys):\r\n```json\r\n{ \r\n  &quot;trades&quot;: [\r\n    {\r\n      &quot;tradeNo&quot;: 0,\r\n      &quot;profitPercentage&quot;: -0.00549085,\r\n      &quot;orders&quot;: [\r\n        {\r\n          &quot;side&quot;: &quot;Long&quot;,\r\n          &quot;placedTime&quot;: &quot;2018-12-16T21:34:46Z&quot;,\r\n          &quot;source&quot;: &quot;SIGNAL&quot;\r\n        },\r\n        {\r\n          &quot;side&quot;: &quot;CloseLong&quot;,\r\n          &quot;placedTime&quot;: &quot;2019-09-17T19:15:00Z&quot;,\r\n          &quot;source&quot;: &quot;SIGNAL&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n``` \r\noutput:\r\n```csv\r\nTradeNo,TradeOpenType,TradeCloseType,TradeOpenSource,TradeCloseSource,TradeOpenTime,TradeCloseTime,PNL,Exposure\r\n0,&quot;Long&quot;,&quot;CloseLong&quot;,&quot;SIGNAL&quot;,&quot;SIGNAL&quot;,&quot;2018-12-16 21:34:46&quot;,&quot;2019-09-17 20:15:00&quot;,-0.549085,&quot;274:22:40&quot;\r\n```\r\n\r\nIf you want to get rid of the double quotes that `jq` adds when generating a CSV (which are completely valid, but you need a real parser to read the CSV) then you can replace `@csv` with `@tsv` and post-process the output with `tr &#39;\\t&#39; &#39;,&#39;`, like this:\r\n\r\n```sh\r\nquery=&#39;\r\n  ...\r\n  |@tsv\r\n&#39;\r\n\r\njq -r &quot;$query&quot; &lt; D.json | tr &#39;\\t&#39; &#39;,&#39; &gt; tradelist.csv\r\n```\r\n\r\nand you&#39;ll get:\r\n```\r\nTradeNo,TradeOpenType,TradeCloseType,TradeOpenSource,TradeCloseSource,TradeOpenTime,TradeCloseTime,PNL,Exposure\r\n0,Long,CloseLong,SIGNAL,SIGNAL,2018-12-16 21:34:46,2019-09-17 20:15:00,-0.549085,274:22:40\r\n```\r\n_**note:** This method of getting rid of the `&quot;` in the CSV is only accurate when there is no `\\n` `\\t` `\\r` `\\` `,` or `&quot;` characters in the input data._",
                "title": "Bash script with jq wont get date difference from strings, and runs quite slowly on i7 16GB RAM"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1638225058,
        "creation_date": 1637738425,
        "last_edit_date": 1637743182,
        "question_id": 70092053,
        "body_markdown": "Need to find the difference between TradeCloseTime and TradeOpenTime time in dd:hh:mm format for the Exposure column in the following script.\r\n\r\nAlso the script runs super slow (~4 mins for 800 rows of json, on Core i7 16gb RAM machine)\r\n\r\n```\r\n#!/bin/bash\r\necho &quot;TradeNo, TradeOpenType, TradeCloseType, TradeOpenSource, TradeCloseSource, TradeOpenTime, TradeCloseTime, PNL, Exposure&quot; &gt; tradelist.csv\r\ntradecount=$(jq -r &#39;.performance.numberOfTrades|tonumber&#39; D.json)\r\nfor ((i=0; i&lt;$tradecount; i++))\r\ndo\r\ntradeNo=$(jq -r &#39;.trades[&#39;$i&#39;]|[.tradeNo][]|tonumber&#39; D.json)\r\nentrySide=$(jq -r &#39;.trades[&#39;$i&#39;].orders[0]|[.side][]&#39; D.json)\r\nexitSide=$(jq -r &#39;.trades[&#39;$i&#39;].orders[1]|[.side][]&#39; D.json)\r\nentrySource=$(jq -r &#39;.trades[&#39;$i&#39;].orders[0]|[.source][]&#39; D.json)\r\nexitSource=$(jq -r &#39;.trades[&#39;$i&#39;].orders[1]|[.source][]&#39; D.json)\r\ntradeEntryTime=$(jq -r &#39;.trades[&#39;$i&#39;].orders[0]|[.placedTime][]&#39; D.json | tr -d &#39;Z&#39; |  tr -s &#39;T&#39; &#39; &#39;)\r\ntradeExitTime=$(jq -r &#39;.trades[&#39;$i&#39;].orders[1]|[.placedTime][]&#39; D.json | tr -d &#39;Z&#39; |  tr -s &#39;T&#39; &#39; &#39;)\r\nprofitPercentage=$(jq -r &#39;(.trades[&#39;$i&#39;]|[.profitPercentage][0]|tonumber)*(100)&#39; D.json)\r\necho $tradeNo&quot;,&quot;$entrySide&quot;,&quot;$exitSide&quot;,&quot;$entrySource&quot;,&quot;$exitSource&quot;,&quot;$tradeEntryTime&quot;,&quot;$tradeExitTime&quot;,&quot;$profitPercentage | tr -d &#39;&quot;&#39; &gt;&gt; tradelist.csv\r\ndone\r\n```\r\n\r\njson file looks like this\r\n\r\n```\r\n{&quot;market&quot;:{&quot;exchange&quot;:&quot;BINANCE_FUTURES&quot;,&quot;coinPair&quot;:&quot;BTC_USDT&quot;},&quot;strategy&quot;:{&quot;name&quot;:&quot;&quot;,&quot;type&quot;:&quot;BACKTEST&quot;,&quot;candleSize&quot;:15,&quot;lookbackDays&quot;:6,&quot;leverageLong&quot;:1.00000000,&quot;leverageShort&quot;:1.00000000,&quot;strategyName&quot;:&quot;ABC&quot;,&quot;strategyVersion&quot;:35,&quot;runNo&quot;:&quot;002&quot;,&quot;source&quot;:&quot;Personal&quot;},&quot;strategyParameters&quot;:[{&quot;name&quot;:&quot;DurationInput&quot;,&quot;value&quot;:&quot;87.0&quot;}],&quot;openPositionStrategy&quot;:{&quot;actionTime&quot;:&quot;CANDLE_CLOSE&quot;,&quot;maxPerSignal&quot;:1.00000000},&quot;closePositionStrategy&quot;:{&quot;actionTime&quot;:&quot;CANDLE_CLOSE&quot;,&quot;minProfit&quot;:&quot;NaN&quot;,&quot;stopLossValue&quot;:0.07000000,&quot;stopLossTrailing&quot;:true,&quot;takeProfit&quot;:0.01290000,&quot;takeProfitDeviation&quot;:&quot;NaN&quot;},&quot;performance&quot;:{&quot;startTime&quot;:&quot;2019-01-01T00:00:00Z&quot;,&quot;endTime&quot;:&quot;2021-11-24T00:00:00Z&quot;,&quot;startAllocation&quot;:1000.00000000,&quot;endAllocation&quot;:3478.58904150,&quot;absoluteProfit&quot;:2478.58904150,&quot;profitPerc&quot;:2.47858904,&quot;buyHoldRatio&quot;:0.62426630,&quot;buyHoldReturn&quot;:4.57228387,&quot;numberOfTrades&quot;:744,&quot;profitableTrades&quot;:0.67833109,&quot;maxDrawdown&quot;:-0.20924885,&quot;avgMonthlyProfit&quot;:0.05242718,&quot;profitableMonths&quot;:0.70370370,&quot;avgWinMonth&quot;:0.09889897,&quot;avgLoseMonth&quot;:-0.05275563,&quot;startPrice&quot;:null,&quot;endPrice&quot;:57623.08000000},&quot;trades&quot;:[{&quot;tradeNo&quot;:0,&quot;profit&quot;:-5.48836165,&quot;profitPercentage&quot;:-0.00549085,&quot;accumulatedBalance&quot;:994.51163835,&quot;compoundProfitPerc&quot;:-0.00548836,&quot;orders&quot;:[{&quot;side&quot;:&quot;Long&quot;,&quot;placedTime&quot;:&quot;2019-09-16T21:15:00Z&quot;,&quot;placedAmount&quot;:0.09700000,&quot;filledTime&quot;:&quot;2019-09-16T21:15:00Z&quot;,&quot;filledAmount&quot;:0.09700000,&quot;filledPrice&quot;:10300.49000000,&quot;commissionPaid&quot;:0.39965901,&quot;source&quot;:&quot;SIGNAL&quot;},{&quot;side&quot;:&quot;CloseLong&quot;,&quot;placedTime&quot;:&quot;2019-09-17T19:15:00Z&quot;,&quot;placedAmount&quot;:0.09700000,&quot;filledTime&quot;:&quot;2019-09-17T19:15:00Z&quot;,&quot;filledAmount&quot;:0.09700000,&quot;filledPrice&quot;:10252.13000000,&quot;commissionPaid&quot;:0.39778264,&quot;source&quot;:&quot;SIGNAL&quot;}]},{&quot;tradeNo&quot;:1,&quot;profit&quot;:-3.52735800,&quot;profitPercentage&quot;:-0.00356403,&quot;accumulatedBalance&quot;:990.98428035,&quot;compoundProfitPerc&quot;:-0.00901572,&quot;orders&quot;:[{&quot;side&quot;:&quot;Long&quot;,&quot;placedTime&quot;:&quot;2019-09-19T06:00:00Z&quot;,&quot;placedAmount&quot;:0.10000000,&quot;filledTime&quot;:&quot;2019-09-19T06:00:00Z&quot;,&quot;filledAmount&quot;:0.10000000,&quot;filledPrice&quot;:9893.16000000,&quot;commissionPaid&quot;:0.39572640,&quot;source&quot;:&quot;SIGNAL&quot;},{&quot;side&quot;:&quot;CloseLong&quot;,&quot;placedTime&quot;:&quot;2019-09-19T06:15:00Z&quot;,&quot;placedAmount&quot;:0.10000000,&quot;filledTime&quot;:&quot;2019-09-19T06:15:00Z&quot;,&quot;filledAmount&quot;:0.10000000,&quot;filledPrice&quot;:9865.79000000,&quot;commissionPaid&quot;:0.39463160,&quot;source&quot;:&quot;SIGNAL&quot;}]},{&quot;tradeNo&quot;:2,&quot;profit&quot;:-5.04965308,&quot;profitPercentage&quot;:-0.00511770,&quot;accumulatedBalance&quot;:985.93462727,&quot;compoundProfitPerc&quot;:-0.01406537,&quot;orders&quot;:[{&quot;side&quot;:&quot;Long&quot;,&quot;placedTime&quot;:&quot;2019-09-25T10:15:00Z&quot;,&quot;placedAmount&quot;:0.11700000,&quot;filledTime&quot;:&quot;2019-09-25T10:15:00Z&quot;,&quot;filledAmount&quot;:0.11700000,&quot;filledPrice&quot;:8430.00000000,&quot;commissionPaid&quot;:0.39452400,&quot;source&quot;:&quot;SIGNAL&quot;},{&quot;side&quot;:&quot;CloseLong&quot;,&quot;placedTime&quot;:&quot;2019-09-25T10:30:00Z&quot;,&quot;placedAmount&quot;:0.11700000,&quot;filledTime&quot;:&quot;2019-09-25T10:30:00Z&quot;,&quot;filledAmount&quot;:0.11700000,&quot;filledPrice&quot;:8393.57000000,&quot;commissionPaid&quot;:0.39281908,&quot;source&quot;:&quot;SIGNAL&quot;}]}\r\n```",
        "link": "https://stackoverflow.com/questions/70092053/bash-script-with-jq-wont-get-date-difference-from-strings-and-runs-quite-slowly",
        "title": "Bash script with jq wont get date difference from strings, and runs quite slowly on i7 16GB RAM"
    },
    {
        "tags": [
            "linux",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637742772,
                "creation_date": 1637742772,
                "answer_id": 70092876,
                "question_id": 70092405,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the JSON from the curl call, the query:\r\n```\r\njq &#39;.value.timeSeries[].values[].value[].value&#39;\r\n```\r\nreturns 9,029 values.  It&#39;s hard to know which ones you&#39;re interested in.  If you wish further assistance, it would help if you could follow the http://stackoverflow.com/help/mcve (aka &quot;mcve&quot;) guidelines.\r\n",
                "title": "Error message &quot;Cannot index array with string &quot;value&quot; &quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637742772,
        "creation_date": 1637740386,
        "question_id": 70092405,
        "body_markdown": "I am trying to produce a plot of water temperatures from this website: https://waterservices.usgs.gov/nwis/dv/?sites=04092440&amp;format=json&amp;period=P520W\r\n\r\nI was able to  get the first value using the following commands: \r\n\r\n```\r\ncurl &quot;https://waterservices.usgs.gov/nwis/dv/?sites=04092440&amp;format=json&amp;period=P520W&quot; | jq .&#39;value.timeSeries[3].values[0].value[0].value&#39;\r\n```\r\n\r\nHowever there are total 478 values. I am wondering how can I print all the values. Thank you! \r\n\r\n\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/70092405/error-message-cannot-index-array-with-string-value",
        "title": "Error message &quot;Cannot index array with string &quot;value&quot; &quot;"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637756135,
                "post_id": 70095177,
                "comment_id": 123910100,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1637765192,
                "last_edit_date": 1637765192,
                "creation_date": 1637764117,
                "answer_id": 70097873,
                "question_id": 70095177,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, you can add line breaks and remove  `. |`\r\n\r\n```jq\r\n[\r\n   .id,\r\n   .meta.lastUpdated,\r\n   .identifier[0].use,\r\n   .identifier[0].system,\r\n   .identifier[0].value,\r\n   .identifier[1].use,\r\n   .identifier[1].system,\r\n   .identifier[1].value,\r\n   .identifier[2].use,\r\n   .identifier[2].system,\r\n   .identifier[2].value,\r\n   .identifier[2].assigner.reference,\r\n   .active,\r\n   .name[0].use,\r\n   .name[0].text,\r\n   .name[0].given[0],\r\n   .name[0].family,\r\n   .name[0]._family.extension[0].valueString,\r\n   .address[0].extension[0].valueString,\r\n   .address[0].type,\r\n   ( .address[0].line[]? | select( contains( &quot;TV^&quot;  ) ) | split( &quot;^&quot; )[1] ) // null,\r\n   ( .address[0].line[]? | select( contains( &quot;NV^&quot;  ) ) | split( &quot;^&quot; )[1] ) // null,\r\n   ( .address[0].line[]? | select( contains( &quot;NVI^&quot; ) ) | split( &quot;^&quot; )[1] ) // null,\r\n   .address[0].city,\r\n   .address[0].state,\r\n   .address[0].postalCode,\r\n   .address[0].country,\r\n   .qualification[0].code.coding[0].system,\r\n   .qualification[0].code.coding[0].code\r\n] | @csv\r\n```\r\n\r\nWe can also move the address line searching logic into a function. With the code isolated, it&#39;s easier to make it better. In the process, I improved it to split first, and to handle multiple matching lines better. (You may need to adjust the select`.)\r\n\r\n```jq\r\ndef addr_special_field($field):\r\n   [ .line[]? | split(&quot;^&quot;) | select( .[0] == $field ) ] | .[0][1]?;\r\n\r\n[\r\n   .id,\r\n   .meta.lastUpdated,\r\n   .identifier[0].use,\r\n   .identifier[0].system,\r\n   .identifier[0].value,\r\n   .identifier[1].use,\r\n   .identifier[1].system,\r\n   .identifier[1].value,\r\n   .identifier[2].use,\r\n   .identifier[2].system,\r\n   .identifier[2].value,\r\n   .identifier[2].assigner.reference,\r\n   .active,\r\n   .name[0].use,\r\n   .name[0].text,\r\n   .name[0].given[0],\r\n   .name[0].family,\r\n   .name[0]._family.extension[0].valueString,\r\n   .address[0].extension[0].valueString,\r\n   .address[0].type,\r\n   ( .address[0] | addr_special_field( &quot;TV&quot;  ) ),\r\n   ( .address[0] | addr_special_field( &quot;NV&quot;  ) ),\r\n   ( .address[0] | addr_special_field( &quot;NVI&quot; ) ),\r\n   .address[0].city,\r\n   .address[0].state,\r\n   .address[0].postalCode,\r\n   .address[0].country,\r\n   .qualification[0].code.coding[0].system,\r\n   .qualification[0].code.coding[0].code\r\n] | @csv\r\n```\r\n\r\nThis is long, but at least it&#39;s readable. Another thing we could do is factor out common terms, though I&#39;m not sure it truly helps.\r\n\r\n```jq\r\ndef addr_special_field($field):\r\n   [ .line[]? | split(&quot;^&quot;) | select( .[0] == $field ) ] | .[0][1]?;\r\n\r\n[\r\n   .id,\r\n   .meta.lastUpdated,\r\n   ( .identifier[0] | .use, .system, .value ),\r\n   ( .identifier[1] | .use, .system, .value ),\r\n   ( .identifier[2] | .use, .system, .value, .assigner.reference ),\r\n   .active,\r\n   ( .name[0] | .use, .text, .given[0], .family, ._family.extension[0].valueString ),\r\n   ( .address[0] |\r\n      .extension[0].valueString,\r\n      .type,\r\n      addr_special_field( &quot;TV&quot;  ),\r\n      addr_special_field( &quot;NV&quot;  ),\r\n      addr_special_field( &quot;NVI&quot; ),\r\n      .city,\r\n      .state,\r\n      .postalCode,\r\n      .country\r\n   ),\r\n   ( .qualification[0].code.coding[0] | .system, .code )\r\n] | @csv\r\n```\r\n\r\n",
                "title": "jq: tidy up mapping expression"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637765192,
        "creation_date": 1637752905,
        "question_id": 70095177,
        "body_markdown": "My `jq` extract expression is getting too much large and I&#39;m getting unconfortable using it:\r\n\r\n```\r\njq -r &#39;[.id,.meta.lastUpdated,.identifier[0].use, .identifier[0].system, .identifier[0].value, .identifier[1].use, .identifier[1].system, .identifier[1].value, .identifier[2].use, .identifier[2].system, .identifier[2].value, .identifier[2].assigner.reference, .active, .name[0].use, .name[0].text, .name[0].given[0], .name[0].family, .name[0]._family.extension[0].valueString, .address[0].extension[0].valueString, .address[0].type, (.address[0].line[]? | select(. | contains(&quot;TV^&quot;)) | split(&quot;^&quot;)[1]) // null, (.address[0].line[]? | select(. | contains(&quot;NV^&quot;)) | split(&quot;^&quot;)[1]) // null, (.address[0].line[]? | select(. | contains(&quot;NVI^&quot;)) | split(&quot;^&quot;)[1]) // null, .address[0].city, .address[0].state, .address[0].postalCode, .address[0].country, .qualification[0].code.coding[0].system, .qualification[0].code.coding[0].code] | @csv&#39; practitioners-pre.json &gt; practitioners-pre.csv\r\n```\r\n\r\nIs there any way tidy it up a bit?",
        "link": "https://stackoverflow.com/questions/70095177/jq-tidy-up-mapping-expression",
        "title": "jq: tidy up mapping expression"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637769717,
                "post_id": 70098897,
                "comment_id": 123916030,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637771373,
                "post_id": 70098897,
                "comment_id": 123916691,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19279387,
                    "reputation": 25,
                    "user_id": 14091692,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e1b5cfc57dd9ccee78d1e2479b8597ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "GavinD",
                    "link": "https://stackoverflow.com/users/14091692/gavind"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637771407,
                "post_id": 70098897,
                "comment_id": 123916710,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19279387,
                    "reputation": 25,
                    "user_id": 14091692,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e1b5cfc57dd9ccee78d1e2479b8597ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "GavinD",
                    "link": "https://stackoverflow.com/users/14091692/gavind"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637771573,
                "post_id": 70098897,
                "comment_id": 123916779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19279387,
                    "reputation": 25,
                    "user_id": 14091692,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e1b5cfc57dd9ccee78d1e2479b8597ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "GavinD",
                    "link": "https://stackoverflow.com/users/14091692/gavind"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637772277,
                "post_id": 70098897,
                "comment_id": 123917091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637773323,
                "post_id": 70098897,
                "comment_id": 123917538,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1637826370,
                "creation_date": 1637826370,
                "answer_id": 70107418,
                "question_id": 70098897,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First things first.\r\n\r\nSince you seem to be having trouble on several fronts , I would suggest that you first get your jq query working the way you want \r\nby using jq with the -f command-line option.  That way, you can write your query without having to worry about\r\nWindows rules for escaping characters on the command line.  When the results are as you wish, you might even to decide to\r\nleave well-enough alone.\r\n\r\nNext, to obtain the values you want, it would seem you will want a jq query like this:\r\n```\r\n.Result | first(.[].ItemTitle), first(.[].Artists[])\r\n```\r\n\r\nWith your JSON, this produces:\r\n```\r\nSometimes It Hurts\r\nVoost\r\n```\r\n\r\nBut you say you want these values in the KEY=VALUE form.  This can be achieved by modifying the basic query, e.g. as follows:\r\n```\r\n.Result|&quot;ItemTitle=\\(first(.[].ItemTitle))&quot;, &quot;Artist=\\(first(.[].Artists[]))&quot;\r\n```\r\n\r\nSomehow I doubt this is really what you want, but the rest should be clear sailing.\r\n",
                "title": "jq-win64.exe: Parsing data from a JSON file in Windows Batch File"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637826370,
        "creation_date": 1637768316,
        "last_edit_date": 1637769681,
        "question_id": 70098897,
        "body_markdown": "I have the following JSON file (song.json) that contains:\r\n\r\n```json\r\n{\r\n  &quot;Result&quot;: [\r\n    {\r\n      &quot;ItemTitle&quot;: &quot;Sometimes It Hurts&quot;,\r\n      &quot;Artists&quot;: [\r\n        &quot;Voost&quot;\r\n      ],\r\n      &quot;MediaEnd&quot;: &quot;00:02:15.8490000&quot;,\r\n      &quot;Extro&quot;: &quot;00:02:12.8200000&quot;,\r\n      &quot;MediaId&quot;: 9551,\r\n      &quot;ActualLength&quot;: &quot;00:02:12.8200000&quot;,\r\n      &quot;ItemType&quot;: &quot;Song&quot;\r\n    },\r\n    {\r\n      &quot;ItemTitle&quot;: &quot;Been a Long Time (Full Intention 2021 Remix)&quot;,\r\n      &quot;Artists&quot;: [\r\n        &quot;The Fog&quot;\r\n      ],\r\n      &quot;MediaEnd&quot;: &quot;00:03:11.3170000&quot;,\r\n      &quot;IntroEnd&quot;: &quot;00:00:07.4700000&quot;,\r\n      &quot;Extro&quot;: &quot;00:03:08.6300000&quot;,\r\n      &quot;MediaId&quot;: 9489,\r\n      &quot;ActualLength&quot;: &quot;00:03:08.6300000&quot;,\r\n      &quot;ItemType&quot;: &quot;Song&quot;\r\n    }\r\n  ],\r\n  &quot;ExceptionMessage&quot;: null,\r\n  &quot;FailMessage&quot;: null,\r\n  &quot;ExceptionTypeName&quot;: null\r\n}\r\n```\r\n\r\nI want to extract the first “ItemTitle” and the first “Artist” and save them as variables. \r\n\r\nIn this example the result I am looking for would be:\r\n```\r\nItemTitle=Sometimes It Hurts\r\n\r\nArtist=Voost\r\n```\r\nI have been trying to use jq-win64.exe as this needs to run in a Windows Batch File, but I can’t get the syntax right. I have tried various examples that I have found on here but none of them appears to work as required. Can anyone suggest a solution?\r\n",
        "link": "https://stackoverflow.com/questions/70098897/jq-win64-exe-parsing-data-from-a-json-file-in-windows-batch-file",
        "title": "jq-win64.exe: Parsing data from a JSON file in Windows Batch File"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 23,
                "is_accepted": true,
                "score": 23,
                "last_activity_date": 1637776306,
                "last_edit_date": 1637776306,
                "creation_date": 1637775726,
                "answer_id": 70100645,
                "question_id": 70100534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are looking to print only those specific fields on the first 3 results, use the [slice operator][1]. See [jqplay][2] for demo\r\n\r\n```none\r\n.identifier[:3] | map({system, value})\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15]\r\n  [2]: https://jqplay.org/s/hVs5QdWWLt",
                "title": "jq: get first n elements of an array field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 19,
        "last_activity_date": 1720534464,
        "creation_date": 1637775253,
        "last_edit_date": 1720534464,
        "question_id": 70100534,
        "body_markdown": "I&#39;m getting some issues trying to get only firsts 3 elements of an array:\r\n\r\njson is like this:\r\n\r\n```lang-json\r\n{\r\n   &quot;resourceType&quot;:&quot;Practitioner&quot;,\r\n   &quot;id&quot;:&quot;328001&quot;,\r\n   &quot;meta&quot;:{\r\n      &quot;versionId&quot;:&quot;1&quot;,\r\n      &quot;lastUpdated&quot;:&quot;2021-11-08T12:47:51.239+01:00&quot;,\r\n      &quot;source&quot;:&quot;#BUkX5uagwf3PcHzd&quot;\r\n   },\r\n   &quot;identifier&quot;:[\r\n      {\r\n         &quot;use&quot;:&quot;official&quot;,\r\n         &quot;system&quot;:&quot;urn:oid:1.3.6.1.4.1.19126.3&quot;,\r\n         &quot;value&quot;:&quot;00396185X&quot;\r\n      },\r\n      {\r\n         &quot;use&quot;:&quot;official&quot;,\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.10.2&quot;,\r\n         &quot;value&quot;:&quot;0831515&quot;\r\n      },\r\n      {\r\n         &quot;use&quot;:&quot;official&quot;,\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.10.2&quot;,\r\n         &quot;value&quot;:&quot;0831515&quot;\r\n      },\r\n      {\r\n         &quot;use&quot;:&quot;official&quot;,\r\n         &quot;system&quot;:&quot;urn:oid:2.16.724.4.9.10.2&quot;,\r\n         &quot;value&quot;:&quot;0831515&quot;\r\n      }\r\n   ],\r\n   &quot;active&quot;:true,\r\n   &quot;name&quot;:[\r\n      {\r\n         &quot;use&quot;:&quot;official&quot;,\r\n         &quot;text&quot;:&quot;JULIAN RODRIGUEZ LARREA&quot;,\r\n         &quot;family&quot;:&quot;RODRIGUEZ&quot;,\r\n         &quot;_family&quot;:{\r\n            &quot;extension&quot;:[\r\n               {\r\n                  &quot;url&quot;:&quot;http://hl7.org/fhir/StructureDefinition/humanname-mothers-family&quot;,\r\n                  &quot;valueString&quot;:&quot;LARREA&quot;\r\n               }\r\n            ]\r\n         },\r\n         &quot;given&quot;:[\r\n            &quot;JULIAN&quot;\r\n         ]\r\n      }\r\n   ],\r\n   &quot;qualification&quot;:[\r\n      {\r\n         &quot;code&quot;:{\r\n            &quot;coding&quot;:[\r\n               {\r\n                  &quot;system&quot;:&quot;urn:oid:2.16.840.1.113883.6.96&quot;,\r\n                  &quot;code&quot;:&quot;62247001&quot;\r\n               }\r\n            ]\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nIs there any way to get only first 3 elements od `.identifier`?\r\n\r\n    jq -r &#39;(.identifier[] | .system, .value)&#39;\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70100534/jq-get-first-n-elements-of-an-array-field",
        "title": "jq: get first n elements of an array field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1637801527,
                "last_edit_date": 1637801527,
                "creation_date": 1637800704,
                "answer_id": 70104574,
                "question_id": 70104513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[][0:-1]` gets you far, just missing the surrounding array in the output.\r\n\r\nEDIT: `[.[][:-1]]` should do it.",
                "title": "recreate array with all items but the last"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1637801527,
        "creation_date": 1637799942,
        "question_id": 70104513,
        "body_markdown": "Given the following:\r\n\r\n**Input:**\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;type&quot;: &quot;strip&quot;,\r\n      &quot;output&quot;: &quot;debian-7-x86_64-strip&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;compress&quot;,\r\n      &quot;output&quot;: &quot;debian-7-x86_64-compress&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;full&quot;,\r\n      &quot;output&quot;: &quot;debian-7-x86_64&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;type&quot;: &quot;strip&quot;,\r\n      &quot;output&quot;: &quot;debian-8-strip&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;compress&quot;,\r\n      &quot;output&quot;: &quot;debian-8-compress&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\nHow to recreate the array with the last object item (from each sub-array) removed?\r\n\r\n**Desired Output:**\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;type&quot;: &quot;strip&quot;,\r\n      &quot;output&quot;: &quot;debian-7-x86_64-strip&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;compress&quot;,\r\n      &quot;output&quot;: &quot;debian-7-x86_64-compress&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;type&quot;: &quot;strip&quot;,\r\n      &quot;output&quot;: &quot;debian-8-strip&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\nI&#39;ve tried using things like `... |= .[:-1]` and `...[to_entries | last]`, and `... | select(last|not)` but I&#39;m having no success.\r\n\r\nMany thanks for the help.",
        "link": "https://stackoverflow.com/questions/70104513/recreate-array-with-all-items-but-the-last",
        "title": "recreate array with all items but the last"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1637834109,
                "post_id": 70108930,
                "comment_id": 123933399,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637834159,
                "post_id": 70108930,
                "comment_id": 123933428,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637834438,
                "post_id": 70108930,
                "comment_id": 123933542,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1637834063,
                "creation_date": 1637834063,
                "answer_id": 70109013,
                "question_id": 70108930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You would use the -n command-line option, e.g.:\r\n\r\n    jq -n input\r\n\r\nor\r\n\r\n    jq -n &#39;first(inputs)&#39;",
                "title": "How to parse json objects not array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1637834649,
        "creation_date": 1637833682,
        "last_edit_date": 1637834649,
        "question_id": 70108930,
        "body_markdown": "For example:\r\n\r\n    echo &#39;{&quot;p&quot;:2}{&quot;q&quot;:3}&#39; | jq &#39;.&#39;\r\n\r\nHow do I select the first object? I want the object below:\r\n\r\n    {&quot;p&quot;:2}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70108930/how-to-parse-json-objects-not-array-using-jq",
        "title": "How to parse json objects not array using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637852497,
                "post_id": 70112581,
                "comment_id": 123940821,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1637850298,
                "creation_date": 1637850298,
                "answer_id": 70112745,
                "question_id": 70112581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following `jq` should give you the desired result -\r\n\r\n```\r\njq -r &#39;def groups(d): if d | length &gt; 0 then d | map(.name) | join(&quot;,&quot;) else &quot;-&quot; end; map(&quot;\\(.user)     \\(.id)     \\(groups(.groups))&quot;) | .[]&#39;\r\n```\r\n\r\n\r\n```\r\nu1     0001     -\r\nu2     0002     G1,G2\r\nu3     0003     G1\r\n```\r\n",
                "title": "jq: print &quot;-&quot; for objects which don&#39;t have a specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637850298,
        "creation_date": 1637849597,
        "question_id": 70112581,
        "body_markdown": "I have following json:\r\n\r\n    [\r\n      {\r\n        &quot;user&quot;: &quot;u1&quot;,\r\n        &quot;id&quot;: &quot;0001&quot;\r\n      },\r\n      {\r\n        &quot;user&quot;: &quot;u2&quot;,\r\n        &quot;id&quot;: &quot;0002&quot;,\r\n        &quot;groups&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;100001&quot;,\r\n            &quot;name&quot;: &quot;G1&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;100002&quot;,\r\n            &quot;name&quot;: &quot;G2&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;user&quot;: &quot;u3&quot;,\r\n        &quot;id&quot;: &quot;0003&quot;,\r\n        &quot;groups&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;100001&quot;,\r\n            &quot;name&quot;: &quot;G1&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nExpected output is:\r\n\r\n    u1      0001    -\r\n    u2      0002    G1,G2\r\n    u3      0003    G1\r\n\r\n\r\nI have following jq command:\r\n\r\n    jq -r &#39;map(select(.groups[].id)?)| map([.user, .id, ([.groups[].name]|join(&quot;,&quot;))] | join(&quot;\\t&quot;)) | join(&quot;\\n&quot;)&#39; json\r\n\r\nwhich produces:\r\n\r\n    u2      0002    G1,G2\r\n    u2      0002    G1,G2\r\n    u3      0003    G1\r\n\r\nHow to have on output also objects having no of the *groups* keys and avoid duplicates as showed above?\r\n",
        "link": "https://stackoverflow.com/questions/70112581/jq-print-for-objects-which-dont-have-a-specific-key",
        "title": "jq: print &quot;-&quot; for objects which don&#39;t have a specific key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1637870995,
                "post_id": 70116658,
                "comment_id": 123946977,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7564361,
                    "reputation": 635,
                    "user_id": 5740734,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4bea46c8d17ca80492001e8f725c0cd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mocart",
                    "link": "https://stackoverflow.com/users/5740734/mocart"
                },
                "reply_to_user": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1637873906,
                "post_id": 70116658,
                "comment_id": 123947703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1,
                "creation_date": 1637878824,
                "post_id": 70116658,
                "comment_id": 123948739,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1637880997,
                "creation_date": 1637880997,
                "answer_id": 70118051,
                "question_id": 70116658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the working solution:\r\n```\r\njq &#39;.ssh_key | {id}&#39;\r\n```\r\nwhich outputs:\r\n```\r\n{\r\n  &quot;id&quot;: 123\r\n}\r\n```",
                "title": "print json object like {key:value} by jq utiliity"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1637880997,
        "creation_date": 1637870449,
        "last_edit_date": 1637878849,
        "question_id": 70116658,
        "body_markdown": "i have json:\r\n\r\n    {\r\n      &quot;ssh_key&quot;: \r\n        {\r\n          &quot;id&quot;: 123,\r\n          &quot;public_key&quot;: &quot;ssh-rsa 1233123333333333333dafseg345345345&quot;,\r\n          &quot;name&quot;: &quot;MY.PUB.KEY&quot;,\r\n          &quot;fingerprint&quot;: &quot;94:45:54:22:3f:55:ff:55&quot;\r\n        }\r\n    }\r\n\r\ni can&#39;t print only 1 object **{&quot;id&quot;:123}** with jq, i tryed like this:\r\n\r\n    jq &#39;.ssh_key | to_entries[] | {&quot;id&quot;: .key, &quot;value&quot;: .value.id}&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index number with string &quot;id&quot;",
        "link": "https://stackoverflow.com/questions/70116658/print-json-object-like-keyvalue-by-jq-utiliity",
        "title": "print json object like {key:value} by jq utiliity"
    },
    {
        "tags": [
            "json",
            "jq",
            "couchbase",
            "couchbase-java-api"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1638429886,
                "creation_date": 1638429886,
                "answer_id": 70195504,
                "question_id": 70134550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the cbq command, you can use the --quiet option to disable the startup connection messages and the --pretty=false to disable pretty-print.  Then, to extract just the documents in cbimport json lines format, I used jq.\r\n\r\nThis worked for me -- selecting documents from travel-sample._default._default (for the jq filter, where I have _default, you would put the Bucket-name, based on your example):\r\n```\r\ncbq --quiet --pretty=false -u Administrator -p password --script=&#39;select * from `travel-sample`._default._default&#39; | jq --compact-output &#39;.results|.[]|._default&#39; &gt; docs.json\r\n```\r\n\r\nThen, importing into test-bucket1:\r\n```\r\ncbimport json -c localhost -u Administrator -p password -b test-bucket1 -d file://./docs.json -f lines -g %type%_%id%\r\n```\r\n\r\ncbq documentation: https://docs.couchbase.com/server/current/tools/cbq-shell.html\r\n\r\ncbimport documentation: https://docs.couchbase.com/server/current/tools/cbimport-json.html\r\n\r\njq documentation:\r\nhttps://stedolan.github.io/jq/manual/#Basicfilters",
                "title": "cbimport not importing file which is extracted from cbq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1638429886,
        "creation_date": 1638014188,
        "last_edit_date": 1638187530,
        "question_id": 70134550,
        "body_markdown": "I tried to extract data from below [cbq][1] command which was successful.\r\n\r\n```cbq -u Administrator -p Administrator -e &quot;http://localhost:8093&quot; --script= SELECT * FROM `sample` where customer.id==&quot;12345&#39;&quot; -q | jq &#39;.results&#39; &gt; temp.json;```\r\n\r\nHowever when I am trying to import the same data in json format to target cluster using below command I am getting error.\r\n\r\n```cbimport json -c http://{target-cluster}:8091 -u Administrator -p Administrator  -b sample -d file://C:\\Users\\{myusername}\\Desktop\\temp.json -f list -g %docId%```\r\n\r\n```\r\nJSON import failed: 0 documents were imported, 0 documents failed to be imported\r\nJSON import failed: input json is invalid: ReadArray: expect [ or , or ] or n, but found {, error found in #1 byte of ...|{\r\n    &quot;requ|..., bigger context ...|{\r\n    &quot;requestID&quot;: &quot;2fc34542-4387-4643-8ae3-914e316|...],```\r\n\r\n    ```{\r\n    &quot;requestID&quot;: &quot;6ef38b8a-8e70-4c3d-b3b4-b73518a09c62&quot;,\r\n    &quot;signature&quot;: {\r\n        &quot;*&quot;: &quot;*&quot;\r\n    },\r\n    &quot;results&quot;: [\r\n    {\r\n        &quot;{Bucket-name}&quot;:{my-data}\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;metrics&quot;: {\r\n        &quot;elapsedTime&quot;: &quot;4.517031ms&quot;,\r\n        &quot;executionTime&quot;: &quot;4.365976ms&quot;,\r\n        &quot;resultCount&quot;: 1,\r\n        &quot;resultSize&quot;: 24926\r\n    }\r\n```\r\n\r\nIt looks like the file which was extracted from cbq command has control fields details like **RequestID, metrics, status etc**. Also json in pretty format. If I manually remove it(remove all fields except {my-data}) then put in a json file and make json unpretty then it works. But I want to automate it in a single run. Is there a way to do it in **cbq command**.\r\n\r\nI don&#39;t find any other utility or way to use **where** condition on [cbexport][2] to do that on Couchbase, because the document which are exported using cbexport can be imported using [cbimport][3] easily.\r\n\r\n\r\n  [1]: https://docs.couchbase.com/server/current/tools/cbq-shell.html\r\n  [2]: https://docs.couchbase.com/server/current/tools/cbexport-json.html\r\n  [3]: https://docs.couchbase.com/server/current/tools/cbimport-json.html",
        "link": "https://stackoverflow.com/questions/70134550/cbimport-not-importing-file-which-is-extracted-from-cbq-command",
        "title": "cbimport not importing file which is extracted from cbq command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638022731,
                "creation_date": 1638022731,
                "answer_id": 70135581,
                "question_id": 70135560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use double quotes for keys that contain non-alphanumeric characters:\r\n\r\n    .results[0].&quot;com.src.main.client.details&quot;",
                "title": "jq parsing complex json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638022731,
        "creation_date": 1638022460,
        "question_id": 70135560,
        "body_markdown": "I need to parse the below complex json and output the result to a file. I was able to parse the .result object. however I need to parse the list &quot;com.src.main.client.details&quot; and pipe it to another file. \r\n\r\nI tried below command but it fails.\r\n\r\n$&gt; `jq &quot;.result[0].com.src.main.client.details&quot; temp.json &gt; result.json`\r\n\r\n`null`\r\n\r\ncan someone please assist me here.\r\n\r\n```\r\n&quot;results&quot;: [\r\n{&quot;com.src.main.client.details&quot;:{\r\n  &quot;doc&quot;: &quot;string&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;amount&quot;: null,\r\n      &quot;output&quot;: null,\r\n     &quot;properties&quot;: [\r\n     {\r\n     &quot;characteristic&quot;: [],\r\n     &quot;component&quot;: null,\r\n     &quot;period&quot;: null,\r\n     &quot;internals&quot;: {\r\n     &quot;Currency&quot;: &quot;EUR&quot;,\r\n     &quot;value&quot;: 0\r\n   }\r\n  }\r\n }```",
        "link": "https://stackoverflow.com/questions/70135560/jq-parsing-complex-json",
        "title": "jq parsing complex json"
    },
    {
        "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": 1638083444,
                "post_id": 70138230,
                "comment_id": 123989630,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1638043269,
                "creation_date": 1638043269,
                "answer_id": 70138275,
                "question_id": 70138230,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `tostring` (or the `@text`) builtin to convert into a string:\r\n```\r\njq &#39;.ssh_key | .id |= tostring&#39;\r\n```\r\n```\r\n{\r\n  &quot;id&quot;: &quot;123&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/78ZJQuFRfE)",
                "title": "print all json objects as string using jq utility"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1638105974,
        "creation_date": 1638042862,
        "last_edit_date": 1638105974,
        "question_id": 70138230,
        "body_markdown": "I have a JSON value:\r\n```json\r\n{\r\n  &quot;ssh_key&quot;: {\r\n    &quot;id&quot;: 123\r\n  }\r\n}\r\n```\r\nHow i can print **id object** by jq utility **as string**? Object value must be (with double quotas):\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;123&quot;\r\n}\r\n```\r\nI use  `jq &#39;.ssh_key | {id}` command for print without double quotes now.\r\n\r\nThanks.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70138230/print-all-json-objects-as-string-using-jq-utility",
        "title": "print all json objects as string using jq utility"
    },
    {
        "tags": [
            "json",
            "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": 1638116989,
                "post_id": 70145294,
                "comment_id": 123996538,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1645598,
                    "reputation": 1671,
                    "user_id": 1517187,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ah2AhA8J.png?s=256",
                    "display_name": "Patlatus",
                    "link": "https://stackoverflow.com/users/1517187/patlatus"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638117057,
                "post_id": 70145294,
                "comment_id": 123996559,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638119312,
                "creation_date": 1638119312,
                "answer_id": 70145682,
                "question_id": 70145294,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think I got it.\r\n\r\nI need to pass the strings as argument and then split it by comma and unbracket them like this:\r\n\r\n    classes=$(./getClasses.sh)\r\n    echo $(cat tests.json) | jq --arg classes $classes &#39;.result.coverage.coverage[] | select(.name == ($classes | split(&quot;,&quot;)[])) | .totalLines&#39; | awk &#39;{s+=$1} END {print s}&#39;",
                "title": "jq select object whose key value in the list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638121672,
                "last_edit_date": 1638121672,
                "creation_date": 1638121451,
                "answer_id": 70145959,
                "question_id": 70145294,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option using `inside()` &lt;sup&gt;\\[[docs][1]]&lt;/sup&gt; to check if `.name` exist in an array.\r\n\r\nThe array is build using: `&quot;ApexClass1,AapexClass2&quot; | split(&quot;,&quot;)` &lt;sup&gt;\\[[docs](https://stedolan.github.io/jq/manual/#example60)]&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\n```\r\njq &#39;[ .result.coverage.coverage[] | select([ .name ] | inside(&quot;ApexClass1,AapexClass2&quot; | split(&quot;,&quot;) ) ) | . ]&#39; tests.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;ApexClass1&quot;,\r\n    &quot;totalLines&quot;: 25,\r\n    &quot;lines&quot;: {},\r\n    &quot;totalCovered&quot;: 23,\r\n    &quot;coveredPercent&quot;: 92\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;ApexClass2&quot;,\r\n    &quot;totalLines&quot;: 25,\r\n    &quot;lines&quot;: {},\r\n    &quot;totalCovered&quot;: 23,\r\n    &quot;coveredPercent&quot;: 92\r\n  }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n##### [Online JqPlay Demo](https://jqplay.org/s/0_xLXGefhd)\r\n\r\n\r\n----------\r\n\r\nLocal demo:\r\n```none\r\n➜  find=&quot;ApexClass1,ApexClass3&quot;\r\n➜ \r\n➜  jq --arg find $find &#39;[ .result.coverage.coverage[] | select([ .name ] | inside($find | split(&quot;,&quot;) ) ) | . ]&#39; tests.json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;ApexClass1&quot;,\r\n    &quot;totalLines&quot;: 25,\r\n    &quot;lines&quot;: {},\r\n    &quot;totalCovered&quot;: 23,\r\n    &quot;coveredPercent&quot;: 92\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;ApexClass3&quot;,\r\n    &quot;totalLines&quot;: 25,\r\n    &quot;lines&quot;: {},\r\n    &quot;totalCovered&quot;: 23,\r\n    &quot;coveredPercent&quot;: 92\r\n  }\r\n]\r\n➜ \r\n```\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example52",
                "title": "jq select object whose key value in the list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1638121672,
        "creation_date": 1638116323,
        "last_edit_date": 1638117043,
        "question_id": 70145294,
        "body_markdown": "I have one script `./getClasses.sh` which returns comma separated list like `ApexClass1,ApexClass2`. There are more than two items in this list.\r\n\r\nI want to use that list in `jq` to filter out JSON values by a certain key value, which coincides with one value from the list\r\n\r\nI tried `in` operator \r\n\r\n    echo $(cat tests.json) | jq &#39;.result.coverage.coverage[] | select(.name included($(./getClasses.sh)))&#39;  \r\n\r\nand `includes` operator \r\n\r\n    echo $(cat tests.json) | jq &#39;.result.coverage.coverage[] | select(.name in($(./getClasses.sh)))&#39; \r\n\r\nbut both of them are failing with en error\r\n\r\n    jq: error: syntax error, unexpected IDENT, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nFile `tests.json` contains a following JSON\r\n\r\n    {&quot;status&quot;: 0,\r\n      &quot;result&quot;: {\r\n        &quot;summary&quot;: {\r\n          &quot;outcome&quot;: &quot;Passed&quot;,\r\n          &quot;testsRan&quot;: 13,\r\n          &quot;passing&quot;: 13,\r\n          &quot;failing&quot;: 0,\r\n          &quot;skipped&quot;: 0,\r\n          &quot;passRate&quot;: &quot;100%&quot;,\r\n          &quot;failRate&quot;: &quot;0%&quot;}, &quot;tests&quot;: [], &quot;coverage&quot;: {\r\n          &quot;coverage&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;ApexClass1&quot;,\r\n              &quot;totalLines&quot;: 25,\r\n              &quot;lines&quot;: {},\r\n              &quot;totalCovered&quot;: 23,\r\n              &quot;coveredPercent&quot;: 92}, {\r\n              &quot;name&quot;: &quot;ApexClass2&quot;,\r\n              &quot;totalLines&quot;: 25,\r\n              &quot;lines&quot;: {},\r\n              &quot;totalCovered&quot;: 23,\r\n              &quot;coveredPercent&quot;: 92}, {\r\n              &quot;name&quot;: &quot;ApexClass3&quot;,\r\n              &quot;totalLines&quot;: 25,\r\n              &quot;lines&quot;: {},\r\n              &quot;totalCovered&quot;: 23,\r\n              &quot;coveredPercent&quot;: 92}\r\n          ],\r\n          &quot;records&quot;: []\r\n        } } }\r\n\r\nHow can I achieve the desired output?",
        "link": "https://stackoverflow.com/questions/70145294/jq-select-object-whose-key-value-in-the-list",
        "title": "jq select object whose key value in the list"
    },
    {
        "tags": [
            "string",
            "bash",
            "compare",
            "jq",
            "carriage-return"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638118552,
                "post_id": 70145572,
                "comment_id": 123996957,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638118775,
                "post_id": 70145572,
                "comment_id": 123997007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15435872,
                    "reputation": 19,
                    "user_id": 11135997,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9626cb61f155e0627ce5efd2cb725951?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "flow",
                    "link": "https://stackoverflow.com/users/11135997/flow"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638120421,
                "post_id": 70145572,
                "comment_id": 123997406,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15435872,
                    "reputation": 19,
                    "user_id": 11135997,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9626cb61f155e0627ce5efd2cb725951?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "flow",
                    "link": "https://stackoverflow.com/users/11135997/flow"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638121006,
                "post_id": 70145572,
                "comment_id": 123997544,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638122074,
                "post_id": 70145572,
                "comment_id": 123997831,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638122409,
                "creation_date": 1638122409,
                "answer_id": 70146092,
                "question_id": 70145572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seems a behavior of jq with the raw output. each result is in a new line.\r\n\r\nread here:\r\nhttps://github.com/stedolan/jq/issues/787\r\n\r\nActually, in 1.5 it&#39;s already the case that you can use -j to stop newlines being printed, but it does put jq into raw-output mode.\r\n\r\nunfortunately it doesnt solve the problem for me. i need to cut the last charakter out... \r\n\r\nmaybe &quot;hostname=`echo $hostname | tr -d &#39;\\n&#39;`&quot; is a solution for me",
                "title": "the string length of jq output is wrong, and it is impossible to compare"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638641210,
                "last_edit_date": 1638641210,
                "creation_date": 1638125295,
                "answer_id": 70146447,
                "question_id": 70145572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the `dos2unix` utility is available, you can use the following :\r\n\r\n    dos2unix $jsonList # or dos2unix -o &quot;$jsonList&quot; on some versions\r\n    while read -r id; do\r\n        #[...]\r\n    done &lt; &lt;(jq -r &#39;.[] | .id, .serverinfos.hostname | @text&#39; &quot;$jsonlist&quot;)\r\n\r\nOtherwise you can loop over each file of `$jsonList` to remove `\\r`s with `tr`:\r\n\r\n    for file in &quot;$jsonList&quot;; do\r\n        tr -d $&#39;\\r&#39; &gt; &quot;${file}.new&quot; &lt; &quot;${file}&quot;\r\n        mv &quot;${file.new}&quot; &quot;${file}&quot;\r\n    done\r\n    while read -r id; do\r\n        #[...]\r\n    done &lt; &lt;(jq -r &#39;.[] | .id, .serverinfos.hostname | @text&#39; &quot;$jsonlist&quot;)",
                "title": "the string length of jq output is wrong, and it is impossible to compare"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1638641210,
        "creation_date": 1638118339,
        "last_edit_date": 1638122598,
        "question_id": 70145572,
        "body_markdown": "i dont get this problem... maybe someone can help me out :)\r\n\r\ni have a Jsonfile and i read out strings and put it into variables. if i compare these after the loop they never are the same.. the outputs of jq have a hidden charakter or so.. \r\n\r\nExamplecode:\r\n\r\n    while read -r id\r\n    do      \r\n        read -r hostname\r\n        for server in &quot;$serverlist&quot;\r\n        do\r\n            if [[ &quot;$hostname&quot; == &quot;$server&quot; ]]; then\r\n                echo &quot;$hostname&quot;\r\n                echo &quot;$server&quot;\r\n            else\r\n                errorser[$i]=$server\r\n                i=$((i+1))\r\n            fi\r\n        done\r\n    done &lt; &lt;(jq -r &#39;.[] | .id, .serverinfos.hostname | @text&#39; $jsonlist)\r\n\r\n\r\nserverlist is a array with strings of hostnames like &quot;flowmox&quot;.\r\nIf i do a simple size on the string which came out if the jq it shows for the text &quot;flowmox&quot; 8 but it is 7...\r\ncutting is also not possible\r\n\r\n\r\n            echo size=${#hostname} \r\n            hostname=&quot;${hostname##*( )}&quot;\r\n            echo size=${#hostname}\r\n            echo size=&quot;flowmox&quot; \r\n\r\nResult: \r\n\r\n    8\r\n    8\r\n    7\r\n\r\n\r\n\r\nadded part of the jsonfile:\r\n\r\n    [\r\n    {\r\n        &quot;id&quot;:1,\r\n        &quot;childofid&quot;:null,\r\n        &quot;parentofids&quot;:[null],\r\n        &quot;infosupdatedat&quot;:&quot;2021-11-27&quot;,\r\n        &quot;serverinfos&quot;:{\r\n            &quot;hostname&quot;:&quot;flowmox&quot;,\r\n            &quot;description&quot;:&quot;Proxmox - Host for vm&#39;s and more&quot;,\r\n            &quot;status&quot;:&quot;ready&quot;,\r\n            &quot;servertype&quot;:&quot;physisch&quot;,\r\n            &quot;category&quot;:&quot;vm-host&quot;,\r\n            &quot;productname&quot;:&quot;ProLiant DL380 G7&quot;,\r\n            &quot;Model&quot;:&quot;589150-421&quot;,\r\n            &quot;Serialnumber&quot;:&quot;&quot;,\r\n            &quot;managementtype&quot;:&quot;ILO3&quot;\r\n        },\r\n.\r\n.\r\n.\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/70145572/the-string-length-of-jq-output-is-wrong-and-it-is-impossible-to-compare",
        "title": "the string length of jq output is wrong, and it is impossible to compare"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1638170066,
                "last_edit_date": 1638170066,
                "creation_date": 1638168339,
                "answer_id": 70150685,
                "question_id": 70150515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [slice operator][1] to extract the sub-elements of the array inside each field and put into an array and use the `@csv`\r\n\r\n```none\r\n[ .results[][:-1] ] | (first | map(.field)), (.[] | map(.value)) | @csv\r\n```\r\n\r\nThe part `.results[][:-1]` extracts all the elements except the last one in the array. From the manual\r\n\r\n&gt; Either index may be negative (in which case it counts backwards from the end of the array), or omitted (in which case it refers to the start or end of the array).\r\n\r\nSee [jqplay][2] for a working demo.\r\n\r\n---\r\n\r\nI was able to reproduce the bug in jq-1.5. Its a known fact that there are major bugs fixed as part of [release 1.6 in del/1][3]. So consider upgrading to use del/1 or use the slice expression as indicated in the answer above\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.5/#.[%3Cstring%3E],.[2],.[10:15]\r\n  [2]: https://jqplay.org/s/JO3tCc3g_-\r\n  [3]: https://stackoverflow.com/a/63750361/5291015",
                "title": "How to remove last &quot;column&quot; in a hash of an array of array of hashes JSON input using jq 1.5?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1638170066,
        "creation_date": 1638167065,
        "question_id": 70150515,
        "body_markdown": "I want to convert the following JSON content stored in a file tmp.json\r\n\r\n```\r\n{\r\n    &quot;results&quot;: [\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value1-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value1-2&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field3&quot;,\r\n               &quot;value&quot;: &quot;value1-3&quot;\r\n           }\r\n        ],\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value2-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value2-2&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field3&quot;,\r\n               &quot;value&quot;: &quot;value2-3&quot;\r\n           }\r\n        ],\r\n        [\r\n           {\r\n               &quot;field&quot;: &quot;field1&quot;,\r\n               &quot;value&quot;: &quot;value3-1&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field2&quot;,\r\n               &quot;value&quot;: &quot;value3-2&quot;\r\n           },\r\n           {\r\n               &quot;field&quot;: &quot;field3&quot;,\r\n               &quot;value&quot;: &quot;value3-3&quot;\r\n           }\r\n        ]\r\n    ]\r\n}\r\n```\r\n\r\ninto CSV output:\r\n\r\n```\r\n&quot;field1&quot;,&quot;field2&quot;\r\n&quot;value1-1&quot;,&quot;value1-2&quot;\r\n&quot;value2-1&quot;,&quot;value2-2&quot;\r\n&quot;value3-1&quot;,&quot;value3-2&quot;\r\n```\r\n\r\nThe closest jq expression I&#39;ve come up with is this:\r\n\r\n```\r\ncat ./tmp.json | jq -r &#39;.results | [ .[] | del(last) ] | (first | map(.field)), (.[] | map(.value)) | @csv&#39;\r\n```\r\n\r\nIt works for jq version 1.6, but for version 1.5, the last &quot;column&quot; is still included in the CSV result. How do I edit the jq code so that it works for version 1.5?\r\n\r\nNote that the number of columns is not limited to 3; it can be more. The jq code should be able to remove the last column in the final CSV result.",
        "link": "https://stackoverflow.com/questions/70150515/how-to-remove-last-column-in-a-hash-of-an-array-of-array-of-hashes-json-input",
        "title": "How to remove last &quot;column&quot; in a hash of an array of array of hashes JSON input using jq 1.5?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3520895,
                    "reputation": 27048,
                    "user_id": 2943218,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/OoyGW.jpg?s=256",
                    "display_name": "Carsten L&#248;vbo Andersen",
                    "link": "https://stackoverflow.com/users/2943218/carsten-l%c3%b8vbo-andersen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638189921,
                "post_id": 70154852,
                "comment_id": 124013843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638190035,
                "post_id": 70154852,
                "comment_id": 124013888,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 15215053,
                    "reputation": 99,
                    "user_id": 10978665,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e78815140d2e2597d8b72f8a07dbf643?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ben B.",
                    "link": "https://stackoverflow.com/users/10978665/ben-b"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638192459,
                "post_id": 70154852,
                "comment_id": 124015004,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638205667,
                "post_id": 70154852,
                "comment_id": 124020937,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638190537,
                "last_edit_date": 1638190537,
                "creation_date": 1638190235,
                "answer_id": 70154955,
                "question_id": 70154852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input is supposed to be an array of objects (then format it as `[{…},{…},{…}]`), you can use `map` to apply filters or a new formatting onto each element of the array.\r\n\r\nConstruct what you need ([Demo](https://jqplay.org/s/WPomqDD9S-)):\r\n```sh\r\njq &#39;map({id,name,age})&#39; \r\n```\r\nOr remove what you don&#39;t need ([Demo](https://jqplay.org/s/LUusoASVEm)):\r\n```sh\r\njq &#39;map(del(.key1,.key2))&#39; \r\n```\r\nBoth produce:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;name&quot;: &quot;someone&quot;,\r\n    &quot;age&quot;: 39\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;1234&quot;,\r\n    &quot;name&quot;: &quot;someone&quot;,\r\n    &quot;age&quot;: 39\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;4567&quot;,\r\n    &quot;name&quot;: &quot;someone&quot;,\r\n    &quot;age&quot;: 60\r\n  }\r\n]\r\n```",
                "title": "Filtering JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1638205563,
        "creation_date": 1638189809,
        "last_edit_date": 1638205563,
        "question_id": 70154852,
        "body_markdown": "I have a JSON file which contains unneeded values. I want to filter them by only selecting those I need, or deleting those I don&#39;t need. For example, I have this JSON file:\r\n\r\n    {\r\n     { &quot;id&quot;    : &quot;1&quot;,\r\n       &quot;key1&quot;  : &quot;val1&quot;,\r\n       &quot;key2&quot;  : &quot;val2&quot;,\r\n       &quot;name&quot;  : &quot;someone&quot;,\r\n       &quot;age&quot;   : 39,\r\n     },\r\n     { &quot;id&quot;    : &quot;1234&quot;,\r\n       &quot;key1&quot;  : &quot;val1&quot;,\r\n       &quot;key2&quot;  : &quot;val2&quot;,\r\n       &quot;name&quot;  : &quot;someone&quot;,\r\n       &quot;age&quot;   : 39\r\n    },\r\n    { &quot;id&quot;    : &quot;4567&quot;,\r\n      &quot;key1&quot;  : &quot;val1&quot;,\r\n      &quot;key2&quot;  : &quot;val2&quot;,\r\n      &quot;name&quot;  : &quot;someone&quot;,\r\n      &quot;age&quot;   : 60\r\n     }\r\n    }\r\n\r\nMy aim is to get the following JSON, by deleting all key1 and key2 items recursively using a jq command:\r\n\r\n    {\r\n     { &quot;id&quot;    : &quot;1&quot;,\r\n       &quot;name&quot;  : &quot;someone&quot;,\r\n       &quot;age&quot;   : 39,\r\n     },\r\n     { &quot;id&quot;    : &quot;1234&quot;,\r\n       &quot;name&quot;  : &quot;someone&quot;,\r\n       &quot;age&quot;   : 39\r\n    },\r\n    { &quot;id&quot;    : &quot;4567&quot;,\r\n      &quot;name&quot;  : &quot;someone&quot;,\r\n      &quot;age&quot;   : 60\r\n     }\r\n    }\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/70154852/filtering-json-objects-with-jq",
        "title": "Filtering JSON objects with jq"
    },
    {
        "tags": [
            "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": 1,
                "creation_date": 1638270011,
                "post_id": 70168107,
                "comment_id": 124038229,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638270510,
                "post_id": 70168107,
                "comment_id": 124038404,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638271348,
                "post_id": 70168107,
                "comment_id": 124038756,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1638274136,
                "last_edit_date": 1638274136,
                "creation_date": 1638272386,
                "answer_id": 70168763,
                "question_id": 70168107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ### Array/String Slice: `.[10:15]` &lt;sup&gt;[[docs](https://stedolan.github.io/jq/manual/#Array/StringSlice)]&lt;/sup&gt;\r\n&gt;\r\n&gt; ... Either index may be negative (in which case it counts backwards from the end of the array), **or omitted (in which case it refers to the start or end of the array)**.\r\n\r\nSo your were first using `.extension[0]` that ment: take index `0` from `.extension` where\r\n\r\n`.extension[:2]` means: take index `0` **up and including** index `2` from `.extension`\r\n\r\n\r\n----------\r\n\r\nAs [@pmf](https://stackoverflow.com/questions/70168107/jq-work-with-array-iterations-in-mapping-expression#comment124038404_70168107) already mentiond, the difference is the returned value, an object at first, but an array on the second.\r\n\r\nSo you can loop over the array using `[]` to return the `.url` and `.valueString` for each object in side the `.extension` array:\r\n```\r\n._birthDate.extension[0] | .url, ( .extension[:2][] | .url, .valueString )\r\n```\r\n&lt;sup&gt;[Online Demo](https://jqplay.org/s/E84lNNpF_V)&lt;/sup&gt;\r\n\r\n----------\r\n\r\n\r\nHowever, since `.extension` is an array with only 2 indexes, the `:2` part doesn&#39;t do anything useful in your example, so why not simplify it to:\r\n\r\n```\r\n._birthDate.extension[0] | .url, ( .extension[] | .url, .valueString )\r\n```\r\n\r\n&lt;sup&gt;[Online Demo](https://jqplay.org/s/bNauNSCwTd)&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Array/StringSlice",
                "title": "jq — Extract strings contained in nested arrays and objects"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638277717,
                "last_edit_date": 1638277717,
                "creation_date": 1638275009,
                "answer_id": 70169320,
                "question_id": 70168107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only need to keep the strings then you can use `..` to recursively traverse your document and `strings` to filter out non-strings yielded along the way:\r\n\r\n```\r\n.. | strings\r\n```\r\n\r\n\r\n\r\n[Demo](https://jqplay.org/s/ztaZHg92ll)",
                "title": "jq — Extract strings contained in nested arrays and objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1638278280,
        "creation_date": 1638269587,
        "last_edit_date": 1638278280,
        "question_id": 70168107,
        "body_markdown": "I have this jq filter and input:\r\n\r\n```none\r\n( ._birthDate.extension[0] | .url, ( .extension[0] | .url, .valueString ), ( .extension[1] | .url, .valueString ) )\r\n```\r\n\r\n```json\r\n{\r\n   &quot;_birthDate&quot;:{\r\n      &quot;extension&quot;:[\r\n         {\r\n            &quot;url&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-dataBirhtDeath&quot;,\r\n            &quot;extension&quot;:[\r\n               {\r\n                  &quot;url&quot;:&quot;country&quot;,\r\n                  &quot;valueString&quot;:&quot;724&quot;\r\n               },\r\n               {\r\n                  &quot;url&quot;:&quot;state&quot;,\r\n                  &quot;valueString&quot;:&quot;08&quot;\r\n               }\r\n            ]\r\n         }\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\n…which yields the following output:\r\n\r\n```json\r\n&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-dataBirhtDeath&quot;\r\n&quot;country&quot;\r\n&quot;724&quot;\r\n&quot;state&quot;\r\n&quot;08&quot;\r\n```\r\n\r\nI wanted to refactor the filter:\r\n\r\n```none\r\n( ._birthDate.extension[0] | .url, ( .extension[:2] | .url, .valueString ) )\r\n```\r\n\r\n…but I am getting the following error:\r\n\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:18): Cannot index array with string &quot;url&quot;\r\n\r\n\r\nSee this [demo](https://jqplay.org/s/PUObKuVqhQ).\r\n",
        "link": "https://stackoverflow.com/questions/70168107/jq-extract-strings-contained-in-nested-arrays-and-objects",
        "title": "jq — Extract strings contained in nested arrays and objects"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1638371077,
                "last_edit_date": 1638371077,
                "creation_date": 1638306196,
                "answer_id": 70176039,
                "question_id": 70176007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try \r\n```\r\n.[] | {path, type: .types[]}\r\n```\r\n```json\r\n{&quot;path&quot;:&quot;x&quot;,&quot;type&quot;:&quot;a&quot;}\r\n{&quot;path&quot;:&quot;x&quot;,&quot;type&quot;:&quot;b&quot;}\r\n{&quot;path&quot;:&quot;y&quot;,&quot;type&quot;:&quot;c&quot;}\r\n{&quot;path&quot;:&quot;y&quot;,&quot;type&quot;:&quot;d&quot;}\r\n```\r\n[Demo](https://jqplay.org/s/IIflXPYHk9)\r\n\r\nUse the `--compact-output` or `-c` option to also have the same *compact* formatting.\r\n\r\n---\r\nEdit:\r\n&gt; This is documented in [the manual](https://stedolan.github.io/jq/manual/) under the heading &quot;Object Construction: `{}`&quot;. Specifically the statement, &quot;If one of the expressions produces multiple results, multiple dictionaries will be produced.&quot;\r\n\r\nThanks to [@shadowtalker](https://stackoverflow.com/questions/70176007/flatten-or-explode-an-array-valued-field-in-an-array-of-objects/70176039?noredirect=1#comment124070536_70176039) for looking it up.",
                "title": "Flatten or &quot;explode&quot; an array-valued field, in an array of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638371077,
        "creation_date": 1638306033,
        "last_edit_date": 1638351061,
        "question_id": 70176007,
        "body_markdown": "I have this data:\r\n\r\n```json\r\n[\r\n  { &quot;path&quot;: &quot;x&quot;, &quot;types&quot;: [&quot;a&quot;, &quot;b&quot;] },\r\n  { &quot;path&quot;: &quot;y&quot;, &quot;types&quot;: [&quot;c&quot;, &quot;d&quot;] }\r\n]\r\n```\r\n\r\nAnd I am looking to obtain this output:\r\n\r\n```json\r\n{ &quot;path&quot;: &quot;x&quot;, &quot;type&quot;: &quot;a&quot; }\r\n{ &quot;path&quot;: &quot;x&quot;, &quot;type&quot;: &quot;b&quot; }\r\n{ &quot;path&quot;: &quot;y&quot;, &quot;type&quot;: &quot;c&quot; }\r\n{ &quot;path&quot;: &quot;y&quot;, &quot;type&quot;: &quot;d&quot; }\r\n```\r\n\r\nHow would I do this with Jq?",
        "link": "https://stackoverflow.com/questions/70176007/flatten-or-explode-an-array-valued-field-in-an-array-of-objects",
        "title": "Flatten or &quot;explode&quot; an array-valued field, in an array of objects?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "export-to-csv"
        ],
        "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": 1638354361,
                "post_id": 70182418,
                "comment_id": 124063814,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638354685,
                "post_id": 70182418,
                "comment_id": 124063923,
                "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": 1638354757,
                "post_id": 70182418,
                "comment_id": 124063948,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638354859,
                "post_id": 70182418,
                "comment_id": 124063979,
                "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": 1638354911,
                "post_id": 70182418,
                "comment_id": 124064002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638354925,
                "post_id": 70182418,
                "comment_id": 124064009,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638355091,
                "post_id": 70182418,
                "comment_id": 124064073,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1638355247,
                "post_id": 70182418,
                "comment_id": 124064146,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1638355395,
                "post_id": 70182418,
                "comment_id": 124064200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638371371,
                "post_id": 70182418,
                "comment_id": 124070855,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1638358970,
                "creation_date": 1638358970,
                "answer_id": 70183565,
                "question_id": 70182418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Flip the table twice using `transpose | transpose` to fill up the slots missing from the unrigged square shape with `null`:\r\n\r\n```sh\r\njq -rs &#39;map(.extension) | transpose | transpose[] | map(.url, .system) | @csv&#39; \r\n```\r\n```csv\r\n&quot;url1&quot;,&quot;system1&quot;,&quot;url2&quot;,&quot;system2&quot;\r\n&quot;url3&quot;,&quot;system3&quot;,,\r\n```\r\n[Demo](https://jqplay.org/s/-cryuF2X1b)",
                "title": "jq: map field array with different length"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638413210,
                "creation_date": 1638413210,
                "answer_id": 70193633,
                "question_id": 70182418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A fairly efficient solution: \r\n```\r\ndef pad:\r\n  (map(length)|max) as $mx\r\n  | map( . + [range(length;$mx)|null] );\r\n\r\n[inputs | [.extension[] | (.url, .system)]]\r\n| pad[]\r\n| @csv\r\n```\r\nThis of course should be used with the -n command-line option.\r\n",
                "title": "jq: map field array with different length"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1638413210,
        "creation_date": 1638353765,
        "last_edit_date": 1638379157,
        "question_id": 70182418,
        "body_markdown": "I&#39;m working with those JSONs:\r\n\r\n```lang-json\r\n{\r\n  &quot;extension&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;url1&quot;,\r\n      &quot;system&quot;: &quot;system1&quot;\r\n    },\r\n    {\r\n      &quot;url&quot;: &quot;url2&quot;,\r\n      &quot;system&quot;: &quot;system2&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;extension&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;url3&quot;,\r\n      &quot;system&quot;: &quot;system3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAs you can see, both JSON objects have different `.extension` lenght.\r\n\r\nI&#39;m using this command in order to map input JSONs:\r\n\r\n```\r\njq --raw-output &#39;[.extension[] | .url, .system] | @csv&#39;\r\n```\r\n\r\nYou can find [jqplay here](https://jqplay.org/s/2XxTtXfRlX).\r\n\r\nI&#39;m getting that:\r\n\r\n```\r\n&quot;url1&quot;,&quot;system1&quot;,&quot;url2&quot;,&quot;system2&quot;\r\n&quot;url3&quot;,&quot;system3&quot;\r\n```\r\n\r\nWhat I would like to get is:\r\n\r\n```\r\n&quot;url1&quot;,&quot;system1&quot;,&quot;url2&quot;,&quot;system2&quot;\r\n&quot;url3&quot;,&quot;system3&quot;,,\r\n```\r\n\r\nAny ideas about how I could map those &quot;fields&quot; &quot;correctly&quot;?",
        "link": "https://stackoverflow.com/questions/70182418/jq-map-field-array-with-different-length",
        "title": "jq: map field array with different length"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638357833,
                "post_id": 70183182,
                "comment_id": 124065164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638358555,
                "post_id": 70183182,
                "comment_id": 124065417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638359920,
                "post_id": 70183182,
                "comment_id": 124065919,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638361325,
                "post_id": 70183182,
                "comment_id": 124066488,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638361934,
                "post_id": 70183182,
                "comment_id": 124066698,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638363371,
                "post_id": 70183182,
                "comment_id": 124067220,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638364096,
                "post_id": 70183182,
                "comment_id": 124067483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638366794,
                "post_id": 70183182,
                "comment_id": 124068630,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638368304,
                "creation_date": 1638368304,
                "answer_id": 70185844,
                "question_id": 70183182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you want to generate the columns by iterating over an array (`.generalPractitioner[]`) while interweaving the output with a constant from a specific iteration step (`.generalPractitioner[0]`) in every fourth column starting with the second, you will have to store that value in a variable (`$system`) to access it from within the iteration.\r\n\r\n```sh\r\njq -r &#39;\r\n  [\r\n    .generalPractitioner\r\n    | .[0].extension[0].valueCodeableConcept.coding[0].system as $system\r\n    | .[range(4)]\r\n    | (.extension[0] | .url, $system, .valueCodeableConcept.coding[0].code),\r\n      .reference\r\n  ]\r\n  | @csv\r\n&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/a4zl5NnBVE)\r\n",
                "title": "jq: getting default when an item array doesn0t exist"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638368304,
        "creation_date": 1638357246,
        "last_edit_date": 1638361875,
        "question_id": 70183182,
        "body_markdown": "I&#39;m getting an issue with those two json objects:\r\n\r\n```\r\n{\r\n   &quot;generalPractitioner&quot;:[\r\n      {\r\n         &quot;extension&quot;:[\r\n            {\r\n               &quot;url&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-tipus-relacio&quot;,\r\n               &quot;valueCodeableConcept&quot;:{\r\n                  &quot;coding&quot;:[\r\n                     {\r\n                        &quot;system&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rel-organitzacio&quot;,\r\n                        &quot;code&quot;:&quot;UPAPASSIG&quot;\r\n                     }\r\n                  ]\r\n               }\r\n            }\r\n         ],\r\n         &quot;reference&quot;:&quot;Organization/132336&quot;\r\n      },\r\n      {\r\n         &quot;extension&quot;:[\r\n            {\r\n               &quot;url&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-tipus-relacio&quot;,\r\n               &quot;valueCodeableConcept&quot;:{\r\n                  &quot;coding&quot;:[\r\n                     {\r\n                        &quot;system&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rel-organitzacio&quot;,\r\n                        &quot;code&quot;:&quot;UPAPTERRI&quot;\r\n                     }\r\n                  ]\r\n               }\r\n            }\r\n         ],\r\n         &quot;reference&quot;:&quot;Organization/132346&quot;\r\n      }\r\n   ]\r\n}\r\n{\r\n   &quot;generalPractitioner&quot;:[\r\n      {\r\n         &quot;extension&quot;:[\r\n            {\r\n               &quot;url&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-tipus-relacio&quot;,\r\n               &quot;valueCodeableConcept&quot;:{\r\n                  &quot;coding&quot;:[\r\n                     {\r\n                        &quot;system&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rel-organitzacio&quot;,\r\n                        &quot;code&quot;:&quot;UPAPASSIG&quot;\r\n                     }\r\n                  ]\r\n               }\r\n            }\r\n         ],\r\n         &quot;reference&quot;:&quot;Organization/132336&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI&#39;m trying:\r\n\r\n&gt; `jq --raw-output &#39;[ ( .generalPractitioner[0] | ( .extension[] | .url, ( .valueCodeableConcept | .coding[] | .system, .code ) ), .reference ), ( .generalPractitioner[1] | ( .extension[] | .url, ( .valueCodeableConcept | .coding[] | .system, .code ) ), .reference ) ] | @csv`\r\n\r\nTyding up, filter expression is:\r\n\r\n```\r\n[\r\n  ( .generalPractitioner[0] |\r\n    ( .extension[] |\r\n        .url,\r\n        ( .valueCodeableConcept |\r\n          .coding[] |\r\n            .system,\r\n            .code\r\n        )\r\n     ),\r\n     .reference\r\n  ),\r\n    ( .generalPractitioner[1] |\r\n    ( .extension[] |\r\n        .url,\r\n        ( .valueCodeableConcept |\r\n          .coding[] |\r\n            .system,\r\n            .code\r\n        )\r\n     ),\r\n     .reference\r\n  ),\r\n] | @csv\r\n```\r\n\r\nI&#39;m getting this message:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:55): Cannot iterate over null (null)\r\n\r\nSecond `generalPractitioner` object only contains 1 element.\r\n\r\nI know I&#39;m trying to get access to an element doesn&#39;t exist.\r\n\r\nI don&#39;t quite figure out how to workaround it using a default `null` object.\r\n\r\nWhat I&#39;m trying to get is this:\r\n\r\n```\r\n.generalPractitioner[0].extension[0].url // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].system // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].code // null, .generalPractitioner[0].reference // null,\r\n.generalPractitioner[1].extension[0].url // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].system // null, .generalPractitioner[1].extension[0].valueCodeableConcept.coding[0].code // null, .generalPractitioner[1].reference // null,\r\n.generalPractitioner[2].extension[0].url // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].system // null, .generalPractitioner[2].extension[0].valueCodeableConcept.coding[0].code // null, .generalPractitioner[2].reference // null,\r\n.generalPractitioner[3].extension[0].url // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].system // null, .generalPractitioner[3].extension[0].valueCodeableConcept.coding[0].code // null, .generalPractitioner[3].reference // null\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70183182/jq-getting-default-when-an-item-array-doesn0t-exist",
        "title": "jq: getting default when an item array doesn0t exist"
    },
    {
        "tags": [
            "json",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1638378331,
                "last_edit_date": 1638378331,
                "creation_date": 1638377987,
                "answer_id": 70188269,
                "question_id": 70187417,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead off `contains` you&#39;ll need `index` &lt;sup&gt;[[docs][1]]&lt;/sup&gt; to check if there&#39;s an index with the value `Service A`:\r\n\r\n```\r\n.groups[] | select(.orgs | index(&quot;Service A&quot;))\r\n```\r\n\r\nWill output:\r\n\r\n```json\r\n{\r\n  &quot;recipients&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Jane Bloggs&quot;,\r\n      &quot;email&quot;: &quot;jane.bloggs@business.org&quot;\r\n    }\r\n  ],\r\n  &quot;orgs&quot;: [\r\n    &quot;Service A&quot;,\r\n    &quot;Service B&quot;,\r\n    &quot;Service C&quot;\r\n  ]\r\n}\r\n```\r\n\r\n##### [JqPlay demo](https://jqplay.org/s/NJjdIgKfEB)\r\n\r\n----------\r\n\r\nWe can extend that to output only the `recipients` like so:\r\n```\r\n.groups[] | select(.orgs | index(&quot;Service A&quot;)) | .recipients | first\r\n```\r\n\r\nWhere we use `first` to select the first object from the `.recipients` array. The output will be:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Jane Bloggs&quot;,\r\n  &quot;email&quot;: &quot;jane.bloggs@business.org&quot;\r\n}\r\n```\r\n\r\n##### [JqPlay demo](https://jqplay.org/s/pb9XoUCHxr)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example51",
                "title": "Array and String cannot have their containment checked error when trying to search array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1638378331,
        "creation_date": 1638374470,
        "question_id": 70187417,
        "body_markdown": "I have a json file that looks roughly like this:\r\n\r\n```\r\n{\r\n    &quot;default&quot;: [\r\n        {\r\n            &quot;name&quot; : &quot;Joe Bloggs&quot;,\r\n            &quot;email&quot; : &quot;joe.bloggs@business.org&quot;\r\n        }\r\n    ],\r\n    &quot;groups&quot;: [\r\n        {\r\n            &quot;recipients&quot; : [\r\n                {\r\n                    &quot;name&quot; : &quot;Jane Bloggs&quot;,\r\n                    &quot;email&quot; : &quot;jane.bloggs@business.org&quot;\r\n                }\r\n            ],\r\n            &quot;orgs&quot; : [  \r\n                &quot;Service A&quot;,\r\n                &quot;Service B&quot;,\r\n                &quot;Service C&quot;\r\n            ]\r\n        },\r\n        {\r\n            &quot;recipients&quot; : [\r\n                {\r\n                    &quot;name&quot; : &quot;Bill Gates&quot;,\r\n                    &quot;email&quot; : &quot;bill.gates@business.org&quot;\r\n                }\r\n            ],\r\n            &quot;orgs&quot; : [\r\n                &quot;Service D&quot;,\r\n                &quot;Service E&quot;\r\n            ]\r\n        },\r\n        {   \r\n            &quot;recipients&quot; : [\r\n                {\r\n                    &quot;name&quot; : &quot;Steve Jobs&quot;,\r\n                    &quot;email&quot; : &quot;steve.jobs@me.com&quot;\r\n                }\r\n            ],\r\n            &quot;orgs&quot; : [\r\n                &quot;Service F&quot;,\r\n                &quot;Service G&quot;\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nUsing jq I want to be able to search using one of the orgs, so for example &#39;Service A&#39; and return only the recipients information\r\n\r\nI can search recipients easy enough using jq like: \r\n\r\n```\r\ncat /path/to/file.json | jq -r &#39;.groups[] | .recipients[] | select(.name | contains(&quot;Jobs&quot;))&#39; )\r\n```\r\n\r\nto return\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Steve Jobs&quot;,\r\n  &quot;email&quot;: &quot;steve.jobs@me.com&quot;\r\n}\r\n```\r\n\r\nBut If I try to search via the orgs array, I get an error:\r\n\r\n```\r\ncat /path/to/file.json | jq -r &#39;.groups[] | select(.orgs | contains(&quot;Service A&quot;))&#39; )\r\n```\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:46): array ([&quot;Service A...) and string (&quot;Service A&quot;) cannot have their containment checked\r\n```\r\n\r\nIs it possible to do what I am looking for with jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70187417/array-and-string-cannot-have-their-containment-checked-error-when-trying-to-sear",
        "title": "Array and String cannot have their containment checked error when trying to search array using jq"
    },
    {
        "tags": [
            "curl",
            "pipe",
            "keycloak",
            "zsh",
            "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": 1638375376,
                "post_id": 70187582,
                "comment_id": 124072553,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5469810,
                    "reputation": 1603,
                    "user_id": 6449910,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OvekE.jpg?s=256",
                    "display_name": "sesodesa",
                    "link": "https://stackoverflow.com/users/6449910/sesodesa"
                },
                "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": 1638375531,
                "post_id": 70187582,
                "comment_id": 124072636,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5469810,
                    "reputation": 1603,
                    "user_id": 6449910,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OvekE.jpg?s=256",
                    "display_name": "sesodesa",
                    "link": "https://stackoverflow.com/users/6449910/sesodesa"
                },
                "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": 1638375910,
                "post_id": 70187582,
                "comment_id": 124072787,
                "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": 1638376095,
                "post_id": 70187582,
                "comment_id": 124072894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5469810,
                    "reputation": 1603,
                    "user_id": 6449910,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OvekE.jpg?s=256",
                    "display_name": "sesodesa",
                    "link": "https://stackoverflow.com/users/6449910/sesodesa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638376152,
                "post_id": 70187582,
                "comment_id": 124072933,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1638376528,
                "creation_date": 1638376528,
                "answer_id": 70187942,
                "question_id": 70187582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of creating a *complex* command, why not split it into 2 actions:\r\n\r\n1) [Save the token to a variable](https://unix.stackexchange.com/questions/354943/setting-jq-output-to-a-bash-variable) \r\n2) [Pass the variable to the header][1]\r\n\r\n\r\n----------\r\n\r\n\r\n```bash\r\n# Get token\r\ntoken=$(curl \\\r\n    -X POST \\\r\n    -d &#39;client_id=app&#39; \\\r\n    -d &#39;username=username&#39; \\\r\n    -d &#39;password=password&#39; \\\r\n    -d &#39;grant_type=password&#39; \\\r\n    -d &quot;client_secret=$APP_SECRET&quot; \\\r\n    &#39;http://localhost:9000/auth/realms/realm/protocol/openid-connect/token&#39; \\\r\n| jq -r &#39;.access_token&#39;)\r\n\r\n# Send request\r\ncurl \\\r\n    -X GET \\\r\n    -H &quot;Accept: application/json&quot; \\\r\n    -H &quot;Authorization: Bearer $token&quot; \\\r\n    -u &quot;username:password&quot; \\\r\n    &quot;http://localhost:8080/app/api/&quot;\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/4181703/how-to-concatenate-string-variables-in-bash",
                "title": "Piping stdin to a cURL header"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638386630,
                "last_edit_date": 1638386630,
                "creation_date": 1638386174,
                "answer_id": 70190012,
                "question_id": 70187582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The other answer provides a better solution, but this post answers the literal question asked.\r\n\r\nYou can use the following:\r\n\r\n```sh\r\n&quot;Authorization: Bearer $( cat )&quot;\r\n```\r\n\r\nDemo:\r\n\r\n```sh\r\n$ echo foo | printf &quot;%s\\n&quot; &quot;Authorization: Bearer $( cat )&quot;\r\nAuthorization: Bearer foo\r\n```\r\n\r\nIn fact, you could put the entire token-fetching code inside of `$()`.\r\n\r\n```sh\r\ncurl                              \\\r\n    -X GET                        \\\r\n    -H &quot;Accept: application/json&quot; \\\r\n    -H &quot;Authorization: Bearer $(\r\n        curl                               \\\r\n            -X POST                        \\\r\n            -d &quot;client_id=app&quot;             \\\r\n            -d &quot;username=username&quot;         \\\r\n            -d &quot;password=password&quot;         \\\r\n            -d &quot;grant_type=password&quot;       \\\r\n            -d &quot;client_secret=$APP_SECRET&quot; \\\r\n            &quot;http://localhost:9000/auth/realms/realm/protocol/openid-connect/token&quot; \\\r\n        | jq -r .access_token\r\n    )&quot;                            \\\r\n    -u &quot;username:password&quot;        \\\r\n    &quot;http://localhost:8080/app/api/&quot;\r\n```\r\n\r\nDemo:\r\n\r\n```sh\r\n$ printf &quot;%s\\n&quot; &quot;Authorization: Bearer $( echo foo )&quot;\r\nAuthorization: Bearer foo\r\n```\r\n\r\nAgain, I consider these inferior to the clearer solution provided by @0stone0. I am posting them for educational purposes.\r\n",
                "title": "Piping stdin to a cURL header"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1638386630,
        "creation_date": 1638375166,
        "last_edit_date": 1638375856,
        "question_id": 70187582,
        "body_markdown": "I am trying to read get an authentication token from a Keycloak endpoint and use it to access another resource. Getting the token is not an issue, but passing it along in the header of another request is turning out to be an impossible feat, at least in a single command:\r\n\r\n\tcurl \\\r\n\t\t-X POST \\\r\n\t\t-d &#39;client_id=app&#39; \\\r\n\t\t-d &#39;username=username&#39; \\\r\n\t\t-d &#39;password=password&#39; \\\r\n\t\t-d &#39;grant_type=password&#39; \\\r\n\t\t-d &quot;client_secret=$APP_SECRET&quot; \\\r\n\t\t&#39;http://localhost:9000/auth/realms/realm/protocol/openid-connect/token&#39; \\\r\n\t| \\\r\n\tjq -r &#39;.access_token&#39; \\\r\n\t| \\\r\n\tcurl \\\r\n\t\t-X GET \\\r\n\t\t-H &quot;Accept: application/json&quot; \\\r\n\t\t-H &quot;Authorization: Bearer @-&quot; \\ # &lt;- read header value from stdin\r\n\t\t-u &quot;username:password&quot; \\\r\n\t\t&quot;http://localhost:8080/app/api/&quot;\r\n\r\nWhat might be an alternative way of achieving this?",
        "link": "https://stackoverflow.com/questions/70187582/piping-stdin-to-a-curl-header",
        "title": "Piping stdin to a cURL header"
    },
    {
        "tags": [
            "json",
            "parent-child",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1638394092,
                "creation_date": 1638394092,
                "answer_id": 70191434,
                "question_id": 70191184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n```sh\r\njq --arg q &quot;VJXWCBDL&quot; &#39;\r\n  .[] | [.id] + (.line_items[] | select(.catalog_object_id == $q) | [.quantity])\r\n&#39; test.json\r\n```\r\n```json\r\n[\r\n  &quot;a&quot;,\r\n  &quot;1&quot;\r\n]\r\n[\r\n  &quot;c&quot;,\r\n  &quot;2&quot;\r\n]\r\n[\r\n  &quot;d&quot;,\r\n  &quot;4&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/Ezx9dlo8NM)",
                "title": "JQ only return matching child results with parent"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1638394092,
        "creation_date": 1638392703,
        "question_id": 70191184,
        "body_markdown": "I am trying to get JSON data where a child key match exists, but I want to exclude data from other child elements that don&#39;t match. An example would use the following JSON, trying to return `id` from the parent and `quantity` from the child, where the child `catalog_object_id` &quot;VJXWCBDL&quot;:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;a&quot;,\r\n        &quot;line_items&quot;: [\r\n          {\r\n            &quot;catalog_object_id&quot;: &quot;IKF7HPIP&quot;,\r\n            &quot;quantity&quot;: &quot;5&quot;\r\n          },\r\n          {\r\n            &quot;catalog_object_id&quot;: &quot;VJXWCBDL&quot;,\r\n            &quot;quantity&quot;: &quot;1&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;b&quot;,\r\n        &quot;line_items&quot;: [\r\n          {\r\n            &quot;catalog_object_id&quot;: &quot;JXOACUE&quot;,\r\n            &quot;quantity&quot;: &quot;4&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;c&quot;,\r\n        &quot;line_items&quot;: [\r\n          {\r\n            &quot;catalog_object_id&quot;: &quot;VJXWCBDL&quot;,\r\n            &quot;quantity&quot;: &quot;2&quot;\r\n          },\r\n          {\r\n            &quot;catalog_object_id&quot;: &quot;RGQMKXKL&quot;,\r\n            &quot;quantity&quot;: &quot;3&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;d&quot;,\r\n        &quot;line_items&quot;: [\r\n          {\r\n            &quot;catalog_object_id&quot;: &quot;VJXWCBDL&quot;,\r\n            &quot;quantity&quot;: &quot;4&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nThe output that I&#39;m looking for is:\r\n\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;1&quot;\r\n    ]\r\n    [\r\n      &quot;c&quot;,\r\n      &quot;2&quot;\r\n    ]\r\n    [\r\n      &quot;d&quot;,\r\n      &quot;4&quot;\r\n    ]\r\n\r\nWhen I use `select` based on the object id, it returns the values for the other ids as well. I&#39;m sure there&#39;s an easy answer to this that I haven&#39;t been able to figure out. \r\n\r\n    jq &#39;.[] | select ( .line_items[].catalog_object_id == &quot;VJXWCBDL&quot; ) | [ .id, .line_items[].quantity ]&#39; test.json\r\n\r\nWhat should I be doing instead?",
        "link": "https://stackoverflow.com/questions/70191184/jq-only-return-matching-child-results-with-parent",
        "title": "JQ only return matching child results with parent"
    },
    {
        "tags": [
            "json",
            "null",
            "jq",
            "defaultifempty"
        ],
        "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": 1638430905,
                "post_id": 70195277,
                "comment_id": 124087128,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638431206,
                "post_id": 70195277,
                "comment_id": 124087208,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1638431310,
                "post_id": 70195277,
                "comment_id": 124087237,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638450473,
                "creation_date": 1638450473,
                "answer_id": 70200069,
                "question_id": 70195277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`// {&quot;url&quot;:null}` works for me:\r\n\r\n    def pick_extension($url):    .extension[] | select( .url == $url);  [  (( pick_extension( &quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-occupation&quot; ) // {&quot;url&quot;:null})  | .url , ( .valueCodeableConcept.coding[0] | .system, .code) ) ] \r\n\r\n https://jqplay.org/s/QlVGUer8Nu",
                "title": "jq: pick null instead of empty"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1638461565,
        "creation_date": 1638428436,
        "last_edit_date": 1638461565,
        "question_id": 70195277,
        "body_markdown": "I&#39;ve created this filter expression:\r\n\r\n```\r\ndef pick_extension($url):\r\n   .extension[] | select( .url == $url);\r\n\r\n[\r\n    ( pick_extension( &quot;http://hl7.org/fhir/StructureDefinition/patient-nationality&quot; ) | .url, ( .extension[0] | .url, ( .valueCodeableConcept.coding[0] | .system, .code ) ) )\r\n]\r\n```\r\n\r\nIssue is that when `pick_extension(url)` doesn&#39;t pick any object, it returns empty.\r\n\r\nThen other piped expression are empty as well.\r\n\r\nCurrently, I&#39;m getting empty arrays:\r\n\r\n```lang-json\r\n[]\r\n[]\r\n[]\r\n```\r\n\r\nDesired output I need would be:\r\n\r\n```lang-json\r\n[null, null, null, null]\r\n[null, null, null, null]\r\n[null, null, null, null]\r\n...\r\n```\r\n\r\nCurrently, I&#39;m working with it in this [jqplay](https://jqplay.org/s/0_Z33058sX).\r\n\r\nHere some json extracted json input object:\r\n\r\n```lang-json\r\n{\r\n   &quot;resourceType&quot;:&quot;Patient&quot;,\r\n   &quot;id&quot;:&quot;14426955&quot;,\r\n   &quot;meta&quot;:{\r\n      &quot;versionId&quot;:&quot;1&quot;,\r\n      &quot;lastUpdated&quot;:&quot;2021-12-01T14:24:11.387+01:00&quot;,\r\n      &quot;source&quot;:&quot;#XbZyfGxZj4fZygTv&quot;\r\n   },\r\n   &quot;extension&quot;:[\r\n      {\r\n         &quot;url&quot;:&quot;http://hl7.org/fhir/StructureDefinition/patient-nationality&quot;,\r\n         &quot;extension&quot;:[\r\n            {\r\n               &quot;url&quot;:&quot;code&quot;,\r\n               &quot;valueCodeableConcept&quot;:{\r\n                  &quot;coding&quot;:[\r\n                     {\r\n                        &quot;system&quot;:&quot;urn:iso:std:iso:3166&quot;,\r\n                        &quot;code&quot;:&quot;724&quot;\r\n                     }\r\n                  ]\r\n               }\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;url&quot;:&quot;http://catsalut.gencat.cat/fhir/StructureDefinition/patient-status&quot;,\r\n         &quot;valueCodeableConcept&quot;:{\r\n            &quot;coding&quot;:[\r\n               {\r\n                  &quot;system&quot;:&quot;http://catsalut.gencat.cat/fhir/EstatRegistre&quot;,\r\n                  &quot;code&quot;:&quot;alta&quot;\r\n               }\r\n            ]\r\n         }\r\n      }\r\n   ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70195277/jq-pick-null-instead-of-empty",
        "title": "jq: pick null instead of empty"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638435335,
                "creation_date": 1638435335,
                "answer_id": 70196525,
                "question_id": 70196458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Subtract `.creator` directly from the array in `.co_author` and apply this to all elements of the top-level array using `map`:\r\n```sh\r\njq &#39;map(.co_author -= [.creator])&#39; test_4.json \r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;creator&quot;: &quot;M.W. Seo&quot;,\r\n    &quot;co_author&quot;: [\r\n      &quot;H.W. Lee&quot;,\r\n      &quot;S.H. Jeon&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;creator&quot;: &quot;Jeffrey A. Laman&quot;,\r\n    &quot;co_author&quot;: [\r\n      &quot;Mike&quot;,\r\n      &quot;Jackson&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/Jkh3gWBH2m)",
                "title": "how do i conditionally delete specific value in specific array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638460651,
        "creation_date": 1638435027,
        "last_edit_date": 1638460651,
        "question_id": 70196458,
        "body_markdown": "This is my JSON data input:\r\n```json\r\n[\r\n  {\r\n    &quot;creator&quot;: &quot;M.W. Seo&quot;,\r\n    &quot;co_author&quot;: [\r\n      &quot;H.W. Lee&quot;,\r\n      &quot;S.H. Jeon&quot;,\r\n      &quot;M.W. Seo&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;creator&quot;: &quot;Jeffrey A. Laman&quot;,\r\n    &quot;co_author&quot;: [\r\n      &quot;Jeffrey A. Laman&quot;,\r\n      &quot;Mike&quot;,\r\n      &quot;Jackson&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nThis is my desired JSON data output:\r\n```json\r\n[\r\n  {\r\n    &quot;creator&quot;: &quot;M.W. Seo&quot;,\r\n    &quot;co_author&quot;: [\r\n      &quot;H.W. Lee&quot;,\r\n      &quot;S.H. Jeon&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;creator&quot;: &quot;Jeffrey A. Laman&quot;,\r\n    &quot;co_author&quot;: [\r\n      &quot;Mike&quot;,\r\n      &quot;Jackson&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nWhat I have tried but is not working:\r\n```sh\r\njq &#39;.[:2]| map(if .co_author[] == .creator then del(.co_author[])&#39; test_4.json\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70196458/how-do-i-conditionally-delete-specific-value-in-specific-array-with-jq",
        "title": "how do i conditionally delete specific value in specific array with jq?"
    },
    {
        "tags": [
            "terraform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1638468808,
                "post_id": 70202278,
                "comment_id": 124102933,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638884983,
                "last_edit_date": 1638884983,
                "creation_date": 1638539277,
                "answer_id": 70215352,
                "question_id": 70202278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;br&gt;\r\nSorry for the detailed question... but thanks for the clue... \r\nI found the issue, if you run a shell script from terraform via data source external then it expects the output of the script should be formatted in Json. &lt;/br&gt;\r\n&lt;br&gt;My scripts returns an output from few gcloud commands&lt;/br&gt;\r\n\r\n-Issue-1\r\n```\r\nopenssl rsa -in public_key -pubin -text -noout \r\n```\r\n&lt;br&gt;it returns an encoded version of private but I am taking any input from this command, so I removed this command from the script.&lt;/br&gt;\r\n\r\n-Issue-2\r\n```\r\ngcloud compute instances add-metadata ${HOSTNAME} --project ${ID} --zone ${ZONE} --metadata-from-file=&quot;windows-keys=metadata_payload.json&quot;\r\n```\r\n&lt;br&gt;It returns an update status, for which I updated as below&lt;/br&gt;\r\n\r\n```\r\ngcloud compute instances add-metadata ${HOSTNAME} --project ${ID} --zone ${ZONE} --metadata-from-file=&quot;windows-keys=metadata_payload.json&quot; &gt;/dev/null 2&gt;&amp;1\r\n```\r\n\r\n-Issue-3\r\n```\r\ngcloud compute instances get-serial-port-output ${HOSTNAME} --project=${ID} --zone=${ZONE} --port=4\r\n```\r\n&lt;br&gt; It returns an exception, for which I updated as below&lt;/br&gt;\r\n```\r\ngcloud compute instances get-serial-port-output ${HOSTNAME} --project=${ID} --zone=${ZONE} --port=4 2&gt;/dev/null\r\n```",
                "title": "terraform data source external with bash script throwing error with JSON structure"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639153735,
        "creation_date": 1638459288,
        "last_edit_date": 1638884640,
        "question_id": 70202278,
        "body_markdown": "I am getting error when executing my (bash) shell script via terraform data source external.\r\nHere is my terraform code\r\n\r\n```\r\nresource &quot;random_id&quot; &quot;win_serv&quot; {\r\n  byte_length = 4\r\n}\r\n\r\nlocals {\r\n  username = &quot;kerbuser1&quot;\r\n}\r\n\r\nresource &quot;google_compute_instance&quot; &quot;win_serv_instance&quot; {\r\n  project      = &quot;burnished-fold-328804&quot;\r\n  name         = &quot;krb-test-${random_id.win_serv.hex}&quot;\r\n  machine_type = &quot;e2-standard-2&quot;\r\n  zone         = &quot;us-central1-b&quot;\r\n\r\n  metadata = {\r\n    windows-startup-script-ps1 = &lt;&lt;EOT\r\n# Installing IIS\r\nImport-Module servermanager\r\nInstall-WindowsFeature Web-Server -IncludeAllSubFeature\r\n\r\n# Ensure the directory exists\r\nif (-not (Test-Path(&quot;C:\\inetpub\\wwwroot&quot;))) {New-Item &quot;C:\\inetpub\\wwwroot&quot; -Type Directory}\r\n\r\n# Write the expanded string out to the file, overwriting the file if it already exists.\r\n&quot;&lt;html&gt;&lt;body&gt;&lt;p&gt;Windows startup script added directly.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;&quot; | Out-File -FilePath C:\\inetpub\\wwwroot\\index.html -Encoding ascii -Force\r\nEOT\r\n  }\r\n\r\n  boot_disk {\r\n    initialize_params {\r\n      image = &quot;windows-server-2004-dc-core-v20211115&quot;\r\n      size  = &quot;50&quot;\r\n      type = &quot;pd-ssd&quot;\r\n    }\r\n  }\r\n\r\n  allow_stopping_for_update = true\r\n\r\n  network_interface {\r\n    network = &quot;default&quot;\r\n  }\r\n\r\n  service_account {\r\n    email  = &quot;292284418153-compute@developer.gserviceaccount.com&quot;\r\n    scopes = [&quot;cloud-platform&quot;]\r\n  }\r\n}\r\n\r\ndata &quot;external&quot; &quot;kerb_auth&quot; {\r\n  program = [ &quot;bash&quot;, &quot;${path.module}/kerb_auth.sh&quot; ]\r\n  query = {\r\n    ZONE     = &quot;us-central1-b&quot;\r\n    ID       = &quot;burnished-fold-328804&quot;\r\n    HOSTNAME = &quot;${google_compute_instance.win_serv_instance.name}&quot;\r\n  }\r\n}\r\n```\r\n\r\nand here is my bash shell script\r\n\r\n```\r\n#!/bin/bash\r\n\r\nUSERNAME=&quot;kerbuser1&quot;\r\nUSER_EMAIL=&quot;kerbuser1@f5lbu.com&quot;\r\nEXPIRE_DATE=$(date --date=&#39;now +10 minutes&#39; +%Y-%m-%dT%H:%M:%SZ)\r\nWORKING_DIR=&quot;/tmp/krbloc&quot;\r\n\r\n#Variables provided in external block query format of the instance tf template\r\neval &quot;$(jq -r &#39;@sh &quot;HOSTNAME=\\(.HOSTNAME) ZONE=\\(.ZONE) ID=\\(.ID)&quot;&#39;)&quot;\r\n\r\n# generate rsa public and private keys\r\nmkdir -p ${WORKING_DIR}\r\ncd ${WORKING_DIR}\r\nopenssl genrsa -out private_key 2048 &gt; /dev/null 2&gt;&amp;1\r\nopenssl rsa -pubout -in private_key -out public_key &gt; /dev/null 2&gt;&amp;1\r\nopenssl rsa -in public_key -pubin -text -noout\r\n\r\nMODULUS=$(cat public_key | grep -v -- ----- | base64 -d | dd bs=1 skip=33 count=256 2&gt;/dev/null | base64 -w 0; echo)\r\nEXPONENT=$(cat public_key | grep -v -- ----- | base64 -d | dd bs=1 skip=291 count=3 2&gt;/dev/null | base64)\r\n\r\nprintf &#39;{&quot;userName&quot;: &quot;%s&quot;, &quot;modulus&quot;: &quot;%s&quot;, &quot;exponent&quot;: &quot;%s&quot;, &quot;expireOn&quot;: &quot;%s&quot;, &quot;email&quot;: &quot;%s&quot;}&#39; &quot;${USERNAME}&quot; &quot;${MODULUS}&quot; &quot;${EXPONENT}&quot; &quot;${EXPIRE_DATE}&quot; &quot;${USER_EMAIL}&quot; &gt; metadata_payload.json\r\n\r\nif [[ -f metadata_payload.json ]]; then\r\n  gcloud compute instances add-metadata ${HOSTNAME} --project ${ID} --zone ${ZONE} --metadata-from-file=&quot;windows-keys=metadata_payload.json&quot;\r\n\r\nelse\r\n  echo &quot;Payload file not found.&quot;\r\nfi\r\n\r\nKRB=$(gcloud compute instances get-serial-port-output ${HOSTNAME} --project=${ID} --zone=${ZONE} --port=4 | jq -r -c --arg MODULUS $MODULUS &#39;select(.modulus == $MODULUS) | .encryptedPassword&#39;)\r\n\r\nPAS=$(echo $KRB | base64 -d | openssl rsautl -decrypt -inkey private_key -oaep)\r\n\r\njq -n --arg passwd &quot;$PAS&quot; &#39;{&quot;password&quot;:$passwd}&#39;\r\n```\r\n\r\nwhen executing the script manually, I don&#39;t see any issues.\r\nbut getting below error while executing from terraform\r\nI suspect its because the password which I am returning in shell script have special character&#39;s.\r\nI have tried altering the quotes and escape characters, but no luck.\r\n\r\n```\r\ndata.external.kerb_auth: Reading...\r\n╷\r\n│ Error: command &quot;bash&quot; produced invalid JSON: invalid character &#39;R&#39; looking for beginning of value\r\n│\r\n│   with data.external.kerb_auth,\r\n│   on main.tf line 76, in data &quot;external&quot; &quot;kerb_auth&quot;:\r\n│   76: data &quot;external&quot; &quot;kerb_auth&quot; {\r\n│\r\n╵\r\n```",
        "link": "https://stackoverflow.com/questions/70202278/terraform-data-source-external-with-bash-script-throwing-error-with-json-structu",
        "title": "terraform data source external with bash script throwing error with JSON structure"
    },
    {
        "tags": [
            "node.js",
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638464820,
                "last_edit_date": 1638464820,
                "creation_date": 1638464225,
                "answer_id": 70203566,
                "question_id": 70203451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way using [`map`][1] and [`if-then-else`][2]:\r\n\r\n```\r\n.results |= map(if .name == &quot;John&quot; then .age = 44 else . end)\r\n```\r\n&lt;sup&gt;[JqPlay Demo][3]&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\nAnother using [`select`][4]:\r\n```\r\n( .results[] | select(.name == &quot;John&quot;) | .age) |= 44\r\n```\r\n&lt;sup&gt;[JqPlay Demo](https://jqplay.org/s/1R1vV3Zquy)&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\nBoth versions rely on:\r\n\r\n* `|=`:  [Update-assignment](https://stedolan.github.io/jq/manual/#Update-assignment:|=)\r\n\r\n\r\n----------\r\n\r\n\r\n----------\r\n\r\n&gt; Additionally, if &quot;age&quot; is not there, I would like to add it.\r\n\r\nThis requires an additional filter, something like\r\n```\r\n( .results[] | select(.age | not )) += { &quot;age&quot;: 1 }\r\n```\r\n\r\nWere we use [`not`][5] to [`select`][4] all the objects without `.age` and then add it.\r\n\r\nCombining both filters, would give something like:\r\n```\r\n( .results[] | select(.age | not )) += { &quot;age&quot;: 1 } | ( .results[] | select(.name == &quot;John&quot;) | .age) |= 44\r\n```\r\n&lt;sup&gt;[JqPlay Demo](https://jqplay.org/s/Q8C4kQu_Tg)&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example21\r\n  [2]: https://stedolan.github.io/jq/manual/#if-then-else\r\n  [3]: https://jqplay.org/s/CSC6IoLfD8\r\n  [4]: https://stedolan.github.io/jq/manual/#example28\r\n  [5]: https://stedolan.github.io/jq/manual/#example76",
                "title": "Using JQ (or any other .json tool), how can I update an object within an array and return the entire parent .json?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638535745,
                "creation_date": 1638535745,
                "answer_id": 70214571,
                "question_id": 70203451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As setting an object&#39;s field to a value given does not require its previous content (or its existence even), there is no need for the update operator `|=`. A simple assignment `=` does suffice to set (or create) a certain field.\r\n```\r\n(.results[] | select(.name == &quot;John&quot;)).age = 44\r\n```\r\nThis [demo](https://jqplay.org/s/v4DuIMKLRG) contains the input twice, once as given and once with John&#39;s `.age` missing.",
                "title": "Using JQ (or any other .json tool), how can I update an object within an array and return the entire parent .json?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1638535745,
        "creation_date": 1638463725,
        "question_id": 70203451,
        "body_markdown": "For example, say I have the following .json blob:\r\n\r\n    {\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;Jane&quot;,  &quot;age&quot;: 10, &quot;city&quot;: &quot;TownB&quot; }\r\n        ]\r\n    }\r\n\r\nI want to change John&#39;s age to 44, and then return the entire blob. I&#39;m looking for the following output:\r\n\r\n    {\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;: 44, &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\r\nAdditionally, if &quot;age&quot; is not there, I would like to add it.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/70203451/using-jq-or-any-other-json-tool-how-can-i-update-an-object-within-an-array-a",
        "title": "Using JQ (or any other .json tool), how can I update an object within an array and return the entire parent .json?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638540767,
                "post_id": 70215572,
                "comment_id": 124122853,
                "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": 1,
                "creation_date": 1638542020,
                "post_id": 70215572,
                "comment_id": 124123397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638542054,
                "post_id": 70215572,
                "comment_id": 124123414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "reply_to_user": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638542666,
                "post_id": 70215572,
                "comment_id": 124123677,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1638543355,
                "last_edit_date": 1638543355,
                "creation_date": 1638543010,
                "answer_id": 70216189,
                "question_id": 70215572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Three issues.\r\n\r\n---\r\n\r\n`.results[i]` should be `.results[]`\r\n\r\n---\r\n\r\nThe following produces a stream of JSON objects:\r\n\r\n```jq\r\n.results[].&quot;com.src.main.client.details&quot;\r\n```\r\n\r\nTo get an array, use\r\n\r\n```jq\r\n[ .results[].&quot;com.src.main.client.details&quot; ]\r\n```\r\n\r\nor\r\n\r\n```jq\r\n.results | map(.&quot;com.src.main.client.details&quot;)\r\n```\r\n\r\n---\r\n\r\nFinally, there was a shell quoting issue. In a &quot;sh-like&quot; shell, you want\r\n\r\n```sh\r\njq -c &#39;.results | map(.&quot;com.src.main.client.details&quot;)&#39;\r\n```\r\n\r\nNote the single quotes.\r\n\r\n---\r\n\r\n[Demo](https://jqplay.org/s/HhM_zlrhuS) on jqplay",
                "title": "jq array filtration from a file to another file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1666482551,
        "creation_date": 1638540247,
        "last_edit_date": 1666482551,
        "question_id": 70215572,
        "body_markdown": "I have the below json in which i want to filter out the **result** object which is an Array using some script, since result object can populate multiple objects in it. I wanted to get the data from &quot;`jq -c .results[i].&quot;com.src.main.client.details&quot;` into a json file to process further.\r\n\r\n```json\r\n{\r\n    &quot;foo&quot;: {\r\n        &quot;requestID&quot;: &quot;89279f54-2f18-4301-b94d-1c413be1cb68&quot;,\r\n        &quot;signature&quot;: {\r\n            &quot;*&quot;: &quot;*&quot;\r\n        }\r\n    },\r\n    &quot;results&quot;: [\r\n        {\r\n            &quot;com.src.main.client.details&quot;: {\r\n                &quot;doc&quot;: &quot;string&quot;,\r\n                &quot;details&quot;: [\r\n                    {\r\n                        &quot;amount&quot;: null,\r\n                        &quot;output&quot;: null,\r\n                        &quot;properties&quot;: [],\r\n                        &quot;characteristic&quot;: [],\r\n                        &quot;component&quot;: null,\r\n                        &quot;period&quot;: null,\r\n                        &quot;internals&quot;: {\r\n                            &quot;Currency&quot;: &quot;EUR&quot;,\r\n                           &quot;value&quot;: 0\r\n                        }\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;com.src.main.client.details&quot;: {\r\n                &quot;doc&quot;: &quot;string&quot;,\r\n                &quot;details&quot;: [\r\n                    {\r\n                        &quot;amount&quot;: null,\r\n                        &quot;output&quot;: null,\r\n                        &quot;properties&quot;: [\r\n                            {\r\n                                &quot;characteristic&quot;: [],\r\n                                &quot;component&quot;: null,\r\n                                &quot;period&quot;: null,\r\n                                &quot;internals&quot;: {\r\n                                    &quot;Currency&quot;: &quot;EUR&quot;,\r\n                                    &quot;value&quot;: 0\r\n                                }\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nIs there a way I can achieve it via one single command or if someone can suggest the scripting logic. Thanks.\r\n\r\nDesire Output:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;doc&quot;: &quot;string&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;amount&quot;: null,\r\n        &quot;output&quot;: null,\r\n        &quot;properties&quot;: [],\r\n        &quot;characteristic&quot;: [],\r\n        &quot;component&quot;: null,\r\n        &quot;period&quot;: null,\r\n        &quot;internals&quot;: {\r\n          &quot;Currency&quot;: &quot;EUR&quot;,\r\n          &quot;value&quot;: 0\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;doc&quot;: &quot;string&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;amount&quot;: null,\r\n        &quot;output&quot;: null,\r\n        &quot;properties&quot;: [\r\n          {\r\n            &quot;characteristic&quot;: [],\r\n            &quot;component&quot;: null,\r\n            &quot;period&quot;: null,\r\n            &quot;internals&quot;: {\r\n              &quot;Currency&quot;: &quot;EUR&quot;,\r\n              &quot;value&quot;: 0\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/70215572/jq-array-filtration-from-a-file-to-another-file",
        "title": "jq array filtration from a file to another file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638552638,
                "last_edit_date": 1638552638,
                "creation_date": 1638544987,
                "answer_id": 70216690,
                "question_id": 70216065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Getting the output of a program into a variable can be done using `read`.\r\n\r\n```sh\r\nperl -M5.010 -MYAML -MJSON::PP -e&#39;\r\n   sub get_next_file { local $/; &quot;&quot;.&lt;&gt; }\r\n   my %filter = map { $_-&gt;{name} =&gt; 1 } values %{ Load(get_next_file)-&gt;{instance} };\r\n   say for grep !$filter{$_}, map $_-&gt;{name}, @{ decode_json(get_next_file) };\r\n&#39; b.yaml a.json |\r\nwhile IFS= read -r id; do\r\n   curl -X DELETE ...&quot;$id&quot;...\r\ndone\r\n```\r\n\r\nI used Perl here because what you had was no way to parse a YAML file. The snippet requires having installed the YAML Perl module.\r\n",
                "title": "Bash JSON compare two list and delete id"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638546836,
                "last_edit_date": 1638546836,
                "creation_date": 1638545976,
                "answer_id": 70216929,
                "question_id": 70216065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your endpoint is **not** proper JSON as it has\r\n- commas after the `.name` field but no following field\r\n- no commas between the elements of the top-level array\r\n\r\nIf this is not just a typo from pasting your example into this question, then you&#39;d need to address this first before proceeding. This is how it should look like:\r\n```json\r\n[\r\n  {\r\n    &quot;hosts&quot;: [\r\n      &quot;server1&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;qz9o847b-f07c-49d1-b1fa-e5ed0b2f0519&quot;,\r\n    &quot;name&quot;: &quot;toto&quot;\r\n  },\r\n  {\r\n    &quot;hosts&quot;: [\r\n      &quot;server2&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;a6aa847b-f07c-49d1-b1fa-e5ed0b2f0519&quot;,\r\n    &quot;name&quot;: &quot;tata&quot;\r\n  },\r\n  {\r\n    &quot;hosts&quot;: [\r\n      &quot;server3&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;a6d9ee7b-f07c-49d1-b1fa-e5ed0b2f0519&quot;,\r\n    &quot;name&quot;: &quot;titi&quot;\r\n  }\r\n]\r\n```\r\n\r\nIf your endpoint **is** proper JSON, try the following. It extracts the names from your .yml file (just as you do - there are plenty of more efficient and less error-prone ways but I&#39;m trying to adapt your approach as much as possible) but instead of a Bash array generates a JSON array using `jq` which for Bash is a simple string. For your `curl` output it&#39;s basically the same thing, extracting a (JSON) array of names into a Bash string. Note that in both cases I use quotes `&lt;var&gt;=&quot;$(…)&quot;` to capture strings that may include spaces (although I also use the `-c` option for `jq` to compact it&#39;s output to a single line). For the difference between the two, everything is taken over by `jq` as it can easily be fed with the JSON arrays as variables, perform the subtraction and output in your preferred format:\r\n```sh\r\nfromyml=&quot;$(cat files.yml | grep name | cut -d &#39;&quot;&#39; -f2 | jq -Rnc &#39;[inputs]&#39;)&quot;\r\nfromcurl=&quot;$(curl -sX GET &quot;XXXX&quot; | jq -c &#39;map(.name)&#39;)&quot;\r\ndiff=&quot;$(jq -nr --argjson fromyml &quot;$fromyml&quot; --argjson fromcurl &quot;$fromcurl&quot; &#39;\r\n  $fromcurl - $fromyml | .[]\r\n&#39;)&quot;\r\n```\r\nThe Bash variable `diff` now contains a list of names only present in the curl output (`$fromcurl - $fromyml`), one per line (if, other than in your example, there happens to be more than one). If the curl output had duplicates, they will still be included (use `$fromcurl - $fromyml | unique | .[]` to get rid of them):\r\n```\r\ntiti\r\n```\r\nAs you can see, this solution has three calls to `jq`. I&#39;ll leave it to you to further reduce that number as it fits your general workflow (basically, it can be put together into one).\r\n",
                "title": "Bash JSON compare two list and delete id"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1638552638,
        "creation_date": 1638542441,
        "last_edit_date": 1638548620,
        "question_id": 70216065,
        "body_markdown": "I have a JSON endpoint which I can fetch value with curl and yml local file. I want to get the difference and delete it with id of name present on JSON endpoint.\r\n\r\nJSON&#39;s endpoint\r\n\r\n    [\r\n      {\r\n        &quot;hosts&quot;: [\r\n          &quot;server1&quot;\r\n        ],\r\n        &quot;id&quot;: &quot;qz9o847b-f07c-49d1-b1fa-e5ed0b2f0519&quot;,\r\n        &quot;name&quot;: &quot;V1_toto_a&quot;\r\n      },\r\n      {\r\n        &quot;hosts&quot;: [\r\n          &quot;server2&quot;\r\n        ],\r\n        &quot;id&quot;: &quot;a6aa847b-f07c-49d1-b1fa-e5ed0b2f0519&quot;,\r\n        &quot;name&quot;: &quot;V1_tata_b&quot;\r\n      },\r\n      {\r\n        &quot;hosts&quot;: [\r\n          &quot;server3&quot;\r\n        ],\r\n        &quot;id&quot;: &quot;a6d9ee7b-f07c-49d1-b1fa-e5ed0b2f0519&quot;,\r\n        &quot;name&quot;: &quot;V1_titi_c&quot;\r\n      }\r\n    ]\r\n\r\nfiles.yml\r\n\r\n    ---\r\n    instance:\r\n      toto:\r\n        name: &quot;toto&quot;\r\n      tata:\r\n        name: &quot;tata&quot;\r\n\r\nBetween JSON&#39;s endpoint and local file, I want to delete it with id of tata, because it is the difference between the sources.\r\n\r\n\r\n    declare -a arr=(_a _b _c)\r\n    ar=$(cat files.yml | grep name | cut -d &#39;&quot;&#39; -f2 | tr &quot;\\n&quot; &quot; &quot;)\r\n\tfileItemArray=($ar)\r\n\tARR_PRE=(&quot;${fileItemArray[@]/#/V1_}&quot;)\r\n    for i in &quot;${arr[@]}&quot;; do local_var+=(&quot;${ARR_PRE[@]/%/$i}&quot;); done\r\n    remote_var=$(curl -sX GET &quot;XXXX&quot; | jq -r &#39;.[].name | @sh&#39; | tr -d \\&#39;\\&quot;)\r\n    diff_=$(echo ${local_var[@]} ${remote_var[@]} | tr &#39; &#39; &#39;\\n&#39; | sort | uniq -u)\r\n\r\noutput = titi\r\n\r\nthe code works, but I want to delete the titi with id dynamically\r\n\r\n\r\ncurl -X DELETE &quot;XXXX&quot; $id_titi\r\n\r\n\r\nI am trying to delete with bash script, but I have no idea to continue...",
        "link": "https://stackoverflow.com/questions/70216065/bash-json-compare-two-list-and-delete-id",
        "title": "Bash JSON compare two list and delete id"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638546150,
                "post_id": 70216698,
                "comment_id": 124125192,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638545367,
                "creation_date": 1638545367,
                "answer_id": 70216795,
                "question_id": 70216698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re very close. Add `-r` to output raw strings instead of JSON, and use `| .key, .value` to output the key and value strings as separate items so they are shown on adjacent lines.\r\n\r\n```\r\njq -r &#39;. | to_entries | .[] | .value |= &quot;  * &quot;+join(&quot;\\n  * &quot;) | .key = &quot;* &quot;+.key | .key, .value&#39;\r\n```",
                "title": "Translate JSON into Markdown list with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638545673,
                "creation_date": 1638545673,
                "answer_id": 70216849,
                "question_id": 70216698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another solution, using `join()` and string interpolation:\r\n```\r\nto_entries[] | &quot;* \\(.key)\\n  * \\(.value | join(&quot;\\n  * &quot;))&quot;\r\n```\r\n\r\nWill produce:\r\n```json\r\n* project1\r\n  * task1a\r\n  * task1b\r\n* project2\r\n  * task2a\r\n  * task2b\r\n  * task2c\r\n```\r\n\r\n```\r\njq -r &#39;to_entries[] | &quot;* \\(.key)\\n  * \\(.value | join(&quot;\\n  * &quot;))&quot;&#39; input\r\n```\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/IaZ1mIJwR-)",
                "title": "Translate JSON into Markdown list with jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1638549668,
                "last_edit_date": 1638549668,
                "creation_date": 1638548140,
                "answer_id": 70217458,
                "question_id": 70216698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yet another solution, without the update operator `|=`, without the `join()` builtin and without explicit newline characters `\\n`:\r\n```sh\r\njq -r &#39;to_entries[] | &quot;* \\(.key)&quot;, &quot;  * \\(.value[])&quot;&#39;\r\n```\r\n```\r\n* project1\r\n  * task1a\r\n  * task1b\r\n* project2\r\n  * task2a\r\n  * task2b\r\n  * task2c\r\n```\r\n[Demo](https://jqplay.org/s/uMN3jcUjPL)",
                "title": "Translate JSON into Markdown list with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1638549668,
        "creation_date": 1638545028,
        "last_edit_date": 1638545140,
        "question_id": 70216698,
        "body_markdown": "I&#39;ve got a JSON structure for projects and tasks:\r\n\r\n```json\r\n{\r\n  &quot;project1&quot;: [\r\n    &quot;task1a&quot;,\r\n    &quot;task1b&quot;\r\n  ],\r\n  &quot;project2&quot;: [\r\n    &quot;task2a&quot;,\r\n    &quot;task2b&quot;,\r\n    &quot;task2c&quot;\r\n  ]\r\n}\r\n```\r\n\r\nwhich I&#39;d like to convert to MD-like list:\r\n\r\n```markdown\r\n* project1\r\n  * task1a\r\n  * task1b\r\n* project2\r\n  * task2a\r\n  * task2b\r\n  * task2c\r\n```\r\n\r\nmainly using `jq` and `sh`/`bash` \r\n\r\nthe best I can do is:\r\n\r\n```shell\r\njq &#39;. | to_entries | .[] | .value |= &quot;  * &quot;+join(&quot;\\n  * &quot;)+&quot;\\n&quot; | .key = &quot;* &quot;+.key&#39;\r\n```\r\n\r\nbut then I&#39;m stuck trying to properly print `.value` string along with `.key` ",
        "link": "https://stackoverflow.com/questions/70216698/translate-json-into-markdown-list-with-jq",
        "title": "Translate JSON into Markdown list with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "environment-variables",
            "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": 1638549559,
                "post_id": 70217481,
                "comment_id": 124126657,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12154724,
                    "reputation": 37,
                    "user_id": 9552400,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63a2ba0b3b2f8c5338473841df0d58f7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Aditya Sharma",
                    "link": "https://stackoverflow.com/users/9552400/aditya-sharma"
                },
                "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": 1638549869,
                "post_id": 70217481,
                "comment_id": 124126800,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1638549226,
                "creation_date": 1638549226,
                "answer_id": 70217707,
                "question_id": 70217481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to `export` the Bash variables to be seen by `jq`:\r\n```sh\r\nexport PROJECT1=&quot;randomtext1&quot;\r\nexport PROJECT2=&quot;randomtext2&quot;\r\nexport PROJECT4=&quot;randomtext3&quot;\r\n```\r\nThen you can go with:\r\n```sh\r\njq -n &#39;with_entries((.value | select(startswith(&quot;$&quot;))) |= env[.[1:]])&#39;\r\n```\r\nand get:\r\n```json\r\n{\r\n  &quot;host1&quot;: &quot;randomtext1&quot;,\r\n  &quot;host2&quot;: &quot;randomtext2&quot;,\r\n  &quot;host3&quot;: &quot;xyz&quot;,\r\n  &quot;host4&quot;: &quot;randomtext3&quot;\r\n}\r\n```",
                "title": "How to replace values in a JSON dictionary with their respective shell variables in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638562946,
                "last_edit_date": 1638562946,
                "creation_date": 1638551749,
                "answer_id": 70218258,
                "question_id": 70217481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Exporting a large number of shell variables might not be such a good idea and does not address the problem of array-valued variables. It might therefore be a good idea to think along the lines of printing the variable=value details to a file, and then combining that file with the template. It’s easy to do and examples on the internet abound and probably here on SO as well. You could, for example, use `printf` like so:\r\n\r\n```\r\nprintf &quot;%s\\t&quot; ${BASH_VERSINFO[@]}\r\n3\t2\t57\t1\t\r\n```\r\n\r\nYou might also find `declare -p` helpful.\r\n\r\nSee also https://github.com/stedolan/jq/wiki/Cookbook#arbitrary-strings-as-template-variables",
                "title": "How to replace values in a JSON dictionary with their respective shell variables in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677583924,
                "creation_date": 1677583924,
                "answer_id": 75591480,
                "question_id": 70217481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a method that replaces all variables in the file regardless of their nesting level. It keeps the values as they are if they are not defined in the environment. In the following example STREET is not defined as environment variable and therefore remains unchanged.\r\n\r\nThe matching regex (^\\\\$[A-Z_-]+$) can be changed to match your needs, e.g. variables defined with ${} or {{}}.\r\n\r\n\r\n    $ cat test.json\r\n    {\r\n      &quot;name&quot;: &quot;$NAME&quot;,\r\n      &quot;address&quot;: [{\r\n        &quot;street&quot;: &quot;$STREET&quot;,\r\n        &quot;other&quot;: &quot;$not_matching&quot;\r\n      }]\r\n    }\r\n\r\n    $ cat test.json | NAME=Joe jq &#39;walk( if type == &quot;string&quot; and test(&quot;^\\\\$[A-Z_-]+$&quot;) then . |= env[.[1:]] // . else . end )&#39;\r\n    {\r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;address&quot;: [\r\n        {\r\n          &quot;street&quot;: &quot;$STREET&quot;,\r\n          &quot;other&quot;: &quot;$not_matching&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThe only limitation is that it only replaces full matched values. It will not work with a value like `https://$HOSTNAME/index.html`. For this use `sed` instead.",
                "title": "How to replace values in a JSON dictionary with their respective shell variables in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1677583924,
        "creation_date": 1638548252,
        "last_edit_date": 1638979772,
        "question_id": 70217481,
        "body_markdown": "I have the following JSON structure:\r\n\r\n```json\r\n{\r\n  &quot;host1&quot;: &quot;$PROJECT1&quot;,\r\n  &quot;host2&quot;: &quot;$PROJECT2&quot;,\r\n  &quot;host3&quot; : &quot;xyz&quot;,\r\n  &quot;host4&quot; : &quot;$PROJECT4&quot;\r\n}\r\n```\r\n\r\nAnd the following environment variables in the shell:\r\n```sh\r\nPROJECT1=&quot;randomtext1&quot;\r\nPROJECT2=&quot;randomtext2&quot;\r\nPROJECT4=&quot;randomtext3&quot;\r\n```\r\n\r\nI want to check the values for each key, if they have a &quot;$&quot; character in them, replace them with their respective environment variable(which is already present in the shell) so that my JSON template is rendered with the correct environment variables.\r\n\r\nI can use the `--args` option of jq but there are quite a lot of variables in my actual JSON template that I want to render.\r\n\r\nI have been trying the following:\r\n```sh\r\njq &#39;with_entries(.values as v | env.$v)\r\n```\r\n\r\nBasically making each value as a variable, then updating its value with the variable from the env object but seems like I am missing out on some understanding. Is there a straightforward way of doing this?\r\n\r\n*EDIT*\r\n\r\nThanks to the answers on this question, I was able to achieve my larger goal for a part of which this question was asked\r\n- iterating over each value in an object, \r\n- checking its value, \r\n    - if it&#39;s a string and starts with the character &quot;$&quot;\r\n       - use the value to update it with an environment variable of the same name . \r\n    - if it&#39;s an array\r\n        - use the value to retrieve an environment variable of the same name \r\n        - split the string with &quot;,&quot; as delimiter, which returns an array of strings\r\n        - Update the value with the array of strings \r\n```\r\n         \r\njq &#39;with_entries(.value |= (if (type==&quot;array&quot;) then (env[.[0][1:]] | split(&quot;,&quot;)) elif (type==&quot;string&quot; and startswith(&quot;$&quot;)) then (env[.[1:]]) else  . end))&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/70217481/how-to-replace-values-in-a-json-dictionary-with-their-respective-shell-variables",
        "title": "How to replace values in a JSON dictionary with their respective shell variables in jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "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": 1638554490,
                "post_id": 70218616,
                "comment_id": 124128437,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638555606,
                "last_edit_date": 1638555606,
                "creation_date": 1638554012,
                "answer_id": 70218737,
                "question_id": 70218616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re projecting to a filtered view of your object (with all the `|` in your filter). Since you just want to do assignments, make sure that is at the top of your filter. `select` the properties you want to adjust then do the assignment.\r\n\r\nIt&#39;ll be easier if you used paths to do this, since you&#39;re filtering based on the path.\r\n\r\n```\r\nsetpath(path(.dependencies[]) | select(.[1] | startswith(&quot;com.company1&quot;)); &quot;0.2&quot;)\r\n```\r\n\r\nwhich produces:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;com.company1.package1&quot;,\r\n  &quot;version&quot;: &quot;0.2&quot;,\r\n  &quot;dependencies&quot;: {\r\n    &quot;com.company1.package2&quot;: &quot;0.2&quot;,\r\n    &quot;com.company2.package1&quot;: &quot;2.3&quot;\r\n  }\r\n}\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/JfzXELoOxj)",
                "title": "Set a value for an element found with select() but return the whole json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638554376,
                "creation_date": 1638554376,
                "answer_id": 70218803,
                "question_id": 70218616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there. Use the update operator `|=` and inside the update a direct assignment `.value = &quot;0.2&quot;`.\r\n```sh\r\njq &#39;.dependencies |= with_entries(select(.key | startswith(&quot;com.company1&quot;)).value = &quot;0.2&quot;)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;com.company1.package1&quot;,\r\n  &quot;version&quot;: &quot;0.2&quot;,\r\n  &quot;dependencies&quot;: {\r\n    &quot;com.company1.package2&quot;: &quot;0.2&quot;,\r\n    &quot;com.company2.package1&quot;: &quot;2.3&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/vzNjTyKfa-)",
                "title": "Set a value for an element found with select() but return the whole json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638635817,
                "last_edit_date": 1638635817,
                "creation_date": 1638635507,
                "answer_id": 70227517,
                "question_id": 70218616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a ruby JSON to do this:\r\n\r\n    ruby -r JSON -e &#39;d=JSON.parse($&lt;.read)\r\n    d[&quot;dependencies&quot;].each {|k,v| d[&quot;dependencies&quot;][k]=&quot;0.2&quot; if k[/\\bcompany1\\b/] }\r\n    puts d.to_json&#39; file | jq .\r\n\r\n    # using jq to pretty print...\r\n\r\nOr, later versions of ruby, you can do:\r\n\r\n    ruby -r JSON -e &#39;d=JSON.parse($&lt;.read)\r\n    d[&quot;dependencies&quot;].each {|k,v| d[&quot;dependencies&quot;][k]=&quot;0.2&quot; if k[/\\bcompany1\\b/] }\r\n    puts JSON.pretty_generate(d)&#39; file \r\n\r\nEither prints:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;com.company1.package1&quot;,\r\n      &quot;version&quot;: &quot;0.2&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;com.company1.package2&quot;: &quot;0.2&quot;,\r\n        &quot;com.company2.package1&quot;: &quot;2.3&quot;\r\n      }\r\n    }",
                "title": "Set a value for an element found with select() but return the whole json"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1638879245,
        "creation_date": 1638553433,
        "last_edit_date": 1638879245,
        "question_id": 70218616,
        "body_markdown": "I have a JSON like this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;com.company1.package1&quot;,\r\n      &quot;version&quot;: &quot;0.2&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;com.company1.package2&quot;: &quot;0.1&quot;,\r\n        &quot;com.company2.package1&quot;: &quot;2.3&quot;\r\n      }\r\n    }\r\n\r\nAnd I want to change all dependencies with keys starting with &quot;com.company1&quot; to &quot;0.2&quot;.\r\n\r\nI managed to change it with this:\r\n\r\n    jq &#39;.dependencies | with_entries(select(.key|startswith(&quot;com.company1&quot;))) | .[]=&quot;0.2&quot;&#39;\r\n\r\nBut this only returns \r\n\r\n    {\r\n      &quot;com.company1.package2&quot;: &quot;0.2&quot;\r\n    }\r\n\r\nI would like to get the whole initial JSON with only this value changed. Like so:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;com.company1.package1&quot;,\r\n      &quot;version&quot;: &quot;0.2&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;com.company1.package2&quot;: &quot;0.2&quot;,\r\n        &quot;com.company2.package1&quot;: &quot;2.3&quot;\r\n      }\r\n    }\r\n\r\nHow could go about that?\r\n",
        "link": "https://stackoverflow.com/questions/70218616/set-a-value-for-an-element-found-with-select-but-return-the-whole-json",
        "title": "Set a value for an element found with select() but return the whole json"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661790740,
                "last_edit_date": 1661790740,
                "creation_date": 1638563288,
                "answer_id": 70220304,
                "question_id": 70220159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your JSON input is **not** proper JSON as it has\r\n- commas after the `.source` field but no following field\r\n- no commas between the elements of the top-level array\r\n- no quotes around the objects&#39; field names\r\n\r\nYou&#39;d need to address these issues first before proceeding. This is how it should look like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;timestamp&quot;: 1638550971085,\r\n    &quot;id&quot;: &quot;54f&quot;,\r\n    &quot;body&quot;: &quot;Orange&quot;,\r\n    &quot;source&quot;: &quot;827261&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: 1638550971096,\r\n    &quot;id&quot;: &quot;54f&quot;,\r\n    &quot;body&quot;: &quot;Apple&quot;,\r\n    &quot;source&quot;: &quot;137261&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: 1638550971126,\r\n    &quot;id&quot;: &quot;5da&quot;,\r\n    &quot;body&quot;: &quot;Pear&quot;,\r\n    &quot;source&quot;: &quot;1da61&quot;\r\n  }\r\n]\r\n```\r\nThen you can go with this\r\n- `localtime` (available since jq 1.6) converts a timestamp of seconds (so, divide yours by 1000) since the Unix epoch into a so-called &quot;broken down time&quot; object (see the [manual](https://stedolan.github.io/jq/manual/)) which you can either process using `strftime` (see the [answer from David Conrad](https://stackoverflow.com/a/73529922/2158479)), or parse yourself manually. With `.[:3] | .[1] += 1 | join(&quot;-&quot;)` I provided a rather primitive example for demonstration purposes which concatenates its first three items (year, month, day) with dashes in between, after incrementing the second item (as the month has a 0-based encoding) - for padding with zeroes check out one of the answers over [here](https://stackoverflow.com/questions/64957982/how-to-pad-numbers-with-jq)\r\n- `@tsv` creates tabs between the columns\r\n```sh\r\njq -r &#39;\r\n  .[]\r\n  | select(.id == &quot;54f&quot;)\r\n  | [(.timestamp / 1000 | localtime | .[:3] | join(&quot;-&quot;)), .body, .source]\r\n  | @tsv\r\n&#39; file.json\r\n```\r\n```\r\n2021-12-3\tOrange\t827261\r\n2021-12-3\tApple\t137261\r\n```\r\n[Demo](https://jqplay.org/s/IAflnD7pPa2)",
                "title": "JQ filter formatting"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661781210,
                "creation_date": 1661781210,
                "answer_id": 73529922,
                "question_id": 70220159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the other answer states, your JSON is not correct. After fixing that, you can filter and extract the data as that answer suggests, but use the `strftime` function to format the dates properly:\r\n\r\n    jq -r &#39;.[] | select(.id == &quot;54f&quot;)\r\n        | [(.timestamp / 1000 | localtime | strftime(&quot;%Y-%m-%d&quot;)), .body, .source]\r\n        | @tsv&#39; file.json\r\n\r\nThe use of `strftime(&quot;%Y-%m-%d&quot;)` is critical to both displaying the correct month and formatting the date with leading zeroes on single-digit months and days.\r\n\r\n    2021-12-03      Orange  827261\r\n    2021-12-03      Apple   137261",
                "title": "JQ filter formatting"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1661790740,
        "creation_date": 1638562388,
        "last_edit_date": 1638565386,
        "question_id": 70220159,
        "body_markdown": "I have a JSON file I&#39;d like to filter by the ID field, and show the matching Body and Source fields. \r\n\r\nFormat of the JSON file to filter\r\n\r\n ```\r\n [\r\n{\r\n \t&quot;timestamp&quot; : 1638550971085,\r\n    &quot;id&quot; : &quot;54f&quot;,\r\n\t&quot;body&quot; : &quot;Orange&quot;,\r\n\t&quot;source&quot; : &quot;827261&quot;\r\n},\r\n{\r\n \t&quot;timestamp&quot; : 1638550971096,\r\n\t&quot;id&quot; : &quot;54f&quot;,\r\n\t&quot;body&quot; : &quot;Apple&quot;,\r\n\t&quot;source&quot; : &quot;137261&quot;\r\n},\r\n{\r\n \t&quot;timestamp&quot; : 1638550971126,\r\n\t&quot;id&quot; : &quot;5da&quot;,\r\n\t&quot;body&quot; : &quot;Pear&quot;,\r\n\t&quot;source&quot; : &quot;1da61&quot;\r\n}\r\n]\r\n```\r\n\r\nIn this example I would like to filter where id = 54f and show the Timestamp (Unixtime converted to local time), Body and Source fields that match, ideally as shown below. \r\n```\r\n[Timestamp]    Orange     827261\r\n[Timestamp]    Apple      137261\r\n```\r\n\r\nI have tried this command, but it is showing extra body / source fields outside of the SQL filter. It also adds a line break between printing the body and source, and ideally I&#39;d like this printed on one line (tab separated). I also don&#39;t know how to convert the timestamp to localtime string.\r\n\r\n\r\n```\r\nmore file.json | jq &#39;.[] | select(.Id==&quot;54f&quot;).body, .source&#39; \r\n```",
        "link": "https://stackoverflow.com/questions/70220159/jq-filter-formatting",
        "title": "JQ filter formatting"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638563969,
                "post_id": 70220217,
                "comment_id": 124131328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638564422,
                "post_id": 70220217,
                "comment_id": 124131455,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1638571113,
                "last_edit_date": 1638571113,
                "creation_date": 1638565158,
                "answer_id": 70220610,
                "question_id": 70220217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Populating a bash array with `mapfile` from null delimited raw output from `jq`:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\nmapfile -d &#39;&#39; all_nvme_volumes &lt; &lt;(\r\n  sudo nvme list --output-format=json |\r\n  jq --join-output &#39;.Devices[].DevicePath + &quot;\\u0000&quot;&#39;\r\n)\r\n```\r\n\r\n",
                "title": "return nvme list as array using jq and loop thru it"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1638571939,
                "last_edit_date": 1638571939,
                "creation_date": 1638567910,
                "answer_id": 70220994,
                "question_id": 70220217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution for bash &lt; 4.4:\r\n\r\n``` bash\r\n#!/bin/bash\r\nIFS=$&#39;\\t&#39; read -r -a all_nvme_volumes &lt; &lt;(\r\n    sudo nvme list -o json | jq -r &#39;[ .Devices[].DevicePath ] | @tsv&#39;\r\n)\r\n```\r\n**note:** device paths shouldn&#39;t be escaped by `@tsv`, so you won&#39;t need to unescape the values, but in case you use this trick for other purposes, you can unescape a value with `printf -v value &#39;%b&#39; &quot;$value&quot;`\r\n\r\n---\r\n\r\n&gt; How do I loop thru them process them individually?\r\n\r\nWell, once you have the array, you can loop though its elements with:\r\n\r\n``` bash\r\nfor nvme_volume in &quot;${all_nvme_volumes[@]}&quot;\r\ndo\r\n    # process &quot;$nvme_volume&quot;\r\ndone\r\n```\r\n\r\nBut, if you only need to loop though the nvme volumes without storing them then you can use @L&#233;aGris &lt;a href=&quot;https://stackoverflow.com/a/70220610/3387716&quot;&gt;null delimiter method&lt;/a&gt; with a `while` loop:\r\n\r\n``` bash\r\n#!/bin/bash\r\nwhile IFS=&#39;&#39; read -r -d &#39;&#39; nvme_volume\r\ndo\r\n    # process &quot;$nvme_volume&quot;\r\ndone &lt; &lt;(sudo nvme list -o json | jq -j &#39;.Devices[].DevicePath + &quot;\\u0000&quot;&#39;)\r\n```",
                "title": "return nvme list as array using jq and loop thru it"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1638571939,
        "creation_date": 1638562717,
        "question_id": 70220217,
        "body_markdown": "This is how I am grabbing all the NVME volumes:\r\n\r\n    all_nvme_volumes=$(sudo nvme list -o json | jq .Devices[].DevicePath)\r\n\r\nThis how the output looks like:\r\n\r\n    &quot;/dev/nvme0n1&quot; &quot;/dev/nvme1n1&quot; &quot;/dev/nvme2n1&quot; &quot;/dev/nvme3n1&quot; &quot;/dev/nvme4n1&quot; &quot;/dev/nvme6n1&quot;\r\n\r\nHow do I loop thru them process them individually?\r\n\r\nI tried `for r in &quot;${all_nvme_volumes[@]}&quot;; do echo &quot;Device Name: $r&quot;; done` but the output is `Device Name: &quot;/dev/nvme0n1&quot;\r\n&quot;/dev/nvme1n1&quot;\r\n&quot;/dev/nvme2n1&quot;\r\n&quot;/dev/nvme3n1&quot;\r\n&quot;/dev/nvme4n1&quot;\r\n&quot;/dev/nvme6n1&quot;`\r\nwhich is one string instead of each element of array:",
        "link": "https://stackoverflow.com/questions/70220217/return-nvme-list-as-array-using-jq-and-loop-thru-it",
        "title": "return nvme list as array using jq and loop thru it"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638727724,
                "last_edit_date": 1638727724,
                "creation_date": 1638678457,
                "answer_id": 70231482,
                "question_id": 70231403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you are selecting bits of data from different levels of the input objects, you will need to specify the selection more precisely.  \r\n\r\nAs your input consists of a stream of JSON objects, let&#39;s start with a function for reading one of those objects:\r\n```\r\n# Input and output: a JSON object\r\ndef get:\r\n  {company_number} as $number\r\n  | .data\r\n  | (.address | {address_line_1,country,locality,postal_code,premises}) as $address\r\n  | {ceased_on,country_of_residence} as $details\r\n  | (.date_of_birth | {month, year}) as $dob\r\n  | $number + $address + $details + $dob + {etag,kind}\r\n  ;\r\n```\r\n\r\nThere are several ways to read JSON streams, but it&#39;s quite convenient to use use `input` and `inputs` with the -n command-line option.  \r\n\r\nTo make things easy to read, let&#39;s next define another helper function for producing an array of the relevant data:\r\n```\r\ndef getRow:\r\n  get | [.[]];\r\n```\r\n\r\nPutting it all together:\r\n```  \r\n(input|get)\r\n| keys_unsorted,\r\n  [.[]],\r\n  (inputs | getRow)\r\n| @csv\r\n```\r\n\r\nDon&#39;t forget the -r and -n command-line options!\r\n\r\n---\r\nFootnote:\r\n\r\n&lt;sup&gt; In general, using [.[]] to &quot;flatten&quot; a JSON object to a flat array of values is ill-advised, but in the present case, we have ensured a consistent ordering of keys in `get`, and it is reasonable to assume that none of the values in the selected fields are compound, as suggested by the snippet and the 500,000 records in one of the snapshot files.  A &quot;robustification&quot; would, however, be trivial to achieve (e.g. using `tostring`), and might therefore be advisable.&lt;/sup&gt;\r\n\r\n&lt;sup&gt;If you were using gojq (the Go implementation of jq), you would have to do things slightly differently as gojq does not respect user-specified ordering of keys.  You&#39;d have to generate the header row differently and make minor changes to `get`.&lt;/sup&gt; ",
                "title": "JSON to CSV conversion using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1638779747,
        "creation_date": 1638677330,
        "last_edit_date": 1638779747,
        "question_id": 70231403,
        "body_markdown": "I have a 1GB JSON file I like to convert to CSV format. The file contains information about UK company people with significant control (PSC).\r\nfile source:  http://download.companieshouse.gov.uk/en_pscdata.html\r\n\r\n\r\nhere is a data snippet of PSC Data product:\r\n\r\n\r\n```\r\n{&quot;company_number&quot;:&quot;04502074&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Grove Hall&quot;,&quot;address_line_2&quot;:&quot;Ashbourne Green&quot;,&quot;locality&quot;:&quot;Ashbourne&quot;,&quot;postal_code&quot;:&quot;DE6 1JD&quot;,&quot;region&quot;:&quot;Derbyshire&quot;},&quot;country_of_residence&quot;:&quot;England&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:11,&quot;year&quot;:1964},&quot;etag&quot;:&quot;f9a632332f63b61f004569f99d6b15e3e6d28192&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/04502074/persons-with-significant-control/individual/34zTsx2BFGMyn0lJe2REL656U8w&quot;},&quot;name&quot;:&quot;Mr Philip Anthony Donlan&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Philip&quot;,&quot;middle_name&quot;:&quot;Anthony&quot;,&quot;surname&quot;:&quot;Donlan&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-50-to-75-percent&quot;],&quot;notified_on&quot;:&quot;2016-04-06&quot;}}\r\n{&quot;company_number&quot;:&quot;10260075&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;country&quot;:&quot;England&quot;,&quot;locality&quot;:&quot;Widnes&quot;,&quot;postal_code&quot;:&quot;WA8 9DH&quot;,&quot;premises&quot;:&quot;1 Stockswell Farm Court&quot;},&quot;country_of_residence&quot;:&quot;England&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:12,&quot;year&quot;:1978},&quot;etag&quot;:&quot;dbf13fc08cb9136450089681b6e9364eb8458129&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/10260075/persons-with-significant-control/individual/Br24rkYIl3ZKam3C9fT4o_9uF7k&quot;},&quot;name&quot;:&quot;Mr Daniel Thomas Ross&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Daniel&quot;,&quot;middle_name&quot;:&quot;Thomas&quot;,&quot;surname&quot;:&quot;Ross&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;English&quot;,&quot;natures_of_control&quot;:[&quot;significant-influence-or-control&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;SC539354&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;5 West Victoria Dock Road&quot;,&quot;locality&quot;:&quot;Dundee&quot;,&quot;postal_code&quot;:&quot;DD1 3JT&quot;,&quot;premises&quot;:&quot;Begbies Traynor (Central) Llp, River Court&quot;},&quot;country_of_residence&quot;:&quot;Scotland&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:4,&quot;year&quot;:1980},&quot;etag&quot;:&quot;37599a22ede050072457db60af6e75ba8e237246&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/SC539354/persons-with-significant-control/individual/T7LPjXkKRuaunfMRjfFrnWiHEnI&quot;},&quot;name&quot;:&quot;Mr Stuart Hemple&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Stuart&quot;,&quot;surname&quot;:&quot;Hemple&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-75-to-100-percent&quot;,&quot;voting-rights-75-to-100-percent&quot;,&quot;right-to-appoint-and-remove-directors&quot;,&quot;significant-influence-or-control&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;02722495&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Beechdene&quot;,&quot;address_line_2&quot;:&quot;108 Coventry Road&quot;,&quot;locality&quot;:&quot;Warwick&quot;,&quot;postal_code&quot;:&quot;CV34 5HH&quot;},&quot;country_of_residence&quot;:&quot;England&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:12,&quot;year&quot;:1953},&quot;etag&quot;:&quot;610138d3809ab3237b609f3cb93bfe4bf89d7581&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/02722495/persons-with-significant-control/individual/8g4ED3usT4wLPEqra7dE97eqmHE&quot;},&quot;name&quot;:&quot;Mr Marshall Fenn Stephenson&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Marshall&quot;,&quot;middle_name&quot;:&quot;Fenn&quot;,&quot;surname&quot;:&quot;Stephenson&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-25-to-50-percent&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;05495733&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Brompton Road&quot;,&quot;country&quot;:&quot;England&quot;,&quot;locality&quot;:&quot;London&quot;,&quot;postal_code&quot;:&quot;SW3 2AS&quot;,&quot;premises&quot;:&quot;253&quot;},&quot;country_of_residence&quot;:&quot;Italy&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:4,&quot;year&quot;:1953},&quot;etag&quot;:&quot;d45e5d2aa905e769e6fd3aa364e301f73b047985&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/05495733/persons-with-significant-control/individual/Oqp-z-D5JTX0mjXTtmOqmct1vR4&quot;},&quot;name&quot;:&quot;Mr Roberto Gavazzi&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Roberto&quot;,&quot;surname&quot;:&quot;Gavazzi&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;Italian&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-50-to-75-percent&quot;,&quot;voting-rights-50-to-75-percent&quot;,&quot;right-to-appoint-and-remove-directors-as-firm&quot;,&quot;significant-influence-or-control-as-firm&quot;],&quot;notified_on&quot;:&quot;2016-06-30&quot;}}\r\n{&quot;company_number&quot;:&quot;SC539355&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;6 Dryden Road&quot;,&quot;country&quot;:&quot;Scotland&quot;,&quot;locality&quot;:&quot;Loanhead&quot;,&quot;postal_code&quot;:&quot;EH20 9LZ&quot;,&quot;premises&quot;:&quot;Bilston Glen Business Centre&quot;},&quot;country_of_residence&quot;:&quot;Scotland&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:10,&quot;year&quot;:1990},&quot;etag&quot;:&quot;b03abb8bb1b6f95039dd896210d7c231d8784c31&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/SC539355/persons-with-significant-control/individual/tYyjuJrp6Ifp327VxThVGeRswMM&quot;},&quot;name&quot;:&quot;Mr David John Kelly&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;David&quot;,&quot;middle_name&quot;:&quot;John&quot;,&quot;surname&quot;:&quot;Kelly&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;Scottish&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-75-to-100-percent&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;SC539356&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Scholes&quot;,&quot;country&quot;:&quot;England&quot;,&quot;locality&quot;:&quot;Wigan&quot;,&quot;postal_code&quot;:&quot;WN1 1YF&quot;,&quot;premises&quot;:&quot;106 Douglas House&quot;},&quot;country_of_residence&quot;:&quot;England&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:3,&quot;year&quot;:1961},&quot;etag&quot;:&quot;2f15d0fbacc68763b00e203ab0820b0911ac5906&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/SC539356/persons-with-significant-control/individual/0eATs-Ecoj9ie0_pBCq29L6UtlM&quot;},&quot;name&quot;:&quot;Mr Mark Edward Sowery&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Mark&quot;,&quot;middle_name&quot;:&quot;Edward&quot;,&quot;surname&quot;:&quot;Sowery&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-75-to-100-percent&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;07674942&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Old Gloucester Street&quot;,&quot;country&quot;:&quot;England&quot;,&quot;locality&quot;:&quot;London&quot;,&quot;postal_code&quot;:&quot;WC1N 3AX&quot;,&quot;premises&quot;:&quot;27&quot;},&quot;country_of_residence&quot;:&quot;Sierra Leone&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:2,&quot;year&quot;:1979},&quot;etag&quot;:&quot;f2e9cc0033cd5ef24fcda06baeff06bb8ea72654&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/07674942/persons-with-significant-control/individual/D31C5Na0B1I4rqM1RYwpy3J8oKA&quot;},&quot;name&quot;:&quot;Mr Muhammad Umar Babar&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Muhammad&quot;,&quot;middle_name&quot;:&quot;Umar&quot;,&quot;surname&quot;:&quot;Babar&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;Pakistani&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-75-to-100-percent&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;09639364&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Galmington Road&quot;,&quot;country&quot;:&quot;United Kingdom&quot;,&quot;locality&quot;:&quot;Taunton&quot;,&quot;postal_code&quot;:&quot;TA1 5NP&quot;,&quot;premises&quot;:&quot;58b&quot;,&quot;region&quot;:&quot;Somerset&quot;},&quot;country_of_residence&quot;:&quot;United Kingdom&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:12,&quot;year&quot;:1977},&quot;etag&quot;:&quot;25ff7d41f9b8f257f0d41ae82e88202017beff34&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/09639364/persons-with-significant-control/individual/qlPpucOQopiIgq1xzZIb6xjO5JQ&quot;},&quot;name&quot;:&quot;Mr Li Ying Cao&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Li&quot;,&quot;middle_name&quot;:&quot;Ying&quot;,&quot;surname&quot;:&quot;Cao&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-75-to-100-percent&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n{&quot;company_number&quot;:&quot;08541397&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Hedley Avenue&quot;,&quot;locality&quot;:&quot;Blyth&quot;,&quot;postal_code&quot;:&quot;NE24 3JP&quot;,&quot;premises&quot;:&quot;27&quot;,&quot;region&quot;:&quot;Northumberland&quot;},&quot;country_of_residence&quot;:&quot;England&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:11,&quot;year&quot;:1949},&quot;etag&quot;:&quot;b843664ca67a4274ee6f6cc9816ab35cd8367190&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/08541397/persons-with-significant-control/individual/KuddC6fZH17ifaXSAVWEcC2ba74&quot;},&quot;name&quot;:&quot;Mr David Harwood&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;David&quot;,&quot;surname&quot;:&quot;Harwood&quot;,&quot;title&quot;:&quot;Mr&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-75-to-100-percent&quot;],&quot;notified_on&quot;:&quot;2016-05-23&quot;}}\r\n{&quot;company_number&quot;:&quot;02832188&quot;,&quot;data&quot;:{&quot;address&quot;:{&quot;address_line_1&quot;:&quot;Lodge Road&quot;,&quot;country&quot;:&quot;England&quot;,&quot;locality&quot;:&quot;London&quot;,&quot;postal_code&quot;:&quot;NW4 4DD&quot;,&quot;premises&quot;:&quot;1&quot;},&quot;country_of_residence&quot;:&quot;England&quot;,&quot;date_of_birth&quot;:{&quot;month&quot;:5,&quot;year&quot;:1952},&quot;etag&quot;:&quot;0c21b2b560ee43ca0c2ffd9f07d5ca564536b6e2&quot;,&quot;kind&quot;:&quot;individual-person-with-significant-control&quot;,&quot;links&quot;:{&quot;self&quot;:&quot;/company/02832188/persons-with-significant-control/individual/Rh8pb-L7fEZzkyhttuCwVjjL_eA&quot;},&quot;name&quot;:&quot;Mrs Rachel Weissman&quot;,&quot;name_elements&quot;:{&quot;forename&quot;:&quot;Rachel&quot;,&quot;surname&quot;:&quot;Weissman&quot;,&quot;title&quot;:&quot;Mrs&quot;},&quot;nationality&quot;:&quot;British&quot;,&quot;natures_of_control&quot;:[&quot;ownership-of-shares-25-to-50-percent&quot;,&quot;voting-rights-25-to-50-percent&quot;,&quot;right-to-appoint-and-remove-directors&quot;,&quot;significant-influence-or-control&quot;],&quot;notified_on&quot;:&quot;2016-07-01&quot;}}\r\n```\r\n\r\n\r\nI have created a input file in.json, contain my json data as providet by companies house: file source:  http://download.companieshouse.gov.uk/en_pscdata.html\r\n\r\nI have created a output file out.csv\r\n\r\nI am trying to run the follwing code:\r\n\r\n    jq -r &#39;map({company_number,address_line_1,country,locality,postal_code,premises,ceased_on,country_of_residence,month,year,etag,kind}) | (first | keys_unsorted) as $keys | map([to_entries[] | .value]) as $rows | $keys,$rows[] | @csv&#39; in.json &gt; out.csv\r\n\r\n\r\nim getting the following error: \r\n\r\n\r\n  jq: error (at in.json:0): Cannot index string with string &quot;company_number&quot;\r\n\r\n\r\n\r\nplease advise on what am I doing wrong and how to get this done.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70231403/json-to-csv-conversion-using-jq",
        "title": "JSON to CSV conversion using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638736975,
                "last_edit_date": 1638736975,
                "creation_date": 1638736658,
                "answer_id": 70238344,
                "question_id": 70238232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you asking for help with the command-line JSON processor [jq](https://github.com/stedolan/jq) or the JavaScript library [jQuery](https://jquery.com/)? They are not the same. For jq, try\r\n```\r\njq &#39;\r\n  .applications\r\n  | map(select(.name == &quot;flv&quot;))[].live.streams\r\n  | map(select(.name == &quot;mystream&quot; and .active))[].meta.video.height\r\n&#39;\r\n```\r\n```\r\n720\r\n```\r\n[Demo](https://jqplay.org/s/A7rj_ltGpI)",
                "title": "json jq request format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1638737355,
        "creation_date": 1638735796,
        "last_edit_date": 1638737355,
        "question_id": 70238232,
        "body_markdown": "I need help to extract data from this JSON file using jq. \r\n\r\nThe app `flv` then verify the streamname `mystrame` is active and extract `meta.video.height`\r\n\r\nI did try lot of queries without success and my jq knowledge is poor. \r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n      &quot;port&quot;: 1935,\r\n      &quot;server_index&quot;: 0,\r\n      &quot;applications&quot;: [{\r\n          &quot;name&quot;: &quot;hls&quot;,\r\n          &quot;live&quot;: {\r\n            &quot;streams&quot;: [{\r\n              &quot;name&quot;: &quot;donbosco&quot;,\r\n              &quot;time&quot;: 2380739,\r\n              &quot;bw_in&quot;: 2112440,\r\n              &quot;bytes_in&quot;: 541618713,\r\n              &quot;bw_out&quot;: 0,\r\n              &quot;bytes_out&quot;: 0,\r\n              &quot;bw_audio&quot;: 35544,\r\n              &quot;bw_video&quot;: 2076888,\r\n              &quot;clients&quot;: [{\r\n                &quot;id&quot;: 453,\r\n                &quot;address&quot;: &quot;127.0.0.1&quot;,\r\n                &quot;time&quot;: 2380959,\r\n                &quot;flashver&quot;: &quot;FMLE/3.0 (compatible; Lavf57.83.100)&quot;,\r\n                &quot;dropped&quot;: 0,\r\n                &quot;avsync&quot;: 28,\r\n                &quot;timestamp&quot;: 2382635,\r\n                &quot;publishing&quot;: true,\r\n                &quot;active&quot;: true\r\n              }],\r\n              &quot;records&quot;: [],\r\n              &quot;meta&quot;: {\r\n                &quot;video&quot;: {\r\n                  &quot;width&quot;: 1168,\r\n                  &quot;height&quot;: 720,\r\n                  &quot;frame_rate&quot;: 25,\r\n                  &quot;codec&quot;: &quot;H264&quot;,\r\n                  &quot;profile&quot;: &quot;High&quot;,\r\n                  &quot;level&quot;: 3.1\r\n                },\r\n                &quot;audio&quot;: {\r\n                  &quot;codec&quot;: &quot;AAC&quot;,\r\n                  &quot;profile&quot;: &quot;LC&quot;,\r\n                  &quot;channels&quot;: 2,\r\n                  &quot;sample_rate&quot;: 16000\r\n                }\r\n              },\r\n              &quot;nclients&quot;: 1,\r\n              &quot;publishing&quot;: true,\r\n              &quot;active&quot;: true\r\n            }],\r\n            &quot;nclients&quot;: 1\r\n          },\r\n          &quot;recorders&quot;: {\r\n            &quot;count&quot;: 0,\r\n            &quot;lists&quot;: []\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;flv&quot;,\r\n          &quot;live&quot;: {\r\n            &quot;streams&quot;: [{\r\n              &quot;name&quot;: &quot;mystream&quot;,\r\n              &quot;time&quot;: 2382811,\r\n              &quot;bw_in&quot;: 2059096,\r\n              &quot;bytes_in&quot;: 541841549,\r\n              &quot;bw_out&quot;: 2059096,\r\n              &quot;bytes_out&quot;: 543351459,\r\n              &quot;bw_audio&quot;: 35472,\r\n              &quot;bw_video&quot;: 2023624,\r\n              &quot;clients&quot;: [{\r\n                  &quot;id&quot;: 452,\r\n                  &quot;address&quot;: &quot;127.0.0.1&quot;,\r\n                  &quot;time&quot;: 2382727,\r\n                  &quot;flashver&quot;: &quot;LNX 9,0,124,2&quot;,\r\n                  &quot;dropped&quot;: 0,\r\n                  &quot;avsync&quot;: -12,\r\n                  &quot;timestamp&quot;: 2384520,\r\n                  &quot;publishing&quot;: false,\r\n                  &quot;active&quot;: true\r\n                },\r\n                {\r\n                  &quot;id&quot;: 451,\r\n                  &quot;address&quot;: &quot;127.0.0.1&quot;,\r\n                  &quot;time&quot;: 2383031,\r\n                  &quot;flashver&quot;: &quot;FMLE/3.0 (compatible; Lavf58.74.100)&quot;,\r\n                  &quot;dropped&quot;: 0,\r\n                  &quot;avsync&quot;: -12,\r\n                  &quot;timestamp&quot;: 2384520,\r\n                  &quot;publishing&quot;: true,\r\n                  &quot;active&quot;: true\r\n                }\r\n              ],\r\n              &quot;records&quot;: [],\r\n              &quot;meta&quot;: {\r\n                &quot;video&quot;: {\r\n                  &quot;width&quot;: 1168,\r\n                  &quot;height&quot;: 720,\r\n                  &quot;frame_rate&quot;: 25,\r\n                  &quot;codec&quot;: &quot;H264&quot;,\r\n                  &quot;profile&quot;: &quot;High&quot;,\r\n                  &quot;level&quot;: 3.1\r\n                },\r\n                &quot;audio&quot;: {\r\n                  &quot;codec&quot;: &quot;AAC&quot;,\r\n                  &quot;profile&quot;: &quot;LC&quot;,\r\n                  &quot;channels&quot;: 2,\r\n                  &quot;sample_rate&quot;: 16000\r\n                }\r\n              },\r\n              &quot;nclients&quot;: 2,\r\n              &quot;publishing&quot;: true,\r\n              &quot;active&quot;: true\r\n            }],\r\n            &quot;nclients&quot;: 2\r\n          },\r\n          &quot;recorders&quot;: {\r\n            &quot;count&quot;: 0,\r\n            &quot;lists&quot;: []\r\n          }\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/70238232/json-jq-request-format",
        "title": "json jq request format"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638777832,
                "creation_date": 1638777832,
                "answer_id": 70242431,
                "question_id": 70242323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two ways to do it:\r\n```bash\r\ncat mock[12].json | jq -s &#39;map(to_entries) | flatten&#39;\r\n```\r\nOr:\r\n```bash\r\njq to_entries mock[12].json | jq -s flatten\r\n```",
                "title": "Index each json file then combine into one json with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638780680,
        "creation_date": 1638777128,
        "question_id": 70242323,
        "body_markdown": "I have a directory of json files, for example:\r\n\r\nmock1.json\r\n```json\r\n[\r\n    { &quot;name&quot;: &quot;John&quot; },\r\n    { &quot;name&quot;: &quot;Mary&quot; }\r\n]\r\n```\r\nmock2.json\r\n```json\r\n[\r\n    { &quot;name&quot;: &quot;Nick&quot; },\r\n    { &quot;name&quot;: &quot;Luke&quot; }\r\n]\r\n```\r\n\r\nI learned that\r\n```bash\r\njq -r &#39;to_entries&#39;\r\n```\r\nwill transform the format to:\r\n```json\r\n[\r\n    {\r\n        &quot;key&quot;: 0,\r\n        &quot;value&quot;: { &quot;name&quot;: &quot;John&quot; }\r\n    },\r\n    {\r\n        &quot;key&quot;: 1,\r\n        &quot;value&quot;: { &quot;name&quot;: &quot;Mary&quot; }\r\n    }\r\n]\r\n```\r\n\r\nI also learned that:\r\n```bash\r\njq -s add [PATH/*.json]\r\n```\r\nCombines all json files in specified path to one json object.\r\n\r\nHowever, I&#39;m struggling to index the json files then combine them. Something like:\r\n```json\r\n[\r\n    {\r\n        &quot;key&quot;: 0,\r\n        &quot;value&quot;: { &quot;name&quot;: &quot;John&quot; }\r\n    },\r\n    {\r\n        &quot;key&quot;: 1,\r\n        &quot;value&quot;: { &quot;name&quot;: &quot;Mary&quot; }\r\n    },\r\n    {\r\n        &quot;key&quot;: 0,\r\n        &quot;value&quot;: { &quot;name&quot;: &quot;Nick&quot; }\r\n    },\r\n    {\r\n        &quot;key&quot;: 1,\r\n        &quot;value&quot;: { &quot;name&quot;: &quot;Luke&quot; }\r\n    }\r\n]\r\n```\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/70242323/index-each-json-file-then-combine-into-one-json-with-jq",
        "title": "Index each json file then combine into one json with jq"
    },
    {
        "tags": [
            "json",
            "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": 1638835188,
                "post_id": 70243586,
                "comment_id": 124188929,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23560175,
                    "reputation": 19,
                    "user_id": 17601640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a23e5863b3c8bbb5dc192e0c20e906?s=256&d=identicon&r=PG",
                    "display_name": "Jeremy",
                    "link": "https://stackoverflow.com/users/17601640/jeremy"
                },
                "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": 1638880427,
                "post_id": 70243586,
                "comment_id": 124200323,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638915282,
                "last_edit_date": 1638915282,
                "creation_date": 1638786591,
                "answer_id": 70244046,
                "question_id": 70243586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming $a holds the contents of one of your JSON entities and $b holds the other, then the following will perform the type of intersection you describe:\r\n```\r\nreduce ($a|paths) as $p (null;\r\n  ($a|getpath($p)) as $va\r\n  | [try ($b|getpath($p)) // empty] as $vb\r\n  | if ($vb | length &gt; 0) and ($va == $vb[0])\r\n    then setpath($p;$va) else . end)\r\n\r\n```\r\n\r\nYou may however wish to explore variations of this, e.g. if there is nothing in common.\r\n\r\n---\r\nFootnote 1:\r\n\r\nThe above is easily adapted to similar problems.  For example, if the common structure is all that matters:\r\n```\r\ndef structural_intersection($a;$b):\r\n  reduce ($a|paths|select(.[-1]|type==&quot;string&quot;)) as $p (null;\r\n  ($a|getpath($p)) as $va\r\n  | [try ($b|getpath($p)) // empty] as $vb\r\n  | if ($vb | length &gt; 0) \r\n    then setpath($p;null) else . end) ;\r\n```\r\n\r\n\r\nFootnote 2:\r\nTo handle arrays using array-intersection, you might wish to consider the following, but please be aware that in some cases, this hybrid approach will probably produce results that you might not expect: \r\n```\r\ndef special_intersection($a;$b):\r\n  def i(x;y): x - (x-y);\r\n  reduce ($a|paths) as $p (null;\r\n    ($a|getpath($p)) as $va\r\n    | [try ($b|getpath($p)) // empty] as $vb\r\n    | if ($vb | length &gt; 0)\r\n      then if ($va == $vb[0])\r\n           then setpath($p;$va)\r\n           elif ($va|type == &quot;array&quot;) and ($vb[0]|type) == &quot;array&quot;\r\n           then setpath($p; i($va; $vb[0]))\r\n\t       else . end\r\n      else . end) ;\r\n```",
                "title": "Intersecting nested JSON documents with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638915282,
        "creation_date": 1638784438,
        "last_edit_date": 1638880664,
        "question_id": 70243586,
        "body_markdown": "I&#39;m looking for a general approach to intersect two nested JSON-objects, in order to retrieve all common key-value pairs.  \r\n\r\nGiven the following JSON-documents\r\n\r\n```\r\n{\r\n    &quot;a&quot;: 0,\r\n    &quot;b&quot;: [\r\n      &quot;ba&quot;,\r\n      {\r\n        &quot;bb&quot;: {\r\n          &quot;bba&quot;: &quot;a&quot;,\r\n          &quot;bbc&quot;: [1, 2]\r\n        }\r\n      },\r\n      {\r\n        &quot;bc&quot;: {\r\n          &quot;bca&quot;: [2],\r\n          &quot;bcb&quot;: 5\r\n        }\r\n      }\r\n    ],\r\n    &quot;c&quot;: 1\r\n  }\r\n\r\n```\r\nand \r\n```\r\n {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: [\r\n      &quot;ba&quot;,\r\n      {\r\n        &quot;bb&quot;: {\r\n          &quot;bba&quot;: &quot;a&quot;,\r\n          &quot;bbc&quot;: [1,3]\r\n        }\r\n      }\r\n    ], \r\n    &quot;c&quot;: 1\r\n  }\r\n```\r\nI want to find their intersection. \r\nI expect to get the following JSON-document which only contains those key-value-pairs JSON-objects that are present in both inputs:  \r\n\r\n```\r\n {\r\n    &quot;b&quot;: [\r\n      &quot;ba&quot;,\r\n      {\r\n        &quot;bb&quot;: {\r\n          &quot;bba&quot;: &quot;a&quot;,\r\n          &quot;bbc&quot;: [1]\r\n        }\r\n      }\r\n    ], \r\n    &quot;c&quot;: 1\r\n  }\r\n```\r\n\r\nI looked into jq&#39;s documentation, but could not find a hint on how to do this. \r\nMy tries to use the minus-operator were unsuccessful yielding `object ... and object cannot be subtracted`. \r\n```\r\n cat obj-list.txt | jq -c &#39;.[1] - (.[0] - .[1])&#39;\r\n```\r\n\r\nCan you give me some hints on how to accomplish a intersection of nested JSON-objects with jq?\r\n\r\nThank you already in advance for helping me out.\r\n\r\n*Update:* \r\nGiven that the JSON-objects do not have the exact same structure, but differ like `a = {&quot;a&quot;: [{&quot;aa&quot;:1]}, b = {&quot;a&quot;: 0}` for example. I&#39;m interested in a solution on how to add error checking to catch `Cannot index number with string`-errors and the like?",
        "link": "https://stackoverflow.com/questions/70243586/intersecting-nested-json-documents-with-jq",
        "title": "Intersecting nested JSON documents with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638813652,
                "post_id": 70249669,
                "comment_id": 124182507,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638813350,
                "last_edit_date": 1638813350,
                "creation_date": 1638813174,
                "answer_id": 70249753,
                "question_id": 70249669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use\r\n```\r\njq -r &#39;.items[] | .name&#39; object.json\r\n```\r\nwhere `-r` option is used to remove double quotes wrapping up the name values.\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/OCnuLPnBdy)&lt;/kbd&gt;",
                "title": "Iterate over JSON array using bash jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638813569,
        "creation_date": 1638812715,
        "last_edit_date": 1638813569,
        "question_id": 70249669,
        "body_markdown": "I&#39;d like to iterate over an array inside a JSON file by index using bash jq, and get for example only the name from each object inside that array:\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;item1&quot;,\r\n      &quot;year&quot;: &quot;2021&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;item2&quot;,\r\n      &quot;year&quot;: &quot;2020&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nAny ideas on how to achieve something like this?\r\n\r\n    item1name=`jq &#39;.items&#39;&lt;???????&gt; object.json | sed &quot;s/\\&quot;//g&quot;`\r\n",
        "link": "https://stackoverflow.com/questions/70249669/iterate-over-json-array-using-bash-jq",
        "title": "Iterate over JSON array using bash jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1638860037,
                "creation_date": 1638860037,
                "answer_id": 70255965,
                "question_id": 70255282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use **del** along with **select** function such as\r\n```\r\njq &#39;del(.data[] | select(.hash == &quot;0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q&quot;))&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/JQOwfm8dsM)&lt;/kbd&gt;",
                "title": "JQ remove objects based on key value"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1638872052,
                "creation_date": 1638872052,
                "answer_id": 70258320,
                "question_id": 70255282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the goal really is:\r\n\r\n&gt; to delete objects from a JSON payload if they have a key with a specific value\r\n\r\nwhere the key is `hash`,\r\nthen you could use `walk` like so:\r\n```\r\nwalk(if type==&quot;object&quot; and\r\n          .hash == &quot;0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q&quot;\r\n     then empty else . end)\r\n```\r\n\r\nNotice that there is no reference to `.data` in this program.\r\n",
                "title": "JQ remove objects based on key value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1638872052,
        "creation_date": 1638854351,
        "question_id": 70255282,
        "body_markdown": "I&#39;m trying to delete objects from a JSON payload if they have a key with a specific value\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-28T01:29:46.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;l3EQR6AJ6R1qE1meHyafDnNF8vJ-X-rH1pujxQRTds4&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-28T00:50:44.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;5fQJY9MprH9b3IstVU1SdfBteUWoF_sdsVuiARPBtTY&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-27T19:01:48.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-27T18:15:17.000000Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to delete the entire object where `.data[].hash` == `0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q` to produce:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-28T01:29:46.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;l3EQR6AJ6R1qE1meHyafDnNF8vJ-X-rH1pujxQRTds4&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-28T00:50:44.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;account&quot;: &quot;12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM&quot;,\r\n      &quot;gateway&quot;: &quot;113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88&quot;,\r\n      &quot;hash&quot;: &quot;5fQJY9MprH9b3IstVU1SdfBteUWoF_sdsVuiARPBtTY&quot;,\r\n      &quot;timestamp&quot;: &quot;2020-08-27T19:01:48.000000Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIs this possible to do? The size of the object can vary and have many different keys in the payload. The one thing that is constant and unique is the `.data[].hash` key\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/70255282/jq-remove-objects-based-on-key-value",
        "title": "JQ remove objects based on key value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639146567,
                "last_edit_date": 1639146567,
                "creation_date": 1638886296,
                "answer_id": 70261684,
                "question_id": 70261491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You first need to select the `DBSnapshots` object, try:\r\n```\r\n.DBSnapshots[] | .DBSnapshotIdentifier\r\n```\r\n\r\nThis will output:\r\n```none\r\n&quot;auto-lims-final-snapshot&quot;\r\n&quot;automation-lims-before-postgres-12-5&quot;\r\n```\r\n\r\nAs you can try [in this online demo](https://jqplay.org/s/AsK1JhgOa6)\r\n\r\n\r\n----------\r\n\r\nTo include the `.TagList.Key` we can add the following:\r\n```\r\n.DBSnapshots[] | .DBSnapshotIdentifier, .TagList[]?.Key\r\n```\r\n\r\nThis will now output\r\n```\r\n&quot;auto-lims-final-snapshot&quot;\r\n&quot;Environment&quot;\r\n&quot;Application&quot;\r\n&quot;automation-lims-before-postgres-12-5&quot;\r\n```\r\n\r\nAs you can try [in this online demo](https://jqplay.org/s/-9xfRJ_K-S)\r\n\r\n\r\n----------\r\n\r\nIf you&#39;d like the `DBSnapshotIdentifier` to be on the same line as the `TagList` we can use string interpolation like so:\r\n```\r\n.DBSnapshots[] | &quot;\\(.DBSnapshotIdentifier) - \\(.TagList[]?.Key)&quot;\r\n```\r\n\r\nThiis will output:\r\n```none\r\n&quot;auto-lims-final-snapshot - Environment&quot;\r\n&quot;auto-lims-final-snapshot - Application&quot;\r\n```\r\n\r\nAs [this demo](https://jqplay.org/s/lbmGboH9uY) demostrates\r\n\r\n----------\r\n\r\nThe `.[]?` from the above command mean:\r\n\r\n&gt; Like `.[]`, but no errors will be output if `.` is not an array or object.\r\n\r\nMore information [in JQ&#39;s documentation](https://stedolan.github.io/jq/manual/#.[]?)",
                "title": "How i can get needest line &quot; DBInstanceIdentifier&quot; from Json output with jq or other tools"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639146567,
        "creation_date": 1638885607,
        "last_edit_date": 1638886339,
        "question_id": 70261491,
        "body_markdown": "this is Json: I try to use\r\n```\r\njq -r &#39;.[] | .DBSnapshotIdentifier&#39;\r\n```\r\n\r\nBut it doesn&#39;t work for me \r\n\r\n```\r\n{\r\n    &quot;DBSnapshots&quot;: [\r\n        {\r\n            &quot;DBSnapshotIdentifier&quot;: &quot;auto-lims-final-snapshot&quot;,\r\n            &quot;DBInstanceIdentifier&quot;: &quot;auto-lims&quot;,\r\n            &quot;SnapshotCreateTime&quot;: &quot;2018-08-15T09:59:23.332000+00:00&quot;,\r\n            &quot;Engine&quot;: &quot;postgres&quot;,\r\n            &quot;AllocatedStorage&quot;: 50,\r\n            &quot;Status&quot;: &quot;available&quot;,\r\n            &quot;Port&quot;: 5432,\r\n            &quot;AvailabilityZone&quot;: &quot;us-east-2a&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-e799fc8f&quot;,\r\n            &quot;InstanceCreateTime&quot;: &quot;2018-04-09T08:28:03.565000+00:00&quot;,\r\n            &quot;MasterUsername&quot;: &quot;postgres&quot;,\r\n            &quot;EngineVersion&quot;: &quot;9.6.6&quot;,\r\n            &quot;LicenseModel&quot;: &quot;postgresql-license&quot;,\r\n            &quot;SnapshotType&quot;: &quot;manual&quot;,\r\n            &quot;OptionGroupName&quot;: &quot;default:postgres-9-6&quot;,\r\n            &quot;PercentProgress&quot;: 100,\r\n            &quot;StorageType&quot;: &quot;gp2&quot;,\r\n            &quot;Encrypted&quot;: false,\r\n            &quot;DBSnapshotArn&quot;: &quot;arn:aws:rds:us-east-2:833682533595:snapshot:auto-lims-final-snapshot&quot;,\r\n            &quot;IAMDatabaseAuthenticationEnabled&quot;: false,\r\n            &quot;ProcessorFeatures&quot;: [],\r\n            &quot;DbiResourceId&quot;: &quot;db-ZL5T2TA2PJVG6CVOJRO7HUOAXQ&quot;,\r\n            &quot;TagList&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;Environment&quot;,\r\n                    &quot;Value&quot;: &quot;auto&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Application&quot;,\r\n                    &quot;Value&quot;: &quot;LIMS&quot;\r\n                }\r\n            ],\r\n            &quot;SnapshotTarget&quot;: &quot;region&quot;\r\n        },\r\n        {\r\n            &quot;DBSnapshotIdentifier&quot;: &quot;automation-lims-before-postgres-12-5&quot;,\r\n            &quot;DBInstanceIdentifier&quot;: &quot;automation-lims&quot;,\r\n            &quot;Engine&quot;: &quot;postgres&quot;,\r\n            &quot;AllocatedStorage&quot;: 500,\r\n            &quot;Status&quot;: &quot;available&quot;,\r\n            &quot;Port&quot;: 5432,\r\n            &quot;AvailabilityZone&quot;: &quot;us-east-2b&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-09fa88d2884ee2083&quot;,\r\n            &quot;InstanceCreateTime&quot;: &quot;2019-12-26T11:19:41.947000+00:00&quot;,\r\n            &quot;MasterUsername&quot;: &quot;lims&quot;,\r\n            &quot;EngineVersion&quot;: &quot;9.6.20&quot;,\r\n            &quot;LicenseModel&quot;: &quot;postgresql-license&quot;,\r\n            &quot;SnapshotType&quot;: &quot;manual&quot;,\r\n            &quot;OptionGroupName&quot;: &quot;default:postgres-9-6&quot;,\r\n            &quot;PercentProgress&quot;: 100\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nHow I can get only nested lines.",
        "link": "https://stackoverflow.com/questions/70261491/how-i-can-get-needest-line-dbinstanceidentifier-from-json-output-with-jq-or-o",
        "title": "How i can get needest line &quot; DBInstanceIdentifier&quot; from Json output with jq or other tools"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 195407,
                    "reputation": 34327,
                    "user_id": 438273,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/88ad8bc15f1a9e787531e9b20340973a?s=256&d=identicon&r=PG",
                    "display_name": "jsejcksn",
                    "link": "https://stackoverflow.com/users/438273/jsejcksn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1638892407,
                "post_id": 70263140,
                "comment_id": 124205731,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23560175,
                    "reputation": 19,
                    "user_id": 17601640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a23e5863b3c8bbb5dc192e0c20e906?s=256&d=identicon&r=PG",
                    "display_name": "Jeremy",
                    "link": "https://stackoverflow.com/users/17601640/jeremy"
                },
                "reply_to_user": {
                    "account_id": 195407,
                    "reputation": 34327,
                    "user_id": 438273,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/88ad8bc15f1a9e787531e9b20340973a?s=256&d=identicon&r=PG",
                    "display_name": "jsejcksn",
                    "link": "https://stackoverflow.com/users/438273/jsejcksn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638894470,
                "post_id": 70263140,
                "comment_id": 124206551,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638902722,
                "last_edit_date": 1638902722,
                "creation_date": 1638896018,
                "answer_id": 70264003,
                "question_id": 70263140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `scalars` filter to find leaf nodes. Scalars are all &quot;simple&quot; JSON values, i.e. `null`, `true`, `false`, numbers and strings. Alternatively you can compare the `type` of each item and use `length` to determine if an object or array has children.\r\n\r\nI&#39;ve expanded your input data a little to distinguish a few more corner cases:\r\n\r\nInput:\r\n```\r\n  {\r\n    &quot;a&quot;: true,\r\n    &quot;b&quot;: [1, 2],\r\n    &quot;c&quot;: {\r\n      &quot;a&quot;: {\r\n        &quot;aa&quot;: 1,\r\n        &quot;bb&quot;: 2\r\n      },\r\n      &quot;b&quot;: &quot;blue&quot;\r\n    },\r\n    &quot;d&quot;: [],\r\n    &quot;e&quot;: [[], []],\r\n    &quot;f&quot;: {}\r\n  }\r\n```\r\n\r\nThis has 15 JSON entities:\r\n* 5 of them are arrays or objects with children.\r\n* 4 of them are empty arrays or objects.\r\n* 6 of them are scalars.\r\n\r\nDepending on what you&#39;re trying to do, you might consider only scalars to be &quot;leaf nodes&quot;, or you might consider both scalars and empty arrays and objects to be leaf nodes.\r\n\r\nHere&#39;s a filter that counts scalars:\r\n\r\n```\r\n[..|scalars]|length\r\n```\r\nOutput:\r\n```\r\n6\r\n```\r\n\r\nAnd here&#39;s a filter that counts all entities which have no children. It just checks for all the scalar types explicitly (there are only six possible types for a JSON value) and if it&#39;s not one of those it must be an array or object, where we can check how many children it has with `length`.\r\n\r\n```\r\n[\r\n  ..|\r\n  select(\r\n    (type|IN(&quot;boolean&quot;,&quot;number&quot;,&quot;string&quot;,&quot;null&quot;)) or\r\n    length==0\r\n  )\r\n]|\r\nlength\r\n```\r\nOutput:\r\n```\r\n10\r\n```",
                "title": "Count elements in nested JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1638947755,
        "creation_date": 1638892221,
        "last_edit_date": 1638947755,
        "question_id": 70263140,
        "body_markdown": "I am trying to count all elements in a nested JSON-document with `jq`?\r\n\r\nGiven the following JSON-document\r\n```json\r\n{&quot;a&quot;: true, &quot;b&quot;: [1, 2], &quot;c&quot;: {&quot;a&quot;: {&quot;aa&quot;:1, &quot;bb&quot;: 2}, &quot;b&quot;: &quot;blue&quot;}}\r\n```\r\nI want to calculate the result `6`.\r\n\r\nIn order to do this, I tried the following:\r\n```bash\r\necho &#39;{&quot;a&quot;: true, &quot;b&quot;: [1, 2], &quot;c&quot;: {&quot;a&quot;: {&quot;aa&quot;:1, &quot;bb&quot;: 2}, &quot;b&quot;: &quot;blue&quot;}}&#39; \\\r\n| jq &#39;reduce (.. | if (type == &quot;object&quot; or type == &quot;array&quot;) \r\n      then length else 0 end) as $counts \r\n      (1; . + $counts)&#39;\r\n\r\n# Actual output: 10\r\n# Desired output: 6\r\n```\r\nHowever, this counts the encountered objects and arrays as well and therefore yields `10` opposing to the desired output: `6`  \r\n\r\nSo, how can I only count the document&#39;s elements/leaf-nodes?\r\n\r\nThanks already in advance for you help!\r\n\r\n*Edit:* What would be an efficient approach to count empty arrays and objects as well?",
        "link": "https://stackoverflow.com/questions/70263140/count-elements-in-nested-json-with-jq",
        "title": "Count elements in nested JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638921444,
                "post_id": 70265019,
                "comment_id": 124215528,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638923183,
                "post_id": 70265019,
                "comment_id": 124215838,
                "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": 1638936086,
                "post_id": 70265019,
                "comment_id": 124217953,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23560175,
                    "reputation": 19,
                    "user_id": 17601640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a23e5863b3c8bbb5dc192e0c20e906?s=256&d=identicon&r=PG",
                    "display_name": "Jeremy",
                    "link": "https://stackoverflow.com/users/17601640/jeremy"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638947993,
                "post_id": 70265019,
                "comment_id": 124220400,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23560175,
                    "reputation": 19,
                    "user_id": 17601640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a23e5863b3c8bbb5dc192e0c20e906?s=256&d=identicon&r=PG",
                    "display_name": "Jeremy",
                    "link": "https://stackoverflow.com/users/17601640/jeremy"
                },
                "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": 1638948082,
                "post_id": 70265019,
                "comment_id": 124220425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638957132,
                "post_id": 70265019,
                "comment_id": 124223258,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638957683,
                "post_id": 70265019,
                "comment_id": 124223491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23560175,
                    "reputation": 19,
                    "user_id": 17601640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a23e5863b3c8bbb5dc192e0c20e906?s=256&d=identicon&r=PG",
                    "display_name": "Jeremy",
                    "link": "https://stackoverflow.com/users/17601640/jeremy"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638990872,
                "post_id": 70265019,
                "comment_id": 124236849,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1638955565,
                "last_edit_date": 1638955565,
                "creation_date": 1638938642,
                "answer_id": 70270065,
                "question_id": 70265019,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @weeble pointed out, the concept of &quot;subtree&quot; is not so simple when arrays are involved.  In particular, the simple path-value approach to your question would not match your requirements, so the following is a bit more complex, but hopefully the layout and nomenclature will help clarify things.\r\n\r\nFirst, some helper functions:\r\n```\r\ndef max(s): reduce s as $x (0; if . == null or $x &gt; . then $x else . end);\r\n\r\ndef elementOf($x):\r\n  . as $in\r\n  | if ($x|type) == &quot;array&quot;\r\n    then $x|index($in)\r\n    else false end;\r\n\r\n# drill down\r\ndef shift($n):\r\n  if $n == 0 then .\r\n  elif type | (. != &quot;object&quot; and . != &quot;array&quot;) then empty\r\n  elif $n == 1 then .[]\r\n  else .[] | shift($n - 1)\r\n  end;\r\n```\r\n\r\nNext, the main function, which defines a (recursive) subfunction to handle\r\nthe relatively straightforward case:\r\n```\r\ndef subtree_of($b):\r\n  def isScalar: type | . != &quot;array&quot; and . != &quot;object&quot;;\r\n\r\n  # direct_subtree_of($b) checks that every path/atomic-value pair of $a is also in $b\r\n  def direct_subtree_of($b):\r\n    . as $a\r\n    | first( ($a|paths(scalars)) as $p\r\n        | ($a | getpath($p)) as $va\r\n        | ([try ($b|getpath($p)) // empty]) as $vb\r\n        | if ($vb |length &gt; 0) \r\n             and (($va == $vb[0])\r\n                  or ($va | subtree_of($vb[0]))\r\n                  or ($va | elementOf($b | getpath( $p[:-1] ))))\r\n          then empty\r\n          else 0\r\n          end) // 1\r\n      | . == 1 ;\r\n    \r\n  . as $a\r\n  | if isScalar then $a == $b\r\n    else direct_subtree_of($b)\r\n         or (max($a|paths|length) as $ma\r\n            | max($b|paths|length) as $mb\r\n            | ($mb - $ma) as $diff\r\n            | any(range(1; 1+$diff);\r\n\t              any(. as $i | $a | subtree_of($b | shift($i)); . )) )\r\n    end ;\r\n```\r\n\r\nAfter correcting your `a`:\r\n```\r\na | subtree_of(b)\r\n```\r\nevaluates to `true`.\r\n",
                "title": "Subtree matching with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638955565,
        "creation_date": 1638900664,
        "last_edit_date": 1638947788,
        "question_id": 70265019,
        "body_markdown": "I am looking for an efficient way to calculate, whether one JSON-document is a subtree/subset of another one. \r\nGiven a JSON-document `a`\r\n```json\r\n{\r\n    &quot;a&quot;: {\r\n        &quot;a&quot;: {&quot;aa&quot;: [&quot;uvw&quot;, &quot;abc&quot;]},\r\n        &quot;b&quot;: {\r\n            &quot;ba&quot;: {\r\n                &quot;baa&quot;: [&quot;none&quot;, &quot;1&quot;],\r\n                &quot;bab&quot;: [&quot;0&quot;]\r\n            },\r\n            &quot;bb&quot;: {\r\n                &quot;baa&quot;: [&quot;yyy&quot;],\r\n                &quot;bab&quot;: [&quot;some_string&quot;]\r\n            }\r\n        },\r\n        &quot;c&quot;: {\r\n            &quot;ca&quot;: [&quot;dd&quot;, &quot;cc&quot;],\r\n            &quot;cb&quot;: 2,\r\n            &quot;cc&quot;: &quot;-&quot; \r\n        }\r\n    },\r\n    &quot;e&quot;: &quot;abc&quot;,\r\n    &quot;d&quot;: 45678\r\n}\r\n```\r\nand a JSON-document `b`\r\n```json\r\n{\r\n    &quot;a&quot;: {\r\n        &quot;a&quot;: {&quot;aa&quot;: [&quot;abc&quot;]},\r\n        &quot;b&quot;: {\r\n            &quot;ba&quot;: {\r\n                &quot;baa&quot;: [&quot;none&quot;],\r\n                &quot;bab&quot;: [&quot;0&quot;]\r\n            },\r\n            &quot;bb&quot;: {\r\n                &quot;bab&quot;: [&quot;some_string&quot;]\r\n            }\r\n        },\r\n        &quot;c&quot;: {\r\n            &quot;ca&quot;: [&quot;cc&quot;]\r\n        }\r\n    },\r\n    &quot;e&quot;: &quot;abc&quot;\r\n}\r\n```\r\nI want to determine, whether `b` is a subset of `a`\r\n\r\nAs a result, I expect a single boolean (or something like `{&#39;match&#39;: true}`) indicating that `b` is a subset of `a`.\r\n\r\nI tried the following\r\n```bash\r\n.[0] as $a | .[1] as $b\r\n| reduce ($a|paths) as $p (null; ($a|getpath($p)) as $va\r\n| try($b|getpath($p)) as $vb\r\n| if $va == $vb then setpath([&quot;match&quot;];true) else setpath([&quot;match&quot;];false) end)\r\n```\r\nbut I miss a way to keep track of failed comparisons. \r\n\r\nHow can I accomplish this subtree-matching with `jq`?\r\n\r\nThank you already in advance for your help!\r\n",
        "link": "https://stackoverflow.com/questions/70265019/subtree-matching-with-jq",
        "title": "Subtree matching with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1638911582,
                "creation_date": 1638911582,
                "answer_id": 70267003,
                "question_id": 70265041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\nmap(select(\r\n   .message |\r\n   contains(&quot;check failed for material:&quot;) or contains(&quot;Error while scheduling&quot;) |\r\n   not\r\n))\r\n```\r\n\r\n[Demo](https://jqplay.org/s/qWuHx_nddk)\r\n\r\nOr for exact matches,\r\n\r\n```jq\r\nmap(select(\r\n   .message |\r\n   . != &quot;check failed for material:&quot; and . != &quot;Error while scheduling&quot;\r\n))\r\n```\r\n\r\n[Demo](https://jqplay.org/s/WvN9_D_Q2Q)\r\n\r\n* We don&#39;t want to eliminate the array, so we use `map` instead of `.[]`. (Alternatively, we could keep using `.[]` but wrap the whole in `[ ... ]`.)\r\n\r\n* `contains(A, B)` check if both A and B are contained, rather than either.\r\n\r\n* And `not` negates the condition so we can eliminate the matching records instead of keeping them.\r\n",
                "title": "How to ignore certain values and print the rest using jq cmd"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1638911946,
        "creation_date": 1638900753,
        "last_edit_date": 1638911946,
        "question_id": 70265041,
        "body_markdown": "Here I&#39;m trying to write jq command that should ignore the message `check failed for material:` and `Error while scheduling`, and print the rest. \r\n\r\nThe other values which I&#39;m trying to print will get changing at every time. But these msg will remain constant (`check failed for material:`, `Error while scheduling`). We need to write a jq cmd that should ignore the mentioned message and print the rest/changing content. \r\nPlease let me know if I&#39;m not clear.\r\nThanks in Advance !\r\n\r\n```json\r\n[\r\n   {\r\n      &quot;message&quot;:&quot;check failed for material:&quot;,\r\n      &quot;detail&quot;:&quot;Error performing&quot;,\r\n      &quot;level&quot;:&quot;ERROR&quot;\r\n   },\r\n   {\r\n      &quot;message&quot;:&quot;check failed for material:&quot;,\r\n      &quot;detail&quot;:&quot;Error performing command&quot;,\r\n      &quot;level&quot;:&quot;ERROR&quot;\r\n   },\r\n   {\r\n      &quot;message&quot;:&quot;Error while scheduling&quot;,\r\n      &quot;detail&quot;:&quot;Maximum limit reached&quot;,\r\n      &quot;level&quot;:&quot;ERROR&quot;\r\n   },\r\n   {\r\n      &quot;message&quot;:&quot;Error while scheduling&quot;,\r\n      &quot;detail&quot;:&quot;Maximum limit reached&quot;,\r\n      &quot;level&quot;:&quot;ERROR&quot;\r\n   },\r\n   {\r\n      &quot;message&quot;:&quot;Duplicate error&quot;,\r\n      &quot;detail&quot;:&quot;Found a mapping value where it is not allowed&quot;,\r\n      &quot;level&quot;:&quot;ERROR&quot;\r\n   },\r\n   {\r\n      &quot;message&quot;:&quot;Invalid Merged Configuration&quot;,\r\n      &quot;detail&quot;:&quot;Number of errors: 44&quot;,\r\n      &quot;level&quot;:&quot;ERROR&quot;\r\n   }\r\n]\r\n```\r\n\r\nOn jqplay: https://jqplay.org/s/tCYiua9KzH\r\n\r\nDesired output:\r\n\r\n```json\r\n[\r\n   {\r\n      &quot;message&quot;: &quot;Duplicate error&quot;,\r\n      &quot;detail&quot;: &quot;Found a mapping value where it is not allowed&quot;,\r\n      &quot;level&quot;: &quot;ERROR&quot;\r\n   },\r\n   {\r\n      &quot;message&quot;: &quot;Invalid Merged Configuration&quot;,\r\n      &quot;detail&quot;: &quot;Number of errors: 44&quot;,\r\n      &quot;level&quot;: &quot;ERROR&quot;\r\n   }\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70265041/how-to-ignore-certain-values-and-print-the-rest-using-jq-cmd",
        "title": "How to ignore certain values and print the rest using jq cmd"
    }
]