[
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1641596264,
                "post_id": 70627822,
                "comment_id": 124854407,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 62026,
                    "reputation": 10207,
                    "user_id": 184509,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/AAjC5.jpg?s=256",
                    "display_name": "Felix",
                    "link": "https://stackoverflow.com/users/184509/felix"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641598483,
                "post_id": 70627822,
                "comment_id": 124854823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641598845,
                "post_id": 70627822,
                "comment_id": 124854900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641599124,
                "post_id": 70627822,
                "comment_id": 124854962,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641599168,
                "post_id": 70627822,
                "comment_id": 124854973,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641599335,
                "post_id": 70627822,
                "comment_id": 124854996,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 62026,
                    "reputation": 10207,
                    "user_id": 184509,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/AAjC5.jpg?s=256",
                    "display_name": "Felix",
                    "link": "https://stackoverflow.com/users/184509/felix"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641599337,
                "post_id": 70627822,
                "comment_id": 124854997,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 62026,
                    "reputation": 10207,
                    "user_id": 184509,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/AAjC5.jpg?s=256",
                    "display_name": "Felix",
                    "link": "https://stackoverflow.com/users/184509/felix"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641599461,
                "post_id": 70627822,
                "comment_id": 124855033,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641596044,
                "creation_date": 1641596044,
                "answer_id": 70628051,
                "question_id": 70627822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you start off with a stream of objects, you may either use the `--slurp` (or `-s`) flag to read in the objects as array members (you don&#39;t have to use another call, just begin with `jq -s &#39;&lt;your filter, maybe using a map&gt;&#39;`), or use `inputs` in conjunction with the `--null-input` (or `-n`) flag, which lets you construct the array more flexibly: `jq -n &#39;[inputs] | …&#39;` or even  `jq -n &#39;[inputs | …]&#39;`, depending on your actual processing pipeline.",
                "title": "collecting objects into array doesn&#39;t work"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641604417,
                "creation_date": 1641604417,
                "answer_id": 70628887,
                "question_id": 70627822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Everything in `jq` is a filter. Even an innocuous value like `1` is a filter: it ignores its input and produces the number `1` as output.\r\n\r\n`[...]` is a filter, too. For each value in its input, it applies the enclosed filter to that value and collects the output into a single array.\r\n\r\nThis means that the only way to create a single array as output is to take a single value as input. If `jq`&#39;s input is a stream of values, `jq &#39;[...]` will produces a stream of outputs. In order to convert a stream of values into a single array, you need to use the `-s` option first.",
                "title": "collecting objects into array doesn&#39;t work"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641604417,
        "creation_date": 1641594310,
        "question_id": 70627822,
        "body_markdown": "I have an input file of JSON objects (log file from an application):\r\n\r\n    { \r\n      &quot;Url&quot;: &quot;http://bla-bla/method1&quot;,\r\n      &quot;ReturnCode&quot;: 200,\r\n      ...\r\n    }\r\n    { \r\n      &quot;Url&quot;: &quot;http://bla-bla/method2&quot;,\r\n      &quot;ReturnCode&quot;: 500,\r\n      ...\r\n    }\r\n\r\netc.\r\n\r\nI manipulate it through a number of transformation in `jq` (such as `select`, regex functions, etc.) and in the end I shape the final object\r\n\r\n    | { UserName, Url, Duration }\r\n\r\nBut I want to collect (as jq calls it) this stream into an array in order to `group_by`. All the examples I see start with array, and then have `| [.[] | { UserName, Url, Duration }]`, which works. However, if I just specify `[{ UserName, Url, Duration }]`, I don&#39;t get a single array; instead I get\r\n\r\n    [\r\n      { \r\n      &quot;UserName&quot;: &quot;John&quot;,\r\n      &quot;Url&quot;: &quot;http://bla-bla/method1&quot;,\r\n      &quot;Duration &quot;: 10\r\n      }\r\n    ]\r\n    [\r\n      { \r\n      &quot;UserName&quot;: &quot;Bob&quot;,\r\n      &quot;Url&quot;: &quot;http://bla-bla/method2&quot;,\r\n      &quot;Duration&quot;: 15\r\n      }\r\n    ]\r\n\r\nDoesn&#39;t make any sense!\r\n\r\nNote - I know that I can use `jq &quot;my rules&quot; | jq -s` and it works. But there should be a way to create an array inside the rules themselves!",
        "link": "https://stackoverflow.com/questions/70627822/collecting-objects-into-array-doesnt-work",
        "title": "collecting objects into array doesn&#39;t work"
    },
    {
        "tags": [
            "json",
            "jq",
            "kubectl",
            "coalesce"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1641613093,
                "creation_date": 1641613093,
                "answer_id": 70629425,
                "question_id": 70628716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has a counterpart to &quot;coalesce&quot; in the form of `//`.\r\nFor example, `null // 0` evaluates to 0, and chances are that it will suffice in your case, perhaps:\r\n```\r\n.status.containerStatuses[].state | (.waiting // .terminated) | .reason\r\n```\r\nor\r\n```\r\n.status.containerStatuses[].state | (.waiting.reason // .terminated.reason )\r\n```\r\nor similar.\r\n\r\nHowever, `//` should only be used with some understanding of what it does, as explained in detail on the jq FAQ at https://github.com/stedolan/jq/wiki/FAQ#or-versus-\r\n\r\nIf `//` is inapplicable for some reason, then the obvious alternative would be an `if ... then ... else ... end` statement, which is quite like C&#39;s `_ ? _ : _` in that it can be used to produce a value, e.g. something along the lines of:\r\n```\r\n.status.containerStatuses[].state\r\n| if has(&quot;waiting&quot;) then .waiting.reason\r\n  else .terminated.reason\r\n  end\r\n```\r\nHowever, if `containerStatuses` is an array, then some care may be required.",
                "title": "Print from jq using a wild card (or coalesce to first non null)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641709742,
                "last_edit_date": 1641709742,
                "creation_date": 1641624874,
                "answer_id": 70630220,
                "question_id": 70628716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case you want to go with `coalesce`:\r\n```\r\n# Stream-oriented version\r\ndef coalesce(s):\r\n  first(s | select(. != null)) // null;\r\n```\r\nor if you prefer to work with arrays:\r\n```\r\n# Input: an array\r\n# Output: the first non-null element if any, else null\r\ndef coalesce: coalesce(.[]);\r\n```\r\n\r\nUsing the stream-oriented version, you could write something along the lines you had in mind with the wildcard, e.g.\r\n\r\n    coalesce(.status.containerStatuses[].state[].reason?)",
                "title": "Print from jq using a wild card (or coalesce to first non null)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 11,
        "last_activity_date": 1641709742,
        "creation_date": 1641602557,
        "last_edit_date": 1641628593,
        "question_id": 70628716,
        "body_markdown": "I have the following command:\r\n\r\n&gt; `kubectl get pod -A -o=json | jq -r &#39;.items[]|select(any( .status.containerStatuses[]; .state.waiting or .state.terminated))|[.metadata.namespace, .metadata.name]|@csv&#39;`\r\n\r\nThis command works great.  It outputs both the namespace and name of my failing pods.\r\n\r\nBut now I want to add one more column to the results.  The column I want is located in one (and only one) of two places:\r\n\r\n* .status.containerStatuses[].state.*waiting*.reason\r\n* .status.containerStatuses[].state.*terminated*.reason\r\n\r\nI first tried adding `.status.containerStatuses[].state.*.reason` to the results fields array.  But that gave me an `unexpected &#39;*&#39;` compile error.\r\n\r\nI then got to thinking about how I would do this with SQL or another programming language.  They frequently have a function that will return the first non-null value of its parameters.  (This is usually called coalesce).  However I could not find any such command for `jq`.\r\n\r\n**How can I return the `reason` as a result of my query?**\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70628716/print-from-jq-using-a-wild-card-or-coalesce-to-first-non-null",
        "title": "Print from jq using a wild card (or coalesce to first non null)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641609147,
                "last_edit_date": 1641609147,
                "creation_date": 1641607902,
                "answer_id": 70629140,
                "question_id": 70629071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re filtering the wrong thing.\r\n\r\n```jq\r\n.items |\r\nmap (\r\n   .status.containerStatuses |= map(\r\n      select(\r\n         (  .state.waiting\r\n         or .state.terminated and .state.terminated.reason != &quot;Completed&quot;\r\n         )\r\n      )\r\n   ) |\r\n   {\r\n      pod:       .metadata.name,\r\n      namespace: .metadata.namespace,\r\n      container: .status.containerStatuses[].name\r\n   }\r\n)\r\n```\r\n",
                "title": "Adding a field to the jq output adds rows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641609147,
        "creation_date": 1641606814,
        "question_id": 70629071,
        "body_markdown": "I have the following command:\r\n\r\n\r\n&gt; `kubectl get pod -A -o=json | jq -r &#39;[.items[]|select(any( .status.containerStatuses[]; .state.waiting or (.state.terminated and .state.terminated.reason!=\\&quot;Completed\\&quot;)))|{pod:.metadata.name, namespace:.metadata.namespace}]&#39;`\r\n\r\nThis works just like I want (except I need to add a field).  This is an excerpt from the results:\r\n\r\n    {\r\n      &quot;pod&quot;: &quot;ops-test-app-blue-54556c9b8b-pq6hd&quot;,\r\n      &quot;namespace&quot;: &quot;software-operations-test-apps&quot;\r\n    },\r\n    {\r\n      &quot;pod&quot;: &quot;ops-test-app-blue-54556c9b8b-vknl8&quot;,\r\n      &quot;namespace&quot;: &quot;software-operations-test-apps&quot;\r\n    }\r\n\r\nWhen I add the extra field I need it ends up looking like this:\r\n\r\n&gt; `kubectl get pod -A -o=json | jq -r &#39;[.items[]|select(any( .status.containerStatuses[]; .state.waiting or (.state.terminated and .state.terminated.reason!=\\&quot;Completed\\&quot;)))|{pod:.metadata.name, container:.status.containerStatuses[].name, namespace:.metadata.namespace}]&#39;`\r\n\r\nThis is the same command, except it adds the container name to the json output.  However, when I do that, it adds extra results (as well as my extra field):\r\n\r\n    {\r\n      &quot;pod&quot;: &quot;ops-test-app-blue-54556c9b8b-pq6hd&quot;,\r\n      &quot;container&quot;: &quot;ops-test-app-blue&quot;,\r\n      &quot;namespace&quot;: &quot;software-operations-test-apps&quot;\r\n    },\r\n    {\r\n      &quot;pod&quot;: &quot;ops-test-app-blue-54556c9b8b-pq6hd&quot;,\r\n      &quot;container&quot;: &quot;istio-proxy&quot;,\r\n      &quot;namespace&quot;: &quot;software-operations-test-apps&quot;\r\n    },\r\n    {\r\n      &quot;pod&quot;: &quot;ops-test-app-blue-54556c9b8b-vknl8&quot;,\r\n      &quot;container&quot;: &quot;ops-test-app-blue&quot;,\r\n      &quot;namespace&quot;: &quot;software-operations-test-apps&quot;\r\n    },\r\n    {\r\n      &quot;pod&quot;: &quot;ops-test-app-blue-54556c9b8b-vknl8&quot;,\r\n      &quot;container&quot;: &quot;istio-proxy&quot;,\r\n      &quot;namespace&quot;: &quot;software-operations-test-apps&quot;\r\n    }\r\n\r\nThe extra results are the rows with the container set to istio-proxy.  This seems to be because there are 2 entries in each instance of `.status.containerStatuses`.  One for the ops-test-app-blue container and one for the istio-proxy app.\r\n\r\nBut when I look at the data for the istio-proxy instance, it does not match the criteria.  Here is an example of the full json for the istio-proxy instance:\r\n\r\n\t{\r\n\t\t&quot;containerID&quot;: &quot;docker://b99e580b64bb70ba1ddbfc726688e8901d05975c097ec55625cad971994c38a8&quot;,\r\n\t\t&quot;image&quot;: &quot;istio/proxyv2:1.10.0&quot;,\r\n\t\t&quot;imageID&quot;: &quot;docker-pullable://istio/proxyv2@sha256:88c6c693e67a0f2492191a0e7d8020ddc85603bfc704f252655cb9eb5eeb3f58&quot;,\r\n\t\t&quot;lastState&quot;: {},\r\n\t\t&quot;name&quot;: &quot;istio-proxy&quot;,\r\n\t\t&quot;ready&quot;: true,\r\n\t\t&quot;restartCount&quot;: 0,\r\n\t\t&quot;started&quot;: true,\r\n\t\t&quot;state&quot;: {\r\n\t\t\t&quot;running&quot;: {\r\n\t\t\t\t&quot;startedAt&quot;: &quot;2022-01-06T23:52:10Z&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\nIt has a `state.running`.  (Not `state.waiting` or `state.terminated` as the select statement is using for its filtering).\r\n\r\nWhy are these extra rows being added?  \r\n\r\n**And is there a way to get the extra field, but not the extra rows?**",
        "link": "https://stackoverflow.com/questions/70629071/adding-a-field-to-the-jq-output-adds-rows",
        "title": "Adding a field to the jq output adds rows"
    },
    {
        "tags": [
            "object",
            "ubuntu",
            "jq",
            "slurp"
        ],
        "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": 1641639239,
                "post_id": 70631402,
                "comment_id": 124860170,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641640007,
                "last_edit_date": 1641640007,
                "creation_date": 1641639076,
                "answer_id": 70631621,
                "question_id": 70631402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To just make it an array of the files&#39; contents, you don&#39;t need `add` builtin as the `-s` flag already puts them together in an array\r\n```sh\r\njq -s . ubuntubionic.json ubuntufocal.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;ubuntu&quot;: {\r\n      &quot;os_ver&quot;: &quot;bionic&quot;,\r\n      &quot;image&quot;: &quot;abcdef&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;abc&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;ubuntu&quot;: {\r\n      &quot;os_ver&quot;: &quot;focal&quot;,\r\n      &quot;image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nIf you want to pull out the `ubuntu` field name, and have each object&#39;s values (which happen to be objects as well) merged into an array, also use the `map` builtin:\r\n\r\n```sh\r\njq -s &#39;{ubuntu: map(.ubuntu)}&#39; ubuntubionic.json ubuntufocal.json\r\n```\r\nor\r\n```sh\r\njq -s &#39;{ubuntu: map(add)}&#39; ubuntubionic.json ubuntufocal.json\r\n```\r\n```json\r\n{\r\n  &quot;ubuntu&quot;: [\r\n    {\r\n      &quot;os_ver&quot;: &quot;bionic&quot;,\r\n      &quot;image&quot;: &quot;abcdef&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;abc&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    },\r\n    {\r\n      &quot;os_ver&quot;: &quot;focal&quot;,\r\n      &quot;image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n",
                "title": "merge couple of objects together with jq slurp add without overwrite duplicate key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1641640007,
        "creation_date": 1641637151,
        "last_edit_date": 1641637948,
        "question_id": 70631402,
        "body_markdown": "i have this two json files:\r\n***ubuntubionic.json**:*\r\n```cat ubuntubionic.json\r\n  {\r\n    &quot;ubuntu&quot;: {\r\n      &quot;os_ver&quot;: &quot;bionic&quot;,\r\n      &quot;image&quot;: &quot;abcdef&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;abc&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    }\r\n  }\r\n```\r\n\r\nand **ubuntufocal.json**:\r\n\r\n```\r\ncat ubuntubionic.json\r\n  {\r\n    &quot;ubuntu&quot;: {\r\n      &quot;os_ver&quot;: &quot;focal&quot;,\r\n      &quot;image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    }\r\n  }`\r\n```\r\n\r\ni want to merge these two files into 1 file to get output that looks like this:\r\n```\r\n{\r\n    &quot;ubuntu&quot;: {\r\n      &quot;os_ver&quot;: &quot;focal&quot;,\r\n      &quot;image&quot;: &quot;abcdef&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;abc&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n    },\r\n      &quot;os_ver&quot;: &quot;bionic&quot;,\r\n      &quot;image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n      &quot;docker_compiler_image&quot;: &quot;xxxx&quot;,\r\n      &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n\r\n  }\r\n```\r\n\r\ni tried jq -s add ubuntufocal.json ubuntubionic.json &gt; all_os.json\r\nbut i&#39;m getting that bionic is overwriting focal\r\n```\r\ncat all_os.json\r\n{\r\n  &quot;ubuntu&quot;: {\r\n    &quot;os_ver&quot;: &quot;bionic&quot;,\r\n    &quot;image&quot;: &quot;xxxx&quot;,\r\n    &quot;image_tag&quot;: &quot;3.33.3&quot;,\r\n    &quot;docker_compiler_image&quot;: &quot;xxxx&quot;,\r\n    &quot;image_compiler_tag&quot;: &quot;4.44.4&quot;\r\n  }\r\n}\r\n```\r\nhow can this be solved? got totally lost in the JQ man page\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70631402/merge-couple-of-objects-together-with-jq-slurp-add-without-overwrite-duplicate-k",
        "title": "merge couple of objects together with jq slurp add without overwrite duplicate key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641713414,
                "post_id": 70631790,
                "comment_id": 124873875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1641640804,
                "creation_date": 1641640804,
                "answer_id": 70631820,
                "question_id": 70631790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argfile` to read in the second file into a variable, then `+=` to add it to the existing array in `.item`\r\n\r\n```sh\r\njq --argfile f file2.json &#39;.item += $f&#39; file1.json\r\n```\r\n```json\r\n{\r\n  &quot;info&quot;: {\r\n    &quot;id&quot;: &quot;&quot;,\r\n    &quot;name&quot;: &quot;Text Fields&quot;,\r\n    &quot;schema&quot;: &quot;url&quot;\r\n  },\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;CompanyName Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;CompanyName is CompanyName1&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Phone Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Phone is 1234&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Job Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Job is Job1&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "jq concatenate arrays from two different files and save the output in the first file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684763436,
        "creation_date": 1641640525,
        "last_edit_date": 1684763436,
        "question_id": 70631790,
        "body_markdown": "Here&#39;s what I&#39;m looking to do. \r\n\r\nfile1.json\r\n```json\r\n{\r\n  &quot;info&quot;: {\r\n    &quot;id&quot;: &quot;&quot;,\r\n    &quot;name&quot;: &quot;Text Fields&quot;,\r\n    &quot;schema&quot;: &quot;url&quot;\r\n  },\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;CompanyName Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;CompanyName is CompanyName1&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nfile2.json\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Phone Field&quot;,\r\n    &quot;item&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Phone is 1234&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Job Field&quot;,\r\n    &quot;item&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Job is Job1&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nExpected output after running jq\r\n\r\nfile1.json\r\n```json\r\n{\r\n  &quot;info&quot;: {\r\n    &quot;id&quot;: &quot;&quot;,\r\n    &quot;name&quot;: &quot;Text Fields&quot;,\r\n    &quot;schema&quot;: &quot;url&quot;\r\n  },\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;CompanyName Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;CompanyName is CompanyName1&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Phone Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Phone is 1234&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Job Field&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Job is Job1&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAs a first step I tried to at least concatenate the arrays of the two files and get that as an output before trying to get them in the first file itself but that itself is not happening. \r\nHere&#39;s what I tried \r\n```sh\r\njq &#39;.item .&#39; file1.json file2.json\r\n```\r\n\r\nbut I get the following error:\r\n```\r\njq: error: syntax error, unexpected $end, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.item .\r\njq: 1 compile error\r\n```\r\n\r\nI tried searching a lot, trust me. There are a lot of queries with similar titles but they all seem to be very specific problems when you look into each one. Please help.",
        "link": "https://stackoverflow.com/questions/70631790/jq-concatenate-arrays-from-two-different-files-and-save-the-output-in-the-first",
        "title": "jq concatenate arrays from two different files and save the output in the first file"
    },
    {
        "tags": [
            "bash",
            "sed",
            "zip",
            "jq",
            "command-substitution"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641677594,
                "last_edit_date": 1641677594,
                "creation_date": 1641677399,
                "answer_id": 70636599,
                "question_id": 70636530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace `build.zip` with `&quot;build_$(cat manifest.json | jq -r .version).zip&quot;`.\r\n\r\nUpdate:\r\n\r\nReplace `build.zip` with `&quot;build_$(jq -r .version manifest.json).zip&quot;`.",
                "title": "bash zip file with version read from file and used in zip file name"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641713937,
                "last_edit_date": 1641713937,
                "creation_date": 1641700619,
                "answer_id": 70638312,
                "question_id": 70636530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\nzip &quot;build_$( jq -r .version manifest.json ).zip&quot; ...\r\n```\r\n\r\n---\r\n\r\nTo include the output of one program in the command line for another, one uses `$(...)`.\r\n\r\n```sh\r\nzip &quot;$( echo &quot;build_$( cat manifest.json | jq .version ).zip&quot; | sed s/\\&quot;//g )&quot; ...\r\n```\r\n\r\nThis is the answer to your question, but you can clean this up immensely.\r\n\r\nFor starters, we can move the dequoting into the inner `$()`.\r\n\r\n```sh\r\nzip &quot;$( echo &quot;build_$( cat manifest.json | jq .version | sed s/\\&quot;//g ).zip&quot; )&quot; ...\r\n```\r\n\r\n`echo &quot;$( ... )&quot;` is effectively just `...`.\r\n\r\n```sh\r\nzip &quot;build_$( cat manifest.json | jq .version | sed s/\\&quot;//g ).zip&quot; ...\r\n```\r\n\r\nLet&#39;s get rid of the useless use of `cat`.\r\n\r\n```sh\r\nzip &quot;build_$( jq .version manifest.json | sed s/\\&quot;//g ).zip&quot; ...\r\n```\r\n\r\nFinally, rather than trying to convert the JSON literal into the string it produces using `sed`, we can use `--raw-output` aka `-r`.\r\n\r\n```sh\r\nzip &quot;build_$( jq -r .version manifest.json ).zip&quot; ...\r\n```\r\n",
                "title": "bash zip file with version read from file and used in zip file name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1641713937,
        "creation_date": 1641676809,
        "last_edit_date": 1641678563,
        "question_id": 70636530,
        "body_markdown": "I&#39;m able to zip a bunch of files with `zip`\r\n\r\n```sh\r\n$ zip build.zip src/*.js src/assets/icons/*.png *.json\r\nupdating: src/addReactionsNav.js (deflated 65%)\r\nupdating: manifest.json (deflated 55%)\r\nupdating: src/assets/icons/icon_128.png (stored 0%)\r\nupdating: src/assets/icons/icon_16.png (stored 0%)\r\nupdating: src/assets/icons/icon_256.png (deflated 0%)\r\nupdating: src/assets/icons/icon_48.png (stored 0%)\r\n```\r\n\r\nbut I would like to automate it so the name of the zip includes the version. Figured out to do this:\r\n\r\n\r\n```sh\r\n$ echo &quot;build_$(cat manifest.json | jq .version).zip&quot; | sed s/\\&quot;//g\r\nbuild_1.1.0.zip\r\n\r\n```\r\n\r\nBut can&#39;t figure out how to &quot;pipe&quot; the two together.\r\n\r\n# Solution\r\n\r\nthanks @cyrus\r\n\r\n```sh\r\nzip &quot;build_$(jq -r .version manifest.json).zip&quot; src/*.js src/assets/icons/*.png *.json\r\n```",
        "link": "https://stackoverflow.com/questions/70636530/bash-zip-file-with-version-read-from-file-and-used-in-zip-file-name",
        "title": "bash zip file with version read from file and used in zip file name"
    },
    {
        "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": 1641784364,
                "post_id": 70647376,
                "comment_id": 124889014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1063904,
                    "reputation": 10488,
                    "user_id": 1064923,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/a58a35ad7423065db700fb44d1b298a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "marked-down",
                    "link": "https://stackoverflow.com/users/1064923/marked-down"
                },
                "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": 1641784431,
                "post_id": 70647376,
                "comment_id": 124889020,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641784743,
                "creation_date": 1641784743,
                "answer_id": 70647433,
                "question_id": 70647376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `with_entries` builtin lets you select upon the value while retaining the object-field structure.\r\n```sh\r\njq &#39;.data | map(with_entries(select(.value | scalars)))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;blah&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;blah&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/Tu9rFEBysy)\r\n",
                "title": "jq: select only scalars in objects in JSON array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649726468,
                "creation_date": 1649726468,
                "answer_id": 71835959,
                "question_id": 70647376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do\r\n\r\n```\r\n[.data[] | to_entries | map(select(.value | scalars)) | from_entries]\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/Y7-_8J-DFt\r\n\r\nWhich is the same as\r\n\r\n```\r\n[.data[] | with_entries(select(.value | scalars))]\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/ZjMBXMYeBC",
                "title": "jq: select only scalars in objects in JSON array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649726468,
        "creation_date": 1641784014,
        "last_edit_date": 1641784459,
        "question_id": 70647376,
        "body_markdown": "I have the following JSON data structure I&#39;d like to filter using `jq`:\r\n\r\n```json\r\n{\r\n &quot;data&quot;: [\r\n  {\r\n   &quot;id&quot;: &quot;blah&quot;,\r\n   &quot;foo&quot;: &quot;bar&quot;,\r\n   &quot;array&quot;: [ ... ]\r\n  },\r\n  {\r\n   &quot;id&quot;: &quot;blah&quot;,\r\n   &quot;foo&quot;: &quot;bar&quot;\r\n   &quot;array&quot;: [ ... ]\r\n  }\r\n ]\r\n}\r\n```\r\n\r\nI want to map this to an array of objects with only the top-level scalar values present in each modified object (i.e. keys containing values like arrays and objects should disappear—I&#39;m not interested in the contents of anything nested here):\r\n\r\n```json\r\n[\r\n  {\r\n   &quot;id&quot;: &quot;blah&quot;,\r\n   &quot;foo&quot;: &quot;bar&quot;\r\n  },\r\n  {\r\n   &quot;id&quot;: &quot;blah&quot;,\r\n   &quot;foo&quot;: &quot;bar&quot;\r\n  }\r\n]\r\n```\r\n\r\nThis should be possible using some combination of `jq`&#39;s `map` and `select` operators in tandem with `scalars`, but I am unable to figure out an exact solution. I expect the answer to be embarrassingly simple. For example, I have tried `.data[] | map(select(scalars))`, etc.\r\n\r\nI am using the latest version of `jq`.",
        "link": "https://stackoverflow.com/questions/70647376/jq-select-only-scalars-in-objects-in-json-array",
        "title": "jq: select only scalars in objects in JSON array?"
    },
    {
        "tags": [
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641792961,
                "creation_date": 1641792961,
                "answer_id": 70648195,
                "question_id": 70648113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "curl is a command used to communicate with the server. Your first URL is an API endpoint for the metaweather location search API. &quot;?query=hyderabad&quot; tells the server to get the data for &quot;hyderabad&quot;. The server responds with:\r\n\r\n    [{&quot;title&quot;:&quot;Hyderabad&quot;,&quot;location_type&quot;:&quot;City&quot;,&quot;woeid&quot;:2295414,&quot;latt_long&quot;:&quot;17.508829,78.434578&quot;}]\r\n\r\nthe &quot;woeid&quot; parameter represents the ID of your location. The command then takes that woeid and sends it to the other API endpoint. The second API takes that woeid, uses it to find your location, and responds with the following info:\r\n\r\n    {&quot;consolidated_weather&quot;:[{&quot;id&quot;:4943876231004160,&quot;weather_state_name&quot;:&quot;Showers&quot;,&quot;weather_state_abbr&quot;:&quot;s&quot;,&quot;wind_direction_compass&quot;:&quot;SSE&quot;,&quot;created&quot;:&quot;2022-01-10T04:50:35.034292Z&quot;,&quot;applicable_date&quot;:&quot;2022-01-10&quot;,&quot;min_temp&quot;:19.145,&quot;max_temp&quot;:27.775,&quot;the_temp&quot;:25.700000000000003,&quot;wind_speed&quot;:4.491323107826295,&quot;wind_direction&quot;:154.44033101452658,&quot;air_pressure&quot;:1015.0,&quot;humidity&quot;:70,&quot;visibility&quot;:9.777586395450568,&quot;predictability&quot;:73},{&quot;id&quot;:6357293160464384,&quot;weather_state_name&quot;:&quot;Light Rain&quot;,&quot;weather_state_abbr&quot;:&quot;lr&quot;,&quot;wind_direction_compass&quot;:&quot;SSE&quot;,&quot;created&quot;:&quot;2022-01-10T04:50:38.005159Z&quot;,&quot;applicable_date&quot;:&quot;2022-01-11&quot;,&quot;min_temp&quot;:18.205,&quot;max_temp&quot;:28.07,&quot;the_temp&quot;:25.89,&quot;wind_speed&quot;:6.292207290389459,&quot;wind_direction&quot;:154.50026675861483,&quot;air_pressure&quot;:1014.5,&quot;humidity&quot;:67,&quot;visibility&quot;:11.256760518571543,&quot;predictability&quot;:75},{&quot;id&quot;:4953107759890432,&quot;weather_state_name&quot;:&quot;Showers&quot;,&quot;weather_state_abbr&quot;:&quot;s&quot;,&quot;wind_direction_compass&quot;:&quot;SSE&quot;,&quot;created&quot;:&quot;2022-01-10T04:50:41.160848Z&quot;,&quot;applicable_date&quot;:&quot;2022-01-12&quot;,&quot;min_temp&quot;:18.115,&quot;max_temp&quot;:29.41,&quot;the_temp&quot;:26.65,&quot;wind_speed&quot;:5.614736243593415,&quot;wind_direction&quot;:163.24826086181199,&quot;air_pressure&quot;:1013.5,&quot;humidity&quot;:63,&quot;visibility&quot;:10.892015628728227,&quot;predictability&quot;:73},{&quot;id&quot;:4781031103135744,&quot;weather_state_name&quot;:&quot;Light Rain&quot;,&quot;weather_state_abbr&quot;:&quot;lr&quot;,&quot;wind_direction_compass&quot;:&quot;SSE&quot;,&quot;created&quot;:&quot;2022-01-10T04:50:44.066091Z&quot;,&quot;applicable_date&quot;:&quot;2022-01-13&quot;,&quot;min_temp&quot;:18.725,&quot;max_temp&quot;:28.77,&quot;the_temp&quot;:25.63,&quot;wind_speed&quot;:6.143865224862801,&quot;wind_direction&quot;:150.42762877821613,&quot;air_pressure&quot;:1013.0,&quot;humidity&quot;:65,&quot;visibility&quot;:10.398646902091784,&quot;predictability&quot;:75},{&quot;id&quot;:4949918276911104,&quot;weather_state_name&quot;:&quot;Showers&quot;,&quot;weather_state_abbr&quot;:&quot;s&quot;,&quot;wind_direction_compass&quot;:&quot;SSW&quot;,&quot;created&quot;:&quot;2022-01-10T04:50:47.040253Z&quot;,&quot;applicable_date&quot;:&quot;2022-01-14&quot;,&quot;min_temp&quot;:19.295,&quot;max_temp&quot;:28.17,&quot;the_temp&quot;:25.805,&quot;wind_speed&quot;:5.159495540358971,&quot;wind_direction&quot;:203.78057282014655,&quot;air_pressure&quot;:1013.5,&quot;humidity&quot;:54,&quot;visibility&quot;:10.962541259047164,&quot;predictability&quot;:73},{&quot;id&quot;:4891149274710016,&quot;weather_state_name&quot;:&quot;Showers&quot;,&quot;weather_state_abbr&quot;:&quot;s&quot;,&quot;wind_direction_compass&quot;:&quot;ESE&quot;,&quot;created&quot;:&quot;2022-01-10T04:50:50.555320Z&quot;,&quot;applicable_date&quot;:&quot;2022-01-15&quot;,&quot;min_temp&quot;:19.435,&quot;max_temp&quot;:27.655,&quot;the_temp&quot;:27.33,&quot;wind_speed&quot;:5.123282828282829,&quot;wind_direction&quot;:114.5,&quot;air_pressure&quot;:1014.0,&quot;humidity&quot;:55,&quot;visibility&quot;:9.999726596675416,&quot;predictability&quot;:73}],&quot;time&quot;:&quot;2022-01-10T11:04:08.669337+05:30&quot;,&quot;sun_rise&quot;:&quot;2022-01-10T06:49:03.997088+05:30&quot;,&quot;sun_set&quot;:&quot;2022-01-10T17:58:25.214998+05:30&quot;,&quot;timezone_name&quot;:&quot;LMT&quot;,&quot;parent&quot;:{&quot;title&quot;:&quot;India&quot;,&quot;location_type&quot;:&quot;Country&quot;,&quot;woeid&quot;:23424848,&quot;latt_long&quot;:&quot;21.786600,82.794762&quot;},&quot;sources&quot;:[{&quot;title&quot;:&quot;BBC&quot;,&quot;slug&quot;:&quot;bbc&quot;,&quot;url&quot;:&quot;http://www.bbc.co.uk/weather/&quot;,&quot;crawl_rate&quot;:360},{&quot;title&quot;:&quot;Forecast.io&quot;,&quot;slug&quot;:&quot;forecast-io&quot;,&quot;url&quot;:&quot;http://forecast.io/&quot;,&quot;crawl_rate&quot;:480},{&quot;title&quot;:&quot;Met Office&quot;,&quot;slug&quot;:&quot;met-office&quot;,&quot;url&quot;:&quot;http://www.metoffice.gov.uk/&quot;,&quot;crawl_rate&quot;:180},{&quot;title&quot;:&quot;OpenWeatherMap&quot;,&quot;slug&quot;:&quot;openweathermap&quot;,&quot;url&quot;:&quot;http://openweathermap.org/&quot;,&quot;crawl_rate&quot;:360},{&quot;title&quot;:&quot;World Weather Online&quot;,&quot;slug&quot;:&quot;world-weather-online&quot;,&quot;url&quot;:&quot;http://www.worldweatheronline.com/&quot;,&quot;crawl_rate&quot;:360}],&quot;title&quot;:&quot;Hyderabad&quot;,&quot;location_type&quot;:&quot;City&quot;,&quot;woeid&quot;:2295414,&quot;latt_long&quot;:&quot;17.508829,78.434578&quot;,&quot;timezone&quot;:&quot;Asia/Kolkata&quot;}\r\n\r\nIt then parses that response and fetches the wind speed and temperature from that data using this command:\r\n\r\n    jq &#39;.consolidated_weather[0].wind_speed,.consolidated_weather[0].the_temp&#39;&quot;\r\n\r\n",
                "title": "Please explain below how these commands work to fetch two URLs?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1641792989,
        "creation_date": 1641792160,
        "last_edit_date": 1641792989,
        "question_id": 70648113,
        "body_markdown": "`watch -n2 &quot;curl -s https://www.metaweather.com/api/location/search/?query=hyderabad | jq -r &#39;.[] | .woeid&#39; |  xargs -I% curl -s https://www.metaweather.com/api/location/%/ | jq &#39;.consolidated_weather[0].wind_speed,.consolidated_weather[0].the_temp&#39;&quot;`\r\n\r\n\r\nIt is the url for fetching location temperature and wind from two URLs. I do not understand how they fetched it. Please explain it to me?\r\n",
        "link": "https://stackoverflow.com/questions/70648113/please-explain-below-how-these-commands-work-to-fetch-two-urls",
        "title": "Please explain below how these commands work to fetch two URLs?"
    },
    {
        "tags": [
            "json",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641798777,
                "last_edit_date": 1641798777,
                "creation_date": 1641796488,
                "answer_id": 70648619,
                "question_id": 70648582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `split` such as\r\n```\r\njq -r &#39;.values[2].name | split(&quot;-&quot;)[1]&#39; response.json\r\n```\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/Lx2zl6BL66)&lt;/kbd&gt;\r\n\r\n**Edit** : Alternatively you can use\r\n```\r\njq -r &#39;.values[].name | select(.|split(&quot;-&quot;)[0]==&quot;reporter&quot;)|split(&quot;-&quot;)[1]&#39; response.json &gt; outfile.txt\r\n```\r\nwithout knowing the order of the name element within the array\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/Nr77-Gw_tF)&lt;/kbd&gt;\r\n",
                "title": "parse json and get values with same type"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641839242,
                "last_edit_date": 1641839242,
                "creation_date": 1641797821,
                "answer_id": 70648765,
                "question_id": 70648582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;.values[]\r\n  | select(.name|index(&quot;reporter&quot;))\r\n  | .name\r\n  | sub(&quot;reporter-&quot;;&quot;&quot;)&#39; in.json &gt; out.txt\r\n```\r\n\r\nOf course you might wish to use a different selection criterion, e.g. using  `startswith` or `test`.",
                "title": "parse json and get values with same type"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1641831231,
                "last_edit_date": 1641831231,
                "creation_date": 1641816961,
                "answer_id": 70652235,
                "question_id": 70648582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `capture` :\r\n\r\n```\r\njq -r &#39;.values[].name\r\n  | capture(&quot;^reporter-(?&lt;name&gt;.*)&quot;).name\r\n  &#39; response.json\r\n```",
                "title": "parse json and get values with same type"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1641839242,
        "creation_date": 1641796168,
        "last_edit_date": 1641796585,
        "question_id": 70648582,
        "body_markdown": "In the below json, I&#39;m unable to get the value which have reporter only.\r\nthe output should be jhoncena only which should written into a file.\r\n\r\n```\r\njq -r &#39;.values&#39; response.json | grep reporter\r\n```\r\n\r\nthe output for this is \r\n```\r\n&quot;name&quot;: &quot;reporter-jhoncena&quot;\r\n```\r\n\r\n```json\r\n{\r\n  &quot;size&quot;: 3,\r\n  &quot;limit&quot;: 25,\r\n  &quot;isLastPage&quot;: true,\r\n  &quot;values&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;hello-world&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test-frame&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;reporter-jhoncena&quot;\r\n    }\r\n  ],\r\n  &quot;start&quot;: 0\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70648582/parse-json-and-get-values-with-same-type",
        "title": "parse json and get values with same type"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "indexing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641836687,
                "creation_date": 1641836687,
                "answer_id": 70656750,
                "question_id": 70656590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option would be using `to_entries` such as\r\n```\r\njq &#39;.list[] | to_entries[] | select(.key==&quot;entryB&quot;) | .value&#39; example.json\r\n```",
                "title": "Use JQ to select an array entry by value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641837044,
                "creation_date": 1641837044,
                "answer_id": 70656818,
                "question_id": 70656590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using the [alternative operator](https://stedolan.github.io/jq/manual/v1.6/#Alternativeoperator://) `//` you can defect to `empty` if the first alternative does not exist. \r\n```sh\r\njq &#39;.list[] | .entryB // empty&#39; example.json\r\n```\r\n```\r\n{\r\n  &quot;item1&quot;: &quot;oof&quot;,\r\n  &quot;item2&quot;: &quot;rab&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/qRYKAfMkRo)\r\n",
                "title": "Use JQ to select an array entry by value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641837044,
        "creation_date": 1641835916,
        "question_id": 70656590,
        "body_markdown": "I have a json file:\r\nexample.json\r\n```\r\n{\r\n  &quot;list&quot;: [\r\n    {\r\n      &quot;entryA&quot;: {\r\n        &quot;item1&quot;: &quot;foo&quot;,\r\n        &quot;item2&quot;: &quot;bar&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;entryB&quot;: {\r\n        &quot;item1&quot;: &quot;oof&quot;,\r\n        &quot;item2&quot;: &quot;rab&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nI would like the output to be the contents of entryB:\r\n```\r\n{\r\n  &quot;item1&quot;: &quot;oof&quot;,\r\n  &quot;item2&quot;: &quot;rab&quot;\r\n}\r\n```\r\nhowever, using the example from the manual for `Optional Object Identifier-Index: .foo?`, I get these results:\r\n```\r\n$ jq &#39;.list[] | .entryB?&#39; example.json\r\nnull\r\n{\r\n  &quot;item1&quot;: &quot;oof&quot;,\r\n  &quot;item2&quot;: &quot;rab&quot;\r\n}\r\n\r\n$ jq &#39;.list[] | .[&quot;entryB&quot;]?&#39; example.json\r\nnull\r\n{\r\n  &quot;item1&quot;: &quot;oof&quot;,\r\n  &quot;item2&quot;: &quot;rab&quot;\r\n}\r\n```\r\n\r\nHow can I format the JQ Query to not include a **`null`** output for `entryA`?",
        "link": "https://stackoverflow.com/questions/70656590/use-jq-to-select-an-array-entry-by-value",
        "title": "Use JQ to select an array entry by value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656249377,
                "last_edit_date": 1656249377,
                "creation_date": 1641843454,
                "answer_id": 70658028,
                "question_id": 70658004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just need to quote the key name such as\r\n```\r\njq &#39;.&quot;target-hosts&quot;&#39; deploy.json  \r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/PnpLP-SC7Jv)&lt;/kbd&gt;",
                "title": "How get element value if name exist symbol &quot;-&quot;?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641843649,
                "creation_date": 1641843649,
                "answer_id": 70658068,
                "question_id": 70658004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to enclose in double quotes:\r\n\r\n    jq &#39;.&quot;target-hosts&quot;&#39;",
                "title": "How get element value if name exist symbol &quot;-&quot;?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641845754,
                "creation_date": 1641845754,
                "answer_id": 70658428,
                "question_id": 70658004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n.&quot;target-hosts&quot;\r\n```\r\n\r\nor\r\n\r\n```jq\r\n.[&quot;target-hosts&quot;]\r\n```\r\n\r\nSo,\r\n\r\n```sh\r\njq &#39;.&quot;target-hosts&quot;&#39; deploy.json\r\n```\r\n\r\nor\r\n\r\n```sh\r\njq &#39;.[&quot;target-hosts&quot;]&#39; deploy.json\r\n```\r\n",
                "title": "How get element value if name exist symbol &quot;-&quot;?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1656249377,
        "creation_date": 1641843329,
        "last_edit_date": 1641843673,
        "question_id": 70658004,
        "body_markdown": "In one of my projects exist json file\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;view1&quot;,\r\n  &quot;version&quot;: &quot;1.1.1&quot;,\r\n  &quot;target-dir&quot;: &quot;/opt/project/spark-jobs/&quot;,\r\n  &quot;target-hosts&quot;: {\r\n    &quot;dev&quot;: [&quot;host1&quot;, &quot;host2&quot;],\r\n    &quot;prod&quot;: [&quot;host3&quot;, &quot;host4&quot;]\r\n  }\r\n}\r\n```\r\nI have to read element of json &quot;target-hosts&quot;,\r\nfor solve try to use JQ, but if try run command\r\n\r\n    jq &#39;.target-hosts&#39; deploy.json  \r\n    jq: error: dir/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .target-hosts        \r\n    jq: 1 compile error\r\n\r\n\r\nHow escape character &quot;-&quot;?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70658004/how-get-element-value-if-name-exist-symbol",
        "title": "How get element value if name exist symbol &quot;-&quot;?"
    },
    {
        "tags": [
            "json",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1641902003,
                "last_edit_date": 1641902003,
                "creation_date": 1641900990,
                "answer_id": 70666122,
                "question_id": 70665995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Re Problem 1 ##\r\n\r\nYou *can* update the relevant IP addresses using\r\n```sh\r\njq &#39;(.. | .ip? | select(. == &quot;10.1.1.49&quot;)) |= &quot;10.10.10.10&quot;&#39;\r\n```\r\n```json\r\n{\r\n  &quot;destination&quot;: {\r\n    &quot;port&quot;: 53,\r\n    &quot;bytes&quot;: 100,\r\n    &quot;ip&quot;: &quot;1.1.1.1&quot;\r\n  },\r\n  &quot;source&quot;: {\r\n    &quot;port&quot;: 54894,\r\n    &quot;bytes&quot;: 84,\r\n    &quot;ip&quot;: &quot;10.10.10.10&quot;\r\n  },\r\n  &quot;related&quot;: {\r\n    &quot;ip&quot;: &quot;10.5.5.45&quot;\r\n  },\r\n  &quot;event&quot;: {\r\n    &quot;code&quot;: &quot;0000000013&quot;,\r\n    &quot;action&quot;: &quot;accept&quot;,\r\n    &quot;type&quot;: [\r\n      &quot;allowed&quot;,\r\n      &quot;connection&quot;,\r\n      &quot;end&quot;,\r\n      &quot;protocol&quot;\r\n    ],\r\n    &quot;outcome&quot;: &quot;success&quot;\r\n  },\r\n  &quot;@timestamp&quot;: &quot;2021-08-29T04:47:10.000+02:00&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/vM2i0CLdpR)\r\n\r\nBut you *cannot* update the file as you can with `sed -i` - at least not with just using a flag. Using temporary files or `sponge` etc. will, however, work fine.\r\n\r\n## Re Problem 2 ##\r\n\r\nRead in the mappings e.g. using `--argfile` and update using a lookup in combination with the alternative operator `//` to fall back to the original value, if it doesn&#39;t exist in the mapping\r\n\r\n```sh\r\njq --argfile mapping mapping.json &#39;(.. | .ip? // empty) |= ($mapping[.]? // .)&#39;\r\n```\r\n[Demo](https://jqplay.org/s/mympT0viH_)\r\n",
                "title": "How to use jq as SED for large json file (optionally with a mapping table)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641902003,
        "creation_date": 1641900445,
        "question_id": 70665995,
        "body_markdown": "I have a large json file which contains several IPs within json files. I want to replace specific IP addresses within the json file (without having to write the putout into a new file). The equivalent SED command would be `sed -i &#39;s/old_ip/new_ip/g&#39;`\r\n\r\nThe structure is as follows (of a single json entry in the json file):\r\n\r\n    {\r\n    \r\n       &quot;destination&quot;:{\r\n          &quot;port&quot;:53,\r\n          &quot;bytes&quot;:100,\r\n          &quot;ip&quot;:&quot;1.1.1.1&quot;\r\n       },\r\n       &quot;source&quot;:{\r\n          &quot;port&quot;:54894,\r\n          &quot;bytes&quot;:84,\r\n          &quot;ip&quot;:&quot;10.1.1.49&quot;,\r\n       },\r\n       &quot;related&quot;:{\r\n          &quot;ip&quot;:&quot;10.5.5.45&quot;\r\n       },\r\n       &quot;event&quot;:{\r\n          &quot;code&quot;:&quot;0000000013&quot;,\r\n          &quot;action&quot;:&quot;accept&quot;,\r\n          &quot;type&quot;:[\r\n             &quot;allowed&quot;,\r\n             &quot;connection&quot;,\r\n             &quot;end&quot;,\r\n             &quot;protocol&quot;\r\n          ],\r\n          &quot;outcome&quot;:&quot;success&quot;\r\n       },\r\n       &quot;@timestamp&quot;:&quot;2021-08-29T04:47:10.000+02:00&quot;\r\n    }\r\n\r\nI have now two problems which I can&#39;t figure to solve.\r\n\r\nProblem 1:\r\nI want to replace every IP by a corresponding IP address. So imagine I want to replace the IP 10.1.1.49 with 10.10.10.10\r\n\r\nI know I can use the command `jq  &#39;(.. | .ip?)&#39; | select(.ip == &quot;10.2.1.49&quot;)| .ip |= &quot;10.10.10.10&quot;&#39;` but unfortunately this just outputs the new IP instead of replacing it in the file like SED does (this refers to all solutions I found on the web). \r\n\r\nProblem 2:\r\nNow suppose I have a mapping table (mapping.json) with the following structure:\r\n\r\n    {\r\n     &quot;10.2.1.49&quot;:&quot;10.10.10.10&quot;,\r\n     &quot;10.15.15.15&quot;:&quot;10.10.10.10&quot;\r\n    }\r\n\r\nCan I provide and combine this mapping table with jq for a find and replace? I have the feeling that this is not possible in jq meaning I would need to figure out my first problem and then writing a bash script. Someone had similar question ([see here][1]) by using --sluprfile. But apparently I can&#39;t use the solution from this link as a ID or unique value for selection is required which I don&#39;t have in my json.\r\n\r\nIs there a simple solution or should I just use SED combined with a shellscript?\r\nThanks\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/66320492/jq-replace-values-based-on-external-map",
        "link": "https://stackoverflow.com/questions/70665995/how-to-use-jq-as-sed-for-large-json-file-optionally-with-a-mapping-table",
        "title": "How to use jq as SED for large json file (optionally with a mapping table)"
    },
    {
        "tags": [
            "json",
            "parsing",
            "environment-variables",
            "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": 1641909969,
                "post_id": 70666454,
                "comment_id": 124926702,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641910260,
                "creation_date": 1641910260,
                "answer_id": 70668246,
                "question_id": 70666454,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming those input objects are in an array, \r\n\r\n```\r\n.[] | select(.metadata.name == &quot;run2&quot;) | .metadata\r\n```\r\n\r\nWill select the object where `.metadata.name === run2`.\r\n\r\nThen it shows the `.metadata` of that object so the output becomes:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;run2&quot;,\r\n  &quot;uid&quot;: &quot;9b0af3&quot;,\r\n  &quot;creationTimestamp&quot;: &quot;2021-01-01T01:01:01Z&quot;\r\n}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/zPyScdoGNx)",
                "title": "I have some JSON but I want to extract data based on a variable using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641910260,
        "creation_date": 1641902442,
        "question_id": 70666454,
        "body_markdown": "I have some JSON data which I want to parse using jq \r\n\r\n    {{\r\n        &quot;metadata&quot;:{\r\n          &quot;name&quot;:&quot;run1&quot;,\r\n          &quot;uid&quot;:&quot;b2c0ce&quot;,\r\n          &quot;creationTimestamp&quot;:&quot;2021-01-01T01:01:01Z&quot;\r\n        },\r\n        &quot;spec&quot;:{\r\n          &quot;arguments&quot;:{}\r\n        },\r\n        &quot;status&quot;:{\r\n          &quot;phase&quot;:&quot;Failed&quot;,\r\n          &quot;startedAt&quot;:&quot;2021-01-01T01:01:01Z&quot;,\r\n          &quot;finishedAt&quot;:&quot;2021-01-01T01:01:01Z&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;metadata&quot;:{\r\n          &quot;name&quot;:&quot;run2&quot;,\r\n          &quot;uid&quot;:&quot;9b0af3&quot;,\r\n          &quot;creationTimestamp&quot;:&quot;2021-01-01T01:01:01Z&quot;\r\n        },\r\n        &quot;spec&quot;:{\r\n          &quot;arguments&quot;:{}\r\n        },\r\n        &quot;status&quot;:{\r\n          &quot;phase&quot;:&quot;Succeeded&quot;,\r\n          &quot;startedAt&quot;:&quot;2021-01-01T01:01:01Z&quot;,\r\n          &quot;finishedAt&quot;:&quot;2021-01-01T01:01:01Z&quot;}}}\r\n\r\nI have a script that a user will enter a &quot;name&quot; and I want to be able to look for and extract the metadata for the name they entered if it exists. So for example if they enter &quot;run7&quot; I wanted the final output to be:\r\n\r\n    {&quot;metadata&quot;:{\r\n        &quot;name&quot;:&quot;run7&quot;,\r\n        &quot;uid&quot;:&quot;b2c0ce&quot;,\r\n        &quot;creationTimestamp&quot;:&quot;2021-01-01T01:01:01Z&quot;}\r\n\r\nor if possible to just show\r\n\r\n    &quot;name&quot;:&quot;run7&quot;,\r\n    &quot;uid&quot;:&quot;b2c0ce&quot;,\r\n    &quot;creationTimestamp&quot;:&quot;2021-01-01T01:01:01Z&quot;\r\n\r\nThe closest ive gotten is:\r\n\r\n    jq -r &#39;.[] | .[] | map({name: .name, uid: .uid, time: .creationTimestamp })&#39;  file.json\r\n\r\nbut im not sure how I can now search only for a certain name. The way I did it gives this:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;run10&quot;,\r\n        &quot;uid&quot;: &quot;af7b51f&quot;,\r\n        &quot;time&quot;: &quot;2021-01-01T01:01:01Z&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: null,\r\n        &quot;uid&quot;: null,\r\n        &quot;time&quot;: null\r\n      },\r\n      {\r\n        &quot;name&quot;: null,\r\n        &quot;uid&quot;: null,\r\n        &quot;time&quot;: null\r\n      } \r\n\r\nI also dont want it to check the &quot;spec&quot; or &quot;status&quot; because thats where the null came from",
        "link": "https://stackoverflow.com/questions/70666454/i-have-some-json-but-i-want-to-extract-data-based-on-a-variable-using-jq",
        "title": "I have some JSON but I want to extract data based on a variable using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1641952620,
                "last_edit_date": 1641952620,
                "creation_date": 1641904791,
                "answer_id": 70666944,
                "question_id": 70666584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `group_by` and `map`\r\n```sh\r\njq -Rn &#39;\r\n  [inputs | select(. != &quot;&quot;) / &quot; &quot;]\r\n  | group_by(.[0])\r\n  | map({(.[0][0]): map({instance: .[1], value: .[2]})})\r\n  | add\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/KZoUT5VBv8)\r\n\r\nUsing `reduce`\r\n```sh\r\njq -Rn &#39;\r\n  reduce (inputs | select(. != &quot;&quot;) / &quot; &quot;) as [$cpu, $instance, $value] ({};\r\n    .[$cpu] += [{$instance, $value}]\r\n  )\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/OPrRwbWHgA)\\\r\n&lt;sub&gt;Improved by [@JeffMercado](https://stackoverflow.com/questions/70666584/how-to-convert-txt-to-json/70666944?noredirect=1#comment124939286_70666944)&lt;/sub&gt;\r\n",
                "title": "how to convert txt to json?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641908611,
                "creation_date": 1641908611,
                "answer_id": 70667844,
                "question_id": 70666584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A scripting language like ruby would work here as well:\r\n```sh\r\nruby -rjson -e &#39;\r\n  data = Hash.new {|h, k| h[k] = []}\r\n  File.new(ARGV.shift).each {|line|\r\n    cpu, ip, num = line.split\r\n    data[cpu] &lt;&lt; {instance: ip, value: num.to_i}\r\n  }\r\n  puts JSON.dump(data)\r\n&#39; input.txt\r\n```\r\n```none\r\n{&quot;CPU20&quot;:[{&quot;instance&quot;:&quot;10.0.20.1&quot;,&quot;value&quot;:12},{&quot;instance&quot;:&quot;10.0.20.2&quot;,&quot;value&quot;:22},{&quot;instance&quot;:&quot;10.0.20.3&quot;,&quot;value&quot;:13},{&quot;instance&quot;:&quot;10.0.20.4&quot;,&quot;value&quot;:11},{&quot;instance&quot;:&quot;10.0.20.5&quot;,&quot;value&quot;:14}],&quot;CPU21&quot;:[{&quot;instance&quot;:&quot;10.0.21.1&quot;,&quot;value&quot;:15},{&quot;instance&quot;:&quot;10.0.21.2&quot;,&quot;value&quot;:24},{&quot;instance&quot;:&quot;10.0.21.3&quot;,&quot;value&quot;:21},{&quot;instance&quot;:&quot;10.0.21.4&quot;,&quot;value&quot;:15},{&quot;instance&quot;:&quot;10.0.21.5&quot;,&quot;value&quot;:16}],&quot;CPU22&quot;:[{&quot;instance&quot;:&quot;10.0.22.1&quot;,&quot;value&quot;:12},{&quot;instance&quot;:&quot;10.0.22.2&quot;,&quot;value&quot;:18},{&quot;instance&quot;:&quot;10.0.22.3&quot;,&quot;value&quot;:19},{&quot;instance&quot;:&quot;10.0.22.4&quot;,&quot;value&quot;:12},{&quot;instance&quot;:&quot;10.0.22.5&quot;,&quot;value&quot;:13}],&quot;CPU23&quot;:[{&quot;instance&quot;:&quot;10.0.20.1&quot;,&quot;value&quot;:17},{&quot;instance&quot;:&quot;10.0.20.2&quot;,&quot;value&quot;:15},{&quot;instance&quot;:&quot;10.0.20.3&quot;,&quot;value&quot;:21},{&quot;instance&quot;:&quot;10.0.20.4&quot;,&quot;value&quot;:22},{&quot;instance&quot;:&quot;10.0.20.5&quot;,&quot;value&quot;:25}]}\r\n```",
                "title": "how to convert txt to json?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641952620,
        "creation_date": 1641902997,
        "question_id": 70666584,
        "body_markdown": "i try use jq \r\nconvert was successful, but I didn&#39;t get the results I wanted. I tried to get the results I wanted, but it&#39;s hard.\r\n\r\n    jq -Rs &#39;[ split(&quot;\\n&quot;)[] | select(length &gt; 0) | split(&quot; &quot;) |  {group:.[0], instnace: .[1], value: .[2]} ]&#39; input.txt\r\n\r\noriginal txt file..\r\nThere are IP addresses and values ​​from cpu20 to 46 in total\r\n\r\n\r\n\r\n    cpu20 10.0.20.1 12\r\n    cpu20 10.0.20.1 22\r\n    cpu20 10.0.20.1 13\r\n    cpu20 10.0.20.1 11\r\n    cpu20 10.0.20.1 14\r\n\r\n....~cpu46\r\n  \r\n\r\n\r\n\r\nIt&#39;s the result of the way I tried.\r\noutput json\r\n\r\n    {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.94&quot;,\r\n        &quot;value&quot;: &quot;10&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.95&quot;,\r\n        &quot;value&quot;: &quot;10&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.96&quot;,\r\n        &quot;value&quot;: &quot;11&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.97&quot;,\r\n        &quot;value&quot;: &quot;8&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.98&quot;,\r\n        &quot;value&quot;: &quot;11&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.99&quot;,\r\n        &quot;value&quot;: &quot;11&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;cpu-46&quot;,\r\n        &quot;instnace&quot;: &quot;10.0.46.100&quot;,\r\n        &quot;value&quot;: &quot;8&quot;\r\n      }\r\n\r\n\r\n\r\n\r\nWhat should I do to get the results as follows?\r\n\r\n\r\n\r\n        {\r\n      &quot;CPU20&quot;: [\r\n        { &quot;instance&quot;: &quot;10.0.20.1&quot;, &quot;value&quot;: 12 },\r\n        { &quot;instance&quot;: &quot;10.0.20.2&quot;, &quot;value&quot;: 22 },\r\n        { &quot;instance&quot;: &quot;10.0.20.3&quot;, &quot;value&quot;: 13 },\r\n        { &quot;instance&quot;: &quot;10.0.20.4&quot;, &quot;value&quot;: 11 },\r\n        { &quot;instance&quot;: &quot;10.0.20.5&quot;, &quot;value&quot;: 14 }\r\n      ],\r\n      &quot;CPU21&quot;: [\r\n        { &quot;instance&quot;: &quot;10.0.21.1&quot;, &quot;value&quot;: 15 },\r\n        { &quot;instance&quot;: &quot;10.0.21.2&quot;, &quot;value&quot;: 24 },\r\n        { &quot;instance&quot;: &quot;10.0.21.3&quot;, &quot;value&quot;: 21 },\r\n        { &quot;instance&quot;: &quot;10.0.21.4&quot;, &quot;value&quot;: 15 },\r\n        { &quot;instance&quot;: &quot;10.0.21.5&quot;, &quot;value&quot;: 16 }\r\n      ],\r\n      &quot;CPU22&quot;: [\r\n        { &quot;instance&quot;: &quot;10.0.22.1&quot;, &quot;value&quot;: 12 },\r\n        { &quot;instance&quot;: &quot;10.0.22.2&quot;, &quot;value&quot;: 18 },\r\n        { &quot;instance&quot;: &quot;10.0.22.3&quot;, &quot;value&quot;: 19 },\r\n        { &quot;instance&quot;: &quot;10.0.22.4&quot;, &quot;value&quot;: 12 },\r\n        { &quot;instance&quot;: &quot;10.0.22.5&quot;, &quot;value&quot;: 13 }\r\n      ],\r\n      &quot;CPU23&quot;: [\r\n        { &quot;instance&quot;: &quot;10.0.20.1&quot;, &quot;value&quot;: 17 },\r\n        { &quot;instance&quot;: &quot;10.0.20.2&quot;, &quot;value&quot;: 15 },\r\n        { &quot;instance&quot;: &quot;10.0.20.3&quot;, &quot;value&quot;: 21 },\r\n        { &quot;instance&quot;: &quot;10.0.20.4&quot;, &quot;value&quot;: 22 },\r\n        { &quot;instance&quot;: &quot;10.0.20.5&quot;, &quot;value&quot;: 25 }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70666584/how-to-convert-txt-to-json",
        "title": "how to convert txt to json?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641919470,
                "last_edit_date": 1641919470,
                "creation_date": 1641916441,
                "answer_id": 70669677,
                "question_id": 70668174,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If we assume all methods (`get`, `post`, etc) of a given path share the same tags, we can simply use the following:\r\n\r\n```jq\r\n.paths |= with_entries( select( .value[].tags | index(&quot;account-tag&quot;) ) )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/R5Nt_sXa9N) on jqplay\r\n\r\n---\r\n\r\nIf that assumption doesn&#39;t hold, we&#39;ll need to filter at two levels.\r\n\r\n```jq\r\n.paths |= with_entries(\r\n   .value |= with_entries(\r\n      select( .value.tags | index(&quot;account-tag&quot;) )\r\n   ) |\r\n   select( .value | length &gt; 0 )\r\n)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/yESry30aVp) on jqplay\r\n\r\nor\r\n\r\n```jq\r\n.paths |= with_entries(\r\n   .value = (\r\n      .value |\r\n      with_entries(\r\n         select( .value.tags | index(&quot;account-tag&quot;) )\r\n      ) |\r\n      select( length &gt; 0 )\r\n   )\r\n)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/w8GXYL8b5Y) on jqplay\r\n\r\n(I hate that I have to use `.value = ( .value | ... )` instead of `.value |= ( ... )` here.)",
                "title": "How can I remove a nested key-value pair, whose value has a deeper nested array with a specific value by using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641919470,
        "creation_date": 1641910000,
        "last_edit_date": 1641917488,
        "question_id": 70668174,
        "body_markdown": "I am currently trying to filter out some path values from a swagger json document, by using jq.\r\n\r\nThe JSON looks something like this:\r\n\r\n``` lang-json\r\n{\r\n  &quot;swagger&quot;: &quot;2.0&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;version&quot;: &quot;1.0.2&quot;,\r\n    &quot;title&quot;: &quot;Some API&quot;\r\n  },\r\n  &quot;host&quot;: &quot;example.com&quot;,\r\n  &quot;basePath&quot;: &quot;/&quot;,\r\n  &quot;paths&quot;: {\r\n    &quot;/api/companies&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [ &quot;company-tag&quot; ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;OK&quot;,\r\n            &quot;schema&quot;: { &quot;$ref&quot;: &quot;#/definitions/CompanyDTO&quot; }\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/api/account&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [ &quot;account-tag&quot; ],\r\n        &quot;operationId&quot;: &quot;getAccount&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;OK&quot;,\r\n            &quot;schema&quot;: { &quot;$ref&quot;: &quot;#/definitions/UserDTO&quot; }\r\n          }\r\n        }\r\n      },\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [ &quot;account-tag&quot; ],\r\n        &quot;operationId&quot;: &quot;createAccount&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;OK&quot;,\r\n            &quot;schema&quot;: { &quot;$ref&quot;: &quot;#/definitions/UserDTO&quot; }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI would like to filter the **paths** values, so that I can get only the paths that contain a specific tag inside the **tags** array.\r\n\r\nFor example: if I want to get the paths for the **account-tag** the JSON should look like this after filtering:\r\n\r\n``` lang-json\r\n{\r\n  &quot;swagger&quot;: &quot;2.0&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;version&quot;: &quot;1.0.2&quot;,\r\n    &quot;title&quot;: &quot;Some API&quot;\r\n  },\r\n  &quot;host&quot;: &quot;example.com&quot;,\r\n  &quot;basePath&quot;: &quot;/&quot;,\r\n  &quot;paths&quot;: {\r\n    &quot;/api/account&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [ &quot;account-tag&quot; ],\r\n        &quot;operationId&quot;: &quot;getAccount&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;OK&quot;,\r\n            &quot;schema&quot;: { &quot;$ref&quot;: &quot;#/definitions/UserDTO&quot; }\r\n          }\r\n        }\r\n      },\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [ &quot;account-tag&quot; ],\r\n        &quot;operationId&quot;: &quot;createAccount&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;OK&quot;,\r\n            &quot;schema&quot;: { &quot;$ref&quot;: &quot;#/definitions/UserDTO&quot; }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**EDIT**\r\n\r\nIkegami&#39;s second suggestion worked as expected.\r\nHere is my final [solution][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/4VmYatAx--",
        "link": "https://stackoverflow.com/questions/70668174/how-can-i-remove-a-nested-key-value-pair-whose-value-has-a-deeper-nested-array",
        "title": "How can I remove a nested key-value pair, whose value has a deeper nested array with a specific value by using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641973053,
                "creation_date": 1641973053,
                "answer_id": 70677841,
                "question_id": 70677758,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just un-wrap the list generated form unique operation using `unique[]` and still use the raw output mode `-r`\r\n\r\n```\r\njq -nr &#39;[inputs | keys_unsorted[]] | unique[]&#39;\r\n```\r\n\r\nI&#39;ve also used `keys_unsorted` over `keys` to preserve the key ordering.\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n\r\n  [1]: https://jqplay.org/s/hs33CTzHDV",
                "title": "Get unique JSON keys with JQ in raw format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641973212,
        "creation_date": 1641972529,
        "last_edit_date": 1641973212,
        "question_id": 70677758,
        "body_markdown": "This is a follow up question on answer to this question:  https://stackoverflow.com/questions/29822622/get-all-unique-json-key-names-with-jq  \r\n\r\nHow to get the unique keys in raw format from this\r\n```\r\n{&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3}\r\n{&quot;a&quot;: 4, &quot;b&quot;: 5, &quot;d&quot;: 6}\r\n```\r\nThe answer to above question is as follows. But this outputs the data in a &#39;list&#39; like format:\r\n```\r\n$ jq -n &#39;[inputs | keys[]] | unique&#39; input.json\r\n[\r\n  &quot;a&quot;,\r\n  &quot;b&quot;,\r\n  &quot;c&quot;,\r\n  &quot;d&quot;\r\n]\r\n```\r\nHow to get just the raw values i.e., a,b,c without open close brackets and double quotes? Usually this can be achieved with ```jq -r``` but not in this case.\r\n```\r\na\r\nb\r\nc\r\nd\r\n```",
        "link": "https://stackoverflow.com/questions/70677758/get-unique-json-keys-with-jq-in-raw-format",
        "title": "Get unique JSON keys with JQ in raw format"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1641991323,
                "last_edit_date": 1641991323,
                "creation_date": 1641988617,
                "answer_id": 70681152,
                "question_id": 70681151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -s &#39;flatten(1)&#39; file.json\r\n```\r\n\r\nExplanation:\r\n\r\n- [`flatten(1)`][1] de-nests arrays with depth of 1.\r\n- `-s` runs the command on all the items (ie. both lists) rather than each item independently.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example36",
                "title": "How to merge two simple JSON arrays together with JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1641991190,
                "creation_date": 1641991190,
                "answer_id": 70681718,
                "question_id": 70681151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another simple way, using just `add`:\r\n\r\n```bash\r\njq -s &#39;add&#39; input.json\r\n```\r\n&lt;sup&gt;[\\[Documentation\\]][1]&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\n* ##### [JqPlay Demo](https://jqplay.org/s/ktA1qJV23T)\r\n\r\n* Local shell example\r\n\r\n  ```none\r\n  $ cat input.json\r\n  [1,2,3,4]\r\n  [5,6,7,8]\r\n  $\r\n  $ jq -s &#39;add&#39; input.json\r\n  [\r\n    1,\r\n    2,\r\n    3,\r\n    4,\r\n    5,\r\n    6,\r\n    7,\r\n    8\r\n  ]\r\n  $\r\n  ```\r\n\r\n\r\n  [1]: http://[1]",
                "title": "How to merge two simple JSON arrays together with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641992356,
                "creation_date": 1641992356,
                "answer_id": 70681996,
                "question_id": 70681151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yet another way\r\n```sh\r\njq -n &#39;[inputs[]]&#39; file.json\r\n```\r\n[Demo](https://jqplay.org/s/4DVGc5Dhp3)",
                "title": "How to merge two simple JSON arrays together with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641993953,
                "creation_date": 1641993953,
                "answer_id": 70682368,
                "question_id": 70681151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `c` option prints to one line.\r\nAlso if you want to merge the two arrays and keep them sorted you can do this:\r\n\r\n    jq -cn &#39;[inputs[]] | sort&#39; file.json\r\n\r\nFor example, it will still be in order in the case below:\r\n\r\n    $ cat file.json\r\n    [1,2,3,5]\r\n    [4,6,7,8]\r\n    $ jq -cn &#39;[inputs[]] | sort &#39;  file.json\r\n    [1,2,3,4,5,6,7,8]\r\n",
                "title": "How to merge two simple JSON arrays together with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1641993953,
        "creation_date": 1641988617,
        "question_id": 70681151,
        "body_markdown": "I want to merge to arrays together.\r\n\r\n```\r\n$ cat file.json\r\n[1,2,3,4]\r\n[5,6,7,8]\r\n$ # command\r\n[1,2,3,4,5,6,7,8]\r\n```\r\n\r\nWhat should `# command` be?",
        "link": "https://stackoverflow.com/questions/70681151/how-to-merge-two-simple-json-arrays-together-with-jq",
        "title": "How to merge two simple JSON arrays together with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "dictionary",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642022945,
                "post_id": 70688524,
                "comment_id": 124965473,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642022996,
                "post_id": 70688524,
                "comment_id": 124965493,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642023143,
                "post_id": 70688524,
                "comment_id": 124965542,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642023753,
                "last_edit_date": 1642023753,
                "creation_date": 1642023207,
                "answer_id": 70688703,
                "question_id": 70688524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You *can* do something along the lines of\r\n```\r\n.Request.required as $req\r\n| .Request.properties |= (\r\n    to_entries\r\n    | sort_by(.key)\r\n    | group_by(IN(.key; $req[]) | not)\r\n    | map(from_entries)\r\n    | add\r\n  )\r\n```\r\n```json\r\n{\r\n  &quot;Request&quot;: {\r\n    &quot;properties&quot;: {\r\n      &quot;avs&quot;: {\r\n        &quot;pattern&quot;: &quot;standard:v2&quot;,\r\n        &quot;type&quot;: &quot;string&quot;\r\n      },\r\n      &quot;data&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;\r\n      },\r\n      &quot;capacity&quot;: {\r\n        &quot;$ref&quot;: &quot;SubscriptionCapacity&quot;\r\n      },\r\n      &quot;metadata&quot;: {\r\n        &quot;$ref&quot;: &quot;MeterDefinitionsAndPolicy&quot;\r\n      }\r\n    },\r\n    &quot;required&quot;: [\r\n      &quot;data&quot;,\r\n      &quot;avs&quot;\r\n    ],\r\n    &quot;type&quot;: &quot;object&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/GokgvBzB9I)\r\n\r\nbut you are not guaranteed that after any follow-up processing the order will stay the same as objects typically *do not have* an order, arrays do.\r\n\r\n",
                "title": "Use jq to sort keys in json using one of the properties"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642023918,
                "last_edit_date": 1642023918,
                "creation_date": 1642023354,
                "answer_id": 70688730,
                "question_id": 70688524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward and fairly efficient approach that takes advantage of the fact that `keys` produces the key names as a sorted array:\r\n```\r\n. as $in\r\n| .Request\r\n| (.required|sort) as $required\r\n| (.properties|keys) as $all\r\n| ($all - $required) as $optional\r\n| .properties as $p\r\n| $in\r\n| .Request.properties = reduce ($required[], $optional[]) as $key ({}; . + {($key): $p[$key]} )\r\n\r\n```\r\n\r\n---\r\nNote that gojq, the Go implementation of jq, does support `keys` but does not in general respect user-specified ordering of keys within objects.",
                "title": "Use jq to sort keys in json using one of the properties"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1642088250,
        "creation_date": 1642022221,
        "last_edit_date": 1642088250,
        "question_id": 70688524,
        "body_markdown": "I need to sort following JSON file by keys with natural order but keys that a listed in the &#39;required` section should go first, how to do that?\r\n\r\nFollowing command sorts only by keys putting them in natural order:    \r\n\r\n    jq --sort-keys . /tmp/source.json &gt; ./tmp/target.json\r\n\r\n```json\r\n{\r\n   &quot;Request&quot;: {\r\n        &quot;properties&quot;: {\r\n          &quot;capacity&quot;: {\r\n            &quot;$ref&quot;: &quot;SubscriptionCapacity&quot;\r\n          },\r\n          &quot;metadata&quot;: {\r\n            &quot;$ref&quot;: &quot;MeterDefinitionsAndPolicy&quot;\r\n          },\r\n          &quot;data&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;avs&quot;: {\r\n            &quot;pattern&quot;: &quot;standard:v2&quot;,\r\n            &quot;type&quot;: &quot;string&quot;\r\n          }\r\n        },\r\n        &quot;required&quot;: [\r\n          &quot;data&quot;,\r\n          &quot;avs&quot;\r\n        ],\r\n        &quot;type&quot;: &quot;object&quot;\r\n      }\r\n}\r\n```\r\n\r\nExpected output should be like:\r\n\r\n```json\r\n{\r\n   &quot;Request&quot;: {\r\n        &quot;properties&quot;: {\r\n          &quot;avs&quot;: {\r\n            &quot;$ref&quot;: &quot;Pricing&quot;\r\n          },\r\n          &quot;data&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          }\r\n          &quot;capacity&quot;: {\r\n            &quot;$ref&quot;: &quot;SubscriptionCapacity&quot;\r\n          },\r\n          &quot;metadata&quot;: {\r\n            &quot;$ref&quot;: &quot;MeterDefinitionsAndPolicy&quot;\r\n          }\r\n        },\r\n        &quot;required&quot;: [\r\n          &quot;data&quot;,\r\n          &quot;avs&quot;\r\n        ],\r\n        &quot;type&quot;: &quot;object&quot;\r\n      }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70688524/use-jq-to-sort-keys-in-json-using-one-of-the-properties",
        "title": "Use jq to sort keys in json using one of the properties"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1642054929,
                "post_id": 70691571,
                "comment_id": 124971245,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6591779,
                    "reputation": 71,
                    "user_id": 5092702,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a5d640fb91816cf8a930636a70259566?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Keshav Kishor",
                    "link": "https://stackoverflow.com/users/5092702/keshav-kishor"
                },
                "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": 1642056239,
                "post_id": 70691571,
                "comment_id": 124971524,
                "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": 1642057259,
                "post_id": 70691571,
                "comment_id": 124971765,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642058156,
                "last_edit_date": 1642058156,
                "creation_date": 1642057186,
                "answer_id": 70692573,
                "question_id": 70691571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the comment, you seem to indicate that there is one value of `$dbname`, so the following should help:\r\n\r\n```\r\ndbname=phx4fo\r\nCRSOUT=input.json\r\njq -r --arg dbname &quot;$dbname&quot; &#39;(.[$dbname] // empty) |.db_sid_list&#39; &quot;$CRSOUT&quot;\r\n```\r\n\r\nWith your sample JSON, the above results in:\r\n```\r\nphx4fo1,phx4fo2\r\n```\r\n\r\nPresumably you will want to split on the comma, which can be done within the same jq query, e.g. by modifying it to:\r\n```\r\n(.[$dbname] // empty) | .db_sid_list/&quot;,&quot; | .[]\r\n```\r\n\r\n---\r\nBy the way, if you are going to use `read -a`, then you will need to understand shell arrays, and modify your shell script accordingly.  I would suggest you break down your problem into small pieces that you can solve independently, so that it will be easier to construct a complete solution.",
                "title": "Why my jq treats null as a proper value while parsing json via jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1642398975,
        "creation_date": 1642049401,
        "last_edit_date": 1642398975,
        "question_id": 70691571,
        "body_markdown": "I have json which looks like this\r\n\r\n```\r\n{\r\n  &quot;phx4fo&quot;: {\r\n    &quot;db_name&quot;: &quot;phx4fo&quot;,\r\n    &quot;db_unique_name&quot;: &quot;phx4fo&quot;,\r\n    &quot;db_crs_state&quot;: &quot;OFFLINE&quot;,\r\n    &quot;db_sid_list&quot;: &quot;phx4fo1,phx4fo2&quot;,\r\n    &quot;db_host_list&quot;: &quot;epxa25-swlke1,epxa25-swlke2&quot;,\r\n    &quot;db_home&quot;: &quot;/u02/app/oracle/product/12.1.0/dbhome_2&quot;\r\n  },\r\n  &quot;phx68r&quot;: {\r\n    &quot;db_name&quot;: &quot;phx68r&quot;,\r\n    &quot;db_unique_name&quot;: &quot;phx68r&quot;,\r\n    &quot;db_crs_state&quot;: &quot;OFFLINE&quot;,\r\n    &quot;db_sid_list&quot;: &quot;phx68r1,phx68r2&quot;,\r\n    &quot;db_host_list&quot;: &quot;epxa25-swlke1,epxa25-swlke2&quot;,\r\n    &quot;db_home&quot;: &quot;/u02/app/oracle/product/19.0.0.0/dbhome_6&quot;\r\n  }}\r\n```\r\n\r\nIn some cases, dbname is present and in some cases, it is not. Now, I want if dbname is not present then it should exit code without doing anything.My code is:-\r\n```\r\nIFS=, read -r -a SIDLIST &lt;&lt;&lt;&quot;$(jq -r &quot;.\\&quot;$dbname\\&quot;.db_sid_list&quot; $CRSOUT)&quot;\r\n    for SIDVAL in $SIDLIST;do\r\n        if [[ ! -z &quot;$SIDVAL&quot; ]];then\r\n             CHECK_SID=$(ps -eawf|grep smon|grep ^oracle|grep -v grep|grep -v ASM|grep -v perl|cut -d&quot;_&quot; -f3| grep $ORA_DB_NAME | grep -w $SIDVAL )\r\n             if [[ ! -z &quot;$CHECK_SID&quot; ]];then\r\n                ORACLE_SID=$CHECK_SID\r\n                break\r\n             fi\r\n            fi\r\n    done\r\n```\r\nBut instead of exit it is proceeding further ",
        "link": "https://stackoverflow.com/questions/70691571/why-my-jq-treats-null-as-a-proper-value-while-parsing-json-via-jq",
        "title": "Why my jq treats null as a proper value while parsing json via 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": 1642114784,
                "post_id": 70694042,
                "comment_id": 124992946,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642068601,
                "last_edit_date": 1642068601,
                "creation_date": 1642067405,
                "answer_id": 70694479,
                "question_id": 70694042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are there brackets `[]` surrounding all these objects? If so, it is an array and there&#39;s missing commas indeed. But jq wouldn&#39;t have missed to produce them unless the previous filter was designed on purpose to behave that way. If there aren&#39;t surrounding brackets (which I presume according to the indentation of the sample), then it is a stream of objects that **do not need** a comma in between. In fact, putting a comma in between without the surrounding brackets would render the file inprocessible as it wouldn&#39;t be valid JSON anymore.\r\n\r\nIf it is a faulty array (the former case) maybe you&#39;re better off not using jq but rather a text stream editor such as sed or awk as you seem to know exactly where the commas are missing (&quot;Is there a command which I can tell to go to line X, column 1 and add a comma there?&quot;)\r\n\r\nIf it is infact a stream of objects (the latter case), then you could use `jq --slurp &#39;…&#39;` or `jq -n &#39;[inputs] | …&#39;` to make it an array (surrounded by brackets and with commas in between) but the file (25 GB) has to fit entirely into your memory. If it doesn&#39;t, you need to use `jq --stream &#39;…&#39;` and handle the document (which has a different format then) according to the [documentation for processing streams](https://stedolan.github.io/jq/manual/v1.6/#Streaming).\r\n\r\n##### Illustrations:\r\nThis is an array of objects:\r\n```json\r\n[\r\n  {&quot;a&quot;: 1},\r\n  {&quot;b&quot;: 2},\r\n  {&quot;c&quot;: 3}\r\n]\r\n```\r\nThis is a stream of objects:\r\n```json\r\n{&quot;a&quot;: 1}\r\n{&quot;b&quot;: 2}\r\n{&quot;c&quot;: 3}\r\n```\r\nThis is not valid JSON:\r\n```json\r\n{&quot;a&quot;: 1},\r\n{&quot;b&quot;: 2},\r\n{&quot;c&quot;: 3}\r\n```\r\n",
                "title": "How to edit specific textline of large json/textfile (~25gb)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1642068601,
        "creation_date": 1642065566,
        "last_edit_date": 1642066006,
        "question_id": 70694042,
        "body_markdown": "I have a json file with ElasticSearch events which can&#39;t be parsed by jq (funnily the json comes from jq) due to a missing comma. Here is an extract from the problematic place in the json file:\r\n\r\n          &quot;end&quot;,\r\n          &quot;protocol&quot;\r\n        ],\r\n        &quot;dataset&quot;: &quot;test&quot;,\r\n        &quot;outcome&quot;: &quot;success&quot;\r\n      },\r\n      &quot;@timestamp&quot;: &quot;2020-08-23T04:47:10.000+02:00&quot;\r\n    }\r\n    {\r\n      &quot;agent&quot;: {\r\n        &quot;hostname&quot;: &quot;fb&quot;,\r\n        &quot;type&quot;: &quot;filebeat&quot;\r\n      },\r\n      &quot;destination&quot;: {\r\n\r\nMy jq command crashes at the closing brace (above &quot;agent&quot;) as there is missing a comma after that brace (since a new event starts there). Now I know exactly the line and would like to add a comma there but couldn&#39;t find any options on how to do that efficiently. Since the file is around 25gb it is unsuitable to open it by nano or other tools. The error is `parse error: Expected separator between values at line 192388762`\r\n\r\nDoes anyone know if there is an efficient way to add a comma there so it looks like this?\r\n\r\n      &quot;@timestamp&quot;: &quot;2020-08-23T04:47:10.000+02:00&quot;\r\n    },\r\n    {\r\n      &quot;agent&quot;: {\r\n\r\nIs there a command which I can tell to go to line X, column 1 and add a comma there (after column1)?",
        "link": "https://stackoverflow.com/questions/70694042/how-to-edit-specific-textline-of-large-json-textfile-25gb",
        "title": "How to edit specific textline of large json/textfile (~25gb)?"
    },
    {
        "tags": [
            "jq",
            "json-flattener"
        ],
        "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": 2,
                "creation_date": 1642069719,
                "post_id": 70694772,
                "comment_id": 124976123,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1642088182,
                "last_edit_date": 1642088182,
                "creation_date": 1642069341,
                "answer_id": 70694963,
                "question_id": 70694772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you looking for something like this?\r\n```sh\r\njq -r &#39;.[].lock_doors[] | [.[]] | @csv&#39;\r\n```\r\n```csv\r\n&quot;OPEN&quot;,&quot;NR1&quot;,&quot;NO_DATA&quot;,&quot;2021-12-29T16:32:23Z&quot;,4.28214,51.34426\r\n&quot;CLOSED&quot;,&quot;NR2&quot;,&quot;WORKING&quot;,&quot;2022-01-12T12:32:52Z&quot;,&quot;2021-12-22T13:13:57Z&quot;,4.28247,51.34424\r\n```\r\n[Demo](https://jqplay.org/s/RdkjJUc4dC)\r\n\r\nTo add column headers, simply prepend them in an array:\r\n```sh\r\njq -r &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;], .[].lock_doors[] | [.[]] | @csv&#39;\r\n```\r\n```csv\r\n&quot;a&quot;,&quot;b&quot;,&quot;c&quot;\r\n&quot;OPEN&quot;,&quot;NR1&quot;,&quot;NO_DATA&quot;,&quot;2021-12-29T16:32:23Z&quot;,4.28214,51.34426\r\n&quot;CLOSED&quot;,&quot;NR2&quot;,&quot;WORKING&quot;,&quot;2022-01-12T12:32:52Z&quot;,&quot;2021-12-22T13:13:57Z&quot;,4.28247,51.34424\r\n```\r\n[Demo](https://jqplay.org/s/1Vblg6pebY)\r\n",
                "title": "flattening json to csv with jqplay"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1642088182,
        "creation_date": 1642068540,
        "question_id": 70694772,
        "body_markdown": "I&#39;m trying to flatten a json file to .csv.  I&#39;d like to use jqplay for this in stead of programming it in python for example. \r\nThe example below is een array that als contains arrays.\r\nMy desired output is one line entry on the 2nd array:\r\nso \r\n\r\nOPEN, NR1, ....\r\n\r\nCLOSED, NR2, ...\r\n\r\n....\r\n\r\nCan anyone help me with a good jq command for this?\r\n\r\n```\r\n[\r\n\t{\r\n\t\t&quot;description&quot;: &quot;Berendrechtsluis&quot;,\r\n\t\t&quot;lock_id&quot;: &quot;BES&quot;,\r\n\t\t&quot;longitude_wgs84&quot;: 4.28561,\r\n\t\t&quot;latitude_wgs84&quot;: 51.34414,\r\n\t\t&quot;lock_doors&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;state&quot;: &quot;OPEN&quot;,\r\n\t\t\t\t&quot;lock_door_id&quot;: &quot;NR1&quot;,\r\n\t\t\t\t&quot;operational_state&quot;: &quot;NO_DATA&quot;,\r\n\t\t\t\t&quot;state_since_in_utc&quot;: &quot;2021-12-29T16:32:23Z&quot;,\r\n\t\t\t\t&quot;longitude_wgs84&quot;: 4.28214,\r\n\t\t\t\t&quot;latitude_wgs84&quot;: 51.34426\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;state&quot;: &quot;CLOSED&quot;,\r\n\t\t\t\t&quot;lock_door_id&quot;: &quot;NR2&quot;,\r\n\t\t\t\t&quot;operational_state&quot;: &quot;WORKING&quot;,\r\n\t\t\t\t&quot;state_since_in_utc&quot;: &quot;2022-01-12T12:32:52Z&quot;,\r\n\t\t\t\t&quot;operational_state_since_in_utc&quot;: &quot;2021-12-22T13:13:57Z&quot;,\r\n\t\t\t\t&quot;longitude_wgs84&quot;: 4.28247,\r\n\t\t\t\t&quot;latitude_wgs84&quot;: 51.34424\r\n\t\t\t},\r\n\t\t\t....\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70694772/flattening-json-to-csv-with-jqplay",
        "title": "flattening json to csv with jqplay"
    },
    {
        "tags": [
            "rest",
            "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": 1642108354,
                "post_id": 70703157,
                "comment_id": 124991216,
                "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": 1642129796,
                "post_id": 70703157,
                "comment_id": 124995631,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642127104,
                "last_edit_date": 1642127104,
                "creation_date": 1642122234,
                "answer_id": 70704935,
                "question_id": 70703157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many tools that will allow you to &quot;pretty-print&quot; JSON to make it easier to read.  In the case of jq, simply presenting the JSON to `jq .` (e.g. `curl ... | jq .`) will pretty-print it, unless it is ridiculously large (i.e., too large to fit into the computer&#39;s memory), in which case you probably won&#39;t want to pretty-print it anyway.\r\n\r\nIf the issue is that even pretty-printing the JSON is insufficient to make it comprehensible, then you might find a simple &quot;schema inference engine&quot; appropriate.  The one I wrote at https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed (schema.jq) produces an easy-to-understand structural schema.  Examples, including examples of how to invoke it, are available at https://github.com/stedolan/jq/wiki/X---Experimental-Benchmarks\r\n\r\nThe simplest way to use it with curl would be to download it as schema.jq, uncomment the very last line, and then invoke it along the following lines:\r\n\r\n    curl .... | jq -f schema.jq\r\n\r\n\r\nE.g.:\r\n```\r\ncurl -Ss https://gitlab.cern.ch/slac_sandbox/ubjson/-/raw/504d419d3e6a4ab87488fcc750bb79c6f5471491/benchmarks/files/jeopardy/jeopardy.json |\r\n  jq --arg nullable true -f schema.jq\r\n{\r\n  &quot;air_date&quot;: &quot;string&quot;,\r\n  &quot;answer&quot;: &quot;string&quot;,\r\n  &quot;category&quot;: &quot;string&quot;,\r\n  &quot;question&quot;: &quot;string&quot;,\r\n  &quot;round&quot;: &quot;string&quot;,\r\n  &quot;show_number&quot;: &quot;string&quot;,\r\n  &quot;value&quot;: &quot;string&quot;\r\n}\r\n```",
                "title": "Cear output from rest api with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1642127104,
        "creation_date": 1642108291,
        "question_id": 70703157,
        "body_markdown": "I am wanting to be able to use rest API and am discouraged about the barely readable json output. Can jq format json into a simpler more clear data. If JQ does not do this does anyone know of a tool that would Make Rest API more readable to humans?",
        "link": "https://stackoverflow.com/questions/70703157/cear-output-from-rest-api-with-jq",
        "title": "Cear output from rest api with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "pgbackrest"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642167640,
                "post_id": 70711416,
                "comment_id": 125005350,
                "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": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642167985,
                "post_id": 70711416,
                "comment_id": 125005483,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1642167790,
                "creation_date": 1642167790,
                "answer_id": 70711510,
                "question_id": 70711416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `.[] | …` use `map(…)` to retain the array.\r\n\r\n```sh\r\njq &#39;map([.backup[] + {name}] | max_by(.timestamp.stop))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144388,\r\n      &quot;stop&quot;: 1642144392\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1168586300\r\n    },\r\n    &quot;type&quot;: &quot;incr&quot;,\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144388,\r\n      &quot;stop&quot;: 1642144392\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1168586300\r\n    },\r\n    &quot;type&quot;: &quot;incr&quot;,\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/L_w_m5kB-z)",
                "title": "how to get a clean array as output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1642167790,
        "creation_date": 1642167423,
        "question_id": 70711416,
        "body_markdown": "As input I have:\r\n```\r\n[\r\n  {\r\n    &quot;backup&quot;: [\r\n      {\r\n        &quot;timestamp&quot;: { &quot;start&quot;: 1642144383, &quot;stop&quot;: 1642144386 },\r\n        &quot;info&quot;: {  &quot;size&quot;: 1200934840},\r\n        &quot;type&quot;: &quot;full&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: {&quot;start&quot;: 1642144388, &quot;stop&quot;:  1642144392 },\r\n        &quot;info&quot;: { &quot;size&quot;: 1168586300\r\n        },\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;backup&quot;: [\r\n      {\r\n        &quot;timestamp&quot;: { &quot;start&quot;: 1642144383, &quot;stop&quot;: 1642144386 },\r\n        &quot;info&quot;: {  &quot;size&quot;: 1200934840},\r\n        &quot;type&quot;: &quot;full&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: {&quot;start&quot;: 1642144388, &quot;stop&quot;:  1642144392 },\r\n        &quot;info&quot;: { &quot;size&quot;: 1168586300\r\n        },\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  }\r\n]\r\n```\r\n\r\nusing  \r\n```\r\njq &#39;.[]\r\n   | [ .backup[] + {name} ]\r\n   | max_by(.timestamp.stop)\r\n&#39;\r\n```\r\n(thanks @pmf) I can re-order this to\r\n```\r\n{\r\n  &quot;timestamp&quot;: {\r\n    &quot;start&quot;: 1642144388,\r\n    &quot;stop&quot;: 1642144392\r\n  },\r\n  &quot;info&quot;: {\r\n    &quot;size&quot;: 1168586300\r\n  },\r\n  &quot;type&quot;: &quot;incr&quot;,\r\n  &quot;name&quot;: &quot;dbname1&quot;\r\n}\r\n{\r\n  &quot;timestamp&quot;: {\r\n    &quot;start&quot;: 1642144388,\r\n    &quot;stop&quot;: 1642144392\r\n  },\r\n  &quot;info&quot;: {\r\n    &quot;size&quot;: 1168586300\r\n  },\r\n  &quot;type&quot;: &quot;incr&quot;,\r\n  &quot;name&quot;: &quot;dbname2&quot;\r\n}\r\n```\r\n\r\nSelected is the dict containing the max timestamp and the name added to it, being the last created backup of a database. There are multiple databases possible. How can I form the output to a cleanly formatted array?\r\nI was hoping for\r\n\r\n```\r\n[\r\n{\r\n  &quot;timestamp&quot;: {\r\n    &quot;start&quot;: 1642144388,\r\n    &quot;stop&quot;: 1642144392\r\n  },\r\n  &quot;info&quot;: {\r\n    &quot;size&quot;: 1168586300\r\n  },\r\n  &quot;type&quot;: &quot;incr&quot;,\r\n  &quot;name&quot;: &quot;dbname1&quot;\r\n},\r\n{\r\n  &quot;timestamp&quot;: {\r\n    &quot;start&quot;: 1642144388,\r\n    &quot;stop&quot;: 1642144392\r\n  },\r\n  &quot;info&quot;: {\r\n    &quot;size&quot;: 1168586300\r\n  },\r\n  &quot;type&quot;: &quot;incr&quot;,\r\n  &quot;name&quot;: &quot;dbname2&quot;\r\n}\r\n]\r\n```\r\nAnd yes, I can add this using sed but I feel jq should be able to do this. So the question is how can should this be written?",
        "link": "https://stackoverflow.com/questions/70711416/how-to-get-a-clean-array-as-output",
        "title": "how to get a clean array as output"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642172664,
                "post_id": 70712566,
                "comment_id": 125007478,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1642172771,
                "post_id": 70712566,
                "comment_id": 125007513,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642172973,
                "post_id": 70712566,
                "comment_id": 125007593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642173506,
                "post_id": 70712566,
                "comment_id": 125007782,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642177131,
                "last_edit_date": 1642177131,
                "creation_date": 1642173453,
                "answer_id": 70712762,
                "question_id": 70712566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This solution aggregates into the first items within each duplicate list (which is not obvious from your sample data, see the [comments](https://stackoverflow.com/questions/70712566/replace-objects-in-json-with-their-sum-using-jq/70712762#comment125007513_70712566)).\r\n\r\n`group_by` groups the items to aggregate, which is determined by a `.Status` greater `1` and the content of `.Action`. Then, with `map` each grouped list&#39;s first (`.[0]`) item&#39;s `.Count` field is calculated by `add`ing up all `.Count` fields&#39; values. The output within each group is the first (`.[0]`) element.\r\n```sh\r\njq &#39;\r\n  group_by([(.Status | tonumber &gt; 1), .Action])\r\n  | map(.[0].Count = (map(.Count | tonumber) | add | tostring) | .[0])\r\n&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;Count&quot;: &quot;226&quot;,\r\n    &quot;Action&quot;: &quot;1&quot;,\r\n    &quot;Status&quot;: &quot;1&quot;,\r\n    &quot;Client&quot;: &quot;26&quot;\r\n  },\r\n  {\r\n    &quot;Count&quot;: &quot;233&quot;,\r\n    &quot;Action&quot;: &quot;2&quot;,\r\n    &quot;Status&quot;: &quot;1&quot;,\r\n    &quot;Client&quot;: &quot;26&quot;\r\n  },\r\n  {\r\n    &quot;Count&quot;: &quot;227&quot;,\r\n    &quot;Action&quot;: &quot;1&quot;,\r\n    &quot;Status&quot;: &quot;2&quot;,\r\n    &quot;Client&quot;: &quot;26&quot;\r\n  },\r\n  {\r\n    &quot;Count&quot;: &quot;7&quot;,\r\n    &quot;Action&quot;: &quot;2&quot;,\r\n    &quot;Status&quot;: &quot;2&quot;,\r\n    &quot;Client&quot;: &quot;26&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/HN9SxM8RfV)\r\n\r\n\r\nAs `.Status` and `.Count` are strings, not numbers, it was necessary to convert them back and forth using `tonumber` and `tostring`. You may want to, especially if you have more calculations to process, first convert them into numbers, then do all the (now simpler) processing, and finally convert them back (if necessary).\r\n\r\n```sh\r\njq &#39;\r\n  map((.Status, .Count) |= tonumber)\r\n  | group_by([(.Status &gt; 1), .Action])\r\n  | map(.[0].Count = (map(.Count) | add) | .[0])\r\n  | map((.Status, .Count) |= tostring)\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/nDHuiVMeQz)",
                "title": "Replace objects in json with their sum using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1642177131,
        "creation_date": 1642172500,
        "question_id": 70712566,
        "body_markdown": "Trying to solve the problem, but even don&#39;t know how to start.\r\nI have json like this\r\n\r\n    [\r\n      {\r\n        &quot;Count&quot;: &quot;226&quot;,\r\n        &quot;Action&quot;: &quot;1&quot;,\r\n        &quot;Status&quot;: &quot;1&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;224&quot;,\r\n        &quot;Action&quot;: &quot;1&quot;,\r\n        &quot;Status&quot;: &quot;2&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;3&quot;,\r\n        &quot;Action&quot;: &quot;1&quot;,\r\n        &quot;Status&quot;: &quot;6&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;233&quot;,\r\n        &quot;Action&quot;: &quot;2&quot;,\r\n        &quot;Status&quot;: &quot;1&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;7&quot;,\r\n        &quot;Action&quot;: &quot;2&quot;,\r\n        &quot;Status&quot;: &quot;2&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      }\r\n    ]\r\n\r\nAnd I need to get sum of counters for distinct Action where Status &gt; 1. Result should replace summarized elements. \r\nExample of result:\r\n\r\n    [\r\n      {\r\n        &quot;Count&quot;: &quot;226&quot;,\r\n        &quot;Action&quot;: &quot;1&quot;,\r\n        &quot;Status&quot;: &quot;1&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;227&quot;,\r\n        &quot;Action&quot;: &quot;1&quot;,\r\n        &quot;Status&quot;: &quot;2&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;233&quot;,\r\n        &quot;Action&quot;: &quot;2&quot;,\r\n        &quot;Status&quot;: &quot;1&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      },\r\n      {\r\n        &quot;Count&quot;: &quot;7&quot;,\r\n        &quot;Action&quot;: &quot;2&quot;,\r\n        &quot;Status&quot;: &quot;2&quot;,\r\n        &quot;Client&quot;: &quot;26&quot;\r\n      }\r\n    ]\r\n\r\nAs you can see, field Count in element with &quot;Action&quot;: &quot;1&quot; and &quot;Status&quot;: &quot;2&quot; was increased on value of object with &quot;Action&quot;: &quot;1&quot; and &quot;Status&quot;: &quot;6&quot;\r\n\r\nI don&#39;t know how to do it. Any help or advice would be appreciated. ",
        "link": "https://stackoverflow.com/questions/70712566/replace-objects-in-json-with-their-sum-using-jq",
        "title": "Replace objects in json with their sum using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1642181951,
                "post_id": 70714377,
                "comment_id": 125011223,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1642184289,
                "last_edit_date": 1642184289,
                "creation_date": 1642182410,
                "answer_id": 70714614,
                "question_id": 70714377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This assumes you are trying to combine the `.indices` object stored in `ie1.json` with an object within the object stored in `ip1.json`. As the keys upon to match are different, I further assumed that you want to match the field name from the `.indices` object, reduced by cutting off everything that comes after the last dash `-`, to the same key in the object from `ip1.json`.\r\n\r\nTo this end, `ip1.json` is read in from `input` as `$ip` (alternatively you can use `jq --argfile ip ip1.json` for that), then the `.indices` object is taken from the first input `ie1.json` and to the inner object accessed via `with_entries(.value …)` is added the result of a lookup within `$ip` at the matching and accordingly reduced `.key`.\r\n\r\n```sh\r\njq &#39;\r\n  input as $ip | .indices | with_entries(.value += $ip[.key | sub(&quot;-[^-]*$&quot;;&quot;&quot;)])\r\n&#39; ie1.json ip1.json\r\n```\r\n```json\r\n{\r\n  &quot;.siem-signals-default-000001&quot;: {\r\n    &quot;action&quot;: &quot;complete&quot;,\r\n    &quot;index&quot;: &quot;.siem-signals-default-000001&quot;,\r\n    &quot;policy&quot;: &quot;.siem-signals-default&quot;,\r\n    &quot;modified_date&quot;: &quot;siem&quot;,\r\n    &quot;version&quot;: 1\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/jzGYJIHzc4)\r\n\r\nIf instead of the `.indices` object&#39;s inner field nane you want to have the content of field `.index` as reference (which in your sample data has the same value), you can go with `map_values` instead of `with_entries` as you don&#39;t need the field&#39;s name anymore.\r\n```sh\r\njq &#39;\r\n  input as $ip | .indices | map_values(. += $ip[.index | sub(&quot;-[^-]*$&quot;;&quot;&quot;)])\r\n&#39;ie1.json ip1.json\r\n```\r\n[Demo](https://jqplay.org/s/D1PeKr0r-2)\r\n\r\nNote: I used `sub` with a regex to manipulate the key name, which you can easily adjust to your liking if in reality it is more complicated. If, however, the pattern is infact as simple as cutting off after the last dash, then using `.[:rindex(&quot;-&quot;)]` instead will also get the job done.\r\n",
                "title": "jq merge json via dynamic sub keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642204647,
                "creation_date": 1642204647,
                "answer_id": 70717770,
                "question_id": 70714377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I also received offline feedback of a simple &quot;workable for my use case&quot; but not exact answer: \r\n\r\n```\r\n$ jq &#39;.indices | map(. * input[.policy])&#39; ie1.json ip1.json\r\n[\r\n  {\r\n    &quot;action&quot;: &quot;complete&quot;,\r\n    &quot;index&quot;: &quot;.siem-signals-default-000001&quot;,\r\n    &quot;policy&quot;: &quot;.siem-signals-default&quot;,\r\n    &quot;modified_date&quot;: &quot;siem&quot;,\r\n    &quot;version&quot;: 1\r\n  }\r\n]\r\n```\r\n\r\nPosting in case someone runs into similar, but other answer&#39;s better.",
                "title": "jq merge json via dynamic sub keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1642204647,
        "creation_date": 1642181227,
        "last_edit_date": 1642181813,
        "question_id": 70714377,
        "body_markdown": "I think I&#39;m a step off from figuring out how to jq [reduce](https://stedolan.github.io/jq/manual/#Reduce) via [filter](https://stedolan.github.io/jq/manual/#Basicfilters) a key to another objects sub-key.\r\n\r\nI&#39;m trying to combine files (simplified from Elasticsearch&#39;s [ILM Explain](https://www.elastic.co/guide/en/elasticsearch/reference/current/ilm-explain-lifecycle.html) &amp; [ILM Policy](https://www.elastic.co/guide/en/elasticsearch/reference/current/ilm-get-lifecycle.html) API responses):\r\n```bash\r\n$ echo &#39;{&quot;.siem-signals-default&quot;: {&quot;modified_date&quot;: &quot;siem&quot;, &quot;version&quot;: 1 }, &quot;kibana-event-log-policy&quot;: {&quot;modified_date&quot;: &quot;kibana&quot;, &quot;version&quot;: 1 } }&#39; &gt; ip1.json\r\n$ echo &#39;{&quot;indices&quot;: {&quot;.siem-signals-default-000001&quot;: {&quot;action&quot;: &quot;complete&quot;, &quot;index&quot;: &quot;.siem-signals-default-000001&quot;, &quot;policy&quot; : &quot;.siem-signals-default&quot;} } }&#39; &gt; ie1.json\r\n```\r\n\r\nSuch that the resulting JSON is:\r\n```json\r\n{\r\n  &quot;.siem-signals-default-000001&quot;: {\r\n    &quot;modified_date&quot;: &quot;siem&quot;,\r\n    &quot;version&quot;: 1\r\n    &quot;action&quot;: &quot;complete&quot;,\r\n    &quot;index&quot;: &quot;.siem-signals-default-000001&quot;,\r\n    &quot;policy&quot;: &quot;.siem-signals-default&quot;\r\n  }\r\n}\r\n```\r\n\r\nWhere ie1 is base JSON and for a child-object, its sub-element `policy` should line up to ip1&#39;s key and copy its sub-elements into itself. I&#39;ve been trying to build off [this](https://stackoverflow.com/questions/64809910), [this](https://stackoverflow.com/a/46255183/15146924), and [this](https://stackoverflow.com/a/66127460/15146924) (from StackOverflow, also [this](https://unix.stackexchange.com/questions/588063/merging-multiple-json-file-into-one-object-using-jq-with-argument), [this](https://www.reddit.com/r/bash/comments/e035cb/is_it_possible_to_use_dynamic_key_in_jq/), [this](https://e.printstacktrace.blog/merging-json-files-recursively-in-the-command-line/) from external sources). I&#39;ll list various rabbit hole attempts building off these, but they&#39;re all insufficient:\r\n\r\n```bash\r\n$ ((cat ie1.json | jq &#39;.indices&#39;) &amp;&amp; cat ip1.json) | jq -s &#39;map(to_entries)|flatten|from_entries&#39; | jq &#39;. as $v| reduce keys[] as $k({}; if true then .[$k] += $v[$k] else . end)&#39;\r\n{\r\n  &quot;.siem-signals-default&quot;: {\r\n    &quot;modified_date&quot;: &quot;siem&quot;,\r\n    &quot;version&quot;: 1\r\n  },\r\n  &quot;.siem-signals-default-000001&quot;: {\r\n    &quot;action&quot;: &quot;complete&quot;,\r\n    &quot;index&quot;: &quot;.siem-signals-default-000001&quot;,\r\n    &quot;policy&quot;: &quot;.siem-signals-default&quot;\r\n  },\r\n  &quot;kibana-event-log-policy&quot;: {\r\n    &quot;modified_date&quot;: &quot;kibana&quot;,\r\n    &quot;version&quot;: 1\r\n  }\r\n}\r\n```\r\n```bash\r\n$ jq --slurpfile ip1 ip1.json &#39;.indices as $ie1|$ie1+{ilm: $ip1 }&#39; ie1.json\r\n{\r\n  &quot;.siem-signals-default-000001&quot;: {\r\n    &quot;action&quot;: &quot;complete&quot;,\r\n    &quot;index&quot;: &quot;.siem-signals-default-000001&quot;,\r\n    &quot;policy&quot;: &quot;.siem-signals-default&quot;\r\n  },\r\n  &quot;ilm&quot;: [\r\n    {\r\n      &quot;.siem-signals-default&quot;: {\r\n        &quot;modified_date&quot;: &quot;siem&quot;,\r\n        &quot;version&quot;: 1\r\n      },\r\n      &quot;kibana-event-log-policy&quot;: {\r\n        &quot;modified_date&quot;: &quot;kibana&quot;,\r\n        &quot;version&quot;: 1\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nI also expected something like this to work, but it compile errors\r\n```bash\r\n$ jq -s ip1 ip1.json &#39;. as $ie1|$ie1 + {ilm:(keys[] as $k; $ip1 | select(.policy == $ie1[$k]) | $ie1[$k]  )}&#39; ie1.json\r\njq: error: ip1/0 is not defined at &lt;top-level&gt;, line 1:\r\nip1\r\njq: 1 compile error\r\n```\r\nFrom this you can see, I&#39;ve determined various ways to join the separate files, but though I have code I thought would play into filtering, it&#39;s not correct / taking effect. Does anyone have an idea how to get the filter part working? TIA",
        "link": "https://stackoverflow.com/questions/70714377/jq-merge-json-via-dynamic-sub-keys",
        "title": "jq merge json via dynamic sub keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642208391,
                "last_edit_date": 1642208391,
                "creation_date": 1642207756,
                "answer_id": 70718039,
                "question_id": 70718004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To remove one field if it is `null`, use `.time_in_seconds |= select(.)`.\r\n\r\nTo remove all fields that are `null`, use `.[] |= select(.)`.\r\n\r\nAdd this inside your `map` at the end, like so:\r\n```\r\njq &#39;map({…} | .[] |= select(.))&#39;\r\n```\r\n[Demo](https://jqplay.org/s/RgWNdsnRVk)\r\n\r\nNote: This will also delete fields with value `false`. If you want to restrict to `null`, make `select(.)` more explicit and change it to `select(. != null)`.",
                "title": "Don&#39;t inject attribute with JQ if there was none"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642231757,
                "creation_date": 1642231757,
                "answer_id": 70719605,
                "question_id": 70718004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To remove all `null` values (or any arbitrary condition) in your input, you could make use of `recurse/0` (`..`) and `del/1`.\r\n\r\n```\r\ndel(.. | select(. == null))\r\n```",
                "title": "Don&#39;t inject attribute with JQ if there was none"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1642231757,
        "creation_date": 1642207274,
        "question_id": 70718004,
        "body_markdown": "    cat &quot;$FileName&quot; | jq --sort-keys &#39;map({&quot;author_id&quot;: .author.id,&quot;author&quot;: .author.name, &quot;badge&quot;: .author.badges[0].title, &quot;message&quot;, &quot;timestamp&quot;, &quot;time_in_seconds&quot;, &quot;time_text&quot;})&#39; &gt; &quot;$TargetName&quot;\r\n\r\nproduces output with `&quot;time_in_seconds&quot;: null` if there was no `&quot;time_in_seconds&quot;` in source JSON. How to eliminate this:\r\n\r\n* for this very attribute?\r\n* for all attributes?",
        "link": "https://stackoverflow.com/questions/70718004/dont-inject-attribute-with-jq-if-there-was-none",
        "title": "Don&#39;t inject attribute with JQ if there was none"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642215129,
                "last_edit_date": 1642215129,
                "creation_date": 1642214285,
                "answer_id": 70718478,
                "question_id": 70718421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `(…)? // empty` to filter for in-depth existence, `unique` to remove duplicates, and `|=` to update:\r\n\r\n```sh\r\njq &#39;map(.author |= .name | ((.emotes[].images)? // empty) |= (map(.url) | unique))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;author&quot;: &quot;Alice&quot;,\r\n    &quot;message&quot;: &quot;Text 1&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Bob&quot;,\r\n    &quot;message&quot;: &quot;Text 2&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Charlie&quot;,\r\n    &quot;emotes&quot;: [\r\n      {\r\n        &quot;images&quot;: [\r\n          &quot;https://some-host.com/some-url.svg&quot;,\r\n          &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg&quot;\r\n        ],\r\n        &quot;name&quot;: &quot;:grinning_face:&quot;\r\n      }\r\n    ],\r\n    &quot;message&quot;: &quot;Text 3&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Dave&quot;,\r\n    &quot;message&quot;: &quot;Text 4&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Erin&quot;,\r\n    &quot;message&quot;: &quot;Text 5&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Faythe&quot;,\r\n    &quot;emotes&quot;: [\r\n      {\r\n        &quot;images&quot;: [\r\n          &quot;https://some-host.com/some-other-url.svg&quot;,\r\n          &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg&quot;\r\n        ],\r\n        &quot;name&quot;: &quot;:waving_hand:&quot;\r\n      }\r\n    ],\r\n    &quot;message&quot;: &quot;Text 6&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/tBoqsu0qLy)",
                "title": "Map nested arrays with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1642245449,
        "creation_date": 1642213539,
        "last_edit_date": 1642245449,
        "question_id": 70718421,
        "body_markdown": "How to transform this:\r\n```json\r\n[\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;name&quot;: &quot;Alice&quot;\r\n    },\r\n    &quot;message&quot;: &quot;Text 1&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;name&quot;: &quot;Bob&quot;\r\n    },\r\n    &quot;message&quot;: &quot;Text 2&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;name&quot;: &quot;Charlie&quot;\r\n    },\r\n    &quot;emotes&quot;: [\r\n      {\r\n        &quot;images&quot;: [\r\n          {\r\n            &quot;url&quot;: &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg&quot;\r\n          },\r\n          {\r\n            &quot;url&quot;: &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg&quot;\r\n          },\r\n          {\r\n            &quot;url&quot;: &quot;https://some-host.com/some-url.svg&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;:grinning_face:&quot;\r\n      }\r\n    ],\r\n    &quot;message&quot;: &quot;Text 3&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;name&quot;: &quot;Dave&quot;\r\n    },\r\n    &quot;message&quot;: &quot;Text 4&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;name&quot;: &quot;Erin&quot;\r\n    },\r\n    &quot;message&quot;: &quot;Text 5&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;name&quot;: &quot;Faythe&quot;\r\n    },\r\n    &quot;emotes&quot;: [\r\n      {\r\n        &quot;images&quot;: [\r\n          {\r\n            &quot;url&quot;: &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg&quot;\r\n          },\r\n          {\r\n            &quot;url&quot;: &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg&quot;\r\n          },\r\n          {\r\n            &quot;url&quot;: &quot;https://some-host.com/some-other-url.svg&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;:waving_hand:&quot;\r\n      }\r\n    ],\r\n    &quot;message&quot;: &quot;Text 6&quot;\r\n  }\r\n]\r\n```\r\nInto this:\r\n```json\r\n[\r\n  {\r\n    &quot;author&quot;: &quot;Alice&quot;,\r\n    &quot;message&quot;: &quot;Text 1&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Bob&quot;,\r\n    &quot;message&quot;: &quot;Text 2&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Charlie&quot;,\r\n    &quot;message&quot;: &quot;Text 3&quot;,\r\n    &quot;emotes&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;:grinning_face:&quot;,\r\n        &quot;images&quot;: [\r\n          &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg&quot;,\r\n          &quot;https://some-host.com/some-url.svg&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Dave&quot;,\r\n    &quot;message&quot;: &quot;Text 4&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Erin&quot;,\r\n    &quot;message&quot;: &quot;Text 5&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: &quot;Faythe&quot;,\r\n    &quot;message&quot;: &quot;Text 6&quot;,\r\n    &quot;emotes&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;:waving_hand:&quot;,\r\n        &quot;images&quot;: [\r\n          &quot;https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg&quot;,\r\n          &quot;https://some-host.com/some-other-url.svg&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nusing jq?\r\n\r\nI have no idea how to map nested arrays in &quot;emotes&quot; nodes.\r\n",
        "link": "https://stackoverflow.com/questions/70718421/map-nested-arrays-with-jq",
        "title": "Map nested arrays with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642366789,
                "creation_date": 1642366789,
                "answer_id": 70734150,
                "question_id": 70734127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you want:\r\n\r\n```\r\njq &#39;(.Targets[]|.EcsParameters)&#39; rule-target.json\r\n```\r\n\r\nWhich results in:\r\n\r\n```\r\n{\r\n  &quot;TaskDefinitionArn&quot;: &quot;arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55&quot;,\r\n  &quot;TaskCount&quot;: 1,\r\n  &quot;EnableECSManagedTags&quot;: false,\r\n  &quot;EnableExecuteCommand&quot;: false,\r\n  &quot;PropagateTags&quot;: &quot;TASK_DEFINITION&quot;\r\n}\r\n```\r\n\r\n",
                "title": "using jq I want to output json object within a json object including the keys not just the value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642367113,
                "last_edit_date": 1642367113,
                "creation_date": 1642366792,
                "answer_id": 70734151,
                "question_id": 70734127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use\r\n```\r\njq &#39;.Targets[] | .EcsParameters&#39; rule-target.json\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/H7SPEJxzCO)&lt;/kbd&gt;\r\n\r\narray wrappers seen in the current case remove the object wrappers ",
                "title": "using jq I want to output json object within a json object including the keys not just the value"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1642366986,
                "last_edit_date": 1642366986,
                "creation_date": 1642366810,
                "answer_id": 70734153,
                "question_id": 70734127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are so close:\r\n\r\n```\r\n$ jq &#39;.Targets[].EcsParameters&#39; rule-target.json \r\n{\r\n  &quot;TaskDefinitionArn&quot;: &quot;arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55&quot;,\r\n  &quot;TaskCount&quot;: 1,\r\n  &quot;EnableECSManagedTags&quot;: false,\r\n  &quot;EnableExecuteCommand&quot;: false,\r\n  &quot;PropagateTags&quot;: &quot;TASK_DEFINITION&quot;\r\n}\r\n```\r\n\r\nAs `EcsParameters` isn&#39;t an array, you shouldn&#39;t unwrap it (`[]`).\r\n\r\nUsually it&#39;s a useless use of `cat` when doing `cat file | cmd`, many commands takes files as arguments:\r\n\r\n```\r\ncmd -flag -flag2 file1.txt file2.txt\r\n```\r\n\r\nand if they don&#39;t then you can redirect stdin:\r\n\r\n```\r\ncmd -flag -flag2 &lt; file1.txt\r\n```",
                "title": "using jq I want to output json object within a json object including the keys not just the value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1642367251,
        "creation_date": 1642366575,
        "last_edit_date": 1642367251,
        "question_id": 70734127,
        "body_markdown": "I have this stored as a file:\r\n```json\r\n{\r\n  &quot;Targets&quot;: [\r\n    {\r\n      &quot;Id&quot;: &quot;xxx_hourly_cron&quot;,\r\n      &quot;Arn&quot;: &quot;arn:aws:ecs:eu-west-2:000000000000:cluster/drupal-cluster&quot;,\r\n      &quot;RoleArn&quot;: &quot;arn:aws:iam::000000000000:role/ecsEventsRole&quot;,\r\n      &quot;EcsParameters&quot;: {\r\n        &quot;TaskDefinitionArn&quot;: &quot;arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55&quot;,\r\n        &quot;TaskCount&quot;: 1,\r\n        &quot;EnableECSManagedTags&quot;: false,\r\n        &quot;EnableExecuteCommand&quot;: false,\r\n        &quot;PropagateTags&quot;: &quot;TASK_DEFINITION&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing bash and jq I want to trim it down this this:\r\n\r\n```json\r\n{\r\n  &quot;TaskDefinitionArn&quot;: &quot;arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55&quot;,\r\n  &quot;TaskCount&quot;: 1,\r\n  &quot;EnableECSManagedTags&quot;: false,\r\n  &quot;EnableExecuteCommand&quot;: false,\r\n  &quot;PropagateTags&quot;: &quot;TASK_DEFINITION&quot;\r\n}\r\n```\r\n\r\nI have tried this but it does not output the keys:\r\n\r\n`cat rule-target.json | jq &#39;(.Targets[] .EcsParameters[])&#39;`\r\n",
        "link": "https://stackoverflow.com/questions/70734127/using-jq-i-want-to-output-json-object-within-a-json-object-including-the-keys-no",
        "title": "using jq I want to output json object within a json object including the keys not just the value"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1642438783,
                "post_id": 70744916,
                "comment_id": 125065616,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642442902,
                "last_edit_date": 1642442902,
                "creation_date": 1642438978,
                "answer_id": 70744985,
                "question_id": 70744916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the `--argjson` option to read in the contents of your shell variable enables you to use it as variable inside the jq filter, too. Your input file can normally be read in via parameter.\r\n\r\n```sh\r\njq --argjson v &quot;${OUR_BIG_JSON}&quot; &#39;…your filter here using $v…&#39; input.json\r\n```\r\n\r\nFor example:\r\n```sh\r\njq --argjson v &quot;${OUR_BIG_JSON}&quot; &#39;$v + {myarray: ($v.myarray + .)}&#39; input.json\r\n```\r\n\r\nOr by making the input too a variable inside the jq filter\r\n```sh\r\njq --argjson v &quot;${OUR_BIG_JSON}&quot; &#39;. as $in | $v | .myarray += $in&#39; input.json\r\n```\r\n\r\nWith the `-n` option you could also reference the input using `input`:\r\n```sh\r\njq --argjson v &quot;${OUR_BIG_JSON}&quot; -n &#39;$v | .myarray += input&#39; input.json\r\n```\r\n\r\nAnd there&#39;s also the options `--argfile` and `--slurpfile` to read in the input file as variable directly...\r\n\r\n---\r\n\r\nAs you have tagged `bash` you could also do it the other way around and use a herestring `&lt;&lt;&lt;` to read in the bash variable as input and then using either `--argfile` or `--slurpfile` to reference the file content through a variable. For instance:\r\n```sh\r\njq --argfile in input.json &#39;.myarray += $in&#39; &lt;&lt;&lt; &quot;${OUR_BIG_JSON}&quot;\r\n```\r\n",
                "title": "how to use jq and bash to inject a files json array contents while appending"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1642442902,
        "creation_date": 1642438650,
        "question_id": 70744916,
        "body_markdown": "I have a .json file which I want to read, take all the contents.. and append it to a json string that&#39;s in a bash variable\r\n\r\n**input.json**\r\n\r\n```\r\n[{\r\n    &quot;maven&quot;: {\r\n        &quot;coordinates&quot;: &quot;somelib&quot;,\r\n        &quot;repo&quot;: &quot;somerepo&quot;\r\n    }\r\n},\r\n{\r\n    &quot;maven&quot;: {\r\n        &quot;coordinates&quot;: &quot;anotherlib&quot;,\r\n        &quot;exclusions&quot;: [&quot;exclude:this&quot;, &quot;*:and-all-that&quot;]\r\n    }\r\n}]\r\n```\r\n\r\n**OUR_BIG_JSON** variable\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;&quot;,\r\n    &quot;myarray&quot;: [\r\n        {\r\n            &quot;generic&quot;: {\r\n                &quot;package&quot;: &quot;somepymodule&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;rcann&quot;: {\r\n                &quot;package&quot;: &quot;anothermodule==3.0.0&quot;\r\n            }\r\n        }\r\n    ],\r\n```\r\n\r\nand a json I want to append to.. it&#39;s residing in a variable so we must echo it as we use `jq`\r\n\r\n**command attempt**\r\n\r\n```\r\necho &quot;starting...&quot;\r\ninputs_json=`cat input.json`\r\n\r\necho &quot;$inputs_json&quot;\r\necho &quot;$OUR_BIG_JSON&quot;\r\n\r\nOUR_BIG_JSON=$(echo &quot;${OUR_BIG_JSON}&quot; |./jq &#39;.myarray += [{&quot;date&quot;:&quot;today&quot;}]&#39;)  # This worked.. \r\n\r\n```\r\n\r\nnext line fails\r\n\r\n```\r\nOUR_BIG_JSON=$(echo &quot;${OUR_BIG_JSON}&quot; |./jq &#39;.myarray += &#39; $inputs_json)\r\n\r\n```\r\n\r\nout comes errors when trying to take the `$inputs_json` contents and just pipe it into the variable.. basically append to the JSON in memory..\r\n\r\n`jq: error: syntax error, unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.myarray += \\&quot;$inputs_json\\&quot;\r\njq: 1 compile error`",
        "link": "https://stackoverflow.com/questions/70744916/how-to-use-jq-and-bash-to-inject-a-files-json-array-contents-while-appending",
        "title": "how to use jq and bash to inject a files json array contents while appending"
    },
    {
        "tags": [
            "javascript",
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6316971,
                    "reputation": 1280,
                    "user_id": 4906552,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://i.sstatic.net/9Bx94.jpg?s=256",
                    "display_name": "Thanh Dao",
                    "link": "https://stackoverflow.com/users/4906552/thanh-dao"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642489380,
                "post_id": 70751435,
                "comment_id": 125076967,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5897554,
                    "reputation": 19703,
                    "user_id": 4642212,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e5ea2c87d14565ecfec13c3db67428a2?s=256&d=identicon&r=PG",
                    "display_name": "Sebastian Simon",
                    "link": "https://stackoverflow.com/users/4642212/sebastian-simon"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1642489383,
                "post_id": 70751435,
                "comment_id": 125076969,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642491714,
                "creation_date": 1642491714,
                "answer_id": 70751856,
                "question_id": 70751435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume that you are interested in a [tag:jq] solution, that the array of objects is in a file objects.json,\r\nand that you are willing to invoke jq along the following lines:\r\n```\r\njq --argjson c &#39;[3,13,33,44]&#39; -f program.jq objects.json\r\n```\r\nLet&#39;s also assume for now that the result should NOT be lossy\r\ni.e., that the length of the resulting array should be the greater of the two input array lengths.\r\n\r\nThen the following jq program will be of interest:\r\n```\r\n&lt; objects.json jq --argjson c &#39;[3,13,33,44]&#39; &#39;\r\n  ({$c}|keys[0]) as $k\r\n  | [., ($c | map ( {($k): .} ))]\r\n  | transpose\r\n  | map(add)\r\n&#39;\r\n```\r\nNotice how the key name (&quot;c&quot;) is derived from the parameter name on the command line.\r\n\r\nThere are various ways to trim the result so it has the length\r\nof the shorter of the two arrays, and it seems reasonable to leave that as an exercise.\r\n",
                "title": "How use JQ to merge array into array of objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642509923,
                "creation_date": 1642509923,
                "answer_id": 70755818,
                "question_id": 70751435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using to_entries :\r\n\r\n```\r\njq --argjson c &#39;[4,13,33,44]&#39;\\\r\n   &#39;to_entries|\r\n    map(\r\n        .value + (if .key&lt;($c|length) then {c:$c[.key]} else {} end)\r\n       )&#39; objects.json\r\n```",
                "title": "How use JQ to merge array into array of objects"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1642509923,
        "creation_date": 1642489231,
        "question_id": 70751435,
        "body_markdown": "I want to see if jq with js can help me to achieve the following:\r\n\r\nI have the following object: \r\n\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: 11,\r\n    &quot;b&quot;: 12\r\n  },\r\n  {\r\n    &quot;a&quot;: 21,\r\n    &quot;b&quot;: 22\r\n  }\r\n]\r\n```\r\n\r\nand the following array: \r\n```\r\n[3,13,33,44]\r\n```\r\n\r\nI want to add the array items to the object according to their order as an extra field, it should also work when array is longer/shorter than the array of objects. \r\n\r\nthe result should look like this: \r\n\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2,\r\n    &quot;c&quot;: 3\r\n  },\r\n  {\r\n    &quot;a&quot;: 11,\r\n    &quot;b&quot;: 12,\r\n    &quot;c&quot;: 13\r\n  },\r\n  {\r\n    &quot;a&quot;: 21,\r\n    &quot;b&quot;: 22,\r\n    &quot;c&quot;: 33\r\n  }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70751435/how-use-jq-to-merge-array-into-array-of-objects",
        "title": "How use JQ to merge array into array of objects"
    },
    {
        "tags": [
            "json",
            "jq",
            "pgbackrest"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user123664"
                },
                "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": 1642494465,
                "post_id": 70752174,
                "comment_id": 125078677,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642494961,
                "creation_date": 1642494961,
                "answer_id": 70752498,
                "question_id": 70752174,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Remove the inner brackets to flatten the array, then `group_by` both criteria (which makes your criteria an array), and `map` your `max_by` onto the result array:\r\n\r\n```sh\r\njq &#39;map(.backup[] + {name}) | group_by([.name, .type]) | map(max_by(.timestamp.stop))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144383,\r\n      &quot;stop&quot;: 1642144386\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1200934840\r\n    },\r\n    &quot;type&quot;: &quot;full&quot;,\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642145388,\r\n      &quot;stop&quot;: 1642145392\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1168586330\r\n    },\r\n    &quot;type&quot;: &quot;incr&quot;,\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144383,\r\n      &quot;stop&quot;: 1642144386\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1200934840\r\n    },\r\n    &quot;type&quot;: &quot;full&quot;,\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144388,\r\n      &quot;stop&quot;: 1642144392\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1168586300\r\n    },\r\n    &quot;type&quot;: &quot;incr&quot;,\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/1kW3ilKdsT)",
                "title": "how to get a max per group and subgroup using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1642495001,
        "creation_date": 1642493313,
        "question_id": 70752174,
        "body_markdown": "jq is an amazing tool and it does a lot.\r\nas input I have\r\n```\r\n[\r\n  {\r\n    &quot;backup&quot;: [\r\n      {\r\n        &quot;timestamp&quot;: { &quot;start&quot;: 1642144383, &quot;stop&quot;: 1642144386 },\r\n        &quot;info&quot;: {  &quot;size&quot;: 1200934840},\r\n        &quot;type&quot;: &quot;full&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: {&quot;start&quot;: 1642144388, &quot;stop&quot;:  1642144392 },\r\n        &quot;info&quot;: { &quot;size&quot;: 1168586300\r\n        },\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: {&quot;start&quot;: 1642145388, &quot;stop&quot;:  1642145392 },\r\n        &quot;info&quot;: { &quot;size&quot;: 1168586330\r\n        },\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;backup&quot;: [\r\n      {\r\n        &quot;timestamp&quot;: { &quot;start&quot;: 1642144383, &quot;stop&quot;: 1642144386 },\r\n        &quot;info&quot;: {  &quot;size&quot;: 1200934840},\r\n        &quot;type&quot;: &quot;full&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: {&quot;start&quot;: 1642144388, &quot;stop&quot;:  1642144392 },\r\n        &quot;info&quot;: { &quot;size&quot;: 1168586300\r\n        },\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  }\r\n]\r\n```\r\nand using \r\n```\r\njq &#39;map([.backup[] + {name}] | max_by(.timestamp.stop))&#39;\r\n```\r\nI get the latest timestamp.stop for a name. How should I change this to get the latest timestamp.stop for a name and group?\r\nin SQL this would be something like max(.timestamp.stop) group by .name,.type\r\nHoping for output like:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144383,\r\n      &quot;stop&quot;: 1642144386\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1200934840\r\n    },\r\n    &quot;type&quot;: &quot;full&quot;,\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642145388,\r\n      &quot;stop&quot;: 1642145392\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1168586330\r\n    },\r\n    &quot;type&quot;: &quot;incr&quot;,\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144383,\r\n      &quot;stop&quot;: 1642144386\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1200934840\r\n    },\r\n    &quot;type&quot;: &quot;full&quot;,\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: {\r\n      &quot;start&quot;: 1642144388,\r\n      &quot;stop&quot;: 1642144392\r\n    },\r\n    &quot;info&quot;: {\r\n      &quot;size&quot;: 1168586300\r\n    },\r\n    &quot;type&quot;: &quot;incr&quot;,\r\n    &quot;name&quot;: &quot;dbname2&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/70752174/how-to-get-a-max-per-group-and-subgroup-using-jq",
        "title": "how to get a max per group and subgroup using jq"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21808613,
                    "reputation": 1162,
                    "user_id": 16106482,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/0dYD2.png?s=256",
                    "display_name": "Otter",
                    "link": "https://stackoverflow.com/users/16106482/otter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642504021,
                "post_id": 70754307,
                "comment_id": 125082629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642512098,
                "post_id": 70754307,
                "comment_id": 125085757,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1642508796,
                "last_edit_date": 1642508796,
                "creation_date": 1642505235,
                "answer_id": 70754860,
                "question_id": 70754307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Doesn&#39;t a simple `select` do what you want? For example using plain string comparison makes easy date ranges inclusive on the left and exclusive on the right:\r\n```sh\r\njq &#39;select(.time &gt; &quot;2022-01-01&quot; and .time &lt; &quot;2022-01-03&quot;)&#39;\r\n```\r\n```\r\n{\r\n  &quot;Name&quot;: &quot;Alex&quot;,\r\n  &quot;Id&quot;: 1,\r\n  &quot;time&quot;: &quot;2022-01-01T04:29:18.9099882Z&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Homer&quot;,\r\n  &quot;Id&quot;: 2,\r\n  &quot;time&quot;: &quot;2022-01-02T04:29:18.9099882Z&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/qGvuheFhxz)\r\n\r\nYou could also convert the date string into e.g. [Unix time](https://en.wikipedia.org/wiki/Unix_time) (&quot;seconds since the Epoch&quot;) using `fromdate` and operate on that as a number (after employing `sub` to cut off second fractions in order to obtain an [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) compatible date):\r\n```sh\r\njq &#39;select(.time | sub(&quot;\\\\.\\\\d+&quot;; &quot;&quot;) | fromdate &lt; 1641100000)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;Name&quot;: &quot;Alex&quot;,\r\n  &quot;Id&quot;: 1,\r\n  &quot;time&quot;: &quot;2022-01-01T04:29:18.9099882Z&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Homer&quot;,\r\n  &quot;Id&quot;: 2,\r\n  &quot;time&quot;: &quot;2022-01-02T04:29:18.9099882Z&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/_4gvINOIW8)\r\n\r\nOr, for the sake of another example, using `strptime` to convert the date into a broken-down array (containing in this order: year, (zero-based) month, day, hour, minute, second, day of week, and day of year) and then filtering e.g. for Mondays (represented as `1` in that array at the (zero-based) position `6`):\r\n```sh\r\njq &#39;select(.time | sub(&quot;\\\\.\\\\d+&quot;; &quot;&quot;) | strptime(&quot;%FT%TZ&quot;) | .[6] == 1)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;Name&quot;: &quot;Bart&quot;,\r\n  &quot;Id&quot;: 3,\r\n  &quot;time&quot;: &quot;2022-01-03T04:29:18.9099882Z&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/3U44MhRBZF)",
                "title": "Get dates from json log file using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642529462,
                "last_edit_date": 1642529462,
                "creation_date": 1642512699,
                "answer_id": 70756402,
                "question_id": 70754307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A powershell example.  Taking the input as an array:\r\n\r\n```\r\n[{\r\n  &quot;Name&quot;: &quot;Alex&quot;,\r\n  &quot;Id&quot;: 1,\r\n  &quot;time&quot;: &quot;2022-01-01T04:29:18.9099882Z&quot;\r\n},\r\n{\r\n  &quot;Name&quot;: &quot;Homer&quot;,\r\n  &quot;Id&quot;: 2,\r\n  &quot;time&quot;: &quot;2022-01-02T04:29:18.9099882Z&quot;\r\n},\r\n{\r\n  &quot;Name&quot;: &quot;Bart&quot;,\r\n  &quot;Id&quot;: 3,\r\n  &quot;time&quot;: &quot;2022-01-03T04:29:18.9099882Z&quot;\r\n}]\r\n```\r\nFor some reason in powershell 5, I have use parentheses to complete the conversion first (could use a lot of memory).  The time fields are converted to the .Net [datetime] type, and then it&#39;s easy to compare them.  The right side of a comparision automatically gets converted to a datetime if it can be.\r\n```\r\n(get-content file.json | convertfrom-json) | \r\nforeach-object { $_.time = [datetime]$_.time; $_ } | \r\nwhere-object { $_.time -ge &#39;1/1/22&#39; -and $_.time -le &#39;1/2/22&#39; }\r\n\r\nName  Id time\r\n----  -- ----\r\nHomer  2 1/1/2022 11:29:18 PM\r\n```\r\nHere&#39;s a workaround for the original file of consecutive json objects:\r\n```\r\nget-content file.json -ReadCount 5 | \r\nforeach-object { $_ | convertfrom-json } | \r\nforeach-object { $_.time = [datetime]$_.time; $_ } | \r\nwhere-object { $_.time -ge &#39;1/1/22&#39; -and $_.time -le &#39;1/2/22&#39; }\r\n```",
                "title": "Get dates from json log file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1642529462,
        "creation_date": 1642502896,
        "last_edit_date": 1642507247,
        "question_id": 70754307,
        "body_markdown": "I have a huge file in this format:\r\n\r\n```json\r\n{\r\n  &quot;Name&quot;: &quot;Alex&quot;,\r\n  &quot;Id&quot;: 1,\r\n  &quot;time&quot;: &quot;2022-01-01T04:29:18.9099882Z&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Homer&quot;,\r\n  &quot;Id&quot;: 2,\r\n  &quot;time&quot;: &quot;2022-01-02T04:29:18.9099882Z&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Bart&quot;,\r\n  &quot;Id&quot;: 3,\r\n  &quot;time&quot;: &quot;2022-01-03T04:29:18.9099882Z&quot;\r\n}\r\n```\r\n\r\nHow can I filter this file by date range and specific period of time? \r\nI was trying to solve this using jq, but was not able to do so. If there another way how to filter it without jq, please let me know.",
        "link": "https://stackoverflow.com/questions/70754307/get-dates-from-json-log-file-using-jq",
        "title": "Get dates from json log file using JQ"
    },
    {
        "tags": [
            "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": 1642516634,
                "post_id": 70757309,
                "comment_id": 125087728,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1642517855,
                "last_edit_date": 1642517855,
                "creation_date": 1642517112,
                "answer_id": 70757503,
                "question_id": 70757309,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should bring you there\r\n```sh\r\njq -r --arg q &quot;app3&quot; &#39;\r\n  .[]\r\n  | select(.[] | .field.name == &quot;appname&quot; and .value.value == $q)\r\n  | .[]\r\n  | select(.field.name == &quot;appstat&quot;).value.value\r\n&#39;\r\n```\r\n```\r\nREADY\r\n```\r\n[Demo](https://jqplay.org/s/eroNIiWjfh)\r\n\r\n---\r\n\r\nHowever, your data structure seems rather complicated. You&#39;d be better off (at least for this use case) with a simpler array of objects to lookup key-value pairs. For example, transform your input like so:\r\n```sh\r\njq &#39;map(map({(first(.field.name)): first(.value.value)}) | add)&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;appname&quot;: &quot;app1&quot;,\r\n    &quot;appstat&quot;: &quot;UP&quot;\r\n  },\r\n  {\r\n    &quot;appname&quot;: &quot;app2&quot;,\r\n    &quot;appstat&quot;: &quot;DOWN&quot;\r\n  },\r\n  {\r\n    &quot;appname&quot;: &quot;app3&quot;,\r\n    &quot;appstat&quot;: &quot;READY&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/SoDxbc9S-l)\r\n\r\nThat way, your lookup would be as simple as\r\n```sh\r\njq -r --arg q &quot;app3&quot; &#39;.[] | select(.appname == $q).appstat&#39;\r\n```\r\n```\r\nREADY\r\n```\r\n[Demo](https://jqplay.org/s/jinW809fVV)\r\n",
                "title": "JQ filter specific item based on inner item"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1642517855,
        "creation_date": 1642516389,
        "last_edit_date": 1642517145,
        "question_id": 70757309,
        "body_markdown": "Having the following Array\r\n\r\n    [\r\n      [\r\n        { &quot;field&quot; : { &quot;name&quot;: &quot;appname&quot; }, &quot;value&quot;: { &quot;value&quot; : &quot;app1&quot; } },\r\n        { &quot;field&quot; : { &quot;name&quot;: &quot;appstat&quot; }, &quot;value&quot;: { &quot;value&quot; : &quot;UP&quot;   } }\r\n      ],\r\n      [\r\n        { &quot;field&quot; : { &quot;name&quot;: &quot;appname&quot; }, &quot;value&quot;: { &quot;value&quot; : &quot;app2&quot; } },\r\n        { &quot;field&quot; : { &quot;name&quot;: &quot;appstat&quot; }, &quot;value&quot;: { &quot;value&quot; : &quot;DOWN&quot; } }\r\n      ],\r\n      [\r\n        { &quot;field&quot; : { &quot;name&quot;: &quot;appname&quot; }, &quot;value&quot;: { &quot;value&quot; : &quot;app3&quot; } },\r\n        { &quot;field&quot; : { &quot;name&quot;: &quot;appstat&quot; }, &quot;value&quot;: { &quot;value&quot; : &quot;READY&quot;} }\r\n      ]\r\n    ]\r\n\r\nI want to be able to select on specific items based on the appname.\r\n\r\nSo i can do for example\r\n\r\njq .[] app3 \r\n\r\nresponse should be ***READY***",
        "link": "https://stackoverflow.com/questions/70757309/jq-filter-specific-item-based-on-inner-item",
        "title": "JQ filter specific item based on inner item"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1642526284,
                "creation_date": 1642526284,
                "answer_id": 70759746,
                "question_id": 70759687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `[]` to turn the list into a series of individual strings, and [`--raw-output` / `-r`](https://stedolan.github.io/jq/manual/v1.6/) to output them without quotes:\r\n\r\n&gt; With this option, if the filter&#39;s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.\r\n\r\n```\r\naws eks list-clusters | jq -r &#39;.clusters[]&#39; | while read cluster; do something; done\r\n```",
                "title": "jq output into a non json list to use for a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1642526330,
        "creation_date": 1642526014,
        "last_edit_date": 1642526330,
        "question_id": 70759687,
        "body_markdown": "I&#39;m sure this has been asked, but I&#39;ve searched and can&#39;t find anything to answer my question...\r\n\r\nI&#39;m looking for a simple way to output a json list as a non json list to process using a while loop.. Which means I need to strip the quotes, commas and brackets.. I know I could do it with `cut` but I&#39;m sure I&#39;m missing an easier way..\r\n\r\nSay I&#39;m using an aws command to get a list of resources and then I want to process that list in a while loop...\r\n\r\n```\r\naws eks list-clusters | jq .clusters | while read cluster; do something; done\r\n```\r\n\r\nSomething along these lines.. am I being stupid here?",
        "link": "https://stackoverflow.com/questions/70759687/jq-output-into-a-non-json-list-to-use-for-a-loop",
        "title": "jq output into a non json list to use for a loop"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-secrets-manager"
        ],
        "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": 1642529065,
                "post_id": 70760147,
                "comment_id": 125093094,
                "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": 1642529076,
                "post_id": 70760147,
                "comment_id": 125093099,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10266047,
                    "reputation": 1109,
                    "user_id": 7576002,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/50e266445d8fa04d0e8eb59bdf48119d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "KSS",
                    "link": "https://stackoverflow.com/users/7576002/kss"
                },
                "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": 1642530041,
                "post_id": 70760147,
                "comment_id": 125093529,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642529907,
                "last_edit_date": 1642529907,
                "creation_date": 1642529075,
                "answer_id": 70760359,
                "question_id": 70760147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`SecretString` is a field name in an object. Therefore you have to address it using a dot before its name: `.SecretString`\r\n\r\nAlso, the content of that field seems to be JSON but encoded as a string which you cannot address directly. You have to decode it first using `fromjson` and encode it again using `tojson`. However, the JSON string in your sample data has an error rendering it invalid JSON (after the value `\\&quot;60\\&quot;,` there is an abundant quotation mark followed by a comma: `\\&quot;,`). Assuming this is just a copy/paste error, let&#39;s continue:\r\n\r\nTo update a value using the value itself to begin with, use the update operator `|=`. To just assign a value use the simple assignment operator `=`.\r\n\r\nLastly, you can give jq the file to process as a parameter. You don&#39;t have to `cat` it first and then pipe it into jq.\r\n\r\nAltogether, this is what you are looking for:\r\n```sh\r\njq &#39;.SecretString |= (fromjson | .ConnectionString = &quot;MyNewConnectionString&quot; | tojson)&#39; json.txt\r\n```\r\n```json\r\n{\r\n  &quot;ARN&quot;: &quot;MyArn&quot;,\r\n  &quot;Name&quot;: &quot;MySecret&quot;,\r\n  &quot;SecretString&quot;: &quot;{\\&quot;ConnectionString\\&quot;:\\&quot;MyNewConnectionString\\&quot;,\\&quot;SqlCommandTimeout\\&quot;:\\&quot;60\\&quot;,\\&quot;ServiceAccountPrincipal\\&quot;:\\&quot;MyServicePrincipal\\&quot;}&quot;,\r\n  &quot;VersionStages&quot;: [\r\n    &quot;AWSCURRENT&quot;\r\n  ],\r\n  &quot;CreatedDate&quot;: &quot;2022-01-13T09:08:55.442000-08:00&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/tjQB0G3tnN)\r\n\r\nSome additional notes:\r\n\r\nIf you want to keep the inner JSON as JSON (to access it more easily in th future), just drop the re-conversion with `tojson`)\r\n\r\nTo manipulate more than just one value, simply add them after the first: `.ConnectionString = &quot;…&quot; | .SqlCommandTimeout = &quot;…&quot; | .ServiceAccountPrincipal = &quot;…&quot;`\r\n\r\nYou can also provide the new value(s) as parameter(s) and access them as variable(s) instead, which makes your filter a little less cluttered, especially if you intend to change more than just that one field.\r\n```sh\r\njq --arg v &quot;MyNewConnectionString&quot; &#39;… .ConnectionString = $v …&#39; json.txt\r\n```",
                "title": "JQ: How To Change A Value in JSON with embedded keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642529806,
                "last_edit_date": 1642529806,
                "creation_date": 1642529485,
                "answer_id": 70760445,
                "question_id": 70760147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First off, note that your example `SecretString` is not valid JSON (there&#39;s a spurious `,&quot;`):\r\n\r\n```\r\n$ echo $ echo &#39;{&quot;ConnectionString&quot;:&quot;MyConnectionString;&quot;,&quot;SqlCommandTimeout&quot;:&quot;60&quot;,&quot;,&quot;ServiceAccountPrincipal&quot;:&quot;MyServicePrincipal&quot;}&#39; | jq\r\nparse error: Invalid numeric literal at line 1, column 94\r\n```\r\n\r\nIf we fix that we can get to the meat of your question, which is dealing with nested JSON. `jq` provides a [`fromjson` function](https://stedolan.github.io/jq/manual/#Convertto/fromJSON) for this purpose (along with `tojson` which we&#39;ll use in a moment), so we can get:\r\n\r\n```\r\n$ cat json.txt | jq &#39;.SecretString | fromjson&#39;\r\n{\r\n  &quot;ConnectionString&quot;: &quot;MyConnectionString;&quot;,\r\n  &quot;SqlCommandTimeout&quot;: &quot;60&quot;,\r\n  &quot;ServiceAccountPrincipal&quot;: &quot;MyServicePrincipal&quot;\r\n}\r\n```\r\n\r\nAnd we can set fields in the resulting JSON:\r\n\r\n```\r\n$ cat json.txt | jq &#39;.SecretString | fromjson | .ConnectionString = &quot;MyNewConnectionString&quot;&#39;\r\n{\r\n  &quot;ConnectionString&quot;: &quot;MyNewConnectionString&quot;,\r\n  &quot;SqlCommandTimeout&quot;: &quot;60&quot;,\r\n  &quot;ServiceAccountPrincipal&quot;: &quot;MyServicePrincipal&quot;\r\n}\r\n```\r\n\r\nI don&#39;t know if it&#39;s possible to apply this assignment to the original input inline (it might be!) but it&#39;s easy enough to just capture this output in a variable and then write it back to the original string:\r\n\r\n```\r\n# notice the tojson call at the end to escape the JSON as a string\r\n$ new_secret=$(cat json.txt | jq &#39;.SecretString | fromjson | .ConnectionString = &quot;MyNewConnectionString&quot; | tojson&#39;)\r\n\r\n$ cat json.txt | jq &quot;.SecretString = ${new_secret}&quot;\r\n{\r\n  &quot;ARN&quot;: &quot;MyArn&quot;,\r\n  &quot;Name&quot;: &quot;MySecret&quot;,\r\n  &quot;SecretString&quot;: &quot;{\\&quot;ConnectionString\\&quot;:\\&quot;MyNewConnectionString\\&quot;,\\&quot;SqlCommandTimeout\\&quot;:\\&quot;60\\&quot;,\\&quot;ServiceAccountPrincipal\\&quot;:\\&quot;MyServicePrincipal\\&quot;}&quot;,\r\n  &quot;VersionStages&quot;: [\r\n    &quot;AWSCURRENT&quot;\r\n  ],\r\n  &quot;CreatedDate&quot;: &quot;2022-01-13T09:08:55.442000-08:00&quot;\r\n}\r\n```\r\n\r\n**EDIT:**\r\n\r\nAh neat, pmf&#39;s answer points out the [`|=`](https://stedolan.github.io/jq/manual/#Update-assignment:|=) operator which does exactly what you need :) I&#39;ll leave this answer up but pmf&#39;s approach is better.",
                "title": "JQ: How To Change A Value in JSON with embedded keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642533586,
                "creation_date": 1642533586,
                "answer_id": 70761259,
                "question_id": 70760147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the problem is truly an upstream problem, then short of having it fixed, you could edit the malformed string in jq: \r\n\r\n```\r\n.SecretString\r\n| sub( &quot;MyConnectionString;\\&quot;&quot;; &quot;MyConnectionString\\&quot;&quot;)\r\n| sub( &quot;60\\&quot;,\\&quot;&quot;; &quot;60\\&quot;&quot;)\r\n```\r\n\r\nusing `|=`, `fromjson`, and `tojson` as appropriate, as described elsewhere on this page.",
                "title": "JQ: How To Change A Value in JSON with embedded keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651729589,
                "creation_date": 1651729589,
                "answer_id": 72122456,
                "question_id": 70760147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We have to use `fromjson` and `tojson` on the value of `SecretString`.\r\n\r\nFilter\r\n```\r\n(.SecretString | fromjson | \r\n.ConnectionString |= &quot;MyNewConnectionString&quot; | tojson) as $secret \r\n| .SecretString |= $secret\r\n```\r\n\r\nInput\r\n```\r\n{\r\n    &quot;ARN&quot;: &quot;MyArn&quot;,\r\n    &quot;Name&quot;: &quot;MySecret&quot;,\r\n    &quot;SecretString&quot;: &quot;{\\&quot;ConnectionString\\&quot;:\\&quot;MyConnectionString\\&quot;,\\&quot;SqlCommandTimeout\\&quot;:\\&quot;60\\&quot;,\\&quot;ServiceAccountPrincipal\\&quot;:\\&quot;MyServicePrincipal\\&quot;}&quot;,\r\n    &quot;VersionStages&quot;: [\r\n        &quot;AWSCURRENT&quot;\r\n    ],\r\n    &quot;CreatedDate&quot;: &quot;2022-01-13T09:08:55.442000-08:00&quot;\r\n}\r\n```\r\n\r\nOutput\r\n```\r\n{\r\n  &quot;ARN&quot;: &quot;MyArn&quot;,\r\n  &quot;Name&quot;: &quot;MySecret&quot;,\r\n  &quot;SecretString&quot;: &quot;{\\&quot;ConnectionString\\&quot;:\\&quot;MyNewConnectionString\\&quot;,\\&quot;SqlCommandTimeout\\&quot;:\\&quot;60\\&quot;,\\&quot;ServiceAccountPrincipal\\&quot;:\\&quot;MyServicePrincipal\\&quot;}&quot;,\r\n  &quot;VersionStages&quot;: [\r\n    &quot;AWSCURRENT&quot;\r\n  ],\r\n  &quot;CreatedDate&quot;: &quot;2022-01-13T09:08:55.442000-08:00&quot;\r\n}\r\n```\r\nYou can see that `ConnectionString` is updated with the new value `MyNewConnectionString` as *json string*.\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/HCsGdg1RLU",
                "title": "JQ: How To Change A Value in JSON with embedded keys"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1652528987,
        "creation_date": 1642527986,
        "last_edit_date": 1652528987,
        "question_id": 70760147,
        "body_markdown": "I have the following JSON that is being returned from an AWS Secret:\r\n\r\n```\r\n{\r\n    &quot;ARN&quot;: &quot;MyArn&quot;,\r\n    &quot;Name&quot;: &quot;MySecret&quot;,\r\n    &quot;SecretString&quot;: &quot;{\\&quot;ConnectionString\\&quot;:\\&quot;MyConnectionString;\\&quot;,\\&quot;SqlCommandTimeout\\&quot;:\\&quot;60\\&quot;,\\&quot;,\\&quot;ServiceAccountPrincipal\\&quot;:\\&quot;MyServicePrincipal\\&quot;}&quot;,\r\n    &quot;VersionStages&quot;: [\r\n        &quot;AWSCURRENT&quot;\r\n    ],\r\n    &quot;CreatedDate&quot;: &quot;2022-01-13T09:08:55.442000-08:00&quot;\r\n}\r\n```\r\nI&#39;d like to be able to modify the ConnectionString, the SqlCommandTimeout and the ServiceAccountPrincipal values.  For brevity, I am just showing the change to the ConnectionString.\r\n\r\nThe &quot;new&quot; JSON would look like this:\r\n\r\n```\r\n{\r\n    &quot;ARN&quot;: &quot;MyArn&quot;,\r\n    &quot;Name&quot;: &quot;MySecret&quot;,\r\n    &quot;SecretString&quot;: &quot;{\\&quot;ConnectionString\\&quot;:\\&quot;MyNewConnectionString;\\&quot;,\\&quot;SqlCommandTimeout\\&quot;:\\&quot;60\\&quot;,\\&quot;,\\&quot;ServiceAccountPrincipal\\&quot;:\\&quot;MyServicePrincipal\\&quot;}&quot;,\r\n    &quot;VersionStages&quot;: [\r\n        &quot;AWSCURRENT&quot;\r\n    ],\r\n    &quot;CreatedDate&quot;: &quot;2022-01-13T09:08:55.442000-08:00&quot;\r\n}\r\n```\r\n\r\nHowever, I am not sure how to do it with JQ.\r\n\r\nWhat I&#39;d like to do is have JQ modify the values for each of these fields and output the JSON object with the updated values.\r\n\r\nThe problem I am having is modifying these values which are inside of embedded JSON object.  I would expect something like this to work, but it doesn&#39;t:\r\n\r\n    cat json.txt | jq &#39;SecretString.ConnectionString = &quot;MyNewConnectionString&quot;&#39;\r\n\r\nI am getting this error:\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:8): Cannot index string with string &quot;ConnectionString&quot;\r\nexit status 5\r\n```\r\nWhat I am doing wrong?\r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70760147/jq-how-to-change-a-value-in-json-with-embedded-keys",
        "title": "JQ: How To Change A Value in JSON with embedded keys"
    },
    {
        "tags": [
            "string",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1642530837,
                "post_id": 70760535,
                "comment_id": 125093811,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8835730,
                    "reputation": 47,
                    "user_id": 6600113,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-dPwGyu3j2fI/AAAAAAAAAAI/AAAAAAAAACw/4ryHTSun0-Y/s256-rj/photo.jpg",
                    "display_name": "Subhadip Banerjee",
                    "link": "https://stackoverflow.com/users/6600113/subhadip-banerjee"
                },
                "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": 1642564762,
                "post_id": 70760535,
                "comment_id": 125101917,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1642531129,
                "creation_date": 1642531129,
                "answer_id": 70760772,
                "question_id": 70760535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to put parantheses around the whole selection to be updated: `(… | .version) += …`\r\n```sh\r\njq &#39;(.B[] | select(.name|test(&quot;jack.&quot;)) | .version) += &quot;-dev&quot;&#39; old.json &gt; new.json\r\n```\r\n```json\r\n{\r\n  &quot;A&quot;: &quot;jack&quot;,\r\n  &quot;B&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;jack/jil&quot;,\r\n      &quot;version&quot;: &quot;0.1-dev&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;went/well&quot;,\r\n      &quot;version&quot;: &quot;1.2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/3yiYsFxIVp)",
                "title": "jq update substring matched object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1642531129,
        "creation_date": 1642529911,
        "last_edit_date": 1642530773,
        "question_id": 70760535,
        "body_markdown": "Json file:\r\n\r\n``` json\r\n{\r\n  &quot;A&quot;: &quot;jack&quot;,\r\n  &quot;B&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;jack/jil&quot;,\r\n      &quot;version&quot;: &quot;0.1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;went/well&quot;,\r\n      &quot;version&quot;: &quot;1.2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nnow I need to update every objects version: &quot;$version-dev&quot; where name starts from `jack` while retaining rest of the json intact.\r\n\r\nthe closest I can get.\r\n\r\n    jq &#39;.B[] |  select(.name|test(&quot;jack.&quot;)) | .version += &quot;-dev&quot;&#39; old.json &gt; new.json\r\n\r\nin the above command I&#39;m only getting the that particular object with updated value in the new.json but I need the whole json too.\r\nany suggestions",
        "link": "https://stackoverflow.com/questions/70760535/jq-update-substring-matched-object",
        "title": "jq update substring matched object"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1642544711,
                "last_edit_date": 1642544711,
                "creation_date": 1642541778,
                "answer_id": 70762657,
                "question_id": 70762485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple `if … then … else … end` might do:\r\n\r\n```sh\r\njq --arg q &quot;b4fd044b9a7ab1146bb638ea42219b99&quot; --arg n &quot;NEWVALUETOADD&quot; &#39;\r\n  if IN(.tags[]; $q) and (IN(.services[]; $n) | not)\r\n  then .services += [$n] else . end\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;enabled&quot;: true,\r\n  &quot;services&quot;: [\r\n    &quot;933579ee8caafc4e818ddfe02ab58fdc&quot;,\r\n    &quot;NEWVALUETOADD&quot;\r\n  ],\r\n  &quot;tags&quot;: [\r\n    &quot;2a521880b86a0f043eb65cff37fac679&quot;,\r\n    &quot;b4fd044b9a7ab1146bb638ea42219b99&quot;\r\n  ],\r\n  &quot;bouquet&quot;: &quot;&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/B80tENcsem)\r\n\r\nIn order to then iterate over each file and modify it you need to use temporary files as jq does not have an in-place editing option (as `sed` does with `sed -i`).\r\n\r\n```sh\r\nfor file in *\r\ndo jq --arg q &quot;b4fd044b9a7ab1146bb638ea42219b99&quot; --arg n &quot;NEWVALUETOADD&quot; &#39;\r\n    if IN(.tags[]; $q) and (IN(.services[]; $n) | not)\r\n    then .services += [$n] else . end\r\n  &#39; &quot;$file&quot; &gt; &quot;$file.new&quot; &amp;&amp; mv &quot;$file.new&quot; &quot;$file&quot;\r\ndone\r\n```\r\n\r\n",
                "title": "Batch add keys into JSON files in a directory based on condition"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642542356,
                "last_edit_date": 1642542356,
                "creation_date": 1642541897,
                "answer_id": 70762680,
                "question_id": 70762485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This way:\r\n\r\n```sh\r\njq --arg nv &quot;NEWVALUETOADD&quot; &#39;select(.tags[] | select(. == &quot;b4fd044b9a7ab1146bb638ea42219b99&quot;) ).services += [$nv]&#39;\r\n```\r\n\r\nThe jq script:\r\n\r\n```js\r\nselect(\r\n  .tags[] | select(\r\n    . == &quot;b4fd044b9a7ab1146bb638ea42219b99&quot;\r\n  )\r\n).services += [$nv]\r\n```\r\n\r\n[jqplay.org with this above](https://jqplay.org/s/Fsi0iM6c2O)",
                "title": "Batch add keys into JSON files in a directory based on condition"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642543075,
                "creation_date": 1642543075,
                "answer_id": 70762909,
                "question_id": 70762485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option would be using index in order to find exact match with the desired value and then add the new element such as\r\n```\r\njq &#39;(select(.tags | index(&quot;b4fd044b9a7ab1146bb638ea42219b99&quot;)).services )+=[&quot;New Value&quot;]&#39; yourfile  \r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/S2R8e2dcFO)&lt;/kbd&gt;\r\n",
                "title": "Batch add keys into JSON files in a directory based on condition"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1642544711,
        "creation_date": 1642540808,
        "last_edit_date": 1642543615,
        "question_id": 70762485,
        "body_markdown": "I am looking for a way to batch add keys to all JSON file in a directory preferably with command line tools. \r\n\r\nFiles:\r\n\r\n    /config$ ls\r\n    166bbdd41c0297755ddb645db2b4c865  46a5c83d30483acba49a542a1ade9c33  87b2a640a5398156bf2d924b130ce42c  ca5b4cbc16a580cf5236097ec39e90e9\r\n\r\nJSON structure is:\r\n\r\n    {\r\n            &quot;enabled&quot;: true,\r\n            &quot;services&quot;: [\r\n                    &quot;933579ee8caafc4e818ddfe02ab58fdc&quot;\r\n            ],\r\n            &quot;tags&quot;: [\r\n                    &quot;2a521880b86a0f043eb65cff37fac679&quot;,\r\n                    &quot;b4fd044b9a7ab1146bb638ea42219b99&quot;\r\n            ],\r\n            &quot;bouquet&quot;: &quot;&quot;\r\n    }\r\n\r\nThe question is, what would be the best way to add new element to array &quot;services&quot; if the file contains &quot;b4fd044b9a7ab1146bb638ea42219b99&quot; value in the &quot;tags&quot; array. If this value does not exists in the &quot;tags&quot; array skip the file, else add &quot;NEWVALUETOADD&quot; to &quot;services&quot;.\r\n\r\nIf &quot;NEWVALUETOADD&quot; already exists we can also skip the file.\r\n\r\nExample output:\r\n\r\n    {\r\n            &quot;enabled&quot;: true,\r\n            &quot;services&quot;: [\r\n                    &quot;NEWVALUETOADD&quot;\r\n                    &quot;933579ee8caafc4e818ddfe02ab58fdc&quot;\r\n            ],\r\n            &quot;tags&quot;: [\r\n                    &quot;2a521880b86a0f043eb65cff37fac679&quot;,\r\n                    &quot;b4fd044b9a7ab1146bb638ea42219b99&quot;\r\n            ],\r\n            &quot;bouquet&quot;: &quot;&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/70762485/batch-add-keys-into-json-files-in-a-directory-based-on-condition",
        "title": "Batch add keys into JSON files in a directory based on condition"
    },
    {
        "tags": [
            "arrays",
            "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": 1642601061,
                "post_id": 70771975,
                "comment_id": 125113802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1107461,
                    "reputation": 3251,
                    "user_id": 1098584,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/7ab6b6d44e367a743580c3089026b7bc?s=256&d=identicon&r=PG",
                    "display_name": "sontags",
                    "link": "https://stackoverflow.com/users/1098584/sontags"
                },
                "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": 1642601293,
                "post_id": 70771975,
                "comment_id": 125113908,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1642601369,
                "creation_date": 1642601369,
                "answer_id": 70772084,
                "question_id": 70771975,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries` would be one way. By accessing `.key` and `.value`, the composition would be:\r\n\r\n```sh\r\njq &#39;[to_entries[] | {key} + .value]&#39; input.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;alpha&quot;,\r\n    &quot;bytes&quot;: {\r\n      &quot;value&quot;: 4789440\r\n    },\r\n    &quot;doc_count&quot;: 7723\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;beta&quot;,\r\n    &quot;bytes&quot;: {\r\n      &quot;value&quot;: 4416862639\r\n    },\r\n    &quot;doc_count&quot;: 1296\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/kyw1qByv63)",
                "title": "Converting a list of objects to an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642606708,
                "creation_date": 1642606708,
                "answer_id": 70773433,
                "question_id": 70771975,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n[ keys_unsorted[] as $key | { $key } + .[$key] ]\r\n```\r\n\r\n[Demo](https://jqplay.org/s/YCpt6W1FRr) on jqplay\r\n\r\nor\r\n\r\n```jq\r\nto_entries | map( { key } + .value )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/lvpIXiDwXA) on jqplay\r\n",
                "title": "Converting a list of objects to an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1642673307,
        "creation_date": 1642600927,
        "last_edit_date": 1642673307,
        "question_id": 70771975,
        "body_markdown": "Given I have a list of objects:\r\n\r\n```json\r\n{\r\n  &quot;alpha&quot;: {\r\n    &quot;bytes&quot;: {\r\n      &quot;value&quot;: 4789440\r\n    },\r\n    &quot;doc_count&quot;: 7723\r\n  },\r\n  &quot;beta&quot;: {\r\n    &quot;bytes&quot;: {\r\n      &quot;value&quot;: 4416862639\r\n      },\r\n    &quot;doc_count&quot;: 1296\r\n  }\r\n}\r\n```\r\n\r\nIs there a way using `jq` to get an array representation of this, such as:\r\n\r\n```json\r\n  [\r\n    {\r\n      &quot;key&quot;: &quot;alpha&quot;,\r\n      &quot;bytes&quot;: {\r\n        &quot;value&quot;: 4789440\r\n      },\r\n      &quot;doc_count&quot;: 7723\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;beta&quot;,\r\n      &quot;bytes&quot;: {\r\n        &quot;value&quot;: 4416862639\r\n      },\r\n      &quot;doc_count&quot;: 1296\r\n    }\r\n  ]\r\n```",
        "link": "https://stackoverflow.com/questions/70771975/converting-a-list-of-objects-to-an-array",
        "title": "Converting a list of objects to an array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1642611659,
                "post_id": 70774649,
                "comment_id": 125119061,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23684379,
                    "reputation": 11,
                    "user_id": 17709532,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyQEbcm64VTQ0dNYYYVdoWnbmF2Hy450tY2D9r-=k-s256",
                    "display_name": "Keyne",
                    "link": "https://stackoverflow.com/users/17709532/keyne"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1642611678,
                "post_id": 70774649,
                "comment_id": 125119074,
                "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": 4,
                "creation_date": 1642612097,
                "post_id": 70774649,
                "comment_id": 125119280,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1642611657,
                "creation_date": 1642611657,
                "answer_id": 70774735,
                "question_id": 70774649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON objects do not have a position (well, they have in the written-out file but another order would be considered equal). Arrays do have an order.\r\n\r\nThe `city` field is located within the `address` field  of the outermost object. Therefore, using jq, you can access it with the filter `.address.city`. The `-r` option unwraps the resulting JSON string into a raw string for the output.\r\n\r\n```sh\r\njq -r &#39;.address.city&#39; input.json\r\n```\r\n```\r\nSurat\r\n```\r\n[Demo](https://jqplay.org/s/geSxbQczqd)\r\n",
                "title": "How can I fetch the value of a key-value pair in a JSON using shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642646883,
                "creation_date": 1642646883,
                "answer_id": 70780268,
                "question_id": 70774649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could get all occurrences of the values corresponding to a key named &quot;city&quot; by:\r\n\r\n    jq &#39;..|objects|.city  // empty&#39;",
                "title": "How can I fetch the value of a key-value pair in a JSON using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1642646883,
        "creation_date": 1642611265,
        "last_edit_date": 1642611316,
        "question_id": 70774649,
        "body_markdown": "How can I fetch the value of a key-value pair in a JSON using shell script\r\nI do not know the positions of key-value pairs in the JSON, I will have to search and get the value of the key-value pair.\r\n\r\n```\r\n{\r\n    &quot;firstName&quot;: &quot;Rajesh&quot;,\r\n    &quot;lastName&quot;: &quot;Kumar&quot;,\r\n    &quot;gender&quot;: &quot;man&quot;,\r\n    &quot;age&quot;: 24,\r\n    &quot;address&quot;: {\r\n        &quot;streetAddress&quot;: &quot;126 Udhna&quot;,\r\n        &quot;city&quot;: &quot;Surat&quot;,\r\n        &quot;state&quot;: &quot;GJ&quot;,\r\n        &quot;postalCode&quot;: &quot;394221&quot;,\r\n        &quot;state&quot;: &quot;WB&quot;\r\n    },\r\n    &quot;phoneNumbers&quot;: [\r\n        { &quot;type&quot;: &quot;home&quot;, &quot;number&quot;: &quot;7383627627&quot; }\r\n    ]\r\n}\r\n```\r\n\r\nSample JSON. I will have to fetch the value of the city and I do not know the position of it as I will have to search and fetch the value.",
        "link": "https://stackoverflow.com/questions/70774649/how-can-i-fetch-the-value-of-a-key-value-pair-in-a-json-using-shell-script",
        "title": "How can I fetch the value of a key-value pair in a JSON using shell script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1642785295,
                "last_edit_date": 1642785295,
                "creation_date": 1642783488,
                "answer_id": 70804714,
                "question_id": 70804610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Usually, when we want to create an array from a stream of inputs, we can use `--slurp`/`-s`. But when combined with `--raw-input`/`-R`, this causes the entire input to be provided as a single string (that contains line feeds).\r\n\r\nSlurping can also be achieved using `--null-input`/`-n` and `[ inputs | ... ]`. And this works as desired for text files.\r\n\r\n```sh\r\njq -nR &#39;[ inputs | split(&quot;\\t&quot;) | { (.[0]) : .[1] } ]&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/bJMiO9Bub4) on jqplay\r\n\r\n---\r\n\r\nThat said, I suspect you will find the following output format more useful:\r\n\r\n```json\r\n{\r\n  &quot;Distributor ID&quot;: &quot;Ubuntu&quot;,\r\n  &quot;Description&quot;: &quot;Ubuntu 20.04.3 LTS&quot;,\r\n  &quot;Release&quot;: &quot;20.04&quot;,\r\n  &quot;Codename&quot;: &quot;focal&quot;\r\n}\r\n```\r\n\r\nThis can be achieved by simply adding `| add`.\r\n\r\n```sh\r\njq -nR &#39;[ inputs | split(&quot;:\\t&quot;) | { (.[0]) : .[1] } ] | add&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/b6qdo5oVKB) on jqplay\r\n\r\nOne can also use `reduce`.\r\n\r\n```sh\r\njq -nR &#39;reduce ( inputs | split(&quot;:\\t&quot;) ) as [ $k, $v ] ( {}; . + { ($k): $v } )&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/qNqEFl5ndg) on jqplay\r\n\r\n",
                "title": "Create JSON with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651040648,
                "creation_date": 1651040648,
                "answer_id": 72024144,
                "question_id": 70804610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter\r\n```\r\nreduce (inputs / &quot;:\\t&quot;) as [$key, $value] ({}; .+{($key): $value})\r\n```\r\nInput\r\n```\r\nDistributor ID:\tUbuntu\r\nDescription:\tUbuntu 20.04.3 LTS\r\nRelease:\t20.04\r\nCodename:\tfocal\r\n```\r\nOutput\r\n\r\n```\r\n{\r\n  &quot;Distributor ID&quot;: &quot;Ubuntu&quot;,\r\n  &quot;Description&quot;: &quot;Ubuntu 20.04.3 LTS&quot;,\r\n  &quot;Release&quot;: &quot;20.04&quot;,\r\n  &quot;Codename&quot;: &quot;focal&quot;\r\n}\r\n```\r\nNote that *each line* of `$key` and `$value` from `inputs` is processed and *combined* by `reduce`.\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/ZBvKf6vQ0F",
                "title": "Create JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1651040648,
        "creation_date": 1642782975,
        "last_edit_date": 1642783287,
        "question_id": 70804610,
        "body_markdown": "I am trying to create a JSON file with jq from the result of the command &quot;lsb_release&quot;\r\n\r\nWhat i have done :\r\n\r\n```sh\r\nif [ -x &quot;$(command -v lsb_release)&quot; ]; then\r\n\tlsb_release -a  | jq  --raw-input &#39;split(&quot;\\t&quot;) | { (.[0]) : .[1] }&#39; &gt; ubuntu_release.json\r\nfi\r\n```\r\n\r\nthe result is \r\n\r\n```json\r\n{\r\n  &quot;Distributor ID:&quot;: &quot;Ubuntu&quot;\r\n}\r\n\r\n{\r\n  &quot;Description:&quot;: &quot;Ubuntu 20.04.3 LTS&quot;\r\n}\r\n\r\n{\r\n  &quot;Release:&quot;: &quot;20.04&quot;\r\n}\r\n\r\n{\r\n  &quot;Codename:&quot;: &quot;focal&quot;\r\n}\r\n```\r\n\r\nbut i want the result\r\n\r\n```json\r\n[\r\n\t{\r\n\t  &quot;Distributor ID:&quot;: &quot;Ubuntu&quot;\r\n\t},\r\n\t{\r\n\t  &quot;Description:&quot;: &quot;Ubuntu 20.04.3 LTS&quot;\r\n\t},\r\n\t{\r\n\t  &quot;Release:&quot;: &quot;20.04&quot;\r\n\t},\r\n\t{\r\n\t  &quot;Codename:&quot;: &quot;focal&quot;\r\n\t}\r\n]\r\n```\r\n\r\ncan anybody body help me ? :)\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70804610/create-json-with-jq",
        "title": "Create JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1642799645,
                "last_edit_date": 1642799645,
                "creation_date": 1642790337,
                "answer_id": 70806130,
                "question_id": 70805891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This assumes that the insert and deletion keys (`field2` and `field3`) are also dynamic, not just the inserted value.\r\n- Use `--arg` and `--argjson` to initialize variables with values from outside the filter, here `field2` as a string and `{&quot;field3&quot;: &quot;new&quot;}` as a JSON object\r\n- Use the update operator `|=` on the element you want to change, here `.key5[]`.\r\n  - Note: `.key5` is an array, not an object, thus it has no fields. But the array does contain objects as its elements. Using `.key5[]` to access the array elements will update **all** objects in the array. To update just one of them, say, the first one, use `.key[0]` instead.\r\n- Use `delpaths` to delete a given path, here the top-level field `[$delkey]`.\r\n- Use simple addition `+` to add a new key/value pair as object, here `$add`.\r\n\r\n```sh\r\njq --arg delkey &#39;field2&#39; --argjson addobj &#39;{&quot;field3&quot;: &quot;new&quot;}&#39; &#39;\r\n  .key5[] |= delpaths([[$delkey]]) + $addobj\r\n&#39; input.json\r\n```\r\n```json\r\n{\r\n  &quot;key1&quot;: [\r\n    &quot;value1&quot;\r\n  ],\r\n  &quot;key2&quot;: [\r\n    &quot;value2&quot;\r\n  ],\r\n  &quot;key3&quot;: [\r\n    &quot;value3&quot;\r\n  ],\r\n  &quot;key4&quot;: {\r\n    &quot;name&quot;: &quot;value4&quot;\r\n  },\r\n  &quot;key5&quot;: [\r\n    {\r\n      &quot;field1&quot;: &quot;abc&quot;,\r\n      &quot;field3&quot;: &quot;new&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/mAjuXE6lt1)\r\n\r\nIf you want to provide the new object&#39;s key and value separately, i.e. as strings, not as a pre-composed JSON, you need a third input variable\r\n```sh\r\njq --arg delkey &#39;field2&#39; --arg addkey &#39;field3&#39; --arg addval &#39;new&#39; &#39;\r\n  .key5[] |= (delpaths([[$delkey]]) | .[$addkey] = $addval)\r\n&#39; input.json\r\n```\r\n[Demo](https://jqplay.org/s/7uN6nVLOCG)",
                "title": "Removing and adding key-value from JSON file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642875052,
                "last_edit_date": 1642875052,
                "creation_date": 1642791965,
                "answer_id": 70806458,
                "question_id": 70805891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.key5[] |= ( ... )` allows you to modify each element of the array found at `.key5`.\r\n\r\nTherein, we can use the usual commands for deleting and adding fields.\r\n\r\n```jq\r\njq &#39;.key5[] |= ( del( .field2 ) | .field3 = &quot;foo&quot; )&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/fsHuKOnO-K) in jqplay\r\n\r\nHere&#39;s a variation where the value to add is provided as a command-line argument:\r\n\r\n```jq\r\njq --arg val foo &#39;.key5[] |= ( del( .field2 ) | .field3 = $val )&#39;\r\n```\r\n",
                "title": "Removing and adding key-value from JSON file using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651038740,
                "creation_date": 1651038740,
                "answer_id": 72023858,
                "question_id": 70805891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try filter:\r\n\r\n```\r\ndel(.key5[0].field2) | .key5[0] |= .+{field3:&quot;foo&quot;}\r\n```\r\n\r\nOutput:\r\n```\r\n{\r\n  &quot;key1&quot;: [\r\n    &quot;value1&quot;\r\n  ],\r\n  &quot;key2&quot;: [\r\n    &quot;value2&quot;\r\n  ],\r\n  &quot;key3&quot;: [\r\n    &quot;value3&quot;\r\n  ],\r\n  &quot;key4&quot;: {\r\n    &quot;name&quot;: &quot;value4&quot;\r\n  },\r\n  &quot;key5&quot;: [\r\n    {\r\n      &quot;field1&quot;: &quot;abc&quot;,\r\n      &quot;field3&quot;: &quot;foo&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/EB8MpWRxU2",
                "title": "Removing and adding key-value from JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1651541883,
        "creation_date": 1642789132,
        "question_id": 70805891,
        "body_markdown": "I have an json file as follows below-\r\n\r\n    {\r\n      &quot;key1&quot;: [\r\n        &quot;value1&quot;\r\n      ],\r\n      &quot;key2&quot;: [\r\n        &quot;value2&quot;\r\n      ],\r\n      &quot;key3&quot;: [\r\n        &quot;value3&quot;\r\n      ],\r\n      &quot;key4&quot;: {\r\n        &quot;name&quot;: &quot;value4&quot;\r\n      },\r\n      &quot;key5&quot;: [\r\n        {\r\n          &quot;field1&quot;: &quot;abc&quot;,\r\n          &quot;field2&quot;: &quot;xyz&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to remove field 2 from key5 array and add another field say field3  in key5 array using jq\r\nI tried various way but couldn&#39;t figure it how to do this in single command.\r\nCan you please help . Thanks in advance\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70805891/removing-and-adding-key-value-from-json-file-using-jq",
        "title": "Removing and adding key-value from JSON file using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642793888,
                "creation_date": 1642793888,
                "answer_id": 70806791,
                "question_id": 70806656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without seeing the original data, my guess is that you get the cartesian product because you are iterating three times (`.experience[]`) within the object construction. You might want to pull out the iteration, maybe save it in a variable, and reference that instead:\r\n```\r\n.experience[] as $experience | {\r\n  personid: .personid,\r\n  company_name: $experience.company.name,\r\n  sdate: $experience.start_date,\r\n  edate: $experience.end_date\r\n}\r\n```\r\nDepending on the outer structure of your construction, also the other way around may be appropriate, ie. storing the `.person` field instead in a variable:\r\n```\r\n.personid as $id | .experience[] | {\r\n  personid: $id,\r\n  company_name: .company.name,\r\n  sdate: .start_date,\r\n  edate: .end_date\r\n}\r\n```\r\n",
                "title": "Reshape JSON with jq to expand each object into multiple rows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1642793888,
        "creation_date": 1642793151,
        "question_id": 70806656,
        "body_markdown": "I have a database of resumes in json format that I want to reshape so that each row corresponds to a person&#39;s employment history at a given company:\r\n\r\npersonid, company_name, start_date, end_date\r\n\r\nHowever, running the following jq command\r\n\r\n```{personid:.personid, company_name: .experience[].company.name, sdate: .experience[].start_date, edate: .experience[].end_date}```\r\n\r\nproduces the cartesian product of all the fields (3 jobs x 3 fields). For example, a person who has held 3 jobs at 3 different companies in the past looks like this after running the jq command above:\r\n\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2020-06&quot;,&quot;edate&quot;:null}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2020-06&quot;,&quot;edate&quot;:null}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2020-06&quot;,&quot;edate&quot;:&quot;2017-07&quot;}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2016-10&quot;,&quot;edate&quot;:null}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2016-10&quot;,&quot;edate&quot;:null}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2016-10&quot;,&quot;edate&quot;:&quot;2017-07&quot;}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2017-05&quot;,&quot;edate&quot;:null}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2017-05&quot;,&quot;edate&quot;:null}\r\n    {&quot;id&quot;:&quot;abc123&quot;,&quot;companyname&quot;:&quot;companyA&quot;,&quot;sdate&quot;:&quot;2017-05&quot;,&quot;edate&quot;:&quot;2017-07&quot;}\r\n\r\nThere are 9 entries for CompanyB and CompanyC each but I truncated the output above for brevity.\r\n\r\nI think I need to use the group_by() command, but I&#39;ve been unsuccessful.\r\n\r\nThanks in advance.\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70806656/reshape-json-with-jq-to-expand-each-object-into-multiple-rows",
        "title": "Reshape JSON with jq to expand each object into multiple rows"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1642887153,
                "creation_date": 1642887153,
                "answer_id": 70817319,
                "question_id": 70817244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.[].builds | to_entries[] | &quot;\\(.key), \\(.value | keys[])&quot;\r\n```\r\n\r\nWill generate\r\n```none\r\n&quot;test, 2021.1.2&quot;\r\n&quot;dev, 2021.2.2&quot;\r\n&quot;test, 2021.1.2&quot;\r\n&quot;dev, 2021.2.1&quot;\r\n&quot;test, 2021.3.1&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\nUse `jq --raw-output` to remove the `&quot;`&#39;s around each line\r\n\r\n\r\n----------\r\n\r\n\r\n[Online demo](https://jqplay.org/s/8MChru9MRB)",
                "title": "how to extract specific keys from json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1642904141,
                "last_edit_date": 1642904141,
                "creation_date": 1642897332,
                "answer_id": 70818232,
                "question_id": 70817244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two approaches using the path:\r\n\r\n---\r\n\r\n```sh\r\njq -r &#39;.[].builds | paths | select(length == 2) | join(&quot;, &quot;)&#39;\r\n```\r\n```\r\ntest, 2021.1.2\r\ndev, 2021.2.2\r\ntest, 2021.1.2\r\ndev, 2021.2.1\r\ntest, 2021.3.1\r\n```\r\n[Demo](https://jqplay.org/s/KuIhFCYpNE)\r\n\r\n---\r\n\r\n~~~sh\r\njq -r &#39;path(.[].builds[][])[2:] | join(&quot;, &quot;)&#39;\r\n~~~\r\n~~~\r\ntest, 2021.1.2\r\ndev, 2021.2.2\r\ntest, 2021.1.2\r\ndev, 2021.2.1\r\ntest, 2021.3.1\r\n~~~\r\n[Demo](https://jqplay.org/s/fdplQcKV6i)\r\n",
                "title": "how to extract specific keys from json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642945913,
                "creation_date": 1642945913,
                "answer_id": 70822704,
                "question_id": 70817244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a ruby if your `jq` is broken that day:\r\n\r\n    ruby -r json -e &#39;JSON.parse($&lt;.read).\r\n    \t\t\t\t each{|h| h.select{|k,v| k==&quot;builds&quot;}.\r\n    \t\t\t\t each{|k,v| [&quot;test&quot;,&quot;dev&quot;].\r\n    \t\t\t\t each{|t| puts &quot;#{t}, #{v[t].keys[0]}&quot; if v.key?(t)}}} &#39; file\t \r\n\r\n    test, 2021.1.2\r\n    dev, 2021.2.2\r\n    test, 2021.1.2\r\n    dev, 2021.2.1\r\n    test, 2021.3.1",
                "title": "how to extract specific keys from json"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1642945913,
        "creation_date": 1642886499,
        "last_edit_date": 1642887941,
        "question_id": 70817244,
        "body_markdown": "\r\nI have following json input file. I need to get the 2 and 3rd keys like below.\r\n\r\nNeed out put as: \r\n\r\n    test, 2021.1.2\r\n    dev, 2021.2.2\r\n    test, 2021.1.2\r\n    dev, 2021.2.1\r\n    test, 2021.3.1\r\n\r\n\r\n\r\n Input json:\r\n\r\n    [\r\n      {\r\n        &quot;builds&quot;: {\r\n          &quot;test&quot;: {\r\n            &quot;2021.1.2&quot;: {\r\n              &quot;stages&quot;: [\r\n                &quot;functional&quot;,\r\n                &quot;integration&quot;\r\n              ]\r\n            }\r\n          },\r\n          &quot;dev&quot;: {\r\n            &quot;2021.2.2&quot;: {\r\n              &quot;stages&quot;: [\r\n                &quot;junit&quot;,\r\n                &quot;nls&quot;\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;dockertag&quot;: &quot;0.1.1&quot;\r\n      },\r\n      {\r\n        &quot;builds&quot;: {\r\n          &quot;test&quot;: {\r\n            &quot;2021.1.2&quot;: {\r\n              &quot;stages&quot;: [\r\n                &quot;functional&quot;\r\n              ]\r\n            }\r\n          },\r\n          &quot;dev&quot;: {\r\n            &quot;2021.2.1&quot;: {\r\n              &quot;stages&quot;: [\r\n                &quot;junit&quot;,\r\n                &quot;nls&quot;\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;dockertag&quot;: &quot;0.1.2&quot;\r\n      },\r\n      {\r\n        &quot;builds&quot;: {\r\n          &quot;test&quot;: {\r\n            &quot;2021.3.1&quot;: {\r\n              &quot;stages&quot;: [\r\n                &quot;functional&quot;,\r\n                &quot;integration&quot;\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;dockertag&quot;: &quot;0.1.3&quot;\r\n      }\r\n    ]\r\n\r\nI tried following code but it is incomplete. I can get the 2nd key but not sure how to further extract 3rd key:\r\n\r\n    jq -r &#39;.[].builds | keys[] as $k | &quot;\\($k), \\(.[$k] | .)&quot;&#39; test.json\r\n\r\nThanks for the help.\r\n    \r\n     \r\n     \r\n",
        "link": "https://stackoverflow.com/questions/70817244/how-to-extract-specific-keys-from-json",
        "title": "how to extract specific keys from json"
    },
    {
        "tags": [
            "json",
            "datetime",
            "jq",
            "iso8601",
            "milliseconds"
        ],
        "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": 1642916396,
                "post_id": 70819375,
                "comment_id": 125197945,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 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": 1642917612,
                "post_id": 70819375,
                "comment_id": 125198081,
                "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": 1642925879,
                "post_id": 70819375,
                "comment_id": 125199246,
                "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": 1642928442,
                "post_id": 70819375,
                "comment_id": 125199699,
                "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": 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": 1642928838,
                "post_id": 70819375,
                "comment_id": 125199766,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645734105,
                "last_edit_date": 1645734105,
                "creation_date": 1642917991,
                "answer_id": 70819571,
                "question_id": 70819375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your system/environment implements the placeholder `%N` for nanoseconds, you could use `%3N` to get the padded milliseconds:\r\n~~~sh\r\nTZ=America/New_York jq -r &#39;\r\n  \r\n  def mydate:\r\n    ./1000 | strflocaltime(&quot;%Y-%m-%d %H:%M:%S.%3N&quot;);\r\n  \r\n  mydate\r\n\r\n&#39; &lt;&lt;&lt; 1642812926681\r\n~~~\r\n~~~\r\n2022-01-21 19:55:26.681\r\n~~~\r\nNo Demo ([jqplay.org](https://jqplay.org/) does not support the `%N` placeholder)\r\n\r\n---\r\n\r\nIf it doesn&#39;t, you could still do some tweaks to shorten it:\r\n\r\n- omit calculating the `floor` for the whole seconds as `strflocaltime` will take care of it\r\n- replace `%Y-%m-%d %H:%M:%S` with `%F %T`\r\n- use string interpolation `&quot;\\(…)&quot;` for easier string conversion\r\n\r\n~~~sh\r\nTZ=America/New_York jq -r &#39;\r\n  \r\n  def mydate:\r\n    (./1000 | strflocaltime(&quot;%F %T.&quot;)) + &quot;00\\(.%1000)&quot;[-3:];\r\n  \r\n  mydate\r\n\r\n&#39; &lt;&lt;&lt; 1642812926681\r\n~~~\r\n~~~\r\n2022-01-21 19:55:26.681\r\n~~~\r\n[Demo](https://jqplay.org/s/JqemgHwZuV)",
                "title": "How to convert an epoch time in millisecond into an ISO like string according to local time?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1645734105,
        "creation_date": 1642915718,
        "last_edit_date": 1642925645,
        "question_id": 70819375,
        "body_markdown": "```\r\n$ TZ=America/New_York jq -r &#39;((./1000 | floor | strflocaltime(&quot;%Y-%m-%d %H:%M:%S&quot;) + &quot;.&quot; + (.%1000 | tostring | (&quot;0&quot; * (3 - length)) + .)))&#39; &lt;&lt;&lt; 1642812926681 # Time is in the number of epoch millisecond.\r\n2022-01-21 19:55:26.926\r\n```\r\n\r\nI can come up with some like the above for the conversion. Is this the most appropriate way to perform such a conversion? How to define a function for such a conversion so that I don&#39;t have to always type such a long jq command?",
        "link": "https://stackoverflow.com/questions/70819375/how-to-convert-an-epoch-time-in-millisecond-into-an-iso-like-string-according-to",
        "title": "How to convert an epoch time in millisecond into an ISO like string according to local time?"
    },
    {
        "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": 1642929214,
                "post_id": 70820479,
                "comment_id": 125199843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9255646,
                    "reputation": 45,
                    "user_id": 6874651,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f46179ef0e313ea89374846ea625139?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Miura",
                    "link": "https://stackoverflow.com/users/6874651/miura"
                },
                "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": 1642937858,
                "post_id": 70820479,
                "comment_id": 125201674,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1642928726,
                "creation_date": 1642928726,
                "answer_id": 70820566,
                "question_id": 70820479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the update operator `//` to introduce another constraint if `history_unban` is existent and not empty.\r\n\r\n~~~sh\r\njq -r &#39;\r\n  to_entries[] | select(.value\r\n    | (.history_ban | max) as $maxban\r\n    | $maxban &gt; &quot;2022-01-16 09:00&quot;\r\n      and (.history_unban | length == 0 // $maxban &gt; max)\r\n  ).key\r\n&#39;\r\n~~~\r\n~~~\r\n2.2.2.2\r\n3.3.3.3\r\n~~~\r\n[Demo](https://jqplay.org/s/-u3wCqFjp-)",
                "title": "jq select compare two max&#39;s of array within object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1642937877,
        "creation_date": 1642927979,
        "last_edit_date": 1642937877,
        "question_id": 70820479,
        "body_markdown": "Let&#39;s say I have to following JSON file:\r\n\r\n```\r\n{\r\n  &quot;1.1.1.1&quot;: {\r\n    &quot;history_ban&quot;: [\r\n      &quot;2021-05-02 14:30&quot;,\r\n      &quot;2022-01-01 12:00&quot;\r\n    ],\r\n    &quot;history_unban&quot;: [\r\n      &quot;2021-05-09 14:30&quot;,\r\n      &quot;2022-01-08 12:00&quot;\r\n    ]\r\n  },\r\n  &quot;2.2.2.2&quot;: {\r\n    &quot;history_ban&quot;: [\r\n      &quot;2022-01-16 07:00&quot;\r\n    ],\r\n    &quot;history_unban&quot;: []\r\n  },\r\n  &quot;3.3.3.3&quot;: {\r\n    &quot;history_ban&quot;: [\r\n      &quot;2022-01-15 22:40&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nMy goals is to get all the keys where:\r\n\r\n 1. Max history_ban date is smaller than &quot;2022-01-16 09:00&quot;\r\n 2. Max history_unban date is empty/non-existent or smaller then Max history_ban date\r\n\r\n\r\nI believe I have the majority of the query working as I wanted, but the &#39;Compare max unban with max ban&#39; is not working. My current (not working) query is as follows:\r\n\r\n```\r\nto_entries[] | select((.value.history_ban != null) and (.value.history_ban | max &lt; &quot;2022-01-16 09:00&quot;) and ((.value.history_unban | length == 0 ) or (.value.history_unban | max &lt; .value.history_ban | max))) | .key\r\n```\r\n\r\nI know my error is within ```(.value.history_unban | max &lt; .value.history_ban | max)``` because, if I replace it with ```(.value.history_unban | max &lt; &quot;somedate&quot;)``` I get a working query.\r\n\r\nThe error I get is\r\n&gt;jq: error (at &lt;stdin&gt;:22): Cannot index array with string &quot;value&quot;\r\nexit status 5\r\n\r\nWhat do I need to do to select/compare these two max values?\r\n\r\nJust to be sure, my expected result in this example is\r\n\r\n - &quot;2.2.2.2&quot;\r\n - &quot;3.3.3.3&quot;",
        "link": "https://stackoverflow.com/questions/70820479/jq-select-compare-two-maxs-of-array-within-object",
        "title": "jq select compare two max&#39;s of array within object"
    },
    {
        "tags": [
            "json",
            "linux",
            "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": 1642992808,
                "post_id": 70828479,
                "comment_id": 125213618,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user17803116"
                },
                "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": 1642993125,
                "post_id": 70828479,
                "comment_id": 125213661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user17803116"
                },
                "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": 1642993183,
                "post_id": 70828479,
                "comment_id": 125213670,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user17803116"
                },
                "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": 1642993217,
                "post_id": 70828479,
                "comment_id": 125213680,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643007512,
                "last_edit_date": 1643007512,
                "creation_date": 1642993407,
                "answer_id": 70828562,
                "question_id": 70828479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like this could be accomplished entirely in jq.\r\n\r\nTry this to change the `data` field directly:\r\n~~~sh\r\njq --argjson deliverableDistance 5000 &#39;\r\n  .data[] += {$deliverableDistance}\r\n&#39; &lt;&lt;&lt; &quot;$data&quot;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;deliveryRegionId&quot;: 2,\r\n      &quot;deliverableDistance&quot;: 5000\r\n    },\r\n    {\r\n      &quot;deliveryRegionId&quot;: 3,\r\n      &quot;deliverableDistance&quot;: 5000\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/pJqaCapO0J)\r\n\r\nOr this, if you want to have the resulting object&#39;s field renamed to `requestArray`:\r\n~~~sh\r\njq --argjson deliverableDistance 5000 &#39;\r\n  {requestArray: (.data | map(. += {$deliverableDistance}))}\r\n&#39; &lt;&lt;&lt; &quot;$data&quot;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;requestArray&quot;: [\r\n    {\r\n      &quot;deliveryRegionId&quot;: 2,\r\n      &quot;deliverableDistance&quot;: 5000\r\n    },\r\n    {\r\n      &quot;deliveryRegionId&quot;: 3,\r\n      &quot;deliverableDistance&quot;: 5000\r\n    }\r\n  ]\r\n}\r\n\r\n~~~\r\n[Demo](https://jqplay.org/s/Ft8FO2rqpf)\r\n",
                "title": "is it impossible to create an empty array and add a json object to it?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643007512,
        "creation_date": 1642992603,
        "last_edit_date": 1642997455,
        "question_id": 70828479,
        "body_markdown": "```\r\nfor region in $(jq &#39;.data | keys | .[]&#39; &lt;&lt;&lt; &quot;$data&quot;); do\r\nvalue=$(jq -r &quot;.data[$region]&quot; &lt;&lt;&lt; &quot;$data&quot;);\r\ndeliveryRegionId=$(jq -r &#39;.deliveryRegionId&#39; &lt;&lt;&lt; &quot;$value&quot;);\r\njson_template=&#39;{}&#39;;\r\njson_data=$(jq --argjson deliveryRegionId &quot;$deliveryRegionId&quot; --arg deliverableDistance 5000 &#39;.deliveryRegionId=$deliveryRegionId | .deliverableDistance=5000&#39; &lt;&lt;&lt;&quot;$json_template&quot;); echo $json_data;\r\njq &#39;.requestArray += &quot;$json_data&quot; // not work\r\ndone;\r\necho $requestArray\r\n```\r\nI want to add ```json_data``` to ```requestArray```, but it seems not to work.\r\nhow can I add ```json_data``` to ```requestArray```?",
        "link": "https://stackoverflow.com/questions/70828479/is-it-impossible-to-create-an-empty-array-and-add-a-json-object-to-it",
        "title": "is it impossible to create an empty array and add a json object to it?"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6611305,
                    "reputation": 3416,
                    "user_id": 5106317,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OfdGU.png?s=256",
                    "display_name": "&#214;zg&#252;r Murat Sağdı&#231;oğlu",
                    "link": "https://stackoverflow.com/users/5106317/%c3%96zg%c3%bcr-murat-sa%c4%9fd%c4%b1%c3%a7o%c4%9flu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643004257,
                "post_id": 70828977,
                "comment_id": 125215427,
                "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": 6611305,
                    "reputation": 3416,
                    "user_id": 5106317,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OfdGU.png?s=256",
                    "display_name": "&#214;zg&#252;r Murat Sağdı&#231;oğlu",
                    "link": "https://stackoverflow.com/users/5106317/%c3%96zg%c3%bcr-murat-sa%c4%9fd%c4%b1%c3%a7o%c4%9flu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643004786,
                "post_id": 70828977,
                "comment_id": 125215527,
                "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": 1643005177,
                "post_id": 70828977,
                "comment_id": 125215600,
                "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": 1643005613,
                "post_id": 70828977,
                "comment_id": 125215681,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643005458,
                "last_edit_date": 1643005458,
                "creation_date": 1643004051,
                "answer_id": 70829584,
                "question_id": 70828977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no jq variable named `$json_data`.\r\n\r\nThere is a shell variable named that, but you can&#39;t access another program&#39;s variables.\r\n\r\n**Provide the value via the environment**\r\n\r\n```bash\r\njson_data=&quot;$json_data&quot; jq &#39;. += [ env.json_data ]&#39; &lt;&lt;&lt;&quot;$requestArray&quot;\r\n```\r\n\r\n**Provide the value via the environment**\r\n\r\n```bash\r\nexport json_data\r\njq &#39;. += [ env.json_data ]&#39; &lt;&lt;&lt;&quot;$requestArray&quot;\r\n```\r\n\r\n**Provide the value as an argument**\r\n\r\n```bash\r\njq --arg json_data &quot;$json_data&quot; &#39;. += [ $json_data ]&#39; &lt;&lt;&lt;&quot;$requestArray&quot;\r\n```\r\n\r\n---\r\n\r\nThere&#39;s no reason to use `jq` so many times! Your entire program can be replaced with this:\r\n\r\n```sh\r\nrequestArray=&quot;$(\r\n   jq &#39;.data | map( { deliveryRegionId, deliverableDistance: 5000 } )&#39; \\\r\n      &lt;&lt;&lt;&quot;$data&quot;\r\n)&quot;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/JcZyEPMCbw) on jqplay",
                "title": "How to make a new array and add json value in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1643005458,
        "creation_date": 1642998126,
        "last_edit_date": 1643002445,
        "question_id": 70828977,
        "body_markdown": "```\r\nfor region in $(jq &#39;.data | keys | .[]&#39; &lt;&lt;&lt; &quot;$data&quot;); do\r\nvalue=$(jq -r &quot;.data[$region]&quot; &lt;&lt;&lt; &quot;$data&quot;);\r\ndeliveryRegionId=$(jq -r &#39;.deliveryRegionId&#39; &lt;&lt;&lt; &quot;$value&quot;);\r\njson_template=&#39;{}&#39;;\r\njson_data=$(jq --argjson deliveryRegionId &quot;$deliveryRegionId&quot; --arg deliverableDistance 5000 &#39;.deliveryRegionId=$deliveryRegionId | .deliverableDistance=5000&#39; &lt;&lt;&lt;&quot;$json_template&quot;); echo $json_data;\r\nrequestArray=$(jq &#39;. += [$json_data]&#39; &lt;&lt;&lt; $requestArray)\r\ndone;\r\n```\r\nAs in the code above, I&#39;m going to create a json value called ```json_data``` and add it to the array.\r\nWhat should I do to make this work?\r\n\r\n```\r\njq: error: $json_data is not defined at &lt;top-level&gt;, line 1:\r\n. += [$json_data]      \r\njq: 1 compile error\r\n```\r\nthis is error",
        "link": "https://stackoverflow.com/questions/70828977/how-to-make-a-new-array-and-add-json-value-in-bash",
        "title": "How to make a new array and add json value in bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643012466,
                "post_id": 70830757,
                "comment_id": 125217477,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1643012693,
                "creation_date": 1643012693,
                "answer_id": 70830878,
                "question_id": 70830757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that your data is actually: \r\n\r\n```\r\n[\r\n   {\r\n      &quot;title&quot;:&quot;second bad commit&quot;,\r\n      &quot;message&quot;:&quot;second bad commit&quot;\r\n   },\r\n   {\r\n      &quot;title&quot;:&quot;first bad commit&quot;,\r\n      &quot;message&quot;:&quot;first bad commit&quot;\r\n   }\r\n]\r\n```\r\n\r\nThen you&#39;ll need to use `map` to map each value:\r\n\r\n```\r\n$ jq &#39;map(.message)&#39;           \r\n[\r\n  &quot;second bad commit&quot;,\r\n  &quot;first bad commit&quot;\r\n]\r\n```\r\n\r\nAnd then just the join pipe:\r\n\r\n```\r\n$ jq &#39;map(.message) | join(&quot;,&quot;)&#39;\r\n&quot;second bad commit,first bad commit&quot;\r\n```\r\n\r\nAnd then adding `-r` to output the raw value.:\r\n\r\n\r\n```\r\n$ jq -r &#39;map(.message) | join(&quot;,&quot;)&#39;\r\nsecond bad commit,first bad commit\r\n```",
                "title": "How to make jq output comma separated when key is absent"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643016107,
        "creation_date": 1643011935,
        "last_edit_date": 1643016107,
        "question_id": 70830757,
        "body_markdown": "I am trying to fetch message field from below json file in comma separated value\r\n\r\n```\r\n[\r\n   {\r\n      &quot;title&quot;:&quot;second bad commit&quot;,\r\n      &quot;message&quot;:&quot;second bad commit&quot;\r\n   },\r\n   {\r\n      &quot;title&quot;:&quot;first bad commit&quot;,\r\n      &quot;message&quot;:&quot;first bad commit&quot;,\r\n   }\r\n]\r\n```\r\n\r\nMy attempt to do that with jq: `jq -r &#39;.message | join(&quot;,&quot;)&#39;`\r\n\r\nIt keeps throwing following error:\r\n`jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;message&quot;`\r\n\r\nSo, how can I make jq output comma separated when key is absent ",
        "link": "https://stackoverflow.com/questions/70830757/how-to-make-jq-output-comma-separated-when-key-is-absent",
        "title": "How to make jq output comma separated when key is absent"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643020054,
                "last_edit_date": 1643020054,
                "creation_date": 1643018866,
                "answer_id": 70832090,
                "question_id": 70831992,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `transpose` builtin, which converts an array of arrays into a zipped array, and `map` to generate an object within each paired array element.\r\n\r\n~~~sh\r\njq &#39;{\r\n  &quot;hash_md5&quot;: .metadata[] | select(.tool == &quot;hash&quot;) | .tool_metadata.md5,\r\n  &quot;assertions&quot;: (\r\n    [\r\n      [.assertions[] | .engine.name],\r\n      [.assertions[] | .metadata.malware_family]\r\n    ]\r\n    | transpose\r\n    | map({&quot;engine&quot;: .[0], &quot;malware&quot;: .[1]})\r\n  )\r\n}&#39; file.json\r\n~~~\r\n\r\nNote that, as both your arrays to be zipped result from the same iteration `.assertions[]` (which is performed twice this way), you could simply pull out the iteration and make it implicit by using a `map`:\r\n\r\n~~~sh\r\njq &#39;{\r\n  &quot;hash_md5&quot;: .metadata[] | select(.tool == &quot;hash&quot;) | .tool_metadata.md5,\r\n  &quot;assertions&quot;: (\r\n    .assertions\r\n    | map({\r\n        &quot;engine&quot;: .engine.name,\r\n        &quot;malware&quot;: .metadata.malware_family\r\n      })\r\n  )\r\n}&#39; file.json\r\n~~~",
                "title": "Parse json with jq and zip two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643049195,
        "creation_date": 1643018377,
        "last_edit_date": 1643049195,
        "question_id": 70831992,
        "body_markdown": "I have the following jq command where I extract a field and create two arrays\r\n\r\n    jq &#39;{\r\n    &quot;hash_md5&quot;: .metadata[] | select(.tool == &quot;hash&quot;) | .tool_metadata.md5,\r\n    &quot;engine&quot;: [.assertions[] | .engine.name],\r\n    &quot;malware&quot;: [.assertions[] | .metadata.malware_family]\r\n    }&#39; file.json\r\n\r\nAs expected, I get the following output:\r\n\r\n```\r\n{\r\n  &quot;hash_md5&quot;: &quot;799c748fe5fbc1900594d6d79bb9f803&quot;,\r\n  &quot;engine&quot;: [\r\n    &quot;A&quot;,\r\n    &quot;B&quot;,\r\n    &quot;C&quot;\r\n  ],\r\n  &quot;malware&quot;: [\r\n    &quot;1&quot;,\r\n    &quot;2&quot;,\r\n    &quot;3&quot;\r\n  ]\r\n}\r\n```\r\nNow, I would like to zip the two arrays and keep the rest to arrive at:\r\n\r\n```\r\n{\r\n  &quot;hash_md5&quot;: &quot;799c748fe5fbc1900594d6d79bb9f803&quot;,\r\n  &quot;assertions&quot;: [\r\n    {\r\n      &quot;engine&quot;:  &quot;A&quot;,\r\n      &quot;malware&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;engine&quot;:  &quot;B&quot;,\r\n      &quot;malware&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;engine&quot;:  &quot;C&quot;,\r\n      &quot;malware&quot;: &quot;3&quot;\r\n    }]\r\n}\r\n```\r\nI saw a post in which they used transpose and map, but I couldn&#39;t get it to work since I would like to keep the other fields.",
        "link": "https://stackoverflow.com/questions/70831992/parse-json-with-jq-and-zip-two-arrays",
        "title": "Parse json with jq and zip two arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643094766,
                "post_id": 70844334,
                "comment_id": 125241942,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3660611,
                    "reputation": 1475,
                    "user_id": 3050530,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/OkoBy.png?s=256",
                    "display_name": "arxoft",
                    "link": "https://stackoverflow.com/users/3050530/arxoft"
                },
                "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": 1643108994,
                "post_id": 70844334,
                "comment_id": 125247090,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643126159,
                "post_id": 70844334,
                "comment_id": 125254111,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643124884,
                "last_edit_date": 1643124884,
                "creation_date": 1643094977,
                "answer_id": 70844684,
                "question_id": 70844334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do a multi-value replacement with `jq` to prevent overwriting the same file again and again.\r\n\r\n    #!/usr/bin/bash\r\n    NAME=name\r\n    DEV=dev\r\n    PROD=prod\r\n    echo -e &quot;$(jq --arg name $NAME --arg dev $DEV --arg prod $PROD &#39;.parameters.name = ($name) | .parameters.dev = ($dev) | .parameters.prod = ($prod)&#39; env.json)&quot; &gt; env.json",
                "title": "jq doesn&#39;t inject value into the json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643095988,
                "creation_date": 1643095988,
                "answer_id": 70844863,
                "question_id": 70844334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is not needed to read the JSON template from a file if it never changes. The template is incorporated in the `jq` filter script that takes a `--null-input` or `-n`, so it can directly be written to the output file, without saving to an intermediate temporary file.\r\n\r\n```sh\r\nNAME=&#39;www foo&#39; PROD=&#39;prod bar thing&#39; DEV=&#39;stuff for dev baz&#39;\r\njq -n --arg name &quot;$NAME&quot; --arg prod &quot;$PROD&quot; --arg dev &quot;$DEV&quot; \\\r\n  &#39;{&quot;parameters&quot;:{&quot;name&quot;:$name,&quot;dev&quot;:$dev,&quot;prod&quot;:$prod}}&#39; &gt; env.json\r\n```\r\n\r\n`cat env.json`:\r\n```json\r\n{\r\n  &quot;parameters&quot;: {\r\n    &quot;name&quot;: &quot;www foo&quot;,\r\n    &quot;dev&quot;: &quot;stuff for dev baz&quot;,\r\n    &quot;prod&quot;: &quot;prod bar thing&quot;\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "jq doesn&#39;t inject value into the json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643109760,
                "creation_date": 1643109760,
                "answer_id": 70847773,
                "question_id": 70844334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Other answers are great, but I made a dumb mistake which I want to point out. In these commands,\r\n\r\n```\r\n  ENVJSON=$(cat env.json)\r\n  jq &#39;.parameters.name = $val&#39; --arg val $NAME &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt; env.json\r\n  jq &#39;.parameters.prod = $val&#39; --arg val $PROD &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt; env.json\r\n  jq &#39;.parameters.dev = $val&#39;  --arg val $DEV  &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt; env.json\r\n```\r\n\r\nI was using the same input in each of these commands, not the updated one. So I changed it to:\r\n\r\n```\r\n  jq &#39;.parameters.name = $val&#39; --arg val $NAME &lt;&lt;&lt;&quot;$(cat env.json)&quot; &gt; env.json\r\n  jq &#39;.parameters.prod = $val&#39; --arg val $PROD &lt;&lt;&lt;&quot;$(cat env.json)&quot; &gt; env.json\r\n  jq &#39;.parameters.dev = $val&#39;  --arg val $DEV  &lt;&lt;&lt;&quot;$(cat env.json)&quot; &gt; env.json\r\n```\r\n\r\nand it worked.",
                "title": "jq doesn&#39;t inject value into the json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1643186069,
                "last_edit_date": 1643186069,
                "creation_date": 1643123123,
                "answer_id": 70850977,
                "question_id": 70844334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that the last use of `jq` is given the original `env.json` rather than the one modified by the earlier uses of `jq`. We can solve this problem by only invoking `jq` once (getting a performance boost as a bonus).\r\n\r\n```sh\r\nENVJSON=&quot;$( cat env.json )&quot;\r\njq \\\r\n   --arg name &quot;$NAME&quot; \\\r\n   --arg prod &quot;$PROD&quot; \\\r\n   --arg dev  &quot;$DEV&quot;  \\\r\n&#39;\r\n  .parameters.name = $name |\r\n  .parameters.prod = $prod |\r\n  .parameters.dev  = $dev\r\n&#39; &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt;env.json\r\n```\r\n\r\nIf the variables are exported, we can even use\r\n\r\n```sh\r\njq &#39;\r\n  .parameters.name = env.name |\r\n  .parameters.prod = env.prod |\r\n  .parameters.dev  = env.dev\r\n&#39;\r\n```\r\n\r\n---\r\n\r\nBy the way, `sponge` is great for reading and writing from the same file.\r\n\r\n```sh\r\njq &#39;...&#39; env.json | sponge env.json\r\n```",
                "title": "jq doesn&#39;t inject value into the json file"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1643186069,
        "creation_date": 1643092584,
        "last_edit_date": 1643094320,
        "question_id": 70844334,
        "body_markdown": "I have json file `env.json` having following content:\r\n\r\n```\r\n{\r\n  &quot;parameters&quot;: {\r\n    &quot;name&quot;: &quot;www&quot;,\r\n    &quot;dev&quot; : &quot;&quot;,\r\n    &quot;prod&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\nNow I want to inject values of `dev` and `prod` via a bash script using `jq`. Here&#39;s the code:\r\n\r\n```\r\n  ENVJSON=$(cat env.json)\r\n  jq &#39;.parameters.name = $val&#39; --arg val $NAME &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt; env.json\r\n  jq &#39;.parameters.prod = $val&#39; --arg val $PROD &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt; env.json\r\n  jq &#39;.parameters.dev = $val&#39;  --arg val $DEV  &lt;&lt;&lt;&quot;$ENVJSON&quot; &gt; env.json\r\n```\r\n\r\nWhen I run this, I get the values of $NAME and $DEV correctly injected into the JSON file. But the $PROD value doesn&#39;t get injected for the `prod` index. It stays empty. Looks like this is an issue with the middle line.\r\n\r\nIf I swap the last two lines, then yes, the middle line doesn&#39;t work.\r\n\r\nWhat could be wrong here?  \r\n\r\n___\r\n\r\nI also tried appending `&amp;&amp; sleep 1` at end of each `jq` command, no luck.",
        "link": "https://stackoverflow.com/questions/70844334/jq-doesnt-inject-value-into-the-json-file",
        "title": "jq doesn&#39;t inject value into the json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643101369,
                "last_edit_date": 1643101369,
                "creation_date": 1643099951,
                "answer_id": 70845621,
                "question_id": 70845507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to `reduce` the input using `to_entries`\r\n\r\n~~~sh\r\njq -s &#39;\r\n  add | reduce to_entries[] as $e ({}; .[$e.value.tags[]] += [$e.key])\r\n&#39; *.json\r\n~~~\r\nwhich would give you a structure like this\r\n~~~json\r\n{\r\n  &quot;A&quot;: [\r\n    &quot;object1&quot;,\r\n    &quot;object2&quot;,\r\n    &quot;object4&quot;\r\n  ],\r\n  &quot;B&quot;: [\r\n    &quot;object2&quot;\r\n  ],\r\n  &quot;C&quot;: [\r\n    &quot;object3&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/qj8_iMHFS4)\r\n\r\nTo then convert this into your desired structure, append another `to_entries`\r\n\r\n~~~sh\r\njq -s &#39;\r\n  add | reduce to_entries[] as $e ({}; .[$e.value.tags[]] += [$e.key])\r\n  | to_entries | map({tag:.key, objects:.value})\r\n&#39; *.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;tag&quot;: &quot;A&quot;,\r\n    &quot;objects&quot;: [\r\n      &quot;object1&quot;,\r\n      &quot;object2&quot;,\r\n      &quot;object4&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;tag&quot;: &quot;B&quot;,\r\n    &quot;objects&quot;: [\r\n      &quot;object2&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;tag&quot;: &quot;C&quot;,\r\n    &quot;objects&quot;: [\r\n      &quot;object3&quot;\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/k0TFOPpAKm)",
                "title": "Extract tags from json datastructures using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643101369,
        "creation_date": 1643099351,
        "question_id": 70845507,
        "body_markdown": "I have multiple JSON files like these:\r\n\r\n    {\r\n      &quot;object1&quot;: {\r\n        &quot;tags&quot;: [&quot;A&quot;],\r\n\r\n        &quot;something&quot;: &quot;else&quot;,\r\n        &quot;other&quot;: &quot;data&quot;\r\n      },\r\n      &quot;object2&quot;: {\r\n        &quot;tags&quot;: [&quot;A&quot;, &quot;B&quot;]\r\n      }\r\n    }\r\n\r\nand\r\n\r\n\r\n    {\r\n      &quot;object3&quot;: {\r\n        &quot;tags&quot;: [&quot;C&quot;],\r\n\r\n        &quot;something&quot;: &quot;else&quot;,\r\n        &quot;other&quot;: &quot;data&quot;\r\n      },\r\n      &quot;object4&quot;: {\r\n        &quot;tags&quot;: [&quot;A&quot;]\r\n      }\r\n    }\r\n\r\nIt is guaranteed that keys of all the objects (`object1` - `object4`) are unique, across all files.\r\n\r\nI need to generate a different json file, that would be an array of used `tag`s, and each tag would have extra information which `object`s use it:\r\n\r\n    [\r\n      { \r\n        &quot;tag&quot;: &quot;A&quot;,\r\n        &quot;objects&quot;: [&quot;object1&quot;, &quot;object2&quot;, &quot;object4&quot;]\r\n      },\r\n      { \r\n        &quot;tag&quot;: &quot;B&quot;,\r\n        &quot;objects&quot;: [&quot;object2&quot;]\r\n      },\r\n      { \r\n        &quot;tag&quot;: &quot;C&quot;,\r\n        &quot;objects&quot;: [&quot;object3&quot;]\r\n      }\r\n    ]\r\n\r\nOrder of tags in this output array is irrelevant.\r\n\r\nSo far I have: `cat *.json | jq -s add | jq &#39;[.[].tags[]] | unique&#39;` which gives me array of tags used across all files, but I don&#39;t quite know how to get the list of `object`s for those tags. I suspect that this is not a right approach, because I am loosing some information (source of the tag) during this transformation.\r\n\r\nAny help with `jq` expressions would be appreciated. Thank you.\r\n",
        "link": "https://stackoverflow.com/questions/70845507/extract-tags-from-json-datastructures-using-jq",
        "title": "Extract tags from json datastructures using jq"
    },
    {
        "tags": [
            "json",
            "string",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1643129911,
                "post_id": 70852574,
                "comment_id": 125255892,
                "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": 2,
                "creation_date": 1643130445,
                "post_id": 70852574,
                "comment_id": 125256096,
                "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": 1643168569,
                "post_id": 70852574,
                "comment_id": 125266385,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1714207862,
                "last_edit_date": 1714207862,
                "creation_date": 1662925690,
                "answer_id": 73682240,
                "question_id": 70852574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your input is actually well-formed and valid JSON:\r\n\r\n```json\r\n{\r\n  &quot;A&quot;: &quot;a&quot;,\r\n  &quot;re&quot;: {\r\n    &quot;jok/pok&quot;: &quot;^20.0&quot;,\r\n    &quot;sok/dok&quot;: &quot;^23.0&quot;,\r\n    &quot;jok/ssd&quot;: &quot;^32.0&quot;\r\n  }\r\n}\r\n```\r\n\r\nThe following jq program generates the output as required:\r\n\r\n```\r\n.re |= with_entries(select(.key|startswith(&quot;jok&quot;)).value += &quot;-dev&quot;)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;A&quot;: &quot;a&quot;,\r\n  &quot;re&quot;: {\r\n    &quot;jok/pok&quot;: &quot;^20.0-dev&quot;,\r\n    &quot;sok/dok&quot;: &quot;^23.0&quot;,\r\n    &quot;jok/ssd&quot;: &quot;^32.0-dev&quot;\r\n  }\r\n}\r\n```\r\n",
                "title": "jq to update key:value objects with matching strings at the begining"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1714207862,
        "creation_date": 1643129484,
        "question_id": 70852574,
        "body_markdown": "I need to update below json file values where key matches a substring.\r\nsample.json\r\n\r\n    {\r\n    &quot;A&quot;: &quot;a&quot;\r\n    &quot;re&quot;: {\r\n      &quot;jok/pok&quot;: ^20.0,\r\n      &quot;sok/dok&quot;: ^23.0,\r\n      &quot;jok/ssd&quot;: ^32.0\r\n    }\r\n    }\r\n\r\nnow I need to append `-dev` to those key/values where key starts with `jok`.\r\n\r\n    {\r\n    &quot;A&quot;: &quot;a&quot;\r\n    &quot;re&quot;: {\r\n      &quot;jok/pok&quot;: ^20.0-dev,\r\n      &quot;sok/dok&quot;: ^23.0,\r\n      &quot;jok/ssd&quot;: ^32.0-dev\r\n    }\r\n    }\r\n\r\nI know I&#39;m missing some really simple solution.\r\n \r\n",
        "link": "https://stackoverflow.com/questions/70852574/jq-to-update-keyvalue-objects-with-matching-strings-at-the-begining",
        "title": "jq to update key:value objects with matching strings at the begining"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1643726361,
                "last_edit_date": 1643726361,
                "creation_date": 1643143005,
                "answer_id": 70855343,
                "question_id": 70855081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found a way:\r\n\r\n```jq\r\n( OBJECT | .[ keys_unsorted[] | select( FILTER ) ] ) |= TRANSFORM\r\n```\r\n\r\nAs applied to the example:\r\n\r\n```jq\r\n( .o | .[ keys_unsorted[] | select( tonumber? ) ] ) |= . + 100\r\n```\r\n\r\n[Demo](https://jqplay.org/s/bNVONxP89E) on jqplay\r\n\r\nSame idea, but using `to_entries` to give the query access to both the key and the value:\r\n\r\n```jq\r\n( .o | .[ to_entries[] | select( .key | tonumber? ) | .key ] ) |= . + 100\r\n```\r\n\r\n[Demo](https://jqplay.org/s/az3Nkvp7Td) on jqplay",
                "title": "`query |= transform` for modifying object values based on keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1643726361,
        "creation_date": 1643141439,
        "last_edit_date": 1643142501,
        "question_id": 70855081,
        "body_markdown": "If you wanted to modify the value of some elements of an array, you could use something like\r\n\r\n```jq\r\nARRAY |= map( if FILTER then TRANSFORM else . end )\r\n```\r\n\r\nor\r\n\r\n```jq\r\nARRAY[] |= if FILTER then TRANSFORM else . end\r\n```\r\n\r\nHowever, I like the `QUERY |= TRANSFORM` pattern.\r\n\r\n```jq\r\n( ARRAY[] | select( FILTER ) ) |= TRANSFORM\r\n```\r\n\r\nAll of these work for objects too (using `map_value` instead of `map`), as long as the filter only depends on the element values. But what if the filter depended on the key? I can come up with solutions such as\r\n\r\n```jq\r\nOBJECT |= with_entries( if .key | FILTER then .value |= TRANSFORM else . end )\r\n```\r\n\r\nBut is there a way get something of the form `QUERY |= TRANSFORM` in that scenario?\r\n\r\n---\r\n\r\n**Concrete example**\r\n\r\n```jq\r\n.o |= with_entries( if .key | tonumber? // false then .value |= . + 100 else . end )\r\n```\r\n\r\n```json\r\n{\r\n  &quot;o&quot;: {\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: 4,\r\n    &quot;1&quot;: 3,\r\n    &quot;2&quot;: 4\r\n  }\r\n}\r\n```\r\n\r\n```json\r\n{\r\n  &quot;o&quot;: {\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: 4,\r\n    &quot;1&quot;: 103,\r\n    &quot;2&quot;: 104\r\n  }\r\n}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/dsB_umZ5zU) on jqplay",
        "link": "https://stackoverflow.com/questions/70855081/query-transform-for-modifying-object-values-based-on-keys",
        "title": "`query |= transform` for modifying object values based on keys"
    },
    {
        "tags": [
            "json",
            "jq",
            "text-manipulation"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643164490,
                "creation_date": 1643164490,
                "answer_id": 70858080,
                "question_id": 70858064,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there. Just set the new context and use the same technique again:\r\n~~~sh\r\njq &#39;.result[] | {name,type,plan: .plan | {name,id}}&#39; some-json-file\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;somewebsite.com&quot;,\r\n  &quot;type&quot;: &quot;secondary&quot;,\r\n  &quot;plan&quot;: {\r\n    &quot;name&quot;: &quot;Enterprise Website&quot;,\r\n    &quot;id&quot;: &quot;77777777777777777777777777&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/bIePUljlxc)\r\n\r\nNote: You don&#39;t need to `cat` the input, `jq` accepts the filename as parameter.",
                "title": "Using JQ to filter JSON data at different levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1643164490,
        "creation_date": 1643164309,
        "question_id": 70858064,
        "body_markdown": "I have this JSON data : **some-json-file** which contains the following\r\n\r\n    {\r\n      &quot;result&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1234567812345678&quot;,\r\n          &quot;name&quot;: &quot;somewebsite.com&quot;,\r\n          &quot;status&quot;: &quot;active&quot;,\r\n          &quot;type&quot;: &quot;secondary&quot;,\r\n          &quot;activated_on&quot;: &quot;2021-12-12T15:44:40.444433Z&quot;,\r\n          &quot;plan&quot;: {\r\n            &quot;id&quot;: &quot;77777777777777777777777777&quot;,\r\n            &quot;name&quot;: &quot;Enterprise Website&quot;,\r\n            &quot;is_subscribed&quot;: true,\r\n            &quot;legacy_id&quot;: &quot;enterprise&quot;,\r\n            &quot;externally_managed&quot;: true\r\n          }\r\n        }\r\n      ],\r\n      &quot;result_info&quot;: {\r\n        &quot;page&quot;: 1,\r\n        &quot;total_pages&quot;: 1\r\n      },\r\n      &quot;success&quot;: true,\r\n      &quot;messages&quot;: []\r\n    }\r\n\r\nAnd I am trying to get this filtered output from it using **jq**\r\n\r\n    {\r\n      &quot;name&quot;: &quot;somewebsite.com&quot;,\r\n      &quot;type&quot;: &quot;secondary&quot;,\r\n      &quot;plan&quot;: {\r\n        &quot;name&quot;: &quot;Enterprise Website&quot;,\r\n        &quot;id&quot;: &quot;77777777777777777777777777&quot;\r\n      }\r\n    }\r\n\r\nBut I can&#39;t figure out how to do that.\r\n\r\nI can filter the first layer of labels like this \r\n\r\n    cat some-json-file | jq &#39;.result[] | {name,type,plan}&#39;\r\n\r\nWhich gets me this output\r\n\r\n    {\r\n      &quot;name&quot;: &quot;somewebsite.com&quot;,\r\n      &quot;type&quot;: &quot;secondary&quot;,\r\n      &quot;plan&quot;: {\r\n        &quot;id&quot;: &quot;77777777777777777777777777&quot;,\r\n        &quot;name&quot;: &quot;Enterprise Website&quot;,\r\n        &quot;is_subscribed&quot;: true,\r\n        &quot;legacy_id&quot;: &quot;enterprise&quot;,\r\n        &quot;externally_managed&quot;: true\r\n      }\r\n    }\r\n\r\nThat gets me close, but I can&#39;t further filter the child labels under **.plan** so that I see just the **.name** and **.id**.\r\n\r\nAny ideas? Thanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70858064/using-jq-to-filter-json-data-at-different-levels",
        "title": "Using JQ to filter JSON data at different levels"
    },
    {
        "tags": [
            "c#",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1036128,
                    "reputation": 17713,
                    "user_id": 1043380,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/2388aa1beb9ac75029a5b4fafec11eec?s=256&d=identicon&r=PG",
                    "display_name": "gunr2171",
                    "link": "https://stackoverflow.com/users/1043380/gunr2171"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643204350,
                "post_id": 70864270,
                "comment_id": 125276722,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6585542,
                    "reputation": 3323,
                    "user_id": 5088381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bbefe3492e0fd87b0b8de54164e09a7c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mwe",
                    "link": "https://stackoverflow.com/users/5088381/mwe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643204522,
                "post_id": 70864270,
                "comment_id": 125276809,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3838048,
                    "reputation": 39193,
                    "user_id": 3181933,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/eQpds.jpg?s=256",
                    "display_name": "ProgrammingLlama",
                    "link": "https://stackoverflow.com/users/3181933/programmingllama"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643204904,
                "post_id": 70864270,
                "comment_id": 125276968,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20868603,
                    "reputation": 516,
                    "user_id": 15329087,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-itUWarugviQ/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnQHXWsxWY2_UagJYz3kKQZZ3-2nw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Ahmad Masalha",
                    "link": "https://stackoverflow.com/users/15329087/ahmad-masalha"
                },
                "reply_to_user": {
                    "account_id": 3838048,
                    "reputation": 39193,
                    "user_id": 3181933,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/eQpds.jpg?s=256",
                    "display_name": "ProgrammingLlama",
                    "link": "https://stackoverflow.com/users/3181933/programmingllama"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643205389,
                "post_id": 70864270,
                "comment_id": 125277202,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3838048,
                    "reputation": 39193,
                    "user_id": 3181933,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/eQpds.jpg?s=256",
                    "display_name": "ProgrammingLlama",
                    "link": "https://stackoverflow.com/users/3181933/programmingllama"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643205480,
                "post_id": 70864270,
                "comment_id": 125277247,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20868603,
                    "reputation": 516,
                    "user_id": 15329087,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-itUWarugviQ/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnQHXWsxWY2_UagJYz3kKQZZ3-2nw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Ahmad Masalha",
                    "link": "https://stackoverflow.com/users/15329087/ahmad-masalha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643205897,
                "post_id": 70864270,
                "comment_id": 125277418,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643205209,
                "creation_date": 1643205209,
                "answer_id": 70864517,
                "question_id": 70864270,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ask yourself: &quot;why are there quotes _around_ the query argument?&quot;\r\n\r\nThat&#39;s because you&#39;re adding an _escaped_ quote. The idea here is that writing `\\&quot;` in the &quot;code&quot; renders `&quot;` in the output.\r\n\r\nYou&#39;re issue is that you need to do this one layer down. You don&#39;t want to _render_ the quotes inside the query _in C#_, you want to render the quotes _in the jq.exe application_. So you need to work backwards.\r\n\r\n* Inside jp.exe, the value should be `&quot;`.\r\n* This means that whatever we send to it (the command line arguments) need to be escaped: `\\&quot;`.\r\n* This means that however we _render_ the command line arguments will need to produce `\\&quot;`, and because both of those characters require escaping, you do it.\r\n\r\n```\r\njq = jq.Replace(&quot;\\&quot;&quot;, &quot;\\\\\\&quot;&quot;);\r\n```\r\nThis says &quot;replace all double quotes in my c# string with a backslash and quote&quot; (essentially, just add a backslash before all quotes).\r\n\r\nThis turns a c# string rendered as `abc &quot;def&quot; ghi` into `abc \\&quot;def\\&quot; ghi`, which is the format your command line argument is expecting.",
                "title": "C# quoted string within a quoted string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643205209,
        "creation_date": 1643204133,
        "last_edit_date": 1643204687,
        "question_id": 70864270,
        "body_markdown": "I&#39;m trying to run JQ on a JSON file, through command line from C# code.\r\nOne of the required arguments includes spaces and quotation marks, so it is itself wrapped between quotation mark. However, this argument is formatted from another string which includes quotations marks:\r\n\r\n    var jq =  &quot;.data[] | select(.name==\\&quot;mytest\\&quot;) | .id == \\&quot;adxd\\&quot;&quot;;\r\n    var psi = new ProcessStartInfo\r\n            {\r\n                FileName = _exe,\r\n                Arguments = $&quot;-c \\&quot;{jq}\\&quot; {_settings.JSONFile}&quot;,\r\n            };\r\n\r\nHowever, the arguments turn out as:\r\n\r\n    -c &quot;.data[] | select(.name==&quot;mytest&quot;) | .id == &quot;adxd&quot;&quot; json.json\r\nWhich of course is wrong.\r\nIt should turn out as:\r\n\r\n    -c &quot;.data[] | select(.name==\\&quot;mytest\\&quot;) | .id == \\&quot;adxd\\&quot;&quot; json.json\r\n\r\nHow can I ensure that the the arguments are decoded correctly with the correct &#39;levels&#39; of quotation marks? ",
        "link": "https://stackoverflow.com/questions/70864270/c-quoted-string-within-a-quoted-string",
        "title": "C# quoted string within a quoted string"
    },
    {
        "tags": [
            "json",
            "linux",
            "unique",
            "slice",
            "jq"
        ],
        "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": 1643207823,
                "post_id": 70864798,
                "comment_id": 125278385,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23864598,
                    "reputation": 41,
                    "user_id": 17867124,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJx3gaToSP--LTKRJdOLxjKs3Hd_c4Z0yh0K4Ucd=k-s256",
                    "display_name": "Ilan",
                    "link": "https://stackoverflow.com/users/17867124/ilan"
                },
                "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": 2,
                "creation_date": 1643209168,
                "post_id": 70864798,
                "comment_id": 125278981,
                "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": 1643209357,
                "post_id": 70864798,
                "comment_id": 125279069,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1643214603,
                "post_id": 70864798,
                "comment_id": 125281538,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23864598,
                    "reputation": 41,
                    "user_id": 17867124,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJx3gaToSP--LTKRJdOLxjKs3Hd_c4Z0yh0K4Ucd=k-s256",
                    "display_name": "Ilan",
                    "link": "https://stackoverflow.com/users/17867124/ilan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643219188,
                "post_id": 70864798,
                "comment_id": 125283609,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643221079,
                "last_edit_date": 1643221079,
                "creation_date": 1643220772,
                "answer_id": 70868320,
                "question_id": 70864798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One could use\r\n\r\n```jq\r\n.add |= [ range(length) as $i | .[$i] | .rownum = $i+1 ]\r\n```\r\n\r\n[Demo](https://jqplay.org/s/rd2GvmatgH) on jqplay\r\n\r\nor\r\n\r\n```jq\r\n.add |= ( to_entries | map( .value.rownum = .key+1 | .value ) )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/PpITMsgN0Y) on jqplay",
                "title": "Split/Slice large JSON sort free Unique by few columns &amp; add additional element using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643241133,
                "creation_date": 1643241133,
                "answer_id": 70871680,
                "question_id": 70864798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses two general-purpose filters - one for enumerating, and the second for a sort-free and stream-oriented variant of `unique_by`:\r\n```\r\n  # counting from 1\r\n  def enumerate(s; $key): foreach s as $x (0; .+1; {($key): .} + $x);\r\n\r\n  # emits a stream of the first item, $x, in the stream for which f assumes the value ($x|f).\r\n  def uniques_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      | if .[$t] | has($y) then . else .[$t][$y] = $x end )\r\n    | .[][] ;\r\n\r\n  .add |= [enumerate(uniques_by(.[]; {city,state,postal}); &quot;rownum&quot;)]\r\n  | del(.add) as $object\r\n  | (.add|_nwise($size) | (&quot;\\t&quot;, $object + {add:.} ))\r\n```",
                "title": "Split/Slice large JSON sort free Unique by few columns &amp; add additional element using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1643241133,
        "creation_date": 1643206331,
        "last_edit_date": 1643214648,
        "question_id": 70864798,
        "body_markdown": "per https://stackoverflow.com/questions/70627447/split-slice-large-json-using-jq we are able to successfully slice huge input file into smaller chunk of data based on array size.. \r\n\r\nWould like to add a new json element to it with incrementing sequence number based on length of original array along with filter/unique per few columns. \r\n\r\nInput:\r\n\r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,\r\n     &quot;country&quot;:&quot;US&quot;,\r\n     &quot;name&quot;:&quot;ABC&quot;,\r\n     &quot;number&quot;:&quot;9828&quot;,\r\n     &quot;add&quot;: [\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;1&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;2&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;3&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77831&quot;},\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;4&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77832&quot;}\r\n     ]\r\n    }\r\n\r\nExpected Output:\r\nAfter performing adding of additional key \r\n\r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,\r\n     &quot;country&quot;:&quot;US&quot;,\r\n     &quot;name&quot;:&quot;ABC&quot;,\r\n     &quot;number&quot;:&quot;9828&quot;,\r\n     &quot;add&quot;: [\r\n         {&quot;rownum&quot;:1,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;1&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},\r\n         {&quot;rownum&quot;:2,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;2&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},\r\n         {&quot;rownum&quot;:3,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;3&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77831&quot;},\r\n         {&quot;rownum&quot;:4,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;4&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77832&quot;}\r\n     ]\r\n    }\r\n\r\nAfter performing filter (by State, City, Postal) and slice per array size of 2\r\n\r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,\r\n     &quot;country&quot;:&quot;US&quot;,\r\n     &quot;name&quot;:&quot;ABC&quot;,\r\n     &quot;number&quot;:&quot;9828&quot;,\r\n     &quot;add&quot;: [\r\n         {&quot;rownum&quot;:1,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;1&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},\r\n         {&quot;rownum&quot;:3,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;3&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77831&quot;}]}\r\n    \r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,\r\n     &quot;country&quot;:&quot;US&quot;,\r\n     &quot;name&quot;:&quot;ABC&quot;,\r\n     &quot;number&quot;:&quot;9828&quot;,\r\n     &quot;add&quot;: [\r\n         {&quot;rownum&quot;:4,&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;4&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77832&quot;}\r\n     ]\r\n    }\r\n\r\nBelow sample was used to filer/unique by few columns, not attaining optimal performance\r\n\r\n    input.json jq -r --argjson size 2 &#39; .add |= unique_by({city,state,postal}) | del(.add) as $object | (.add|_nwise($size) | (&quot;\\t&quot;, $object + {add:.} )) &#39; | awk &#39; /^\\t/ {fn++; next} { print &gt;&gt; &quot;part-&quot; fn &quot;.json&quot;}&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70864798/split-slice-large-json-sort-free-unique-by-few-columns-add-additional-element",
        "title": "Split/Slice large JSON sort free Unique by few columns &amp; add additional element using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1643278844,
                "creation_date": 1643278844,
                "answer_id": 70876892,
                "question_id": 70876734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since it&#39;s an array, we&#39;ll need some sort of loop, use\r\n```\r\n.containerDefinitions[] += { &quot;image&quot;:&quot;IMAGE1_NAME&quot; }\r\n```\r\n\r\nTo add `{ &quot;image&quot;:&quot;IMAGE1_NAME&quot; }` on each item in the `containerDefinitions` key\r\n\r\n\r\n----------\r\n\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/A9StRkIJMA)",
                "title": "Add a new element to a JSON array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643278889,
                "creation_date": 1643278889,
                "answer_id": 70876903,
                "question_id": 70876734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input JSON is not formatted correctly. Assuming your actual input is\r\n~~~json\r\n{\r\n  &quot;taskDefinitionArn&quot;: &quot;arn:aws&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;dev-service&quot;,\r\n      &quot;cpu&quot;: 0,\r\n      &quot;portMappings&quot;: [\r\n        {\r\n          &quot;containerPort&quot;: 8080,\r\n          &quot;hostPort&quot;: 8080,\r\n          &quot;protocol&quot;: &quot;tcp&quot;\r\n        }\r\n      ],\r\n      &quot;essential&quot;: true,\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Hi, EMC!!&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\nwhich would mean that `containerDefinitions` is an array, not an object. Thus, to add an object **as another array item**, go with\r\n~~~sh\r\njq &#39;.containerDefinitions += [{&quot;image&quot;:&quot;&lt;IMAGE1_NAME&gt;&quot;}]&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;taskDefinitionArn&quot;: &quot;arn:aws&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;dev-service&quot;,\r\n      &quot;cpu&quot;: 0,\r\n      &quot;portMappings&quot;: [\r\n        {\r\n          &quot;containerPort&quot;: 8080,\r\n          &quot;hostPort&quot;: 8080,\r\n          &quot;protocol&quot;: &quot;tcp&quot;\r\n        }\r\n      ],\r\n      &quot;essential&quot;: true,\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Hi, EMC!!&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;image&quot;: &quot;&lt;IMAGE1_NAME&gt;&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/gBDZ9C7SDb)\r\n\r\nIf, however, you wanted to merge that object into one of the array items (if to all of them, use `[]` instead of `[0]`), go with\r\n~~~sh\r\njq &#39;.containerDefinitions[0] += {&quot;image&quot;:&quot;&lt;IMAGE1_NAME&gt;&quot;}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;taskDefinitionArn&quot;: &quot;arn:aws&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;dev-service&quot;,\r\n      &quot;cpu&quot;: 0,\r\n      &quot;portMappings&quot;: [\r\n        {\r\n          &quot;containerPort&quot;: 8080,\r\n          &quot;hostPort&quot;: 8080,\r\n          &quot;protocol&quot;: &quot;tcp&quot;\r\n        }\r\n      ],\r\n      &quot;essential&quot;: true,\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;message&quot;,\r\n          &quot;value&quot;: &quot;Hi, EMC!!&quot;\r\n        }\r\n      ],\r\n      &quot;image&quot;: &quot;&lt;IMAGE1_NAME&gt;&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/g4S9KTETeM)\r\n",
                "title": "Add a new element to a JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1643278889,
        "creation_date": 1643278186,
        "question_id": 70876734,
        "body_markdown": "I have a json as mentioned in the first section and i want to add an element(&quot;image&quot;: &quot;&lt;IMAGE1_NAME&gt;&quot;,) in the json as specified in the expected output. \r\n\r\nI tired to use jq like this:\r\n\r\n    &#39;.containerDefinitions += {&quot;operation&quot;:&quot;delete&quot;}&#39;\r\nbut this seem to not work. can anyone help me the jq command to achieve the result i want.\r\n\r\n    {\r\n    &quot;taskDefinitionArn&quot;: &quot;arn:aws&quot;,\r\n    &quot;containerDefinitions&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;dev-service&quot;,\r\n            &quot;cpu&quot;: 0,\r\n            &quot;portMappings&quot;: [\r\n                {\r\n                    &quot;containerPort&quot;: 8080,\r\n                    &quot;hostPort&quot;: 8080,\r\n                    &quot;protocol&quot;: &quot;tcp&quot;\r\n                }\r\n            ],\r\n            &quot;essential&quot;: true,\r\n            &quot;environment&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;message&quot;,\r\n                    &quot;value&quot;: &quot;Hi, EMC!!&quot;\r\n                }\r\n            ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n\r\n\r\nexpected output :\r\n\r\n    {\r\n    &quot;taskDefinitionArn&quot;: &quot;arn:aws:ecs:us-west-2:619867110810:task-definition/emc-dev-backend:30&quot;,\r\n    &quot;containerDefinitions&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;dev-service&quot;,\r\n            &quot;image&quot;: &quot;&lt;IMAGE1_NAME&gt;&quot;,\r\n            &quot;cpu&quot;: 0,\r\n            &quot;portMappings&quot;: [\r\n                {\r\n                    &quot;containerPort&quot;: 8080,\r\n                    &quot;hostPort&quot;: 8080,\r\n                    &quot;protocol&quot;: &quot;tcp&quot;\r\n                }\r\n            ],\r\n            &quot;essential&quot;: true,\r\n            &quot;environment&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;message&quot;,\r\n                    &quot;value&quot;: &quot;Hi, EMC!!&quot;\r\n                }\r\n            ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70876734/add-a-new-element-to-a-json-array-using-jq",
        "title": "Add a new element to a JSON array using jq"
    },
    {
        "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": 1643368054,
                "post_id": 70880255,
                "comment_id": 125326682,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9162277,
                    "reputation": 15895,
                    "user_id": 6813231,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/gy8Sg.jpg?s=256",
                    "display_name": "Alexei",
                    "link": "https://stackoverflow.com/users/6813231/alexei"
                },
                "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": 1643374235,
                "post_id": 70880255,
                "comment_id": 125328855,
                "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": 1643376636,
                "post_id": 70880255,
                "comment_id": 125329756,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643358913,
                "last_edit_date": 1643358913,
                "creation_date": 1643294535,
                "answer_id": 70880511,
                "question_id": 70880255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Seems you need stringify, then you can use **tostring** such as\r\n```\r\njq -r &#39;.issues[] \r\n        | [.key ,.component, .textRange[], (.flows[].locations[]|tostring), .status] \r\n        | @csv&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/V74iqcH7h7)&lt;/kbd&gt;",
                "title": "Array in array: jq: error (at test.json:91): object ({&quot;locations...) is not valid in a csv row"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1647941109,
                "last_edit_date": 1647941109,
                "creation_date": 1643295747,
                "answer_id": 70880826,
                "question_id": 70880255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you want the objects in `.flows[].locations[]` to be **appended** as separate rows?\r\n~~~sh\r\njq -r &#39;.issues[]\r\n  | .key as $key | ., .flows[].locations[]\r\n  | [$key ,.component, .textRange[], .status]\r\n  | @csv\r\n&#39;\r\n~~~\r\n~~~\r\n&quot;1&quot;,&quot;my_component&quot;,35,35,46,84,&quot;OPEN&quot;\r\n&quot;2&quot;,&quot;my component 2&quot;,34,34,3,52,\r\n&quot;2&quot;,&quot;some component&quot;,35,35,3,50,\r\n&quot;2&quot;,&quot;another component&quot;,36,36,3,71,\r\n&quot;2&quot;,&quot;Alarm.java&quot;,37,37,3,76,\r\n&quot;2&quot;,&quot;Alarm.java&quot;,38,38,3,50,\r\n~~~\r\n[Demo](https://jqplay.org/s/zjnAYuIY-r)",
                "title": "Array in array: jq: error (at test.json:91): object ({&quot;locations...) is not valid in a csv row"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1647941109,
        "creation_date": 1643293574,
        "last_edit_date": 1643374581,
        "question_id": 70880255,
        "body_markdown": "I want to convert json to csv. \r\n\r\nI use tool &quot;jq&quot; for this\r\n\r\n[jq][1]\r\n\r\n\r\nHere json\r\n\r\n \r\n\r\n     {\r\n      &quot;total&quot;: 2040,\r\n      &quot;created_at&quot;: &quot;2022-01-27T09:50:59+0200&quot;,\r\n      &quot;project&quot;: &quot;my project&quot;,\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;key_1&quot;,\r\n          &quot;component&quot;: &quot;my_component&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 35,\r\n            &quot;endLine&quot;: 35,\r\n            &quot;startOffset&quot;: 46,\r\n            &quot;endOffset&quot;: 84\r\n          },\r\n          &quot;flows&quot;: [],\r\n          &quot;status&quot;: &quot;OPEN&quot;,\r\n          &quot;creationDate&quot;: &quot;2022-01-24T06:42:58+0200&quot;,\r\n          &quot;updateDate&quot;: &quot;2022-01-24T06:42:58+0200&quot;,\r\n          &quot;type&quot;: &quot;BUG&quot;,\r\n          &quot;scope&quot;: &quot;MAIN&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;key2&quot;,\r\n          &quot;component&quot;: &quot;my component 2&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 34,\r\n            &quot;endLine&quot;: 34,\r\n            &quot;startOffset&quot;: 3,\r\n            &quot;endOffset&quot;: 52\r\n          },\r\n          &quot;flows&quot;: [\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;some component&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 35,\r\n                    &quot;endLine&quot;: 35,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 50\r\n                  },\r\n                  &quot;msg&quot;: &quot;any  message&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;another component&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 36,\r\n                    &quot;endLine&quot;: 36,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 71\r\n                  },\r\n                  &quot;msg&quot;: &quot;message custom&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;Alarm.java&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 37,\r\n                    &quot;endLine&quot;: 37,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 76\r\n                  },\r\n                  &quot;msg&quot;: &quot;message number 2&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;Alarm.java&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 38,\r\n                    &quot;endLine&quot;: 38,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 50\r\n                  },\r\n                  &quot;msg&quot;: &quot;message number 3&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;my_key3&quot;,\r\n          &quot;component&quot;: &quot;my component 3&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 548,\r\n            &quot;endLine&quot;: 548,\r\n            &quot;startOffset&quot;: 14,\r\n            &quot;endOffset&quot;: 15\r\n          },\r\n          &quot;flows&quot;: [],\r\n          &quot;status&quot;: &quot;OPEN&quot;,\r\n          &quot;creationDate&quot;: &quot;2022-01-21T17:16:06+0200&quot;,\r\n          &quot;updateDate&quot;: &quot;2022-01-21T17:16:06+0200&quot;,\r\n          &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n          &quot;scope&quot;: &quot;LOCAL&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nAnd here convert to csv only some flelds:\r\n\r\n    jq -r &#39;.issues[] | [.key ,.component, .textRange[], .status] | @csv&#39; test.json\r\n\r\n\r\nAnd here result:\r\n\r\n    &quot;1&quot;,&quot;my_component&quot;,35,35,46,84,&quot;OPEN&quot;\r\n    &quot;2&quot;,&quot;my component 2&quot;,34,34,3,52,\r\n\r\n\r\nNice. \r\n\r\nNow I want to convert field (array)  **flows**. I try this:\r\n\r\n    jq -r &#39;.issues[] | [.key ,.component, .textRange[], .flows[], .status] | @csv&#39; test.json\r\n\r\n\r\nAnd here result:\r\n\r\n    &quot;1&quot;,&quot;my_component&quot;,35,35,46,84,&quot;OPEN&quot;\r\n    jq: error (at test.json:91): object ({&quot;locations...) is not valid in a csv row\r\n\r\n\r\nHow fix convert? Array (**locations**) in array (**flows**) \r\n\r\n\r\nThe result must be like this (first line are fields&#39;s names):\r\n\r\n    total,created_at,project,issues,key,component,textRange,startLine,endLine,startOffset,endOffset,status,creationDate,updateDate,type,scope,flows,locations,component,textRange,startLine,endLine,startOffset,endOffset,msg\r\n    2040,2022-01-27T09:50:59+0200,my project,,key_1,my_component,,35,35,46,84,OPEN,2022-01-24T06:42:58+0200,2022-01-24T06:42:58+0200,BUG,MAIN,,,,,,,,,\r\n    ,,,,key2,my component 2,,34,34,3,52,,,,,,,,some component,,35,35,3,50,any  message\r\n    ,,,,,,,,,,,,,,,,,,another component,,36,36,3,71,message custom\r\n    ,,,,,,,,,,,,,,,,,,Alarm.java,,37,37,3,76,message number 2\r\n    ,,,,,,,,,,,,,,,,,,Alarm.java,,38,38,3,50,message number 3\r\n    ,,,,my_key3,my component 3,,548,548,14,15,OPEN,2022-01-21T17:16:06+0200,2022-01-21T17:16:06+0200,CODE_SMELL,LOCAL,,,,,,,,,\r\n\r\n\r\nIt&#39;s important to show values not only `issues` but also fields&#39;s values: `total,created_at,project`\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70880255/array-in-array-jq-error-at-test-json91-object-locations-is-not-vali",
        "title": "Array in array: jq: error (at test.json:91): object ({&quot;locations...) is not valid in a csv row"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643319822,
                "creation_date": 1643319822,
                "answer_id": 70886145,
                "question_id": 70885782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Right on the money with the good ol&#39; select tool, since you need data from an arbitrary index. I fumbled a bit before I unwrapped the inner array that gets piped to my select.\r\n\r\n`jq -r &#39;.[] | [{id: .id, identifier: .identifier | .[] | select(.system.value | contains(&quot;urn:oid:1.3.6.1.4.1.19126.3&quot;)) | .value.value }]&#39;` \r\n\r\nStill new to jq myself, so any feedback is welcome.",
                "title": "jq: filter array and project other field"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643319970,
                "creation_date": 1643319970,
                "answer_id": 70886176,
                "question_id": 70885782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This approach uses `first` to get the first result, in case there is more than one array item matching the criteria.\r\n\r\n~~~sh\r\njq --arg v &quot;urn:oid:1.3.6.1.4.1.19126.3&quot; &#39;\r\n  map(.identifier |= first(.[] | select(.system.value == $v).value.value))\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;9f0e27fe-3b8f-4857-8e1d-e57e7a3f4c31&quot;,\r\n    &quot;identifier&quot;: &quot;Y3454867M&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/pguO4lrIHY)",
                "title": "jq: filter array and project other field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1643319970,
        "creation_date": 1643317839,
        "question_id": 70885782,
        "body_markdown": "Here my document:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;9f0e27fe-3b8f-4857-8e1d-e57e7a3f4c31&quot;,\r\n    &quot;identifier&quot;: [\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:1.3.6.1.4.1.19126.3&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;Y3454867M&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.10.2&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;108505134&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI need to pick only `.identifier[where .system.value == &quot;urn:oid:1.3.6.1.4.1.19126.3&quot;]` and project `.identifier.value.value`.\r\n\r\nDesired output:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;9f0e27fe-3b8f-4857-8e1d-e57e7a3f4c31&quot;,\r\n    &quot;identifier&quot;: &quot;Y3454867M&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve been playing with `map` and `select` but I don&#39;t quite figure out what&#39;s the right way to get it.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70885782/jq-filter-array-and-project-other-field",
        "title": "jq: filter array and project other field"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq",
            "transpose"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643320329,
                "post_id": 70886182,
                "comment_id": 125315682,
                "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": 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": 1643321076,
                "post_id": 70886182,
                "comment_id": 125315915,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643320404,
                "creation_date": 1643320404,
                "answer_id": 70886253,
                "question_id": 70886182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input file entirely fits into your memory, use `--slurp` and `reduce`:\r\n~~~sh\r\njq --slurp &#39;reduce .[] as $k ({}; .[$k.dni] = $k.id)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;78081181&quot;: &quot;06b6751f-5125-4e48-b588-fcc8ff56004f&quot;,\r\n  &quot;77834021&quot;: &quot;4bdcf9e9-4a3e-4e13-963d-1270b94955dc&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/XRL6R33t6S)",
                "title": "jq: flip or transpose to dict object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643320836,
                "creation_date": 1643320836,
                "answer_id": 70886329,
                "question_id": 70886182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Each object can be transformed using the `{ (.value) : (.key) }` formula. Use `-s` to read all the objects to an array, merge all the objects into one with `add`.\r\n\r\n    jq  -s &#39;[ .[] | { (.dni) : (.id) } ] | add&#39; doc.json",
                "title": "jq: flip or transpose to dict object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643341126,
                "last_edit_date": 1643341126,
                "creation_date": 1643327521,
                "answer_id": 70887292,
                "question_id": 70886182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To reduce memory requirements to a minimum (at least within the realm of jq):\r\n```\r\njq -n &#39;reduce inputs as $in ({}; . + ($in | {(.dni): .id}))&#39; input.jstream\r\n```",
                "title": "jq: flip or transpose to dict object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1643462949,
        "creation_date": 1643319989,
        "last_edit_date": 1643462949,
        "question_id": 70886182,
        "body_markdown": "Here my document:\r\n\r\n```lang-json\r\n{\r\n   &quot;id&quot;:&quot;06b6751f-5125-4e48-b588-fcc8ff56004f&quot;,\r\n   &quot;dni&quot;:&quot;78081181&quot;\r\n}\r\n{\r\n   &quot;id&quot;:&quot;4bdcf9e9-4a3e-4e13-963d-1270b94955dc&quot;,\r\n   &quot;dni&quot;:&quot;77834021&quot;\r\n}\r\n```\r\n\r\nI need to get:\r\n\r\n```\r\n{\r\n&quot;78081181&quot;: &quot;06b6751f-5125-4e48-b588-fcc8ff56004f&quot;,\r\n&quot;77834021&quot;: &quot;4bdcf9e9-4a3e-4e13-963d-1270b94955dc&quot;\r\n}\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70886182/jq-flip-or-transpose-to-dict-object",
        "title": "jq: flip or transpose to dict object"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1643321592,
                "creation_date": 1643321592,
                "answer_id": 70886443,
                "question_id": 70886385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update `|=` the `names` array by `select`ing only those items that match. `length` applied to a string will output its length counting Unicode codepoints.\r\n\r\n~~~sh\r\njq &#39;.names |= map(select(.name | length &gt; 10))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;names&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Jackson Longfellow&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/N52Ul4xAr1)",
                "title": "How to select jq items where length of key value exceeds a number"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1643346942,
        "creation_date": 1643321234,
        "last_edit_date": 1643346942,
        "question_id": 70886385,
        "body_markdown": "I have this JSON input to JQjq\r\n\r\n```json\r\n{\r\n  &quot;names&quot;: [{\r\n    &quot;name&quot;: &quot;John Smith&quot;\r\n  },{\r\n    &quot;name&quot;: &quot;Jane Doe&quot;\r\n  },{\r\n    &quot;name&quot;: &quot;Jackson Longfellow&quot;\r\n  }]\r\n}\r\n```\r\n\r\nI&#39;d like to use jq to select all the items where the length of the name is &gt; 10 characters.  This means the output would be:\r\n\r\n```json\r\n{\r\n  &quot;names&quot;: [{\r\n    &quot;name&quot;: &quot;Jackson Longfellow&quot;\r\n  }]\r\n}\r\n```\r\n\r\nThe `length` filter only seems to count items in an array.  Is there some other built-in filter to use for this?",
        "link": "https://stackoverflow.com/questions/70886385/how-to-select-jq-items-where-length-of-key-value-exceeds-a-number",
        "title": "How to select jq items where length of key value exceeds a number"
    },
    {
        "tags": [
            "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": 1643364672,
                "post_id": 70891949,
                "comment_id": 125325357,
                "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": 1643364820,
                "post_id": 70891949,
                "comment_id": 125325419,
                "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": 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": 1643364823,
                "post_id": 70891949,
                "comment_id": 125325423,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643365484,
                "last_edit_date": 1643365484,
                "creation_date": 1643365107,
                "answer_id": 70892082,
                "question_id": 70891949,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap(\r\n    select(.identifier?[]?.system.value == &quot;urn:oid:2.16.724.4.9.10.2&quot;) \r\n    | { id, &quot;dni&quot;: .identifier[].value.value }\r\n)\r\n```\r\n\r\nWill generate:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;f3b8c257-9950-45e7-9e79-ace19ec8905e&quot;,\r\n    &quot;dni&quot;: &quot;10839812&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nThe trick here is `.identifier?[]?.system.value` where the `?` will ignore `.identifier` if it&#39;s `null`\r\n\r\n----------\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/BfFzE-1gbk)",
                "title": "jq: where select clause is applied"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643366124,
                "creation_date": 1643366124,
                "answer_id": 70892302,
                "question_id": 70891949,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to deal with the case if `.identifier` is `null`. Here, the `?` operator may help.\r\n\r\n- without selection\r\n~~~sh\r\njq &#39;map({id, dni: (.identifier[]?).value.value})&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/32DHYOH5eM)\r\n\r\n- with selection\r\n~~~sh\r\njq &#39;map({id, dni: (.identifier[]? | select(.system.value == &quot;urn:oid:2.16.724.4.9.10.2&quot;)).value.value})&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/VnOwRKUAuM)\r\n\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;f3b8c257-9950-45e7-9e79-ace19ec8905e&quot;,\r\n    &quot;dni&quot;: &quot;10839812&quot;\r\n  }\r\n]\r\n~~~\r\n",
                "title": "jq: where select clause is applied"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1643366124,
        "creation_date": 1643364546,
        "last_edit_date": 1643364793,
        "question_id": 70891949,
        "body_markdown": "Here my documents:\r\n\r\n```lang-json\r\n[\r\n   {\r\n      &quot;id&quot;:&quot;f3b8c257-9950-45e7-9e79-ace19ec8905e&quot;,\r\n      &quot;identifier&quot;:[\r\n         {\r\n            &quot;system&quot;:{\r\n               &quot;value&quot;:&quot;urn:oid:2.16.724.4.9.10.2&quot;\r\n            },\r\n            &quot;value&quot;:{\r\n               &quot;value&quot;:&quot;10839812&quot;\r\n            }\r\n         }\r\n      ]\r\n   },\r\n   {\r\n      &quot;id&quot;:&quot;f0a1e3ae-826f-4a03-b29e-10ef3bc86ea0&quot;,\r\n      &quot;identifier&quot;:null\r\n   }\r\n]\r\n```\r\n\r\nCurrently, I&#39;m aplying this jq filter:\r\n\r\n```\r\nmap(\r\n    {\r\n        id,\r\n        dni: .identifier[] | (select(.system.value == &quot;urn:oid:1.3.6.1.4.1.19126.3&quot;) | .value.value)\r\n    }\r\n)\r\n```\r\n\r\nHowever, I&#39;m getting this message:\r\n\r\n&gt; jq: error (at practitioner-mongoexport.json:146715): Cannot iterate over null (null)\r\n\r\nAs you can guess, problem arises processing second object where `.identifier: null`.\r\n\r\nI&#39;ve tried with that:\r\n\r\n```\r\nmap(\r\n    {\r\n        id,\r\n        dni: select(.identifier) | .identifier[] | (select(.system.value == &quot;urn:oid:1.3.6.1.4.1.19126.3&quot;) | .value.value)\r\n    }\r\n)\r\n```\r\n\r\nI&#39;ve also tried with:\r\n\r\n```\r\nmap(\r\n    select(.identifier) |\r\n    {\r\n        id,\r\n        dni: .identifier[] | (select(.system.value == &quot;urn:oid:1.3.6.1.4.1.19126.3&quot;) | .value.value)\r\n    }\r\n)\r\n```\r\n\r\nThen result is `[]`.\r\n\r\nI don&#39;t quite figure out what I&#39;m doing wrong.\r\n\r\nMy desired output would be:\r\n\r\n```lang-json\r\n[\r\n   {\r\n      &quot;id&quot;:&quot;f3b8c257-9950-45e7-9e79-ace19ec8905e&quot;,\r\n      &quot;dni&quot;: &quot;10839812&quot;\r\n   }\r\n]\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70891949/jq-where-select-clause-is-applied",
        "title": "jq: where select clause is applied"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1643373015,
                "creation_date": 1643373015,
                "answer_id": 70893823,
                "question_id": 70893769,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Store the `nodes` array&#39;s elements in a variable for reference. Storing the elements rather than the whole array automatically also iterates for the next step. Then, just compose your desired output objects using the `nodes` array item as object `{$node}` added to the looked-up object in `.vars[$node]`.\r\n\r\n~~~sh\r\njq &#39;.nodes[] as $node | {$node} + .vars[$node]&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;node&quot;: &quot;node1&quot;,\r\n  &quot;field1&quot;: &quot;a&quot;,\r\n  &quot;field2&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;node&quot;: &quot;node2&quot;,\r\n  &quot;field1&quot;: &quot;x&quot;,\r\n  &quot;field2&quot;: &quot;y&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/b-lMFTYK5v)",
                "title": "jq: Include the lookup key as a field in the result value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1643376827,
        "creation_date": 1643372689,
        "last_edit_date": 1643376827,
        "question_id": 70893769,
        "body_markdown": "I have a JSON object of the following form:\r\n\r\n```\r\n{\r\n  &quot;vars&quot;: {\r\n    &quot;node1&quot;: {&quot;field1&quot;: &quot;a&quot;, &quot;field2&quot;: &quot;b&quot;},\r\n    &quot;node2&quot;: {&quot;field1&quot;: &quot;x&quot;, &quot;field2&quot;: &quot;y&quot;}\r\n    &quot;unrelated&quot;: {&quot;blah&quot;: &quot;blah&quot;}\r\n  },\r\n  &quot;nodes&quot;: [&quot;node1&quot;, &quot;node2&quot;]\r\n}\r\n```\r\n\r\nNow, I can get the fields per node (excluding `unrelated`) using the following `jq` expression:\r\n\r\n```\r\n.vars[.nodes[]]\r\n```\r\n\r\n*Output:*\r\n```\r\n{\r\n  &quot;field1&quot;: &quot;a&quot;,\r\n  &quot;field2&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;field1&quot;: &quot;x&quot;,\r\n  &quot;field2&quot;: &quot;y&quot;\r\n}\r\n```\r\n\r\nMy question is, how do I include the `vars` key as a field in the output, i.e.\r\n\r\n```\r\n{\r\n  &quot;node&quot;: &quot;node1&quot;,\r\n  &quot;field1&quot;: &quot;a&quot;,\r\n  &quot;field2&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;node&quot;: &quot;node2&quot;,\r\n  &quot;field1&quot;: &quot;x&quot;,\r\n  &quot;field2&quot;: &quot;y&quot;\r\n}\r\n```\r\n\r\nThe name of the key (`node` in the example) is not important.\r\n\r\nBased on [this post](https://remysharp.com/drafts/jq-recipes) I found an approximate solution:\r\n\r\n```\r\n.vars | to_entries | map_values(.value + {node: .key})[]\r\n```\r\n\r\nwhich outputs\r\n\r\n```\r\n{\r\n  &quot;field1&quot;: &quot;a&quot;,\r\n  &quot;field2&quot;: &quot;b&quot;,\r\n  &quot;node&quot;: &quot;node1&quot;\r\n}\r\n{\r\n  &quot;field1&quot;: &quot;x&quot;,\r\n  &quot;field2&quot;: &quot;y&quot;,\r\n  &quot;node&quot;: &quot;node2&quot;\r\n}\r\n{\r\n  &quot;blah&quot;: &quot;blah&quot;,\r\n  &quot;node&quot;: &quot;unrelated&quot;\r\n}\r\n```\r\n\r\nBut it still includes the unrelated field which is shouldn&#39;t.",
        "link": "https://stackoverflow.com/questions/70893769/jq-include-the-lookup-key-as-a-field-in-the-result-value",
        "title": "jq: Include the lookup key as a field in the result value"
    },
    {
        "tags": [
            "json",
            "csv",
            "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": 2,
                "creation_date": 1643381066,
                "post_id": 70894977,
                "comment_id": 125331654,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9162277,
                    "reputation": 15895,
                    "user_id": 6813231,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/gy8Sg.jpg?s=256",
                    "display_name": "Alexei",
                    "link": "https://stackoverflow.com/users/6813231/alexei"
                },
                "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": 1,
                "creation_date": 1643386004,
                "post_id": 70894977,
                "comment_id": 125333716,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643389164,
                "creation_date": 1643389164,
                "answer_id": 70897411,
                "question_id": 70894977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this for starters\r\n~~~sh\r\njq -r &#39;\r\n  .issues[]\r\n  | (.flows |= first), (.flows[1:][] | {flows:.})\r\n  | [\r\n      .key, .component, (\r\n        .textRange | null, .startLine, .endLine, .startOffset, .endOffset\r\n      ), .status, .type, .scope, (\r\n        .flows.locations[]? // {} | null, null, .component, (\r\n          .textRange | null, .startLine, .endLine, .startOffset, .endOffset\r\n        ), .msg\r\n      )\r\n    ]\r\n  | join(&quot;,&quot;)\r\n&#39;\r\n~~~\r\n~~~\r\nkey_1,my_component,,1,11,111,1111,OPEN,BUG,MAIN,,,,,,,,,\r\nkey2,my component 2,,2,22,222,2222,,,,,,some component,,35,35,3,50,any  message\r\n,,,,,,,,,,,,another component,,36,36,3,71,message custom\r\n,,,,,,,,,,,,Alarm.java,,37,37,3,76,message number 2\r\n,,,,,,,,,,,,Alarm.java,,38,38,3,50,message number 3\r\nmy_key3,my component 3,,548,548,14,15,OPEN,CODE_SMELL,LOCAL,,,,,,,,,\r\n~~~\r\n[Demo](https://jqplay.org/s/_W1BlQ4-R7)\r\n\r\nNote: You may want to use `@csv` instead of `join(&quot;,&quot;)` but it&#39;ll wrap the strings in quotes.\r\n\r\nAlso, to add a header line, prepend the filters before the `join`/`@csv` with a simple array of strings.",
                "title": "Can&#39;t parse array in another array - jq: error (at test.issues.json:100): object ({&quot;component...) is not valid in a csv row"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643389164,
        "creation_date": 1643378497,
        "question_id": 70894977,
        "body_markdown": "File test.issues.json\r\n\r\n    {\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;key_1&quot;,\r\n          &quot;component&quot;: &quot;my_component&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 1,\r\n            &quot;endLine&quot;: 11,\r\n            &quot;startOffset&quot;: 111,\r\n            &quot;endOffset&quot;: 1111\r\n          },\r\n          &quot;flows&quot;: [],\r\n          &quot;status&quot;: &quot;OPEN&quot;,\r\n          &quot;type&quot;: &quot;BUG&quot;,\r\n          &quot;scope&quot;: &quot;MAIN&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;key2&quot;,\r\n          &quot;component&quot;: &quot;my component 2&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 2,\r\n            &quot;endLine&quot;: 22,\r\n            &quot;startOffset&quot;: 222,\r\n            &quot;endOffset&quot;: 2222\r\n          },\r\n          &quot;flows&quot;: [\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;some component&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 35,\r\n                    &quot;endLine&quot;: 35,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 50\r\n                  },\r\n                  &quot;msg&quot;: &quot;any  message&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;another component&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 36,\r\n                    &quot;endLine&quot;: 36,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 71\r\n                  },\r\n                  &quot;msg&quot;: &quot;message custom&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;Alarm.java&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 37,\r\n                    &quot;endLine&quot;: 37,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 76\r\n                  },\r\n                  &quot;msg&quot;: &quot;message number 2&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;locations&quot;: [\r\n                {\r\n                  &quot;component&quot;: &quot;Alarm.java&quot;,\r\n                  &quot;textRange&quot;: {\r\n                    &quot;startLine&quot;: 38,\r\n                    &quot;endLine&quot;: 38,\r\n                    &quot;startOffset&quot;: 3,\r\n                    &quot;endOffset&quot;: 50\r\n                  },\r\n                  &quot;msg&quot;: &quot;message number 3&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;my_key3&quot;,\r\n          &quot;component&quot;: &quot;my component 3&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 548,\r\n            &quot;endLine&quot;: 548,\r\n            &quot;startOffset&quot;: 14,\r\n            &quot;endOffset&quot;: 15\r\n          },\r\n          &quot;flows&quot;: [],\r\n          &quot;status&quot;: &quot;OPEN&quot;,\r\n          &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n          &quot;scope&quot;: &quot;LOCAL&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI need to convert to csv. \r\n\r\nI try this:\r\n\r\n    jq -r &#39;.issues[] | [.key,.component,.textRange[], (.flows[].locations[]), .status, .type, .scope] | @csv&#39; test.issues.json\r\n\r\nBut I get error:\r\n\r\n\r\n    &quot;key_1&quot;,&quot;my_component&quot;,1,11,111,1111,&quot;OPEN&quot;,&quot;BUG&quot;,&quot;MAIN&quot;\r\n    jq: error (at test.issues.json:100): object ({&quot;component...) is not valid in a csv row\r\n\r\n\r\nI need to get smt like this:\r\n\r\n    key,component,textRange,startLine,endLine,startOffset,endOffset,status,type,scope,flows,locations,component,textRange,startLine,endLine,startOffset,endOffset,msg\r\n    key_1,my_component,,1,11,111,1111,OPEN,BUG,MAIN,,,,,,,,,\r\n    key2,my component 2,,2,22,222,2222,,,,,,some component,,35,35,3,50,any  message\r\n    ,,,,,,,,,,,,another component,,36,36,3,71,message custom\r\n    ,,,,,,,,,,,,Alarm.java,,37,37,3,76,message number 2\r\n    ,,,,,,,,,,,Alarm.java,,38,38,3,50,message number 3\r\n    my_key3,my component 3,,548,548,14,15,OPEN,CODE_SMELL,LOCAL,,,,,,,,,\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70894977/cant-parse-array-in-another-array-jq-error-at-test-issues-json100-object",
        "title": "Can&#39;t parse array in another array - jq: error (at test.issues.json:100): object ({&quot;component...) is not valid in a csv row"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643535550,
                "last_edit_date": 1643535550,
                "creation_date": 1643499265,
                "answer_id": 70910657,
                "question_id": 70910624,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nYou are probably looking for this filter pattern, which iterates over the array elements `.[]`, filters for matching items using `select` and outputs the field `id` as raw text due to the `-r` flag.\r\n~~~sh\r\njq -r &#39;.[] | select( … ).id&#39;\r\n~~~\r\n\r\nWhat the expression within your `select` filter should be, depends on how you define &quot;having values containing [a] string&quot;.\r\n\r\nIf the search string has to match the last part of a slash-delimited list of substrings (as your sample data might suggest), you could split up the target string using `/` (or `split`), extract the `last` item and use `IN` to apply the test to a stream of search strings. ([Demo](https://jqplay.org/s/0efQaHAK6r))\r\n~~~\r\nIN(.profile.extensions[].name / &quot;/&quot; | last; &quot;AAAAAA&quot;, &quot;BBBBBB&quot;)\r\n~~~\r\n\r\nIf the slashes should not be considered specially (i.e. a search string could also contain slashes) and if a search string simply appearing at the end of the target string is a match, then you can use `endswith` to test it and `any` to prevent multiple matches for the same `id` if several `name`s within the same iterated object end with a given search string. ([Demo](https://jqplay.org/s/ma-xC4HsSp))\r\n~~~\r\n[.profile.extensions[].name | endswith(&quot;AAAAAA&quot;, &quot;BBBBBB&quot;)] | any\r\n~~~\r\n\r\nIf, however, the search string is allowed to appear *anywhere* in the `name`, just change `endswith` to `contains`. ([Demo](https://jqplay.org/s/_PiiwglIiS))\r\n~~~\r\n[.profile.extensions[].name | contains(&quot;AAAAAA&quot;, &quot;BBBBBB&quot;)] | any\r\n~~~\r\n\r\n---\r\n\r\nRegarding your update which altered the output to include the matching search string, and your additional [comment](https://stackoverflow.com/questions/70910624/find-object-id-when-key-value-in-nested-array-has-given-string/70910657?noredirect=1#comment125361655_70910657) stating that the target string is indeed a slash-separated list, the approach now is as follows:\r\n\r\nIn order to test *and* output the search string, i.e. to use *and* to reference it again, we need to store it in a variable (using `$s` here), which has to happen outside the `select` filter in order to have its scope reach until the output reference.\r\n~~~sh\r\njq -r &#39;.[] | (&quot;AAAAAA&quot;, &quot;BBBBBB&quot;) as $s\r\n  | select(IN(.profile.extensions[].name / &quot;/&quot; | last; $s))\r\n  | &quot;\\(.id) \\($s)&quot;\r\n&#39;\r\n~~~\r\n~~~\r\n00001 AAAAAA\r\n00002 BBBBBB\r\n~~~\r\n[Demo](https://jqplay.org/s/-42b4uCl9U)\r\n",
                "title": "find object id when key value in nested array has given string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643535550,
        "creation_date": 1643498962,
        "last_edit_date": 1643534112,
        "question_id": 70910624,
        "body_markdown": "Input json is:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;00001&quot;,\r\n        &quot;profile&quot;: {\r\n          &quot;extensions&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/somepath1...../AAAAAA&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;/somepath2...../xxxxxx&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;00002&quot;,\r\n        &quot;profile&quot;: {\r\n          &quot;extensions&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/somepath1...../zzzzzz&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;/somepath2...../BBBBBB&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;00003&quot;,\r\n        &quot;profile&quot;: {\r\n          &quot;extensions&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/somepath1...../yyyyyy&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;00004&quot;,\r\n        &quot;profile&quot;: {\r\n          &quot;extensions&quot;: []\r\n        }\r\n      }\r\n    ]\r\n\r\nI need to find id of object having .profile.extensions[].name having values containing string AAAAAA or BBBBBB.\r\n\r\nExpected output for above json example would be:\r\n\r\n    00001 AAAAAA \r\n    00002 BBBBBB\r\n\r\nBecause in the first one the is AAAAAA and in second BBBBBB",
        "link": "https://stackoverflow.com/questions/70910624/find-object-id-when-key-value-in-nested-array-has-given-string",
        "title": "find object id when key value in nested array has given string"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643538324,
                "post_id": 70913725,
                "comment_id": 125362330,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643538521,
                "creation_date": 1643538521,
                "answer_id": 70913773,
                "question_id": 70913725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are creating the headers inside the iteration. Pull them up front\r\n~~~sh\r\n[&quot;key&quot;,&quot;component&quot;, &quot;textRange&quot;],\r\n(.issues[] | [.key,.component, .textRange[]])\r\n| @csv\r\n~~~\r\n~~~\r\n&quot;key&quot;,&quot;component&quot;,&quot;textRange&quot;\r\n&quot;key_1&quot;,&quot;my_component&quot;,1,11,111,1111\r\n&quot;key2&quot;,&quot;my component 2&quot;,2,22,222,2222\r\n&quot;my_key3&quot;,&quot;my component 3&quot;,548,548,14,15\r\n~~~\r\n[Demo](https://jqplay.org/s/6sazNT-Jqn)",
                "title": "duplicate headers after convert to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1643538521,
        "creation_date": 1643538149,
        "question_id": 70913725,
        "body_markdown": "In json file:\r\n\r\n    {\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;key_1&quot;,\r\n          &quot;component&quot;: &quot;my_component&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 1,\r\n            &quot;endLine&quot;: 11,\r\n            &quot;startOffset&quot;: 111,\r\n            &quot;endOffset&quot;: 1111\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;key2&quot;,\r\n          &quot;component&quot;: &quot;my component 2&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 2,\r\n            &quot;endLine&quot;: 22,\r\n            &quot;startOffset&quot;: 222,\r\n            &quot;endOffset&quot;: 2222\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;my_key3&quot;,\r\n          &quot;component&quot;: &quot;my component 3&quot;,\r\n          &quot;textRange&quot;: {\r\n            &quot;startLine&quot;: 548,\r\n            &quot;endLine&quot;: 548,\r\n            &quot;startOffset&quot;: 14,\r\n            &quot;endOffset&quot;: 15\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI want to convert to csv and add headers.\r\n\r\nI try this:\r\n\r\n    jq -r &#39;.issues[] | [&quot;key&quot;,&quot;component&quot;, &quot;textRange&quot;], [.key,.component, .textRange[]] | @csv&#39; test.issues.json\r\n\r\nResult:\r\n\r\n    &quot;key&quot;,&quot;component&quot;,&quot;textRange&quot;\r\n    &quot;key_1&quot;,&quot;my_component&quot;,1,11,111,1111\r\n    &quot;key&quot;,&quot;component&quot;,&quot;textRange&quot;\r\n    &quot;key2&quot;,&quot;my component 2&quot;,2,22,222,2222\r\n    &quot;key&quot;,&quot;component&quot;,&quot;textRange&quot;\r\n    &quot;my_key3&quot;,&quot;my component 3&quot;,548,548,14,15\r\n\r\nWhy headers are duplicate?",
        "link": "https://stackoverflow.com/questions/70913725/duplicate-headers-after-convert-to-csv",
        "title": "duplicate headers after convert to csv"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643542138,
                "post_id": 70914110,
                "comment_id": 125363023,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643551154,
                "last_edit_date": 1643551154,
                "creation_date": 1643542165,
                "answer_id": 70914180,
                "question_id": 70914110,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [jq](https://stedolan.github.io/jq/)\r\n\r\n```\r\nDROPLETID=&quot;$(curl -X GET \\\r\n  -H &quot;Content-Type: application/json&quot; \\\r\n  -H &quot;Authorization: Bearer $DIGITALOCEAN_TOKEN&quot; \\\r\n  &quot;https://api.digitalocean.com/v2/droplets?tag_name=$TAG&quot; | jq &#39;.droplets[0].id&#39;)&quot;\r\n\r\n```",
                "title": "How can I save in a variable a portion of my cURL GET command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1643551154,
        "creation_date": 1643541593,
        "last_edit_date": 1643550688,
        "question_id": 70914110,
        "body_markdown": "I&#39;m currently trying to setup an automated server on DigitalOcean API, and I need to extract the ID of my server to use it later in a command.\r\n\r\nMy bash command is the following :\r\n\r\n    DROPLETID=&quot;$(curl -X GET \\\r\n      -H &quot;Content-Type: application/json&quot; \\\r\n      -H &quot;Authorization: Bearer $DIGITALOCEAN_TOKEN&quot; \\\r\n      &quot;https://api.digitalocean.com/v2/droplets?tag_name=$TAG&quot; | grep &quot;id&quot;: | sed &#39;s/&quot;id&quot;: //g&#39; | tr -d &#39;\\r&#39;)&quot;\r\n\r\nThe answer for the cURL command is this :\r\n\r\n    {&quot;droplets&quot;:[{&quot;id&quot;:012345678,&quot;name&quot;:&quot;ppg-active&quot;,&quot;memory&quot;:1024,&quot;vcpus&quot;:1,&quot;disk&quot;:25,&quot;locked&quot;:false,&quot;status&quot;:&quot;active&quot;,&quot;kernel&quot;:null,&quot;created_at&quot;:&quot;2022-01-30T10:28:10Z&quot;,&quot;features&quot;:[&quot;droplet_agent&quot;,&quot;private_networking&quot;],&quot;backup_ids&quot;:[],&quot;next_backup_window&quot;:null,&quot;snapshot_ids&quot;:[],&quot;image&quot;:{&quot;id&quot;:01234567,&quot;name&quot;:&quot;18.04 (LTS) x64&quot;,&quot;distribution&quot;:&quot;Ubuntu&quot;,&quot;slug&quot;:&quot;ubuntu-18-04-x64&quot;,&quot;public&quot;:true,&quot;regions&quot;:[&quot;nyc3&quot;,&quot;nyc1&quot;,&quot;sfo1&quot;,&quot;nyc2&quot;,&quot;ams2&quot;,&quot;sgp1&quot;,&quot;lon1&quot;,&quot;ams3&quot;,&quot;fra1&quot;,&quot;tor1&quot;,&quot;sfo2&quot;,&quot;blr1&quot;,&quot;sfo3&quot;],&quot;created_at&quot;:&quot;2022-01-11T21:07:39Z&quot;,&quot;min_disk_size&quot;:15,&quot;type&quot;:&quot;base&quot;,&quot;size_gigabytes&quot;:0.41,&quot;description&quot;:&quot;Ubuntu 18.04 x86 image&quot;,&quot;tags&quot;:[],&quot;status&quot;:&quot;available&quot;},&quot;volume_ids&quot;:[],&quot;size&quot;:{&quot;slug&quot;:&quot;s-1vcpu-1gb&quot;,&quot;memory&quot;:1024,&quot;vcpus&quot;:1,&quot;disk&quot;:25,&quot;transfer&quot;:1.0,&quot;price_monthly&quot;:5.0,&quot;price_hourly&quot;:0.00744,&quot;regions&quot;:[&quot;ams3&quot;,&quot;blr1&quot;,&quot;fra1&quot;,&quot;lon1&quot;,&quot;nyc1&quot;,&quot;nyc3&quot;,&quot;sfo3&quot;,&quot;sgp1&quot;,&quot;tor1&quot;],&quot;available&quot;:true,&quot;description&quot;:&quot;Basic&quot;},&quot;size_slug&quot;:&quot;s-1vcpu-1gb&quot;,&quot;networks&quot;:{&quot;v4&quot;:[{&quot;ip_address&quot;:&quot;XXX.XXX.XXX.XX&quot;,&quot;netmask&quot;:&quot;255.255.240.0&quot;,&quot;gateway&quot;:&quot;XXX.XXX.XXX.X&quot;,&quot;type&quot;:&quot;public&quot;},{&quot;ip_address&quot;:&quot;XX.XXX.XX.X&quot;,&quot;netmask&quot;:&quot;255.255.240.0&quot;,&quot;gateway&quot;:&quot;XX.XXX.X.X&quot;,&quot;type&quot;:&quot;private&quot;}],&quot;v6&quot;:[]},&quot;region&quot;:{&quot;name&quot;:&quot;Frankfurt 1&quot;,&quot;slug&quot;:&quot;fra1&quot;,&quot;features&quot;:[&quot;backups&quot;,&quot;ipv6&quot;,&quot;metadata&quot;,&quot;install_agent&quot;,&quot;storage&quot;,&quot;image_transfer&quot;],&quot;available&quot;:true,&quot;sizes&quot;:[&quot;s-1vcpu-1gb&quot;,&quot;s-1vcpu-1gb-amd&quot;,&quot;s-1vcpu-1gb-intel&quot;,&quot;s-1vcpu-2gb&quot;,&quot;s-1vcpu-2gb-amd&quot;,&quot;s-1vcpu-2gb-intel&quot;,&quot;s-2vcpu-2gb&quot;,&quot;s-2vcpu-2gb-amd&quot;,&quot;s-2vcpu-2gb-intel&quot;,&quot;s-2vcpu-4gb&quot;,&quot;s-2vcpu-4gb-amd&quot;,&quot;s-2vcpu-4gb-intel&quot;,&quot;s-4vcpu-8gb&quot;,&quot;c-2&quot;,&quot;c2-2vcpu-4gb&quot;,&quot;s-4vcpu-8gb-amd&quot;,&quot;s-4vcpu-8gb-intel&quot;,&quot;g-2vcpu-8gb&quot;,&quot;gd-2vcpu-8gb&quot;,&quot;s-8vcpu-16gb&quot;,&quot;m-2vcpu-16gb&quot;,&quot;c-4&quot;,&quot;c2-4vcpu-8gb&quot;,&quot;s-8vcpu-16gb-amd&quot;,&quot;s-8vcpu-16gb-intel&quot;,&quot;m3-2vcpu-16gb&quot;,&quot;g-4vcpu-16gb&quot;,&quot;so-2vcpu-16gb&quot;,&quot;m6-2vcpu-16gb&quot;,&quot;gd-4vcpu-16gb&quot;,&quot;so1_5-2vcpu-16gb&quot;,&quot;m-4vcpu-32gb&quot;,&quot;c-8&quot;,&quot;c2-8vcpu-16gb&quot;,&quot;m3-4vcpu-32gb&quot;,&quot;g-8vcpu-32gb&quot;,&quot;so-4vcpu-32gb&quot;,&quot;m6-4vcpu-32gb&quot;,&quot;gd-8vcpu-32gb&quot;,&quot;so1_5-4vcpu-32gb&quot;,&quot;m-8vcpu-64gb&quot;,&quot;c-16&quot;,&quot;c2-16vcpu-32gb&quot;,&quot;m3-8vcpu-64gb&quot;,&quot;g-16vcpu-64gb&quot;,&quot;so-8vcpu-64gb&quot;,&quot;m6-8vcpu-64gb&quot;,&quot;gd-16vcpu-64gb&quot;,&quot;so1_5-8vcpu-64gb&quot;,&quot;m-16vcpu-128gb&quot;,&quot;c-32&quot;,&quot;c2-32vcpu-64gb&quot;,&quot;m3-16vcpu-128gb&quot;,&quot;m-24vcpu-192gb&quot;,&quot;g-32vcpu-128gb&quot;,&quot;so-16vcpu-128gb&quot;,&quot;m6-16vcpu-128gb&quot;,&quot;gd-32vcpu-128gb&quot;,&quot;m3-24vcpu-192gb&quot;,&quot;g-40vcpu-160gb&quot;,&quot;so1_5-16vcpu-128gb&quot;,&quot;m-32vcpu-256gb&quot;,&quot;gd-40vcpu-160gb&quot;,&quot;so-24vcpu-192gb&quot;,&quot;m6-24vcpu-192gb&quot;,&quot;m3-32vcpu-256gb&quot;,&quot;so1_5-24vcpu-192gb&quot;,&quot;so-32vcpu-256gb&quot;,&quot;m6-32vcpu-256gb&quot;,&quot;so1_5-32vcpu-256gb&quot;]},&quot;tags&quot;:[&quot;mc&quot;],&quot;vpc_uuid&quot;:&quot;ef01391b-98c0-443f-94b2-0c4b94142c5a&quot;}],&quot;links&quot;:{},&quot;meta&quot;:{&quot;total&quot;:1}}\r\n\r\nI only need to save as a variable the first ID the cURL command gives me, the ideal would be that when I enter :\r\n\r\n    echo $DROPLETID\r\n\r\nI get :\r\n\r\n    01234678\r\n\r\nAs you can see in my first command, I tried to grep the ID, and sed it but it doesn&#39;t work.\r\nDoes anyone have any idea ?\r\n\r\nThanks a lot",
        "link": "https://stackoverflow.com/questions/70914110/how-can-i-save-in-a-variable-a-portion-of-my-curl-get-command",
        "title": "How can I save in a variable a portion of my cURL GET command?"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1643591299,
                "post_id": 70920280,
                "comment_id": 125373977,
                "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": 1643602886,
                "post_id": 70920280,
                "comment_id": 125375452,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643597509,
                "creation_date": 1643597509,
                "answer_id": 70920805,
                "question_id": 70920280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the Q has the [tag:jq] tag, it might help to note that jq does (unless otherwise instructed) preserve the ordering of keys.  Apart from the headers, you could do worse than:\r\n\r\n    jq -r &#39;(.[0]|keys_unsorted) as $keys | [.[][$keys[]]] | @csv&#39; output.json ",
                "title": "Moving column to the end of JSON in bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643597509,
        "creation_date": 1643590529,
        "question_id": 70920280,
        "body_markdown": "I&#39;m officially out of options, I tried everything.\r\n\r\nI have a CSV that looks like this \r\n\r\n| from/email | to/email | template_id |\r\n| -------- | -------------- | -------------- |\r\n| me@x.com    | mike@x.com            | 12345            |\r\n| me@x.com   | pete@x.com            | 12345            |\r\n\r\nI run a package called csvkit to convert CSV to JSON like this\r\n\r\n\r\n`csvjson input.csv &gt; output.json`\r\n\r\nand pipe it into curl\r\n\r\n`curl -X POST http://website.com -d @output.json`\r\n\r\nand get a big fat error from the server saying &quot;to/email is required&quot;\r\n\r\nI check my json in Sublime and it&#39;s fine\r\n\r\n```\r\n[\r\n  {\r\n    &quot;from/email&quot;: &quot;me@x.com&quot;,\r\n    &quot;to/0/email&quot;: &quot;mike@x.com&quot;,\r\n    &quot;template_id&quot;: &quot;12345&quot;\r\n  }\r\n]\r\n```\r\nbut I check my json with the terminal jtbl tool to visualize json\r\n\r\n`cat output.json | jtbl`\r\n\r\nand I get\r\n\r\n| from/email | template_id | to/email |\r\n| -------- | -------------- | -------------- |\r\n| me@x.com    | 12345            | mike@x.com            |\r\n| me@x.com   | 12345            | pete@x.com            |\r\n\r\nwhich makes no sense. I have no idea what I&#39;m doing wrong. Is there a way to move my `template_id` column back to the end of the file instead of in the middle?",
        "link": "https://stackoverflow.com/questions/70920280/moving-column-to-the-end-of-json-in-bash",
        "title": "Moving column to the end of JSON in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643622700,
                "last_edit_date": 1643622700,
                "creation_date": 1643621126,
                "answer_id": 70923627,
                "question_id": 70923511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of mapping `pick_address` onto the `address` array\r\n~~~\r\nmap(.address | map(pick_address))\r\n~~~\r\njust apply it directly onto its elements:\r\n~~~\r\nmap(.address[] | pick_address)\r\n~~~\r\n[Demo](https://jqplay.org/s/f-WWqJ--ZD)\r\n\r\nOn a side note: If within `pick_address` the operation `.value` is being applied to *all* fields, then `def pick_address: map_values(.value);` would be equivalent. [Demo](https://jqplay.org/s/1iuHhhuqYR)",
                "title": "jq: avoid nested array mapping"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643621390,
                "creation_date": 1643621390,
                "answer_id": 70923693,
                "question_id": 70923511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Isn&#39;t it simpler to just do this?\r\n\r\n```\r\njq &#39;.[].address[] | [{city: .city.value, state: .state.value, postalCode: .postalCode.value}]&#39;\r\n```",
                "title": "jq: avoid nested array mapping"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643716087,
                "last_edit_date": 1643716087,
                "creation_date": 1643622526,
                "answer_id": 70923944,
                "question_id": 70923511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More dynamic solution without any hardcoded keys, using \r\n- [`with_entries()`][1]\r\n- [`--slurp`][2]\r\n\r\n```none\r\njq --slurp &#39;map(.address[] | with_entries(.value |= .value))&#39;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nWill produce\r\n```json\r\n[\r\n  {\r\n    &quot;city&quot;: &quot;2505300&quot;,\r\n    &quot;state&quot;: &quot;25&quot;,\r\n    &quot;postalCode&quot;: &quot;25132&quot;\r\n  },\r\n  {\r\n    &quot;city&quot;: &quot;2521700&quot;,\r\n    &quot;state&quot;: &quot;25&quot;,\r\n    &quot;postalCode&quot;: &quot;25300&quot;\r\n  }\r\n]\r\n```\r\n\r\nAs you can test in this [online demo](https://jqplay.org/s/jNbRsuipPA)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example27\r\n  [2]: https://stedolan.github.io/jq/manual/",
                "title": "jq: avoid nested array mapping"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1643716247,
        "creation_date": 1643620463,
        "last_edit_date": 1643716247,
        "question_id": 70923511,
        "body_markdown": "Here&#39;s my document:\r\n\r\n```json\r\n{\r\n  &quot;_id&quot;: &quot;a6c8004c-efdc-4462-b474-31df2d417be3&quot;,\r\n  &quot;address&quot;: [\r\n    {\r\n      &quot;city&quot;: {\r\n        &quot;value&quot;: &quot;2505300&quot;\r\n      },\r\n      &quot;state&quot;: {\r\n        &quot;value&quot;: &quot;25&quot;\r\n      },\r\n      &quot;postalCode&quot;: {\r\n        &quot;value&quot;: &quot;25132&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;_id&quot;: &quot;aa4b4ba9-32e3-4384-8cd8-0852bae0029b&quot;,\r\n  &quot;address&quot;: [\r\n    {\r\n      &quot;city&quot;: {\r\n        &quot;value&quot;: &quot;2521700&quot;\r\n      },\r\n      &quot;state&quot;: {\r\n        &quot;value&quot;: &quot;25&quot;\r\n      },\r\n      &quot;postalCode&quot;: {\r\n        &quot;value&quot;: &quot;25300&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nCurrently, I&#39;m applying this JQ filter:\r\n\r\n```\r\ndef pick_address:\r\n    {\r\n        city: .city | .value,\r\n        postalCode: .postalCode | .value,\r\n        state: .state | .value\r\n    };\r\n\r\nmap(.address | map(pick_address))\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nI&#39;m getting this:\r\n\r\n```json\r\n[\r\n  [\r\n    {\r\n      &quot;city&quot;: &quot;2505300&quot;,\r\n      &quot;postalCode&quot;: &quot;25132&quot;,\r\n      &quot;state&quot;: &quot;25&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;city&quot;: &quot;2521700&quot;,\r\n      &quot;postalCode&quot;: &quot;25300&quot;,\r\n      &quot;state&quot;: &quot;25&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nAs you can see, I&#39;m getting above objects with nested array.\r\n\r\nI need to get it as:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;city&quot;: &quot;2505300&quot;,\r\n    &quot;postalCode&quot;: &quot;25132&quot;,\r\n    &quot;state&quot;: &quot;25&quot;\r\n  },\r\n  {\r\n    &quot;city&quot;: &quot;2521700&quot;,\r\n    &quot;postalCode&quot;: &quot;25300&quot;,\r\n    &quot;state&quot;: &quot;25&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nI don&#39;t quite figure out what&#39;s wrong.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70923511/jq-avoid-nested-array-mapping",
        "title": "jq: avoid nested array mapping"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643652359,
                "post_id": 70930666,
                "comment_id": 125392061,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 743248,
                    "reputation": 3258,
                    "user_id": 725932,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/54143122a36bf3aa8d447589e3ab7490?s=256&d=identicon&r=PG",
                    "display_name": "superstator",
                    "link": "https://stackoverflow.com/users/725932/superstator"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643652362,
                "post_id": 70930666,
                "comment_id": 125392063,
                "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": 1643654406,
                "post_id": 70930666,
                "comment_id": 125392856,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1643654627,
                "last_edit_date": 1643654627,
                "creation_date": 1643654221,
                "answer_id": 70931137,
                "question_id": 70930666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the message suggests, there&#39;s no need to remove them; you just need to escape them. For example, byte 0A could be replaced with `\\u000a`. That particular one could also be replaced with `\\n`.\r\n\r\nThis can be used to fix up your input:\r\n\r\n```sh\r\nperl -pe&#39;s/[\\x00-\\x1F]/ sprintf &quot;\\\\u%04X&quot;, ord $&amp; /eg&#39;\r\n```\r\n\r\n[Specifying file to process to Perl one-liner](https://stackoverflow.com/q/41742890/589924)\r\n\r\nSo, you could chain the two.\r\n\r\n```sh\r\nperl -pe&#39;s/[\\x00-\\x1F]/ sprintf &quot;\\\\u%04X&quot;, ord $&amp; /eg&#39; output.json |\r\n   jq .data.gherkin \r\n```\r\n",
                "title": "Using jq to process json with control characters"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643654465,
                "creation_date": 1643654465,
                "answer_id": 70931183,
                "question_id": 70930666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input,\r\n```\r\nsed &#39;s/$/\\\\n/&#39; | tr -d &#39;\\n&#39; | sed -e &#39;s/“/&quot;/g&#39; -e &#39;s/”/&quot;/g&#39; | sed &#39;$ s/\\\\n$//&#39; | jq .\r\n```\r\nyields:\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;gherkin&quot;: &quot;Given user successful login\\nAnd status is &#39;&lt;currentStatus&gt;&#39;\\nWhen user clicks &#39;&lt;nextStatus&gt;’\\nThen status message should change to &#39;&lt;message&gt;&#39;\\n    Examples:\\n        | currentStatus | nextStatus    | message       |\\n        | READY         | PROCESS   | ready to process |\\n        | PROCESS       | COMPLETE  | ready to complete |\\n&quot;\r\n  }\r\n}\r\n```\r\nThe point being that once you have valid JSON, you can use jq or any other JSON-oriented tool.",
                "title": "Using jq to process json with control characters"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1643654627,
        "creation_date": 1643651965,
        "question_id": 70930666,
        "body_markdown": "I have the following json file (output.json) with control characters in it (line break, tabs, etc):\r\n\r\n```\r\n{&quot;data”:{“gherkin”:”Given user successful login\r\nAnd status is &#39;&lt;currentStatus&gt;&#39;\r\nWhen user clicks &#39;&lt;nextStatus&gt;’\r\nThen status message should change to &#39;&lt;message&gt;&#39;\r\n\tExamples:\r\n\t\t| currentStatus | nextStatus    | message       |\r\n\t\t| READY         | PROCESS  \t| ready to process |\r\n\t\t| PROCESS       | COMPLETE \t| ready to complete |\r\n&quot;}}\r\n```\r\nI need to get the value from &quot;gherkin&quot; field and write it into another file keeping the same format as in the original json. \r\n\r\nWhen using jq command:\r\n\r\n```\r\njq .data.gherkin output.json\r\n```\r\n\r\nit throws an error:\r\n```\r\nparse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 9, column 1\r\n```\r\n\r\nIf I remove all control characters from output.json, I will lose the original format of the value of &quot;gherkin&quot; field. Is there a way to accomplish this using jq? \r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/70930666/using-jq-to-process-json-with-control-characters",
        "title": "Using jq to process json with control characters"
    },
    {
        "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": 1643656491,
                "post_id": 70931571,
                "comment_id": 125393661,
                "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": 1643656540,
                "post_id": 70931571,
                "comment_id": 125393683,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15944965,
                    "reputation": 1378,
                    "user_id": 11505813,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fdb185821fb32e77eb5f2b4f36194f51?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Somethingwhatever",
                    "link": "https://stackoverflow.com/users/11505813/somethingwhatever"
                },
                "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": 1643656609,
                "post_id": 70931571,
                "comment_id": 125393722,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15944965,
                    "reputation": 1378,
                    "user_id": 11505813,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fdb185821fb32e77eb5f2b4f36194f51?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Somethingwhatever",
                    "link": "https://stackoverflow.com/users/11505813/somethingwhatever"
                },
                "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": 1643656651,
                "post_id": 70931571,
                "comment_id": 125393734,
                "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": 1643656692,
                "post_id": 70931571,
                "comment_id": 125393750,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643662632,
                "creation_date": 1643662632,
                "answer_id": 70932721,
                "question_id": 70931571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You failed to mention the relevant error:\r\n\r\n```jq\r\njq: error (at &lt;stdin&gt;:17): Cannot index array with string &quot;name&quot;\r\n```\r\n\r\nThe program should be\r\n\r\n```jq\r\n.[].name\r\n```\r\n\r\nBecause you provided an incorrect program to `jq`, it exited earlier than it normally would. This caused the pipe between `curl` and `jq` to close, which cause `curl` to become unable to write to the pipe, which caused `curl` to emit the error message you did provide.\r\n ",
                "title": "How to use jq package to parse name and id from json?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647924548,
                "creation_date": 1647924548,
                "answer_id": 71567045,
                "question_id": 70931571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Demo\r\nhttps://jqplay.org/s/nolGbk3sD1\r\n\r\nUse filter\r\n\r\n```\r\n.[] | .name, .id\r\n```",
                "title": "How to use jq package to parse name and id from json?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1647924548,
        "creation_date": 1643656378,
        "question_id": 70931571,
        "body_markdown": "I have an output that i am getting in this format :- \r\n\r\n    [\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n        &quot;name&quot;: &quot;my-name&quot;,\r\n        &quot;id&quot;: &quot;123&quot;\r\n      },\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n        &quot;name&quot;: &quot;my-name2&quot;,\r\n        &quot;id&quot;: &quot;456&quot;\r\n      },\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.model.FreeStyleProject&quot;,\r\n        &quot;name&quot;: &quot;my-name3&quot;,\r\n        &quot;id&quot;: &quot;789&quot;\r\n      }\r\n    ]\r\n\r\nHow can i parse the name and id using jq? \r\n\r\nI tried to use `[].name` \r\n\r\nbut i get `curl: (23) Failed writing body (320 != 1338)`\r\n\r\nAny help will be appreciated. Thank you.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70931571/how-to-use-jq-package-to-parse-name-and-id-from-json",
        "title": "How to use jq package to parse name and id from json?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1643707276,
                "last_edit_date": 1643707276,
                "creation_date": 1643667418,
                "answer_id": 70933483,
                "question_id": 70933470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq, the `join` builtin, when applied to an object, will pull out the field values and concatenate them using a separator string. The `-r` option ensures that raw text is being output (rather than JSON).\r\n\r\n~~~sh\r\njq -r &#39;.[] | join(&quot;#&quot;)&#39; contents.json\r\n~~~\r\n~~~\r\nsome code#some name#some country#some cost#Some type\r\nsome code#some name#some country#some cost#Some type\r\nsome code#some name#some country#some cost#Some type\r\n~~~\r\n[Demo](https://jqplay.org/s/w9W3KVgHu6)\r\n\r\n---\r\nUpdate: If in the input objects the keys cannot be guaranteed to always be in the same order, just specify their order explicitly using an array.\r\n\r\n~~~sh\r\njq -r &#39;.[] | [.Code,.Name,.Country,.Cost,.Type] | join(&quot;#&quot;)&#39; contents.json\r\n~~~\r\n~~~\r\nsome code#some name#some country#some cost#Some type\r\nsome code#some name#some country#some cost#Some type\r\nsome code#some name#some country#some cost#Some type\r\n~~~\r\n[Demo](https://jqplay.org/s/0Nyy-3Hlr0)\r\n",
                "title": "Print json block from a json array on new line joined by &#39;#&#39;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643799780,
                "last_edit_date": 1643799780,
                "creation_date": 1643670009,
                "answer_id": 70933852,
                "question_id": 70933470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I won&#39;t recommend &lt;a href=&quot;https://miller.readthedocs.io/en/latest/&quot;&gt;Miller&lt;/a&gt; over `jq` for dealing with JSON, but in this case the JSON is compatible and `mlr` powerful features could become handy for further processing of the input:\r\n\r\n``` sh\r\nmlr --ijson --ocsv --ofs &#39;#&#39; unsparsify file.json\r\n```\r\n\r\n``` csv\r\nCode#Name#Country#Cost#Type\r\nsome code#some name#some country#some cost#Some type\r\nsome code#some name#some country#some cost#Some type\r\nsome code#some name#some country#some cost#Some type\r\n```\r\n**notes:**\r\n\r\n* You can avoid displaying the header with the `-N` option\r\n* Unordered or missing keys in the JSON objects won&#39;t break the output\r\n",
                "title": "Print json block from a json array on new line joined by &#39;#&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1643799780,
        "creation_date": 1643667284,
        "last_edit_date": 1643674954,
        "question_id": 70933470,
        "body_markdown": "I have a json array that looks as below -\r\n\r\n    [\r\n      {\r\n        &quot;Code&quot;: &quot;some code&quot;,\r\n        &quot;Name&quot;: &quot;some name&quot;,\r\n        &quot;Country&quot;: &quot;some country&quot;,\r\n        &quot;Cost&quot;: &quot;some cost&quot;,\r\n        &quot;Type&quot;: &quot;Some type&quot;\r\n      },{\r\n        &quot;Code&quot;: &quot;some code&quot;,\r\n        &quot;Name&quot;: &quot;some name&quot;,\r\n        &quot;Country&quot;: &quot;some country&quot;,\r\n        &quot;Cost&quot;: &quot;some cost&quot;,\r\n        &quot;Type&quot;: &quot;Some type&quot;\r\n      },{\r\n        &quot;Code&quot;: &quot;some code&quot;,\r\n        &quot;Name&quot;: &quot;some name&quot;,\r\n        &quot;Country&quot;: &quot;some country&quot;,\r\n        &quot;Cost&quot;: &quot;some cost&quot;,\r\n        &quot;Type&quot;: &quot;Some type&quot;\r\n      }\r\n    ]\r\n\r\nI am trying print each json block on a new line with fields separated by `&#39;#&#39;`\r\n\r\n**Expected output**\r\n\r\n    some code#some name#some country#some cost#some type\r\n    some code#some name#some country#some cost#some type\r\n    some code#some name#some country#some cost#some type\r\n\r\n\r\nI&#39;ve tried the code below which separates the content with `&#39;#&#39;`. However, it merges all blocks into a single line like this - `some code#some name#some country#some cost#some type#some code#some name#some country#some cost#some type#some code#some name#some country#some cost#some type`\r\n\r\n     cat contents.json | sed &#39;s/^[ \\t]*//;s/[ \\t]*$//&#39; | awk  -F &#39;: *&#39; &#39;BEGIN { RS=&quot;,\\n\\&quot;|\\n},&quot; } { gsub(/[\\n\\]\\[\\}]/,&quot;&quot;,$2); if ($2) { printf(&quot;%s#&quot;, $2); } }&#39;\r\n\r\nPlease could someone guide me to et this right?",
        "link": "https://stackoverflow.com/questions/70933470/print-json-block-from-a-json-array-on-new-line-joined-by",
        "title": "Print json block from a json array on new line joined by &#39;#&#39;"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1643711613,
                "creation_date": 1643711613,
                "answer_id": 70939061,
                "question_id": 70938826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do something as naive as:\r\n\r\n    $ jq -r &#39;.content.list[][][1]?&#39; test.json\r\n    John\r\n    Smith\r\n\r\nWhich will extract the second field from the array third nested arrays, and ignore the numeric literal.\r\n\r\nAlternative you could manipulate the data before-hand to make it easier to manipulate afterwards: \r\n\r\n```\r\n$ jq &#39;.content.list | map(map({ (.[0]): .[1] }?) | add)&#39; \r\n[\r\n  {\r\n    &quot;name&quot;: &quot;John&quot;,\r\n    &quot;surname&quot;: &quot;Smith&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\nExtracting the name(s) would be as simple as just using `| [].name`:\r\n\r\n    $ jq &#39;.content.list | map(map({ (.[0]): .[1] }?) | add) | .[].name&#39;\r\n    &quot;John&quot;",
                "title": "JQ - access nested square brackets with fields with no names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1643721313,
        "creation_date": 1643710634,
        "last_edit_date": 1643721313,
        "question_id": 70938826,
        "body_markdown": "trying to access a field in the list array via jq.  The fields doesnt have a name for me to gain access to and extract.  Please assist?\r\n\r\nTrying to extract John and Smith.\r\n\r\n    $ cat test.txt\r\n    {\r\n        &quot;content&quot;: {\r\n            &quot;list&quot;: [\r\n                [\r\n                    [\r\n                        &quot;name&quot;,\r\n                        &quot;John&quot;,\r\n                        123\r\n                    ],\r\n                    [\r\n                        &quot;surname&quot;,\r\n                        &quot;Smith&quot;,\r\n                        345\r\n                    ],\r\n                    1\r\n                ]\r\n            ]\r\n        }\r\n    }\r\n    \r\n    $ jq -r &#39;.content | {name: .&quot;list&quot;}&#39; test.txt\r\n    {\r\n      &quot;name&quot;: [\r\n        [\r\n          [\r\n            &quot;name&quot;,\r\n            &quot;John&quot;,\r\n            123\r\n          ],\r\n          [\r\n            &quot;surname&quot;,\r\n            &quot;Smith&quot;,\r\n            345\r\n          ],\r\n          1\r\n        ]\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/70938826/jq-access-nested-square-brackets-with-fields-with-no-names",
        "title": "JQ - access nested square brackets with fields with no names"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "amazon-cloudfront",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3753628,
                    "reputation": 1752,
                    "user_id": 3120562,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3af077ad10afd25edfe4b406e4143889?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ErnieAndBert",
                    "link": "https://stackoverflow.com/users/3120562/ernieandbert"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643753341,
                "post_id": 70947832,
                "comment_id": 125422750,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1643752168,
                "creation_date": 1643752168,
                "answer_id": 70947979,
                "question_id": 70947832,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Navigate to the items using `.CloudFrontOriginAccessIdentityList.Items[]`, then choose only the matching ones using `select` and output the part you&#39;re interested in. Using the `-r` flag turns the output into raw text (rather than JSON).\r\n~~~sh\r\n… | jq -r &#39;\r\n    .CloudFrontOriginAccessIdentityList.Items[]\r\n    | select(.Comment == &quot;Created for Nackle Shared CF in pprd&quot;).Id\r\n  &#39;\r\n~~~\r\n~~~\r\nE1P6ZIBDB6I6FZ\r\n~~~\r\n[Demo](https://jqplay.org/s/slS_jrvy43)\r\n\r\nTo import the query string into the filter, use the `--arg` option:\r\n~~~sh\r\n… | jq -r --arg q &quot;Created for Nackle Shared CF in pprd&quot; &#39;\r\n    .CloudFrontOriginAccessIdentityList.Items[]\r\n    | select(.Comment == $q).Id\r\n  &#39;\r\n~~~",
                "title": "With AWS cli how do I get the CloudFront OAI ID for one record with a specific name/comment?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1643752168,
        "creation_date": 1643751246,
        "last_edit_date": 1643752160,
        "question_id": 70947832,
        "body_markdown": "In the below output I only want to get the Id of the CloudFront Origin Access ID with the comment ```Created for Nackle Shared CF in pprd```.\r\n\r\nTherefore I want the output to be ``E1P6ZIBDB6I6FZ```.\r\n\r\n\r\n\r\nHere is the command I used to get everything so far:\r\n\r\n```aws cloudfront list-cloud-front-origin-access-identities```\r\n\r\nI have played with jq and grep and can not get it to pull what I want out. I also tried to use --filter but I do not think that works with this CloudFront command.\r\n\r\n\r\n\r\nHere is the output of the command:\r\n```\r\n{\r\n    &quot;CloudFrontOriginAccessIdentityList&quot;: {\r\n        &quot;Items&quot;: [\r\n            {\r\n                &quot;Id&quot;: &quot;E3IQ5CFYM436DX&quot;,\r\n                &quot;S3CanonicalUserId&quot;: &quot;0301338e0173a8fa18a117f8234f7f30ddf87fcf45fcf70412a374414d592bee3eea9697f41d06b284617232122dd&quot;,\r\n                &quot;Comment&quot;: &quot;Created for Nackle Shared CF in qa&quot;\r\n            },\r\n            {\r\n                &quot;Id&quot;: &quot;E1P6ZIBDB6I6FZ&quot;,\r\n                &quot;S3CanonicalUserId&quot;: &quot;c21bc4e37661a49846db7dd6798b25a71ce81decb4f6403b5c6602da6e49f6a831ca3a0f682f87fc4b15285785b9c&quot;,\r\n                &quot;Comment&quot;: &quot;Created for Nackle Shared CF in pprd&quot;\r\n            },\r\n            {\r\n                &quot;Id&quot;: &quot;EMLFRR2NYMLFT&quot;,\r\n                &quot;S3CanonicalUserId&quot;: &quot;5123661394e931636d038d3370399d6cb110844505f4058aa2ee0aab21e52d09ced60fffa2fb438d2872366821eb1&quot;,\r\n                &quot;Comment&quot;: &quot;Created for Nackle Shared CF in prod&quot;\r\n            },\r\n            {\r\n                &quot;Id&quot;: &quot;E1EXEX5YNA4N51&quot;,\r\n                &quot;S3CanonicalUserId&quot;: &quot;e5c969d27e56434c73c3b7509ffa51c8a29cf690eeb1f3c85db8c6f85b09f5efb3c5d3f891ea5b9f6c5729af2f5c3&quot;,\r\n                &quot;Comment&quot;: &quot;Do Not Want&quot;\r\n            },\r\n            {\r\n                &quot;Id&quot;: &quot;E1RDNKSTCZ8CTF&quot;,\r\n                &quot;S3CanonicalUserId&quot;: &quot;d5a6931f306807e37ec245f87a4f8ef247fbc362ab016f9b02e5136029ce8b7a79e1d1d5e4fe4b751cf0fa66832ad&quot;,\r\n                &quot;Comment&quot;: &quot;Also do not want&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nI also just tried with --query and I think i got closer :\r\n\r\n```aws cloudfront list-cloud-front-origin-access-identities --query &quot;CloudFrontOriginAccessIdentityList.Items[]&quot;```\r\n\r\n\r\n\r\nGave me :\r\n```\r\n[\r\n    {\r\n        &quot;Id&quot;: &quot;E3IQ5CFYM436DX&quot;,\r\n        &quot;S3CanonicalUserId&quot;: &quot;57b0301338e0173a8fa18a117f8234f7f30ddf87fcf45fcf70412a374414d592bee3eea9697f41d06b284617232122dd&quot;,\r\n        &quot;Comment&quot;: &quot;Created for Nackle Shared CF in qa&quot;\r\n    },\r\n    {\r\n        &quot;Id&quot;: &quot;E1P6ZIBDB6I6FZ&quot;,\r\n        &quot;S3CanonicalUserId&quot;: &quot;7fbc21bc4e37661a49846db7dd6798b25a71ce81decb4f6403b5c6602da6e49f6a831ca3a0f682f87fc4b15285785b9c&quot;,\r\n        &quot;Comment&quot;: &quot;Created for Nackle Shared CF in pprd&quot;\r\n    },\r\n    {\r\n        &quot;Id&quot;: &quot;EMLFRR2NYMLFT&quot;,\r\n        &quot;S3CanonicalUserId&quot;: &quot;02d5123661394e931636d038d3370399d6cb110844505f4058aa2ee0aab21e52d09ced60fffa2fb438d2872366821eb1&quot;,\r\n        &quot;Comment&quot;: &quot;Created for Nackle Shared CF in prod&quot;\r\n    },\r\n    {\r\n        &quot;Id&quot;: &quot;E1EXEX5YNA4N51&quot;,\r\n        &quot;S3CanonicalUserId&quot;: &quot;49de5c969d27e56434c73c3b7509ffa51c8a29cf690eeb1f3c85db8c6f85b09f5efb3c5d3f891ea5b9f6c5729af2f5c3&quot;,\r\n        &quot;Comment&quot;: &quot;Do Not Want&quot;\r\n    },\r\n    {\r\n        &quot;Id&quot;: &quot;E1RDNKSTCZ8CTF&quot;,\r\n        &quot;S3CanonicalUserId&quot;: &quot;0a1d5a6931f306807e37ec245f87a4f8ef247fbc362ab016f9b02e5136029ce8b7a79e1d1d5e4fe4b751cf0fa66832ad&quot;,\r\n        &quot;Comment&quot;: &quot;Also do not want&quot;\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/70947832/with-aws-cli-how-do-i-get-the-cloudfront-oai-id-for-one-record-with-a-specific-n",
        "title": "With AWS cli how do I get the CloudFront OAI ID for one record with a specific name/comment?"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "jsonpath"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1643797208,
                "creation_date": 1643797208,
                "answer_id": 70953872,
                "question_id": 70950803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m guessing `zsh` is your shell. The `%` is an indicator output by your shell to say that the last line output by `kubectl` had no newline character at the end. So it&#39;s not _extra_ output, it&#39;s actually an indicator that the raw `kubectl` command outputs _less_ than `jq`.\r\n\r\nYou could explicitly add a newline to the jsonpath output if you want it:\r\n```\r\nkubectl get pods -l app=mssql-primary --output jsonpath=&#39;{.items[0].metadata.name}{&quot;\\n&quot;}&#39;\r\n```\r\n\r\nOr in the other direction you could tell `jq` not to add newlines at all by specifying `-j` instead of `-r`:\r\n```\r\nkubectl get pods -l app=mssql-primary -o json | jq -j &#39;.items[0].metadata.name&#39;\r\n```",
                "title": "Why is the same jsonpath query returning a different output?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643798041,
                "last_edit_date": 1643798041,
                "creation_date": 1643797374,
                "answer_id": 70953900,
                "question_id": 70950803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I reproduced your case with the same deployment name and label. And I get the same output from both of your commands:\r\n```bash\r\nmssqlag-primary-deployment-77b8974bb9-dbltl\r\n```\r\nBut `kubectl ... --output jsonpath` does not print a new line in terminal while `kubectl -o json | jq -r` prints new line.\r\n\r\nSo, if you assign the output of your commands to a variable, there will be the same string.\r\n\r\n```bash\r\nOUTPUT1=$(kubectl get pods -l app=mssql-primary --output jsonpath=&#39;{.items[0].metadata.name}&#39;)\r\nOUTPUT2=$(kubectl get pods -l app=mssql-primary -o json | jq -r &#39;.items[0].metadata.name&#39;)\r\n```\r\nThe $OUTPUT1 is equal to $OUTPUT2.\r\n\r\nAnd you got % just because of the specifics of your shell/terminal.\r\n \r\n ",
                "title": "Why is the same jsonpath query returning a different output?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1643798041,
        "creation_date": 1643779073,
        "question_id": 70950803,
        "body_markdown": "I am trying to extract podname using the below jq query.\r\n\r\n```shell\r\n❯ kubectl get pods -l app=mssql-primary --output jsonpath=&#39;{.items[0].metadata.name}&#39;\r\nmssqlag-primary-deployment-77b8974bb9-dbltl%                                                                                                                                                                                                                              \r\n❯ kubectl get pods -l app=mssql-primary -o json | jq -r &#39;.items[0].metadata.name&#39;\r\nmssqlag-primary-deployment-77b8974bb9-dbltl\r\n```\r\n\r\nWhile they both provide the same out put the first one has a % character at the end of the pod name. Any reason why ? Is there something wrong with the jsonpath representation in the first command ?",
        "link": "https://stackoverflow.com/questions/70950803/why-is-the-same-jsonpath-query-returning-a-different-output",
        "title": "Why is the same jsonpath query returning a different output?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "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": 1643811940,
                "post_id": 70957230,
                "comment_id": 125438496,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643812010,
                "post_id": 70957230,
                "comment_id": 125438529,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643812099,
                "post_id": 70957230,
                "comment_id": 125438578,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 653447,
                    "reputation": 16384,
                    "user_id": 447901,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/11ea5dd4ad290e75422e32e1e340772e?s=256&d=identicon&r=PG",
                    "display_name": "lit",
                    "link": "https://stackoverflow.com/users/447901/lit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643812114,
                "post_id": 70957230,
                "comment_id": 125438589,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643812208,
                "post_id": 70957230,
                "comment_id": 125438628,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643812311,
                "post_id": 70957230,
                "comment_id": 125438673,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23000202,
                    "reputation": 734,
                    "user_id": 17124277,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJy4woheCr7maYBdri2jSRuHNT8mLNL2mxoWvlPc=k-s256",
                    "display_name": "John Byro",
                    "link": "https://stackoverflow.com/users/17124277/john-byro"
                },
                "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": 1643812398,
                "post_id": 70957230,
                "comment_id": 125438712,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643813537,
                "last_edit_date": 1643813537,
                "creation_date": 1643812167,
                "answer_id": 70957421,
                "question_id": 70957230,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The only part you&#39;re missing is a `while read` loop.\r\n\r\n```\r\ndata=$(curl ...)\r\nwhile IFS= read -r line; do\r\n  curl -XPUT -d&quot;$line&quot; http://some_url\r\ndone &lt; &lt;(jq -c ... &lt;&lt;&lt;&quot;$data&quot;)\r\n```\r\n\r\n...or...\r\n\r\n```\r\ncurl ... |\r\n  jq -c ... |\r\n  xargs -d $&#39;\\n&#39; -n 1 curl -XPUT http://some_url -d\r\n```\r\n\r\nNote:\r\n\r\n- `xargs -d $&#39;\\n&#39;` tells `xargs` to treat only newlines (and not other whitespace) as separators between items; it also turns off treatment of quotes and backslashes as syntactic rather than literal.\r\n- `xargs -n 1` tells `xargs` only to pass one data item to each copy of curl.\r\n- Making the last argument to `curl` be `-d` means that xargs will place the data immediately after that position.",
                "title": "How to iterate each object in json array jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643813359,
                "last_edit_date": 1643813359,
                "creation_date": 1643812191,
                "answer_id": 70957426,
                "question_id": 70957230,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could loop through using `while read`:\r\n\r\n~~~sh\r\nwhile IFS= read -r line\r\ndo\r\n  \r\n  # your PUT goes here\r\n\r\n  # dummy\r\n  printf &#39;PUTting JSON: %s\\n&#39; &quot;$line&quot;\r\n\r\ndone &lt; &lt;(jq -c &#39;.name[] | select(.type == &quot;B&quot;) | .class = true&#39;)\r\n~~~\r\n\r\nIf you absolutely need to use `xargs` then use a newline character as delimiter\r\n\r\n~~~sh\r\njq -c &#39;.name[] | select(.type == &quot;B&quot;) | .class = true&#39; \\\r\n| xargs -d $&#39;\\n&#39; printf &#39;PUTting JSON: %s\\n&#39; # dummy\r\n~~~\r\n",
                "title": "How to iterate each object in json array jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1643813537,
        "creation_date": 1643811411,
        "last_edit_date": 1643812383,
        "question_id": 70957230,
        "body_markdown": "Intention: Need to iterate the each item in json array using jq and proccess seperately\r\n\r\napi returns data in form\r\n```\r\n{\r\n  &quot;name&quot;: [\r\n    {\r\n      &quot;first&quot;: &quot;first&quot;,\r\n      &quot;class&quot;: false,\r\n      &quot;type&quot;: &quot;B&quot;\r\n    },\r\n    {\r\n      &quot;first&quot;: &quot;second&quot;,\r\n      &quot;class&quot;: false,\r\n      &quot;type&quot;: &quot;B&quot;\r\n    },\r\n    {\r\n      &quot;first&quot;: &quot;third&quot;,\r\n      &quot;class&quot;: false,\r\n      &quot;type&quot;: &quot;A&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd i am able to parse it as \r\n```\r\ndata=`curl http://some.ur;l`\r\necho &quot;$data&quot; | jq -rc &#39;.name[] | select(.type==&quot;B&quot;) | .class=true&#39;\r\n```\r\nit returns data as \r\n```\r\n{&quot;first&quot;: &quot;first&quot;,&quot;class&quot;: true, &quot;type&quot;: &quot;B&quot;}\r\n{&quot;first&quot;: &quot;second&quot;, &quot;class&quot;: true, &quot;type&quot;: &quot;B&quot;}\r\n```\r\nNow i want to proccess these `two` outputs in such a way so that i can make a PUT call for each of them . I tried to learn some concepts of `xargs` but could not make it done \r\n\r\nI piped the output to `| xargs -n1` but it removed all the quotes from the string ",
        "link": "https://stackoverflow.com/questions/70957230/how-to-iterate-each-object-in-json-array-jq",
        "title": "How to iterate each object in json array jq"
    },
    {
        "tags": [
            "bash",
            "jq",
            "jsonpath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1643815071,
                "post_id": 70957827,
                "comment_id": 125440001,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18043900,
                    "reputation": 206,
                    "user_id": 13115377,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-8jUR-leOJiU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAhIYAv7mylzkoXdrVWOawXSHCoqQ/s256-rj/photo.jpg",
                    "display_name": "depak",
                    "link": "https://stackoverflow.com/users/13115377/depak"
                },
                "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": 1643815550,
                "post_id": 70957827,
                "comment_id": 125440255,
                "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": 1,
                "creation_date": 1643815600,
                "post_id": 70957827,
                "comment_id": 125440281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18043900,
                    "reputation": 206,
                    "user_id": 13115377,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-8jUR-leOJiU/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nAhIYAv7mylzkoXdrVWOawXSHCoqQ/s256-rj/photo.jpg",
                    "display_name": "depak",
                    "link": "https://stackoverflow.com/users/13115377/depak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643815693,
                "post_id": 70957827,
                "comment_id": 125440324,
                "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": 1643829118,
                "post_id": 70957827,
                "comment_id": 125445898,
                "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": 1643829501,
                "post_id": 70957827,
                "comment_id": 125446052,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1643816157,
                "creation_date": 1643816157,
                "answer_id": 70958427,
                "question_id": 70957827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to get userName value by specifying agentId\r\n```\r\njq &#39;.endpointAgents[] | select(.agentId == &quot;MyId&quot;) | .clients[].userProfile.userName&#39;\r\n```\r\n\r\nWill output `&quot;Name&quot;`\r\n\r\n\r\n----------\r\n\r\n\r\n- `.endpointAgents[]`  \r\n    Loop over each `endpointAgent`\r\n\r\n- `select(.agentId == &quot;MyId&quot;)`  \r\n    Select the objects where `.agentId == &quot;MyId&quot;`\r\n\r\n- `.clients[].userProfile.userName`  \r\n    Since `clients` is an array, loop over it, and show `.userProfile.userName` for each object.\r\n\r\n\r\n----------\r\n\r\n\r\n### [Try it online!](https://jqplay.org/s/t0OoN_iCfC)",
                "title": "Query JSONPath in JQ Format"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643829356,
                "last_edit_date": 1643829356,
                "creation_date": 1643828654,
                "answer_id": 70961362,
                "question_id": 70957827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand correctly, you want to produce the agent id of endpoints with a client whose name matches `a`.\r\n\r\n```jq\r\n.endpointAgents[] |\r\nselect( any( .clients[].userProfile.userName; test(&quot;a&quot;) ) ) |\r\n.agentId\r\n```\r\n\r\nTo produce the agent id of endpoints with a client whose name is equal to `a`, use the following instead:\r\n\r\n```jq\r\n.endpointAgents[] |\r\nselect( any( .clients[].userProfile.userName; . == &quot;a&quot; ) ) |\r\n.agentId\r\n```\r\n",
                "title": "Query JSONPath in JQ Format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1643829356,
        "creation_date": 1643813742,
        "last_edit_date": 1643828834,
        "question_id": 70957827,
        "body_markdown": "I have JSONPath:\r\n\r\n```none\r\n$.endpointAgents[?(@.clients.userName=~ &#39;a&#39;)].agentId\r\n```\r\n\r\nHow it will look in `jq` format on Linux??\r\n\r\n```bash\r\njq &#39;.endpointAgents [] | select(.clients.userName=~&quot;a&quot;) | {agentId}&#39;)&quot;\r\n``` \r\n\r\ndoes not work.\r\n\r\nCode:\r\n\r\n```json\r\n{\r\n  &quot;endpointAgents&quot;: [\r\n    {\r\n      &quot;agentId&quot;: &quot;MyId&quot;,\r\n      &quot;agentName&quot;: &quot;MYNAME&quot;,\r\n      &quot;location&quot;: {\r\n        &quot;locationName&quot;: &quot;location&quot;\r\n      },\r\n      &quot;clients&quot;: [\r\n        {\r\n          &quot;userProfile&quot;: {\r\n            &quot;userName&quot;: &quot;Name&quot;\r\n          },\r\n          &quot;browserExtensions&quot;: [\r\n            {\r\n              &quot;active&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;totalMemory&quot;: &quot;16222 MB&quot;,\r\n      &quot;agentType&quot;: &quot;enterprise&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70957827/query-jsonpath-in-jq-format",
        "title": "Query JSONPath in JQ Format"
    },
    {
        "tags": [
            "jquery",
            "json",
            "bash",
            "jq",
            "jsonpath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643824931,
                "post_id": 70960472,
                "comment_id": 125444292,
                "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": 1643825047,
                "post_id": 70960472,
                "comment_id": 125444341,
                "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": 2,
                "creation_date": 1643825087,
                "post_id": 70960472,
                "comment_id": 125444356,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643826835,
                "last_edit_date": 1643826835,
                "creation_date": 1643825540,
                "answer_id": 70960700,
                "question_id": 70960472,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your input JSON is\r\n~~~json\r\n{\r\n  &quot;endpointAgents&quot;: [\r\n    {\r\n      &quot;agentId&quot;: &quot;MyId&quot;,\r\n      &quot;agentName&quot;: &quot;MYNAME&quot;,\r\n      &quot;location&quot;: {\r\n        &quot;locationName&quot;: &quot;location&quot;\r\n      },\r\n      &quot;clients&quot;: [\r\n        {\r\n          &quot;userProfile&quot;: {\r\n            &quot;userName&quot;: &quot;Name&quot;\r\n          },\r\n          &quot;browserExtensions&quot;: [\r\n            {\r\n              &quot;active&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;totalMemory&quot;: &quot;16222 MB&quot;,\r\n      &quot;agentType&quot;: &quot;enterprise&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n\r\nTo get the `agentId` values from **all** items of the `endpointAgents` array where in the same object **at least one** object in the `clients` array has a `userProfile.userName` string value that **contains** a given substring, I&#39;d go with\r\n~~~sh\r\njq -r &#39;\r\n  .endpointAgents[]\r\n  | select(.clients | map(.userProfile.userName | contains(&quot;a&quot;)) | any)\r\n  | .agentId\r\n&#39;\r\n~~~\r\n~~~\r\nMyId\r\n~~~\r\n[Demo](https://jqplay.org/s/5_FLiPJAnD)\r\n\r\nIn order import the query string from outside jq, use the `--arg` parameter\r\n~~~\r\njq -r --arg query &quot;a&quot; &#39; … contains($query) … &#39;\r\n~~~\r\n",
                "title": "Get value of parent element by child jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1643866884,
        "creation_date": 1643824443,
        "last_edit_date": 1643866884,
        "question_id": 70960472,
        "body_markdown": "Code:\r\n\r\n    {\r\n      &quot;endpointAgents&quot;: [\r\n        {\r\n          &quot;agentId&quot;: &quot;MyId&quot;,\r\n          &quot;agentName&quot;: &quot;MYNAME&quot;,\r\n          &quot;location&quot;: {\r\n            &quot;locationName&quot;: &quot;location&quot;\r\n          },\r\n          &quot;clients&quot;: [\r\n            {\r\n              &quot;userProfile&quot;: {\r\n                &quot;userName&quot;: &quot;Name&quot;\r\n              },\r\n              &quot;browserExtensions&quot;: [\r\n                {\r\n                  &quot;active&quot;: false\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;totalMemory&quot;: &quot;16222 MB&quot;,\r\n          &quot;agentType&quot;: &quot;enterprise&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\nI need to return the **agentId** value with the value **userName**.\r\nI know how to do it with JSONPath \r\n\r\n&gt; ($.endpointAgents[?(@.clients.userName=~ &#39;a&#39;)].agentId)\r\n\r\n, but don&#39;t know how with jq.",
        "link": "https://stackoverflow.com/questions/70960472/get-value-of-parent-element-by-child-jq",
        "title": "Get value of parent element by child jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643833458,
                "last_edit_date": 1643833458,
                "creation_date": 1643832228,
                "answer_id": 70962168,
                "question_id": 70962045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create a new object and assign the fields correspondigly\r\n~~~\r\n… | .[] |= {ParameterKey: .key, ParameterValue: .value}\r\n~~~\r\n[Demo](https://jqplay.org/s/WipBR4iJ5-)\r\n\r\nInstead of the update operator `|=` you could also use `map`\r\n~~~\r\n… | map({ParameterKey: .key, ParameterValue: .value})\r\n~~~\r\n[Demo](https://jqplay.org/s/N1rViircGt)\r\n\r\nDepending on the actual structure of your three input files, this can probably be simplified using `reduce` instead.\r\n\r\nAlso, if you want to import the actual replacement names from outside jq (as their sample names suggest), use the `--arg` parameter to create an externally initialized variable and use it when creating the objects\r\n~~~\r\njq -s --arg key &quot;ParameterKey&quot; --arg value &quot;ParameterValue&quot; &#39;\r\n  … {($key):.key, ($value):.value} …\r\n&#39;\r\n~~~",
                "title": "How to change &quot;key&quot; and &quot;value&quot; keys of to_entries to &quot;ParameterKey&quot; and &quot;ParameterValue&quot; in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1643833458,
        "creation_date": 1643831684,
        "question_id": 70962045,
        "body_markdown": "I have 3 json files that when merged using `*` produces the following result:\r\n\r\n```\r\n$ jq -s &#39;.[0] * .[1] * .[2] | to_entries&#39; a.json b.json c.json\r\n[\r\n  {\r\n    &quot;key&quot; : &quot;...&quot;,\r\n    &quot;value&quot; : &quot;...&quot;\r\n  },\r\n  {\r\n    &quot;key&quot; : &quot;...&quot;,\r\n    &quot;value&quot; : &quot;...&quot;\r\n  },\r\n  {\r\n    &quot;key&quot; : &quot;...&quot;,\r\n    &quot;value&quot; : &quot;...&quot;\r\n  }\r\n] \r\n```\r\n\r\nHow can I use different names for &quot;key&quot; and &quot;value&quot;, e.g.:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;ParameterKey&quot; : &quot;...&quot;,\r\n    &quot;ParameterValue&quot; : &quot;...&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot; : &quot;...&quot;,\r\n    &quot;ParameterValue&quot; : &quot;...&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot; : &quot;...&quot;,\r\n    &quot;ParameterValue&quot; : &quot;...&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/70962045/how-to-change-key-and-value-keys-of-to-entries-to-parameterkey-and-parame",
        "title": "How to change &quot;key&quot; and &quot;value&quot; keys of to_entries to &quot;ParameterKey&quot; and &quot;ParameterValue&quot; in jq?"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643837749,
                "last_edit_date": 1643837749,
                "creation_date": 1643837572,
                "answer_id": 70963165,
                "question_id": 70963091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`join()`](https://stedolan.github.io/jq/manual/#example61) such as\r\n```\r\njq &#39;.issues[] | [.key , .fields.status.name , .fields.fixVersions[].name] | join(&quot;,&quot;)&#39;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### &lt;kbd&gt;[Try it online!](https://jqplay.org/s/uY2-u8VzqF)&lt;/kbd&gt;",
                "title": "How to join array elements with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1643837749,
        "creation_date": 1643837215,
        "question_id": 70963091,
        "body_markdown": "I&#39;m attempting to generate a .csv from json output in a specific format. The JSON is as follows:\r\n\r\n    {\r\n      &quot;expand&quot;: &quot;names,schema&quot;,\r\n      &quot;startAt&quot;: 0,\r\n      &quot;maxResults&quot;: 50,\r\n      &quot;total&quot;: 1,\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n          &quot;id&quot;: &quot;42202&quot;,\r\n          &quot;self&quot;: &quot;https://www.myjira.com/jira/rest/api/2/issue/42202&quot;,\r\n          &quot;key&quot;: &quot;JIRAISSUE-369&quot;,\r\n          &quot;fields&quot;: {\r\n            &quot;fixVersions&quot;: [\r\n              {\r\n                &quot;self&quot;: &quot;https://www.myjira.com/jira/rest/api/2/version/15701&quot;,\r\n                &quot;id&quot;: &quot;15701&quot;,\r\n                &quot;name&quot;: &quot;MR1&quot;,\r\n                &quot;archived&quot;: false,\r\n                &quot;released&quot;: false,\r\n                &quot;releaseDate&quot;: &quot;2014-06-10&quot;\r\n              },\r\n              {\r\n                &quot;self&quot;: &quot;https://www.myjira.com/jira/rest/api/2/version/15702&quot;,\r\n                &quot;id&quot;: &quot;15702&quot;,\r\n                &quot;name&quot;: &quot;MR2&quot;,\r\n                &quot;archived&quot;: false,\r\n                &quot;released&quot;: false,\r\n                &quot;releaseDate&quot;: &quot;2014-04-14&quot;\r\n              }\r\n            ],\r\n            &quot;status&quot;: {\r\n              &quot;self&quot;: &quot;https://www.myjira.com/jira/rest/api/2/status/3&quot;,\r\n              &quot;description&quot;: &quot;This issue is being actively worked on at the moment by the assignee.&quot;,\r\n              &quot;iconUrl&quot;: &quot;https://www.myjira.com/jira/images/icons/statuses/inprogress.png&quot;,\r\n              &quot;name&quot;: &quot;In Progress&quot;,\r\n              &quot;id&quot;: &quot;3&quot;,\r\n              &quot;statusCategory&quot;: {\r\n                &quot;self&quot;: &quot;https://www.myjira.com/jira/rest/api/2/statuscategory/4&quot;,\r\n                &quot;id&quot;: 4,\r\n                &quot;key&quot;: &quot;indeterminate&quot;,\r\n                &quot;colorName&quot;: &quot;yellow&quot;,\r\n                &quot;name&quot;: &quot;In Progress&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like to have a comma separated list with fixVersions&#39; elements being comma separated. I&#39;ve gotten this far.\r\n\r\n    curl -X GET -H &quot;Content-Type: application/json&quot; -k &quot;https://www.myjira.com/jira/rest/api/2/search?jql=filter%3D60100&amp;fields=key,status,fixVersions&quot; -u user1 | jq -r &#39;.issues[] | .key + &quot;,&quot; + .fields.status.name + &quot;,&quot; + .fields.fixVersions[].name&#39;\r\n\r\nOutput:\r\n\r\n    JIRAISSUE-369,In Progress,MR1\r\n    JIRAISSUE-369,In Progress,MR2\r\n\r\nDesired output:\r\n\r\n    JIRAISSUE-369,In Progress,MR1,MR2\r\n\r\nHow do I take each .issues.fixVersions[].name and comma separate them at the end?",
        "link": "https://stackoverflow.com/questions/70963091/how-to-join-array-elements-with-jq",
        "title": "How to join array elements with 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": 1643847983,
                "post_id": 70964556,
                "comment_id": 125451435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1643849354,
                "last_edit_date": 1643849354,
                "creation_date": 1643848354,
                "answer_id": 70964611,
                "question_id": 70964556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[String interpolation](https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-%5C(foo)) combined with [`join()`][2]:\r\n```\r\njq --raw-output &#39;map(&quot;\\&quot;\\(join(&quot;=&quot;))\\&quot;&quot;) | join(&quot; &quot;)&#39;\r\n```\r\n\r\nto generate\r\n```\r\n&quot;SimpleNumber=123&quot; &quot;SimpleString=Hello&quot; &quot;ComplexString=Hello World&quot;\r\n```\r\n\r\n[Try it online](https://jqplay.org/s/4KziA3nZll)\r\n\r\n----------\r\n\r\n\r\nOr to it &#39;by hand&#39; to quote only the value:\r\n```\r\njq --raw-output &#39;map(&quot;\\(.key)=\\&quot;\\(.value)\\&quot;&quot;) | join(&quot; &quot;)&#39;\r\n```\r\n```\r\nSimpleNumber=&quot;123&quot; SimpleString=&quot;Hello&quot; ComplexString=&quot;Hello World&quot;\r\n```\r\n\r\n[Try it online](https://jqplay.org/s/4hQi15uxC3)\r\n\r\n  [2]: https://stedolan.github.io/jq/manual/#join(str)",
                "title": "How to map a list of key/values to a space separated list of keyValue=valueValue entries in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1643848394,
                "creation_date": 1643848394,
                "answer_id": 70964617,
                "question_id": 70964556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use string interpolation and put the quotes as you see fit:\r\n\r\n1) around whole items\r\n~~~sh\r\njq -r &#39;map(&quot;\\&quot;\\(.key)=\\(.value)\\&quot;&quot;) | join(&quot; &quot;)&#39;\r\n~~~\r\n~~~\r\n&quot;SimpleNumber=123&quot; &quot;SimpleString=Hello&quot; &quot;ComplexString=Hello World&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/76sJeRhG2M)\r\n\r\n2) just around the &quot;value&quot;\r\n~~~sh\r\njq -r &#39;map(&quot;\\(.key)=\\&quot;\\(.value)\\&quot;&quot;) | join(&quot; &quot;)&#39;\r\n~~~\r\n~~~\r\nSimpleNumber=&quot;123&quot; SimpleString=&quot;Hello&quot; ComplexString=&quot;Hello World&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/4hQi15uxC3)",
                "title": "How to map a list of key/values to a space separated list of keyValue=valueValue entries in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1643988142,
        "creation_date": 1643847769,
        "last_edit_date": 1643988142,
        "question_id": 70964556,
        "body_markdown": "How can I transform this output:\r\n\r\n```\r\n$ jq -s &#39;.[0] * .[1] * .[2] | to_entries&#39; a.json b.json c.json\r\n[\r\n  {\r\n    &quot;key&quot; : &quot;SimpleNumber&quot;,\r\n    &quot;value&quot; : &quot;123&quot;\r\n  },\r\n  {\r\n    &quot;key&quot; : &quot;SimpleString&quot;,\r\n    &quot;value&quot; : &quot;Hello&quot;\r\n  },\r\n  {\r\n    &quot;key&quot; : &quot;ComplexString&quot;,\r\n    &quot;value&quot; : &quot;Hello World&quot;\r\n  }\r\n]\r\n```\r\n\r\nto:\r\n\r\n1)\r\n\r\n```\r\n&quot;SimpleNumber=123&quot; &quot;SimpleString=Hello&quot; &quot;ComplexString=Hello World&quot;\r\n```\r\n\r\nand\r\n\r\n2)\r\n\r\n```\r\nSimpleNumber=&quot;123&quot; SimpleString=&quot;Hello&quot; ComplexString=&quot;Hello World&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70964556/how-to-map-a-list-of-key-values-to-a-space-separated-list-of-keyvalue-valuevalue",
        "title": "How to map a list of key/values to a space separated list of keyValue=valueValue entries in jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "logging",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1643934306,
                "last_edit_date": 1643934306,
                "creation_date": 1643927732,
                "answer_id": 70979252,
                "question_id": 70979212,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--compact-output` or `-c` option: `jq -c --arg … &#39;…&#39; &gt;&gt; logs.log`\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/v1.6):\r\n\r\n~~~\r\n--compact-output / -c:\r\n    By default, jq pretty-prints JSON output. Using this option will\r\n    result in more compact output by instead putting  each JSON object\r\n    on a single line.\r\n~~~\r\n\r\n---\r\nAfter having read your linked article about &quot;Structured Logging&quot;, this is how I would have implemented said `__log` function:\r\n~~~sh\r\n__log(){\r\n  jq -Mcn --arg log_level &quot;$1&quot; --arg message &quot;$2&quot; \\\r\n    &#39;{timestamp: now|todate, $log_level, $message}&#39;\r\n}\r\n__log &quot;INFO&quot; &quot;Hello, World!&quot;\r\n~~~\r\n",
                "title": "Stuctured logs in shell script using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643928081,
                "creation_date": 1643928081,
                "answer_id": 70979303,
                "question_id": 70979212,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&#129318; Somehow I completely missed Step 3.0 The Finishing Touches of [this terrific guide](https://medium.com/@jesse.riddle/structured-logging-in-a-shell-script-with-jq-f7542a94a1f6) which answers my question perfectly.\r\n\r\nIn case anyone else was curious, the solution is here:\r\n```\r\n__timestamp(){\r\n  date &quot;+%Y%m%dT%H%M%S&quot;\r\n}\r\n__log(){\r\n  log_level=&quot;$1&quot;\r\n  message=&quot;$2&quot;\r\n  echo &#39;{}&#39; | \\\r\n  jq  --monochrome-output \\\r\n      --compact-output \\\r\n      --raw-output \\\r\n      --arg timestamp &quot;$(__timestamp)&quot; \\\r\n      --arg log_level &quot;$log_level&quot; \\\r\n      --arg message &quot;$message&quot; \\\r\n      &#39;.timestamp=$timestamp|.log_level=$log_level|.message=$message&#39;\r\n}\r\n__log &quot;INFO&quot; &quot;Hello, World!&quot;\r\n```\r\n\r\nWhich outputs:\r\n```\r\n{&quot;timestamp&quot;:&quot;20210812T191730&quot;,&quot;log_level&quot;:&quot;INFO&quot;,&quot;message&quot;:&quot;Hello, World!&quot;}\r\n```",
                "title": "Stuctured logs in shell script using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1643988089,
        "creation_date": 1643927472,
        "last_edit_date": 1643988089,
        "question_id": 70979212,
        "body_markdown": "I&#39;ve been wanting to logs some shells scripts to a file to be picked up by an agent like Fluentbit and shipped off to Cloudwatch and Datadog. \r\n\r\nI found [this example](https://medium.com/@jesse.riddle/structured-logging-in-a-shell-script-with-jq-f7542a94a1f6) on the web which works like a charm using `jq`.\r\n\r\n```\r\n__timestamp(){\r\n  date &quot;+%Y%m%dT%H%M%S&quot;\r\n}\r\n__log(){\r\n  log_level=&quot;$1&quot;\r\n  message=&quot;$2&quot;\r\n  echo &#39;{}&#39; | jq \\\r\n    --arg timestamp &quot;$(__timestamp)&quot;\r\n    --arg log_level &quot;$log_level&quot; \\\r\n    --arg message &quot;$message&quot; \\\r\n    &#39;.timestamp=$timestamp|.log_level=$log_level|.message=$message&#39; &gt;&gt; logs.log\r\n}\r\n__log &quot;INFO&quot; &quot;Hello, World!&quot;\r\n```\r\n\r\nThe one issue is that the output is rendering a full json with newlines and tabs.  Easy on the eyes, but not great for cloud logging services.\r\n\r\n```\r\n{\r\n  &quot;timestamp&quot;: &quot;20220203T162320&quot;,\r\n  &quot;log_level&quot;: &quot;INFO&quot;,\r\n  &quot;message&quot;: &quot;Hello, World!&quot;\r\n}\r\n```\r\n\r\nHow would I modify to render the output on one line like so?\r\n\r\n`{&quot;timestamp&quot;: &quot;20220203T171908&quot;,&quot;log_level&quot;: &quot;INFO&quot;,&quot;message&quot;: &quot;Hello, World!&quot;}`",
        "link": "https://stackoverflow.com/questions/70979212/stuctured-logs-in-shell-script-using-jq",
        "title": "Stuctured logs in shell script using JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "jtc"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1643968752,
                "last_edit_date": 1643968752,
                "creation_date": 1643960681,
                "answer_id": 70982949,
                "question_id": 70982029,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re looking for a solution using `jq`, then it should be just updating the `entities` array using `add`:\r\n~~~sh\r\njq &#39;.entities |= add&#39; input.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;entities&quot;: {\r\n    &quot;chuck123&quot;: {\r\n      &quot;type&quot;: &quot;barebone&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;customer_name&quot;: &quot;Batman&quot;,\r\n        &quot;subdomain&quot;: &quot;Gotham&quot;,\r\n        &quot;console&quot;: &quot;radio&quot;,\r\n        &quot;portal_url&quot;: &quot;blue&quot;,\r\n        &quot;subdomain_partner&quot;: &quot;Bking&quot;,\r\n        &quot;platform&quot;: &quot;arch&quot;,\r\n        &quot;group&quot;: &quot;DC Squad&quot;,\r\n        &quot;endpoint_type&quot;: &quot;bridge&quot;,\r\n        &quot;operating_system&quot;: &quot;ubuntu&quot;\r\n      }\r\n    },\r\n    &quot;sam123&quot;: {\r\n      &quot;type&quot;: &quot;barebone&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;customer_name&quot;: &quot;Robin&quot;,\r\n        &quot;subdomain&quot;: &quot;Circus&quot;,\r\n        &quot;console&quot;: &quot;radio&quot;,\r\n        &quot;portal_url&quot;: &quot;purple&quot;,\r\n        &quot;subdomain_partner&quot;: &quot;BurgerNFries&quot;,\r\n        &quot;platform&quot;: &quot;arch&quot;,\r\n        &quot;group&quot;: &quot;DC Squad&quot;,\r\n        &quot;endpoint_type&quot;: &quot;carbank&quot;,\r\n        &quot;operating_system&quot;: &quot;debian&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/An3o-DnYc8)",
                "title": "Need assistance formatting json output, lifting an object within an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1643968752,
        "creation_date": 1643954328,
        "last_edit_date": 1643954898,
        "question_id": 70982029,
        "body_markdown": "**Current output from script.** \r\n```\r\n    {\r\n      &quot;entities&quot;: [\r\n        {\r\n          &quot;chuck123&quot;: {\r\n            &quot;type&quot;: &quot;barebone&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;customer_name&quot;: &quot;Batman&quot;,\r\n              &quot;subdomain&quot;: &quot;Gotham&quot;,\r\n              &quot;console&quot;: &quot;radio&quot;,\r\n              &quot;portal_url&quot;: &quot;blue&quot;,\r\n              &quot;subdomain_partner&quot;: &quot;Bking&quot;,\r\n              &quot;platform&quot;: &quot;arch&quot;,\r\n              &quot;group&quot;: &quot;DC Squad&quot;,\r\n              &quot;endpoint_type&quot;: &quot;bridge&quot;,\r\n              &quot;operating_system&quot;: &quot;ubuntu&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;sam123&quot;: {\r\n            &quot;type&quot;: &quot;barebone&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;customer_name&quot;: &quot;Robin&quot;,\r\n              &quot;subdomain&quot;: &quot;Circus&quot;,\r\n              &quot;console&quot;: &quot;radio&quot;,\r\n              &quot;portal_url&quot;: &quot;purple&quot;,\r\n              &quot;subdomain_partner&quot;: &quot;BurgerNFries&quot;,\r\n              &quot;platform&quot;: &quot;arch&quot;,\r\n              &quot;group&quot;: &quot;DC Squad&quot;,\r\n              &quot;endpoint_type&quot;: &quot;carbank&quot;,\r\n              &quot;operating_system&quot;: &quot;debian&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n```\r\nPerferred Format - I am trying to move the object up one layer.  \r\n```\r\n{\r\n  &quot;entities&quot;: {\r\n      &quot;chuck123&quot;: {\r\n        &quot;type&quot;: &quot;barebone&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;customer_name&quot;: &quot;Batman&quot;,\r\n          &quot;subdomain&quot;: &quot;Gotham&quot;,\r\n          &quot;console&quot;: &quot;radio&quot;,\r\n          &quot;portal_url&quot;: &quot;blue&quot;,\r\n          &quot;subdomain_partner&quot;: &quot;Bking&quot;,\r\n          &quot;platform&quot;: &quot;arch&quot;,\r\n          &quot;group&quot;: &quot;DC Squad&quot;,\r\n          &quot;endpoint_type&quot;: &quot;bridge&quot;,\r\n          &quot;operating_system&quot;: &quot;ubuntu&quot;\r\n        }\r\n      },\r\n      &quot;sam123&quot;: {\r\n        &quot;type&quot;: &quot;barebone&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;customer_name&quot;: &quot;Robin&quot;,\r\n          &quot;subdomain&quot;: &quot;Circus&quot;,\r\n          &quot;console&quot;: &quot;radio&quot;,\r\n          &quot;portal_url&quot;: &quot;purple&quot;,\r\n          &quot;subdomain_partner&quot;: &quot;BurgerNFries&quot;,\r\n          &quot;platform&quot;: &quot;arch&quot;,\r\n          &quot;group&quot;: &quot;DC Squad&quot;,\r\n          &quot;endpoint_type&quot;: &quot;carbank&quot;,\r\n          &quot;operating_system&quot;: &quot;debian&quot;\r\n        }\r\n      }\r\n   }\r\n}\r\n```\r\nI could definitely use some help. Been trying every combination I can think of to alter the output up one layer without any success. I&#39;ve tried jq and jtc and am most likely overthinking it. Appreciate any assistance others can provide. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/70982029/need-assistance-formatting-json-output-lifting-an-object-within-an-object",
        "title": "Need assistance formatting json output, lifting an object within an object"
    },
    {
        "tags": [
            "python",
            "node.js",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14938620,
                    "reputation": 37961,
                    "user_id": 10785975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7c4cd389600c4eae23561fc6afdd71a2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Daweo",
                    "link": "https://stackoverflow.com/users/10785975/daweo"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1643986923,
                "post_id": 70988508,
                "comment_id": 125492190,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user2849202"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1643986942,
                "post_id": 70988508,
                "comment_id": 125492198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22229002,
                    "reputation": 1,
                    "user_id": 16465515,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8a93829aa36809cdb7974ec905bd31e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "horagreensburg",
                    "link": "https://stackoverflow.com/users/16465515/horagreensburg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643988787,
                "post_id": 70988508,
                "comment_id": 125493014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22229002,
                    "reputation": 1,
                    "user_id": 16465515,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8a93829aa36809cdb7974ec905bd31e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "horagreensburg",
                    "link": "https://stackoverflow.com/users/16465515/horagreensburg"
                },
                "reply_to_user": {
                    "account_id": 14938620,
                    "reputation": 37961,
                    "user_id": 10785975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7c4cd389600c4eae23561fc6afdd71a2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Daweo",
                    "link": "https://stackoverflow.com/users/10785975/daweo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643989547,
                "post_id": 70988508,
                "comment_id": 125493354,
                "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": 1643991834,
                "post_id": 70988508,
                "comment_id": 125494368,
                "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": 1643991873,
                "post_id": 70988508,
                "comment_id": 125494390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2434269,
                    "reputation": 130,
                    "user_id": 2124559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b9905f79eeb192ac01808ee928cb3298?s=256&d=identicon&r=PG",
                    "display_name": "dataman",
                    "link": "https://stackoverflow.com/users/2124559/dataman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644457652,
                "post_id": 70988508,
                "comment_id": 125614815,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644109167,
                "last_edit_date": 1644109167,
                "creation_date": 1644004881,
                "answer_id": 70992226,
                "question_id": 70988508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your problem should be broken down into two parts: parsing CSV data for conversion into JSON, and building a JSON structure following path-like descriptors.\r\n\r\nFor the first part, it is necessary to clarify the formatting of the CSV input, as there is no general standard for CSV, just a fundamental description in the [RFC 4180 proposal](https://datatracker.ietf.org/doc/html/rfc4180) and a lot of adoptions tailored to specific use cases or data types. As you didn&#39;t provide any actual CSV content, let&#39;s assume for the sake of simplicity that records are separated by newlines, fields are separated by commas, and field delimiters are not present as the data itself never contains any of these separators. Let&#39;s further assume that all records have the exact same number of fields, and that exactly one of them (namely the first) represents the headers. You may want to adjust these assumptions to your actual CSV data.\r\n\r\n~~~sh\r\ncat input.csv\r\n~~~\r\n~~~\r\nfrom/email,to/0/email,personalization/0/email,personalization/0/data/first_name,personalization/0/data/company_name,personalization/0/data/job_title,template_id\r\nme@x.com,mike@x.com,mike@x.com,Mike,X.com,Chef,123456\r\n~~~\r\n\r\nBased on this formatting, you can read in the CSV data using the `--raw-input` or `-R` option which streams in each newline-separated segment of raw text as a JSON string input. Ideally, your filter should then convert each input string record into an array of string fields by splitting at the comma, e.g. using the `/` operator:\r\n\r\n~~~sh\r\njq -R &#39;. / &quot;,&quot;&#39; input.csv\r\n~~~\r\n~~~json\r\n[\r\n  &quot;from/email&quot;,\r\n  &quot;to/0/email&quot;,\r\n  &quot;personalization/0/email&quot;,\r\n  &quot;personalization/0/data/first_name&quot;,\r\n  &quot;personalization/0/data/company_name&quot;,\r\n  &quot;personalization/0/data/job_title&quot;,\r\n  &quot;template_id&quot;\r\n]\r\n[\r\n  &quot;me@x.com&quot;,\r\n  &quot;mike@x.com&quot;,\r\n  &quot;mike@x.com&quot;,\r\n  &quot;Mike&quot;,\r\n  &quot;X.com&quot;,\r\n  &quot;Chef&quot;,\r\n  &quot;123456&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/2FL2J9_wr_)\r\n\r\nAs for the second part, you can now easily process these JSON arrays. In order to treat the first one (the headers) separately, you could use the `--slurp` or `-s` option which turns the input stream into an array whose elements can then be accessed using indices. Also, the `setpath` builtin comes in handy as it can set values within a JSON structure described as an array of strings and integers representing object fields and array indices, just as you do in your headers. This leaves you turning the header strings into such arrays by splitting at &quot;/&quot; and converting number-like segments into actual numbers. Finally, to successively build up your JSON objects you could iterate through the record fields using a `reduce` statement and align the record fields to their corresponding header fields using `transpose`:\r\n\r\n~~~sh\r\n… | jq -s &#39;\r\n  (.[0] | map(. / &quot;/&quot; | map(tonumber? // .))) as $headers\r\n  | .[1:] | map(\r\n    reduce ([$headers, .] | transpose[]) as [$path, $value] (\r\n      {}; setpath($path; $value)\r\n    )\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;from&quot;: {\r\n      &quot;email&quot;: &quot;me@x.com&quot;\r\n    },\r\n    &quot;to&quot;: [\r\n      {\r\n        &quot;email&quot;: &quot;mike@x.com&quot;\r\n      }\r\n    ],\r\n    &quot;personalization&quot;: [\r\n      {\r\n        &quot;email&quot;: &quot;mike@x.com&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;first_name&quot;: &quot;Mike&quot;,\r\n          &quot;company_name&quot;: &quot;X.com&quot;,\r\n          &quot;job_title&quot;: &quot;Chef&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;template_id&quot;: &quot;123456&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/8_yG8UH6rp)\r\n\r\nNotes\r\n- My showcase disregards the fact that your sample JSON output also provides an additional field `name` under the top-level field `from` because your sample CSV input headers don&#39;t include a matching field `from/name`\r\n- To emphasize the bipartite nature of this approach, I concluded with two cascading invocations of jq. This generally could (and mostly should) be combined into one. However, as combining the options `--raw-input` and `--slurp` would alter jq&#39;s read-in behaviour, you&#39;d rather want to add the `--null-input` or `-n` option with `[inputs | …]` in the first filter which lets you dismiss the `--slurp` option in the second: `jq -Rn &#39;[inputs / &quot;/&quot;] | …&#39;` ([Demo](https://jqplay.org/s/dFUfMv-WHP))",
                "title": "Convert CSV to Nested JSON using / header delimiter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1644161561,
        "creation_date": 1643986850,
        "last_edit_date": 1643989427,
        "question_id": 70988508,
        "body_markdown": "My CSV headers look something like\r\n\r\n| from/email | to/0/email | personalization/0/email/ | personalization/0/data/first_name | personalization/0/data/company_name | personalization/0/data/job_title | template_id |\r\n| ---------- | ---------- | ------------------------ | ------------------------------ |  ------------------------------ |  ------------------------------ | ---\r\n\r\n\r\n\r\n\r\nOutput should be:\r\n\r\n```\r\n[\r\n {\r\n   &quot;from&quot;: {\r\n      &quot;email&quot;: &quot;me@x.com&quot;,\r\n      &quot;name&quot;: &quot;Me&quot;\r\n   },\r\n   &quot;to&quot;: [\r\n      {\r\n         &quot;email&quot;: &quot;mike@x.com&quot;\r\n      }\r\n   ],\r\n   &quot;personalization&quot;: [\r\n      {\r\n         &quot;email&quot;: &quot;mike@x.com&quot;,\r\n         &quot;data&quot;: {\r\n            &quot;first_name&quot;: &quot;Mike&quot;,\r\n            &quot;company_name&quot;: &quot;X.com&quot;,\r\n            &quot;job_title&quot;: &quot;Chef&quot;\r\n         }\r\n      }\r\n   ],\r\n   &quot;template_id&quot;: &quot;123456&quot;\r\n},\r\n```\r\n\r\nI tried \r\n\r\n```\r\ncsvjson input.csv output.csv\r\n```\r\n```\r\ncsvtojson input.csv output.csv\r\n```\r\n```\r\ncsv2json input.csv output.csv\r\n```\r\n```\r\npython3 app.py\r\n\r\nimport csv \r\nimport json \r\n\r\ndef csv_to_json(csvFilePath, jsonFilePath):\r\n    jsonArray = []\r\n      \r\n    #read csv file\r\n    with open(csvFilePath, encoding=&#39;utf-8&#39;) as csvf: \r\n        #load csv file data using csv library&#39;s dictionary reader\r\n        csvReader = csv.DictReader(csvf) \r\n\r\n        #convert each csv row into python dict\r\n        for row in csvReader: \r\n            #add this python dict to json array\r\n            jsonArray.append(row)\r\n  \r\n    #convert python jsonArray to JSON String and write to file\r\n    with open(jsonFilePath, &#39;w&#39;, encoding=&#39;utf-8&#39;) as jsonf: \r\n        jsonString = json.dumps(jsonArray, indent=4)\r\n        jsonf.write(jsonString)\r\n          \r\ncsvFilePath = r&#39;outputt1.csv&#39;\r\njsonFilePath = r&#39;outputt1.json&#39;\r\ncsv_to_json(csvFilePath, jsonFilePath)\r\n```\r\n```\r\nnode app.js\r\n\r\nconst CSVToJSON = require(&#39;csvtojson&#39;);\r\n\r\n// convert users.csv file to JSON array\r\nCSVToJSON().fromFile(&#39;outputt1.csv&#39;)\r\n    .then(from =&gt; {\r\n\r\n        // from is a JSON array\r\n        // log the JSON array\r\n        console.log(from);\r\n    }).catch(err =&gt; {\r\n        // log error if any\r\n        console.log(err);\r\n    });\r\n```\r\n\r\nAll output some variation of single-line JSON with no nesting.\r\n\r\nThe only thing that worked was uploading it to https://www.convertcsv.com/csv-to-json.htm and converting each file by hand, but that is obviously not a solution.\r\n\r\nI have seen a post recommending Choetl.Json for this exact purpose but was unable to install it on mac",
        "link": "https://stackoverflow.com/questions/70988508/convert-csv-to-nested-json-using-header-delimiter",
        "title": "Convert CSV to Nested JSON using / header delimiter"
    },
    {
        "tags": [
            "json",
            "shell",
            "parsing",
            "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": 1643992270,
                "post_id": 70989639,
                "comment_id": 125494577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9901716,
                    "reputation": 2367,
                    "user_id": 7331538,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/603a48331ac6169d86f15d0d1b3a32e6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bcsta",
                    "link": "https://stackoverflow.com/users/7331538/bcsta"
                },
                "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": 1643992505,
                "post_id": 70989639,
                "comment_id": 125494672,
                "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": 1643992543,
                "post_id": 70989639,
                "comment_id": 125494686,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9901716,
                    "reputation": 2367,
                    "user_id": 7331538,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/603a48331ac6169d86f15d0d1b3a32e6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bcsta",
                    "link": "https://stackoverflow.com/users/7331538/bcsta"
                },
                "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": 1643992679,
                "post_id": 70989639,
                "comment_id": 125494744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9901716,
                    "reputation": 2367,
                    "user_id": 7331538,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/603a48331ac6169d86f15d0d1b3a32e6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bcsta",
                    "link": "https://stackoverflow.com/users/7331538/bcsta"
                },
                "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": 1643992982,
                "post_id": 70989639,
                "comment_id": 125494870,
                "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": 1,
                "creation_date": 1643993311,
                "post_id": 70989639,
                "comment_id": 125495017,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9901716,
                    "reputation": 2367,
                    "user_id": 7331538,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/603a48331ac6169d86f15d0d1b3a32e6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bcsta",
                    "link": "https://stackoverflow.com/users/7331538/bcsta"
                },
                "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": 1643993987,
                "post_id": 70989639,
                "comment_id": 125495299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1643997334,
                "post_id": 70989639,
                "comment_id": 125496595,
                "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": 1643997413,
                "post_id": 70989639,
                "comment_id": 125496628,
                "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": 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": 1643997476,
                "post_id": 70989639,
                "comment_id": 125496654,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1643997508,
                "post_id": 70989639,
                "comment_id": 125496665,
                "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": 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": 1643998017,
                "post_id": 70989639,
                "comment_id": 125496848,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9901716,
                    "reputation": 2367,
                    "user_id": 7331538,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/603a48331ac6169d86f15d0d1b3a32e6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bcsta",
                    "link": "https://stackoverflow.com/users/7331538/bcsta"
                },
                "reply_to_user": {
                    "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": 1643998149,
                "post_id": 70989639,
                "comment_id": 125496881,
                "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": 1643998279,
                "post_id": 70989639,
                "comment_id": 125496926,
                "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": 1643998375,
                "post_id": 70989639,
                "comment_id": 125496973,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1644014205,
                "last_edit_date": 1644014205,
                "creation_date": 1643996939,
                "answer_id": 70990725,
                "question_id": 70989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Fetching the value of a jq variable doesn&#39;t cause it to be executed as jq code.\r\n\r\nFurthermore, jq lacks the facility to take a string, compile it as jq code, and evaluate the result. (This is commonly known as `eval`.)\r\n\r\nSo, short of a writing a jq parser and evaluator in jq, you will need to impose limits and/or accept a different format.\r\n\r\nFor example,\r\n\r\n```sh\r\nkeys=&#39;[ [ &quot;key1&quot;, &quot;childkey&quot; ], [ &quot;key2&quot;, &quot;childkey2&quot; ] ]&#39;  # JSON\r\njq --argjson keys &quot;$keys&quot; &#39;.[] | [ getpath( $keys[] ) ]&#39; file.json\r\n```\r\n\r\nor\r\n\r\n```sh\r\nkeys=&#39;key1.childkey,key2.childkey2&#39;\r\njq --arg keys &quot;$keys&quot; &#39;\r\n   ( ( $keys / &quot;,&quot; ) | map( . / &quot;.&quot; ) ) as $keys |\r\n   .[] | [ getpath( $keys[] ) ]\r\n&#39; file.json\r\n```\r\n",
                "title": "jq how to pass json keys from a shell variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644011489,
                "last_edit_date": 1644011489,
                "creation_date": 1644000788,
                "answer_id": 70991468,
                "question_id": 70989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Suppose you have:\r\n\r\n    cat file\r\n    [{\r\n    &quot;key1&quot;:1,\r\n    &quot;key2&quot;:2\r\n    }]\r\n    [{\r\n    &quot;key1&quot;:1,\r\n    &quot;key2&quot;:2\r\n    }]\r\n\r\nYou can use a `jq` command like so:\r\n\r\n    jq &#39;.[] | [.key1,.key2]&#39; file\r\n    [\r\n      1,\r\n      2\r\n    ]\r\n    [\r\n      1,\r\n      2\r\n    ]\r\n\r\nYou can use `-f` to execute a filter from a file and nothing keeps you from creating the file separately from the shell variables.\r\n\r\nExample:\r\n\r\n    keys=&quot;.key1&quot;\r\n    echo &quot;.[] | [${keys}]&quot; &gt;jqf\r\n    \r\n    jq -f jqf file\r\n    [\r\n      1\r\n    ]\r\n    [\r\n      1\r\n    ]\r\n\r\nOr just build the string directly into `jq`:\r\n\r\n    # note double &quot; causing string interpolation\r\n    jq &quot;.[] | [${keys}]&quot; file\r\n\r\n    ",
                "title": "jq how to pass json keys from a shell variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651734963,
                "last_edit_date": 1651734963,
                "creation_date": 1651733166,
                "answer_id": 72122970,
                "question_id": 70989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--argjson` option and `destructuring`.\r\n\r\nfile.json\r\n```\r\n[{&quot;key1&quot;:{&quot;a&quot;:1},&quot;key2&quot;:{&quot;b&quot;:2}}]\r\n[{&quot;key1&quot;:{&quot;c&quot;:1},&quot;key2&quot;:{&quot;d&quot;:2}}]\r\n```\r\n\r\n```\r\n$ in=&#39;[&quot;key1&quot;,&quot;key2&quot;]&#39; jq -c --argjson keys &quot;$in&quot; &#39;$keys as [$key1,$key2] | .[] | [.[$key1,$key2]]&#39; file.json\r\n```\r\n\r\noutput:\r\n```\r\n[{&quot;a&quot;:1},{&quot;b&quot;:2}]\r\n[{&quot;c&quot;:1},{&quot;d&quot;:2}]\r\n```",
                "title": "jq how to pass json keys from a shell variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652077013,
                "last_edit_date": 1652077013,
                "creation_date": 1652074756,
                "answer_id": 72167397,
                "question_id": 70989639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Elaborating on ikegami&#39;s answer.\r\n\r\nTo start with here&#39;s my version of the answer:\r\n\r\n```\r\n$ in=&#39;key1.a,key2.b&#39;; jq -c --arg keys &quot;$in&quot; &#39;($keys/&quot;,&quot;|map(./&quot;.&quot;)) as $paths | .[] | [getpath($paths[])]&#39; &lt;&lt;&lt;$&#39;[{&quot;key1&quot;:{&quot;a&quot;:1},&quot;key2&quot;:{&quot;b&quot;:2}}] [{&quot;key1&quot;:{&quot;a&quot;:3},&quot;key2&quot;:{&quot;b&quot;:4}}]&#39;\r\n```\r\n\r\nThis gives output\r\n\r\n```\r\n[1,2]\r\n[3,4]\r\n```\r\n\r\nLet&#39;s try it.\r\n\r\nWe have input\r\n```\r\n[{&quot;key1&quot;:{&quot;a&quot;:1},&quot;key2&quot;:{&quot;b&quot;:2}}]\r\n[{&quot;key1&quot;:{&quot;a&quot;:3},&quot;key2&quot;:{&quot;b&quot;:4}}]\r\n```\r\n\r\nAnd we want to construct array\r\n\r\n```\r\n[[&quot;key1&quot;,&quot;a&quot;],[&quot;key2&quot;,&quot;b&quot;]]\r\n```\r\n\r\nthen use it on `getpath(PATHS)` builtin to extract values out of our input.\r\n\r\nTo start with we are given `in` *shell variable* with string value `key1.a,key2.b`. Let&#39;s call this `$keys`.\r\n\r\nThen `$keys/&quot;,&quot;` gives\r\n\r\n```\r\n[&quot;key1.a&quot;,&quot;key2.b&quot;]\r\n[&quot;key1.a&quot;,&quot;key2.b&quot;]\r\n```\r\n\r\nAfter that `$keys/&quot;,&quot;|map(./&quot;.&quot;)` gives what we want.\r\n\r\n```\r\n[[&quot;key1&quot;,&quot;a&quot;],[&quot;key2&quot;,&quot;b&quot;]]\r\n[[&quot;key1&quot;,&quot;a&quot;],[&quot;key2&quot;,&quot;b&quot;]]\r\n```\r\nLet&#39;s call this `$paths`.\r\n\r\nNow if we do `.[]|[getpath($paths[])]` we get the values from our `input` equivalent to\r\n\r\n```\r\n[.[] | .key1.a, .key2.b]\r\n```\r\nwhich is\r\n\r\n```\r\n[1,2]\r\n[3,4]\r\n```",
                "title": "jq how to pass json keys from a shell variable"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1652077013,
        "creation_date": 1643991805,
        "last_edit_date": 1643997978,
        "question_id": 70989639,
        "body_markdown": "I have a json file I am parsing with `jq`. This is a sample of the file\r\n\r\n    [{\r\n    &quot;key1&quot;:{...},\r\n    &quot;key2&quot;:{...}\r\n    }]\r\n    [{\r\n    &quot;key1&quot;:{...},\r\n    &quot;key2&quot;:{...}\r\n    }]\r\n    ...\r\n\r\neach line is a list containing a json (which I know is not technically a `json` format but `jq` still works on such a file)\r\n\r\nThe below `jq` command works:\r\n\r\n    cat file.json | jq -r &#39;.[] | [.key1,.key2]&#39;\r\n\r\nThe above correctly shows:\r\n\r\n    [\r\n    &lt;value_of_key1&gt;,&lt;value_of_key2&gt;\r\n    ]\r\n    [\r\n    &lt;value_of_key1&gt;,&lt;value_of_key2&gt;\r\n    ]\r\n\r\nHowever, I want `.key1,.key2` to be dynamic since these keys can change. So I want to pass a variable to `jq`. Something like:\r\n\r\n    $KEYS=.key1,.key2\r\n    cat file.json | jq -r --arg var &quot;$KEYS&quot; &#39;.[] | [$var]&#39;\r\n\r\nBut the above is returning the keys themselves:\r\n\r\n    [\r\n    &quot;.key1,.key2&quot;\r\n    ]\r\n    [\r\n    &quot;.key1,.key2&quot;\r\n    ]\r\n\r\n\r\nwhy is this happening? what is the correct command to make this happen?\r\n\r\n[This answer](https://stackoverflow.com/questions/35841309/construct-json-with-a-variable-key-using-jq) does not help me. I am not getting any errors as the OP in that question.\r\n",
        "link": "https://stackoverflow.com/questions/70989639/jq-how-to-pass-json-keys-from-a-shell-variable",
        "title": "jq how to pass json keys from a shell variable"
    },
    {
        "tags": [
            "terraform",
            "jq",
            "kubectl"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644014965,
                "post_id": 70992268,
                "comment_id": 125501984,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1644016061,
                "post_id": 70992268,
                "comment_id": 125502177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16708546,
                    "reputation": 23,
                    "user_id": 17025502,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6be1755a85dc38fddd96b38205a6ffb7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "renpen",
                    "link": "https://stackoverflow.com/users/17025502/renpen"
                },
                "reply_to_user": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644071438,
                "post_id": 70992268,
                "comment_id": 125510526,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16708546,
                    "reputation": 23,
                    "user_id": 17025502,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6be1755a85dc38fddd96b38205a6ffb7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "renpen",
                    "link": "https://stackoverflow.com/users/17025502/renpen"
                },
                "reply_to_user": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644071572,
                "post_id": 70992268,
                "comment_id": 125510551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16708546,
                    "reputation": 23,
                    "user_id": 17025502,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6be1755a85dc38fddd96b38205a6ffb7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "renpen",
                    "link": "https://stackoverflow.com/users/17025502/renpen"
                },
                "reply_to_user": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644072101,
                "post_id": 70992268,
                "comment_id": 125510668,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644092723,
                "creation_date": 1644092723,
                "answer_id": 71001868,
                "question_id": 70992268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As per my comment: the `KUBECONFIG` environment variable needs to be a list of configuration files and not the content of the file itself [1]:\r\n\r\n&gt; The KUBECONFIG environment variable is a list of paths to configuration files.\r\n\r\nThe original problem was that the content of the file was encoded in `base64` format [2] and used in that format without decoding it before. Thankfully, Terraform has both functions built-in, so using `base64decode` [3] would return the &quot;normal&quot; file content. Still, it would be the __file content__ and not __path to the config file__. Based on the other comments, I guess the important thing to note is the `additional_roles_aws_auth.yaml` file has to be in the same directory as the root module. As the command is a bit more complicated, I am not sure if you could use Terraform built-in `path` object [4] to make sure the file is searched for in the root of the module:\r\n\r\n```\r\nkubectl get cm aws-auth -n kube-system -o json | jq --arg add &quot;`cat ${path.root}/additional_roles_aws_auth.yaml`&quot; &#39;.data.mapRoles += $add&#39; | kubectl apply -f -\r\n``` \r\n\r\n---\r\n\r\n[1] https://kubernetes.io/docs/tasks/access-application-cluster/configure-access-multiple-clusters/#set-the-kubeconfig-environment-variable\r\n\r\n[2] https://www.terraform.io/language/functions/base64encode\r\n\r\n[3] https://www.terraform.io/language/functions/base64decode\r\n\r\n[4] https://www.terraform.io/language/expressions/references#filesystem-and-workspace-info\r\n",
                "title": "Terraform &quot;file name too long&quot; when executing with &quot;null_resource&quot; &quot;apply&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659428285,
                "creation_date": 1659428285,
                "answer_id": 73204137,
                "question_id": 70992268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The base64 encoded kubeconfig is called in your command so you must decode it: \r\n\r\n    kubectl &lt;YOUR_COMMAND&gt; --kubeconfig &lt;(echo $KUBECONFIG | base64 --decode)",
                "title": "Terraform &quot;file name too long&quot; when executing with &quot;null_resource&quot; &quot;apply&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1659428285,
        "creation_date": 1644005095,
        "last_edit_date": 1644071386,
        "question_id": 70992268,
        "body_markdown": "I&#39;m trying to execute the following command:\r\n```kubectl get cm aws-auth -n kube-system -o json | jq --arg add &quot;`cat additional_roles_aws_auth.yaml`&quot; &#39;.data.mapRoles += $add&#39; | kubectl apply -f -```\r\nas part of a local Terraform exeuction as follows:\r\n```\r\nlocals {\r\n  kubeconfig = yamlencode({\r\n    apiVersion      = &quot;v1&quot;\r\n    kind            = &quot;Config&quot;\r\n    current-context = &quot;terraform&quot;\r\n    clusters = [{\r\n      name = module.eks.cluster_id\r\n      cluster = {\r\n        certificate-authority-data = module.eks.cluster_certificate_authority_data\r\n        server                     = module.eks.cluster_endpoint\r\n      }\r\n    }]\r\n    contexts = [{\r\n      name = &quot;terraform&quot;\r\n      context = {\r\n        cluster = module.eks.cluster_id\r\n        user    = &quot;terraform&quot;\r\n      }\r\n    }]\r\n    users = [{\r\n      name = &quot;terraform&quot;\r\n      user = {\r\n        token = data.aws_eks_cluster_auth.this.token\r\n      }\r\n    }]\r\n  })\r\n}\r\nresource &quot;null_resource&quot; &quot;apply&quot; {\r\n  triggers = {\r\n    kubeconfig = base64encode(local.kubeconfig)\r\n    cmd_patch  = &lt;&lt;-EOT\r\n      kubectl get cm aws-auth -n kube-system -o json | jq --arg add &quot;`cat additional_roles_aws_auth.yaml`&quot; &#39;.data.mapRoles += $add&#39; | kubectl apply -f -\r\n    EOT\r\n  }\r\n    provisioner &quot;local-exec&quot; {\r\n    interpreter = [&quot;/bin/bash&quot;, &quot;-c&quot;]\r\n    environment = {\r\n      KUBECONFIG = self.triggers.kubeconfig\r\n    }\r\n    command = self.triggers.cmd_patch\r\n  }\r\n}\r\n```\r\n\r\nExecuting the same command outside of Terraform, plainly on the command line works fine. \r\nHowever, I always get the following error when executing as part of the Terraform script:\r\n```\r\n│ &#39;: exit status 1. Output:\r\n│ iAic2FtcGxlLWNsdXN0ZXI...WaU5ERXdNekEiCg==&quot;:\r\n│ open\r\n│ ImFwaVZlcnNpb24iOiAidjEiy...RXdNekEiCg==:\r\n│ file name too long\r\n```\r\nAnybody any ideas what the issues could be ?",
        "link": "https://stackoverflow.com/questions/70992268/terraform-file-name-too-long-when-executing-with-null-resource-apply",
        "title": "Terraform &quot;file name too long&quot; when executing with &quot;null_resource&quot; &quot;apply&quot;"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq",
            "git-bash",
            "xargs"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663157,
                    "reputation": 17637,
                    "user_id": 3776927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f97178932f070cb24d06de16a905b196?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "derpirscher",
                    "link": "https://stackoverflow.com/users/3776927/derpirscher"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644005448,
                "post_id": 70992275,
                "comment_id": 125499306,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644005535,
                "post_id": 70992275,
                "comment_id": 125499334,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9803753,
                    "reputation": 335,
                    "user_id": 7264254,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/728cd96f30788b2e32304de489cc4776?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Artexias",
                    "link": "https://stackoverflow.com/users/7264254/artexias"
                },
                "reply_to_user": {
                    "account_id": 4663157,
                    "reputation": 17637,
                    "user_id": 3776927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f97178932f070cb24d06de16a905b196?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "derpirscher",
                    "link": "https://stackoverflow.com/users/3776927/derpirscher"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644005665,
                "post_id": 70992275,
                "comment_id": 125499383,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9803753,
                    "reputation": 335,
                    "user_id": 7264254,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/728cd96f30788b2e32304de489cc4776?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Artexias",
                    "link": "https://stackoverflow.com/users/7264254/artexias"
                },
                "reply_to_user": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644005897,
                "post_id": 70992275,
                "comment_id": 125499461,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663157,
                    "reputation": 17637,
                    "user_id": 3776927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f97178932f070cb24d06de16a905b196?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "derpirscher",
                    "link": "https://stackoverflow.com/users/3776927/derpirscher"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644005961,
                "post_id": 70992275,
                "comment_id": 125499486,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9803753,
                    "reputation": 335,
                    "user_id": 7264254,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/728cd96f30788b2e32304de489cc4776?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Artexias",
                    "link": "https://stackoverflow.com/users/7264254/artexias"
                },
                "reply_to_user": {
                    "account_id": 4663157,
                    "reputation": 17637,
                    "user_id": 3776927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f97178932f070cb24d06de16a905b196?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "derpirscher",
                    "link": "https://stackoverflow.com/users/3776927/derpirscher"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644006108,
                "post_id": 70992275,
                "comment_id": 125499537,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644008372,
                "creation_date": 1644008372,
                "answer_id": 70992787,
                "question_id": 70992275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the end result. The issue was I was not familiar with the jq utility and my json kept coming in wrong. \r\n\r\n    cat CurlArgsFile.json | jq -r &#39;.Requests[]|tojson&#39; | xargs -0 -I % curl -d % -H &quot;Content-Type: application/json&quot; -X POST http://localhost:53391/mySVC/writeData",
                "title": "How to get json array from file, format with jq and curl a post request with ddata from json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645521166,
                "creation_date": 1645521166,
                "answer_id": 71218609,
                "question_id": 70992275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use GNU `xargs`, the `-d` flag is usefule:\r\n\r\n```sh\r\njq &#39;.Requests[]&#39; -rc file.json |\r\n  xargs -d &#39;\\n&#39; -0 -P0 -I@ curl -X POST -H &#39;Content-Type: application/json&#39; -d @ http://localhost:53391/mySVC/writeData\r\n```\r\n\r\nOtherwise, use `tr` to make it compatible with other `xargs` such as BSD or BusyBox.\r\n\r\n\r\n```sh\r\njq &#39;.Requests[]&#39; -rc file.json |\r\n  tr &#39;\\n&#39; &#39;\\0&#39; |\r\n  xargs -0 -P0 -I@ curl -X POST -H &#39;Content-Type: application/json&#39; -d @ http://localhost:53391/mySVC/writeData\r\n```",
                "title": "How to get json array from file, format with jq and curl a post request with ddata from json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1645521166,
        "creation_date": 1644005126,
        "last_edit_date": 1644006018,
        "question_id": 70992275,
        "body_markdown": "I&#39;m trying to get an array from a json file.\r\n\r\n    {\r\n    \t&quot;Requests&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;Item1&quot;: &quot;2020-01-27 16:24:49&quot;,\r\n    \t\t\t&quot;Item2&quot;: &quot;203i1Kj2gTEQgfdsfds23&quot;,\r\n    \t\t\t&quot;Item3&quot;: 1603,\r\n    \t\t\t&quot;Item4&quot;: &quot;generic&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Item1&quot;: &quot;2020-01-27 16:24:49&quot;,\r\n    \t\t\t&quot;Item2&quot;: &quot;203i1Kj2gTEQgfdsfds23&quot;,\r\n    \t\t\t&quot;Item3&quot;: 1603,\r\n    \t\t\t&quot;Item4&quot;: &quot;generic&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Item1&quot;: &quot;2020-01-27 16:24:49&quot;,\r\n    \t\t\t&quot;Item2&quot;: &quot;203i1Kj2gTEQgfdsfds23&quot;,\r\n    \t\t\t&quot;Item3&quot;: 1603,\r\n    \t\t\t&quot;Item4&quot;: &quot;generic&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Item1&quot;: &quot;2020-01-27 16:24:49&quot;,\r\n    \t\t\t&quot;Item2&quot;: &quot;203i1Kj2gTEQgfdsfds23&quot;,\r\n    \t\t\t&quot;Item3&quot;: 1603,\r\n    \t\t\t&quot;Item4&quot;: &quot;generic&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nThen I want to pass each of these items to a curl request and possibly handle that in parralel with xargs\r\n\r\n\r\nI&#39;m still stumbling on getting one item to the curl endpoint.\r\n\r\n\r\n    cat CurlArgsFile.json | jq -c &#39;.[][0]&#39; | xargs -I % curl -d % -H &quot;Content-Type: application/json&quot; -X POST http://localhost:53391/mySVCS/writeData\r\n\r\nI&#39;m running this on Git Bash on Windows 10. When I try to echo the json output into a file I get the below without the quotes and now I&#39;m not sure if that&#39;s the correct json I&#39;m sending at all. \r\n\r\n    \r\n\r\n    {Item1:2020-01-27 16:24:49,Item2:203i1Kj2gTEQgfdsfds23,Item3:1603,Item4:generic}\r\n\r\nHow do I send the first item from the json to the endpoint and the enpoint recognizes it? \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70992275/how-to-get-json-array-from-file-format-with-jq-and-curl-a-post-request-with-dda",
        "title": "How to get json array from file, format with jq and curl a post request with ddata from json"
    },
    {
        "tags": [
            "json",
            "jq",
            "jtc"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1644092835,
                "last_edit_date": 1644092835,
                "creation_date": 1644092115,
                "answer_id": 71001788,
                "question_id": 71001713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We&#39;re going to use `test(&quot;^@t&quot;)` instead of `contains(&quot;@t&quot;)` since we want to check for a *leading* `@t`. But that&#39;s not why you are getting that error. You have the wrong object on the left-hand side of `|=`, and `map` doesn&#39;t do what you think for objects.\r\n\r\nTwo solutions:\r\n\r\n* Using filtering (like you were attempting):\r\n\r\n    ```jq\r\n    .process_state |= with_entries(\r\n       select( .key | test(&quot;^@t&quot;) | not )\r\n    )\r\n    ```\r\n    \r\n    [Demo](https://jqplay.org/s/2LskhGpvhy) on jqplay\r\n\r\n* Using deletion:\r\n\r\n    ```jq\r\n    .process_state |= del(\r\n       .[\r\n          keys_unsorted[] |\r\n          select( test(&quot;^@t&quot;) )\r\n       ]\r\n    )\r\n    ```\r\n    \r\n    [Demo](https://jqplay.org/s/Q1mjThmx1f) on jqplay\r\n    \r\n",
                "title": "Need help deleting elements with special character @ from json object with jtc or jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660476309,
                "creation_date": 1660476309,
                "answer_id": 73351229,
                "question_id": 71001713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is correct `jtc` usage:\r\n```\r\nbash $ &lt;file jtc -w&#39;&lt;^@t&gt;L:&#39; -p\r\n{\r\n   &quot;process_state&quot;: {\r\n      &quot;@user_id&quot;: &quot;john smith&quot;\r\n   }\r\n}\r\nbash $ \r\n\r\n```",
                "title": "Need help deleting elements with special character @ from json object with jtc or jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1660476309,
        "creation_date": 1644091456,
        "last_edit_date": 1644091882,
        "question_id": 71001713,
        "body_markdown": "I&#39;m trying to identify object elements which a key starting with `@t`. My goal is to delete them from the object all together. \r\n\r\nExample Input\r\n```\r\n{\r\n  &quot;process_state&quot;: {\r\n    &quot;@user_id&quot;: &quot;john smith&quot;,\r\n    &quot;@t39ee396f50&quot;: 1,\r\n    &quot;@t375b0311e8&quot;: 1,\r\n    &quot;@t12dd92bf45&quot;: 1\r\n     }\r\n}\r\n```\r\n\r\nExpected Output\r\n\r\n```\r\n{\r\n  &quot;process_state&quot;: {\r\n    &quot;@user_id&quot;: &quot;john smith&quot;,\r\n     }\r\n}\r\n```\r\n\r\nI&#39;ve tried using jq and jtc to accomplish this and both seem to struggle with the leading @ symbol. I&#39;m assuming it&#39;s a format issue with my code. Can I use wildcards? I&#39;ve tried a couple methods with no luck. \r\n\r\nJQ\r\n\r\njq &#39;. |= map(select(. | contains(&quot;@t&quot;) | not))&#39; &lt;file&gt; \r\n\r\nError: and string (&quot;@t&quot;) cannot have their containment checked\r\n\r\nJTC\r\n\r\n&lt;file jtc -w&#39;&lt;process_state.@t*&gt;l:&#39;\r\n\r\nNo error but @t* fields still exist in json object.\r\n\r\nAny help is much appreciated. \r\n",
        "link": "https://stackoverflow.com/questions/71001713/need-help-deleting-elements-with-special-character-from-json-object-with-jtc-o",
        "title": "Need help deleting elements with special character @ from json object with jtc or jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644099786,
                "last_edit_date": 1644099786,
                "creation_date": 1644094385,
                "answer_id": 71002051,
                "question_id": 71001996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq you can *structurally* turn the input into your desired JSON document using simple filters like `map(./&quot;.&quot;)`, but regarding the requested *readability*, the output wouldn&#39;t have exactly your desired *formatting*.\r\n\r\nWithout any further flags, jq would pretty-print the output as:\r\n~~~json\r\n[\r\n  [\r\n    &quot;key1&quot;,\r\n    &quot;childk2&quot;\r\n  ],\r\n  [\r\n    &quot;key2&quot;,\r\n    &quot;childk3&quot;\r\n  ]\r\n]\r\n\r\n~~~\r\n[Demo](https://jqplay.org/s/Xwylv798eq)\r\n\r\nUsing the `--compact-output` or `-c` flag would compress the whole JSON document into one line, not just the elements of the outer array:\r\n~~~json\r\n[[&quot;key1&quot;,&quot;childk2&quot;],[&quot;key2&quot;,&quot;childk3&quot;]]\r\n~~~\r\n[Demo](https://jqplay.org/s/qV2MmBMJZE)\r\n\r\nSo, if you *really* wanted to, you could also glue together the parts yourself as you like them to be formatted from within jq, but honestly, I would discourage you from doing so as by circumventing jq&#39;s internal JSON composer you might end up outputting invalid JSON.\r\n\r\n~~~sh\r\njq -r &#39;&quot;[&quot;, &quot;  &quot; + (map(./&quot;.&quot; | tojson) | .[:-1][] += &quot;,&quot;)[], &quot;]&quot;&#39;\r\n~~~\r\n~~~json\r\n[\r\n  [&quot;key1&quot;,&quot;childk2&quot;],\r\n  [&quot;key2&quot;,&quot;childk3&quot;]\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/XQpHK9VgvT)",
                "title": "Shell - jq: Turning json list of `keys.childkeys` into list of lists"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644095475,
                "last_edit_date": 1644095475,
                "creation_date": 1644094409,
                "answer_id": 71002053,
                "question_id": 71001996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use jq `split` filter:\r\n\r\n``` bash\r\njq &#39;[.[] | split(&quot;.&quot;)]&#39;\r\n```\r\n``` json\r\n[\r\n  [\r\n    &quot;key1&quot;,\r\n    &quot;childk2&quot;\r\n  ],\r\n  [\r\n    &quot;key2&quot;,\r\n    &quot;childk3&quot;\r\n  ]\r\n]\r\n```\r\n\r\nYou should use it somewhere in the original jq command",
                "title": "Shell - jq: Turning json list of `keys.childkeys` into list of lists"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644097959,
                "last_edit_date": 1644097959,
                "creation_date": 1644096222,
                "answer_id": 71002266,
                "question_id": 71001996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a `ruby` to do that:\r\n\r\n    ruby -r json -e &#39;puts JSON.parse($&lt;.read).map{|e| e.split(&quot;.&quot;)}.to_json&#39; file\r\n\r\n    [[&quot;key1&quot;,&quot;childk2&quot;],[&quot;key2&quot;,&quot;childk3&quot;]]\r\n\r\nOr if you want it **pretty**:\r\n\r\n    ruby -r json -e &#39;puts JSON.pretty_generate(\r\n    \t\t\tJSON.parse($&lt;.read).map{|e| e.split(&quot;.&quot;)})\r\n    &#39; file\r\n    [\r\n      [\r\n        &quot;key1&quot;,\r\n        &quot;childk2&quot;\r\n      ],\r\n      [\r\n        &quot;key2&quot;,\r\n        &quot;childk3&quot;\r\n      ]\r\n    ]\r\n\r\nOr you can produce your *precise* format:\r\n\r\n    ruby -r json -e &#39;\r\n    l=[]\r\n    JSON.parse($&lt;.read).map{|e| l &lt;&lt; e.split(&quot;.&quot;).to_s}\r\n    puts &quot;[\\n\\t#{l.join(&quot;,\\n\\t&quot;)}\\n]&quot;\r\n    &#39; file \r\n    [\r\n    \t[&quot;key1&quot;, &quot;childk2&quot;],\r\n    \t[&quot;key2&quot;, &quot;childk3&quot;]\r\n    ]",
                "title": "Shell - jq: Turning json list of `keys.childkeys` into list of lists"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1644099786,
        "creation_date": 1644093987,
        "question_id": 71001996,
        "body_markdown": "I am using jq to parse a `json file`. This is the current output from `jq`:\r\n\r\n    [\r\n     &quot;key1.childk2&quot;,\r\n     &quot;key2.childk3&quot;\r\n    ]\r\n\r\nI would like to turn this into a readable json format itself as list of lists like below:\r\n\r\n        [ \r\n          [&quot;key1&quot;,&quot;childk2&quot;],\r\n          [&quot;key2&quot;,&quot;childk3&quot;]\r\n        ]\r\n\r\nI would ideally prefer to do this with `jq`, however any other shell tool that can work on shell variables is fair game. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71001996/shell-jq-turning-json-list-of-keys-childkeys-into-list-of-lists",
        "title": "Shell - jq: Turning json list of `keys.childkeys` into list of lists"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "header",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1644142934,
                "creation_date": 1644142934,
                "answer_id": 71006175,
                "question_id": 71005490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you have stream in your json, you need `inputs` instead of `.[]`\r\n\r\n```\r\njq -nr &#39;([&quot;a&quot;,&quot;b&quot;], (inputs | map(.k1.k2,.k3.k2))) | @csv&#39; input-json\r\n```",
                "title": "Shell jq is adding header to every other line in csv output, not just once at the top"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644142990,
                "creation_date": 1644142990,
                "answer_id": 71006188,
                "question_id": 71005490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is a stream of JSON documents. Thus, your filter gets executed once for each document, including constructing the headers.\r\n\r\nOne solution would be to use the `--slurp` or `-s` option to read in the stream as an array. This, however, would necessitate to go one level deeper in your iteration (`.[][]` instead of just `.[]`):\r\n~~~\r\njq -s &#39;[&quot;a&quot;,&quot;b&quot;], (.[][] | [.k1.k2,.k3.k2]) | @csv&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/mLmpcEogcH)\r\n\r\nAnother way would be to use `inputs` which gives you all input documents at once. This, however, would necessitate to iterate over that (`input[]` instead of `.[]`) and use the `--null-input` or `-n` flag to avoid swallowing up the first elemment:\r\n~~~\r\njq -n &#39;[&quot;a&quot;,&quot;b&quot;], (inputs[] | [.k1.k2,.k3.k2]) | @csv&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/WewrznwJlu)\r\n\r\nNote: You also may want to use the `--raw-output` or `-r` flag to produce raw text instead of JSON when generating the output with `@csv` (as I already did in the demos).\r\n",
                "title": "Shell jq is adding header to every other line in csv output, not just once at the top"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1644144436,
        "creation_date": 1644136873,
        "last_edit_date": 1644144436,
        "question_id": 71005490,
        "body_markdown": "I am extracting keys from a `json` with this format:\r\n```json\r\n[\r\n {\r\n   &quot;k1&quot;:{&quot;k2&quot;:4},\r\n   &quot;k3&quot;:{&quot;k2&quot;:6}\r\n }\r\n]\r\n[\r\n {\r\n   &quot;k1&quot;:{&quot;k2&quot;:4},\r\n   &quot;k3&quot;:{&quot;k2&quot;:6}\r\n }\r\n]\r\n```\r\nI am using this command `[&quot;a&quot;,&quot;b&quot;], (.[] | [.k1.k2,.k3.k2]) | @csv` to extract two keys and adding two headers (`a`, `b`) to the csv. But The output to this is a header in every other line:\r\n\r\n    &quot;\\&quot;a\\&quot;,\\&quot;b\\&quot;&quot;\r\n    &quot;4,6&quot;\r\n    &quot;\\&quot;a\\&quot;,\\&quot;b\\&quot;&quot;\r\n    &quot;4,6&quot;\r\n\r\nYou can see this in this [jq play](https://jqplay.org/s/VWOZCeaKLZ). How can I change to filter to just put header on the first line?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71005490/shell-jq-is-adding-header-to-every-other-line-in-csv-output-not-just-once-at-th",
        "title": "Shell jq is adding header to every other line in csv output, not just once at the top"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644156129,
                "last_edit_date": 1644156129,
                "creation_date": 1644155816,
                "answer_id": 71007885,
                "question_id": 71007765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your question is quite broad. What is a &quot;block&quot;?\r\n\r\nLet&#39;s assume you want to delete from within the object under `http-01` each field that is of type array and has at index `0` an object satisfying `.domain.main == &quot;domain.tld&quot;`. Then first navigate to where you want to delete from, and update it (`|=`) using `del` and `select` which performs the filtered deletion.\r\n\r\n~~~sh\r\njq &#39;\r\n  .&quot;http-01&quot; |= del(\r\n    .[] | select(arrays[0] | objects.domain.main == &quot;domain.tld&quot;)\r\n  )\r\n&#39; acme.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;http-01&quot;: {\r\n    &quot;Account&quot;: {\r\n      &quot;Email&quot;: &quot;email@domain.tld&quot;,\r\n      &quot;Registration&quot;: {\r\n        &quot;body&quot;: {\r\n          &quot;status&quot;: &quot;valid&quot;,\r\n          &quot;contact&quot;: [\r\n            &quot;mailto:email@domain.tld&quot;\r\n          ]\r\n        },\r\n        &quot;uri&quot;: &quot;https://acme-v02.api.letsencrypt.org/acme/acct/110801506&quot;\r\n      },\r\n      &quot;PrivateKey&quot;: &quot;long_key_string&quot;,\r\n      &quot;KeyType&quot;: &quot;4096&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/SdmDUsXNfF)\r\n\r\nIf your &quot;block&quot; is deeper, go deeper before updating. If it is higher, the whole document for instance, there&#39;s no need to update, just start with `del`.",
                "title": "Delete json block with jq command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1644165901,
                "creation_date": 1644165901,
                "answer_id": 71009413,
                "question_id": 71007765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To delete domain block &quot;www.some_domain.tld&quot; :\r\n\r\n```\r\njq &#39;.&quot;http-01&quot;.Certificates |= map(select(.domain.main != &quot;www.some_domain.tld&quot;))&#39; input.json\r\n```",
                "title": "Delete json block with jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1644199724,
        "creation_date": 1644154903,
        "last_edit_date": 1644199724,
        "question_id": 71007765,
        "body_markdown": "I have json file with multiple domains which is formated as is showed below. How can I delete whole blocks with domains? For example if I will want to delete whole block in json for domain `domain.tld`?\r\n\r\n\r\nI tryed this, but output is error:\r\n\r\n    jq &#39;.&quot;http-01&quot;.&quot;domain&quot;[].&quot;main&quot;=&quot;domain.tld&quot;&#39; acme.json\r\n    jq: error (at acme.json:11483): Cannot iterate over null (null)\r\n\r\n\r\nformating example file:\r\n\r\n        {\r\n      &quot;http-01&quot;: {\r\n        &quot;Account&quot;: {\r\n          &quot;Email&quot;: &quot;mail@placeholder.tld&quot;,\r\n          &quot;Registration&quot;: {\r\n            &quot;body&quot;: {\r\n              &quot;status&quot;: &quot;valid&quot;,\r\n              &quot;contact&quot;: [\r\n                &quot;mailto:mail@placeholder.tld&quot;\r\n              ]\r\n            },\r\n            &quot;uri&quot;: &quot;https://acme-v02.api.letsencrypt.org/acme/acct/110801506&quot;\r\n          },\r\n          &quot;PrivateKey&quot;: &quot;main_priv_key_string&quot;,\r\n          &quot;KeyType&quot;: &quot;4096&quot;\r\n        },\r\n        &quot;Certificates&quot;: [\r\n          {\r\n            &quot;domain&quot;: {\r\n              &quot;main&quot;: &quot;www.some_domain.tld&quot;\r\n            },\r\n            &quot;certificate&quot;: &quot;cert_string&quot;,\r\n            &quot;key&quot;: &quot;key_string&quot;,\r\n            &quot;Store&quot;: &quot;default&quot;\r\n          },\r\n          {\r\n            &quot;domain&quot;: {\r\n              &quot;main&quot;: &quot;some_domain.tld&quot;\r\n            },\r\n            &quot;certificate&quot;: &quot;cert_string&quot;,\r\n            &quot;key&quot;: &quot;key_string&quot;,\r\n            &quot;Store&quot;: &quot;default&quot;\r\n          },\r\n          {\r\n            &quot;domain&quot;: {\r\n              &quot;main&quot;: &quot;www.some_domain2.tld&quot;\r\n            },\r\n            &quot;certificate&quot;: &quot;cert_string&quot;,\r\n            &quot;key&quot;: &quot;key_string&quot;,\r\n            &quot;Store&quot;: &quot;default&quot;\r\n          },\r\n          {\r\n            &quot;domain&quot;: {\r\n              &quot;main&quot;: &quot;some_domain2.tld&quot;\r\n            },\r\n            &quot;certificate&quot;: &quot;cert_string&quot;,\r\n            &quot;key&quot;: &quot;key_string&quot;,\r\n            &quot;Store&quot;: &quot;default&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71007765/delete-json-block-with-jq-command",
        "title": "Delete json block with jq command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644159712,
                "creation_date": 1644159712,
                "answer_id": 71008417,
                "question_id": 71008416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Open to other solutions, but one way to combine is to use [**Object Construction**][1] like\r\n\r\n```js\r\n[.[]|{nameWithOwner, defaultBranchName: .defaultBranchRef.name}]\r\n```\r\n\r\nWhich [results in the following output][2]:\r\n\r\n```json[\r\n  {\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/stack-posts&quot;,\r\n    &quot;defaultBranchName&quot;: &quot;main&quot;\r\n  },\r\n  {\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/HelloSERN&quot;,\r\n    &quot;defaultBranchName&quot;: &quot;master&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\n[1]: https://stedolan.github.io/jq/manual/#ObjectConstruction:{}\r\n[2]: https://jqplay.org/s/-6FNUDE2rj",
                "title": "Extract child key and flatten into parent object output in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644159923,
                "last_edit_date": 1644159923,
                "creation_date": 1644159851,
                "answer_id": 71008440,
                "question_id": 71008416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just update `|=` the `defaultBranchRef` field to the content of its `name` subfield:\r\n~~~sh\r\njq &#39;.[].defaultBranchRef |= .name&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;defaultBranchRef&quot;: &quot;main&quot;,\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/stack-posts&quot;\r\n  },\r\n  {\r\n    &quot;defaultBranchRef&quot;: &quot;master&quot;,\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/HelloSERN&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/YgodN5agGI)",
                "title": "Extract child key and flatten into parent object output in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1644159923,
        "creation_date": 1644159712,
        "question_id": 71008416,
        "body_markdown": "I&#39;m trying to simplify a nested JSON structure using JQ\r\n\r\n### Input\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;defaultBranchRef&quot;: {\r\n      &quot;name&quot;: &quot;main&quot;\r\n    },\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/stack-posts&quot;\r\n  },\r\n  {\r\n    &quot;defaultBranchRef&quot;: {\r\n      &quot;name&quot;: &quot;master&quot;\r\n    },\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/HelloSERN&quot;\r\n  }\r\n]\r\n```\r\n\r\n### Desired Output\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/stack-posts&quot;,\r\n    &quot;defaultBranchName&quot;: &quot;main&quot;\r\n  },\r\n  {\r\n    &quot;nameWithOwner&quot;: &quot;KyleMit/HelloSERN&quot;,\r\n    &quot;defaultBranchName&quot;: &quot;master&quot;\r\n  }\r\n]\r\n```\r\n\r\n### Attempted Solution\r\n\r\nI can retrieve each of the individual fields at any depth\r\n\r\n* [Get `nameWithOwner`](https://jqplay.org/s/6H2F1AkdAO)\r\n\r\n    ```js\r\n    [.[]|.nameWithOwner] // [&quot;KyleMit/stack-posts&quot;,&quot;KyleMit/HelloSERN&quot;]\r\n    ```\r\n\r\n* [Get `defaultBranchRef.name`](https://jqplay.org/s/ySBjK4KpsY)\r\n\r\n    ```js\r\n    [.[]|.defaultBranchRef.name] // [&quot;main&quot;,&quot;master&quot;]\r\n    ```\r\n\r\nBut can&#39;t quite get how to combine fields / selectors to return mulitple values",
        "link": "https://stackoverflow.com/questions/71008416/extract-child-key-and-flatten-into-parent-object-output-in-jq",
        "title": "Extract child key and flatten into parent object output in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644179046,
                "creation_date": 1644179046,
                "answer_id": 71011338,
                "question_id": 71011322,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to put quotes around both the field name (as it contains the `@` character), and around the query string (as it is a string):\r\n~~~sh\r\njq &#39;.media.track[] | select(.&quot;@type&quot; == &quot;General&quot;) | .Duration&#39;\r\n~~~\r\n~~~\r\n&quot;1531.263&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/sCwNyKmB3b)\r\n\r\nNote: If you want to get the output as text `1531.263` rather than a JSON string `&quot;1531.263&quot;` (in quotes), then add the `--raw-output` or `-r` flag when calling jq. ([Demo](https://jqplay.org/s/PxjGIqb-x8))",
                "title": "JQ: Extract value of a particular Key using pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1644179046,
        "creation_date": 1644178938,
        "question_id": 71011322,
        "body_markdown": "- In the following json:\r\n\r\n\r\n```bash\r\nmediainfo --Output=JSON &#39;Brazil.mp4&#39; | jq &#39;.media.track[]&#39;\r\n```\r\n\r\n```json\r\n{\r\n  &quot;@type&quot;: &quot;General&quot;,\r\n  &quot;VideoCount&quot;: &quot;1&quot;,\r\n  &quot;AudioCount&quot;: &quot;1&quot;,\r\n  &quot;FileExtension&quot;: &quot;mp4&quot;,\r\n  &quot;Format&quot;: &quot;MPEG-4&quot;,\r\n  &quot;Format_Profile&quot;: &quot;Base Media&quot;,\r\n  &quot;CodecID&quot;: &quot;isom&quot;,\r\n  &quot;CodecID_Compatible&quot;: &quot;isom/iso2/avc1/mp41&quot;,\r\n  &quot;FileSize&quot;: &quot;620542062&quot;,\r\n  &quot;Duration&quot;: &quot;1531.263&quot;,\r\n  &quot;OverallBitRate_Mode&quot;: &quot;VBR&quot;,\r\n  &quot;OverallBitRate&quot;: &quot;3241988&quot;,\r\n  &quot;FrameRate&quot;: &quot;30.000&quot;,\r\n  &quot;FrameCount&quot;: &quot;45934&quot;,\r\n  &quot;StreamSize&quot;: &quot;1454348&quot;,\r\n  &quot;HeaderSize&quot;: &quot;40&quot;,\r\n  &quot;DataSize&quot;: &quot;619584223&quot;,\r\n  &quot;FooterSize&quot;: &quot;957799&quot;,\r\n  &quot;IsStreamable&quot;: &quot;No&quot;,\r\n  &quot;File_Modified_Date&quot;: &quot;UTC 2022-02-06 19:28:26&quot;,\r\n  &quot;File_Modified_Date_Local&quot;: &quot;2022-02-06 20:28:26&quot;\r\n}\r\n{\r\n  &quot;@type&quot;: &quot;Video&quot;,\r\n  &quot;StreamOrder&quot;: &quot;0&quot;,\r\n  &quot;ID&quot;: &quot;1&quot;,\r\n  &quot;Format&quot;: &quot;AVC&quot;,\r\n  &quot;Format_Profile&quot;: &quot;High&quot;,\r\n  &quot;Format_Level&quot;: &quot;4&quot;,\r\n  &quot;Format_Settings_CABAC&quot;: &quot;Yes&quot;,\r\n  &quot;Format_Settings_RefFrames&quot;: &quot;4&quot;,\r\n  &quot;CodecID&quot;: &quot;avc1&quot;,\r\n  &quot;Duration&quot;: &quot;1531.238&quot;,\r\n  &quot;Source_Duration&quot;: &quot;1531.538&quot;,\r\n  &quot;BitRate&quot;: &quot;3019356&quot;,\r\n  &quot;Width&quot;: &quot;1912&quot;,\r\n  &quot;Width_Original&quot;: &quot;1920&quot;,\r\n  &quot;Height&quot;: &quot;1088&quot;,\r\n  &quot;Height_Original&quot;: &quot;1080&quot;,\r\n  &quot;Stored_Height&quot;: &quot;1088&quot;,\r\n  &quot;Sampled_Width&quot;: &quot;1920&quot;,\r\n  &quot;Sampled_Height&quot;: &quot;1080&quot;,\r\n  &quot;PixelAspectRatio&quot;: &quot;1.000&quot;,\r\n  &quot;DisplayAspectRatio&quot;: &quot;1.778&quot;,\r\n  &quot;Rotation&quot;: &quot;0.000&quot;,\r\n  &quot;FrameRate_Mode&quot;: &quot;VFR&quot;,\r\n  &quot;FrameRate&quot;: &quot;30.000&quot;,\r\n  &quot;FrameRate_Minimum&quot;: &quot;6.000&quot;,\r\n  &quot;FrameRate_Maximum&quot;: &quot;120.000&quot;,\r\n  &quot;FrameCount&quot;: &quot;45934&quot;,\r\n  &quot;ColorSpace&quot;: &quot;YUV&quot;,\r\n  &quot;ChromaSubsampling&quot;: &quot;4:2:0&quot;,\r\n  &quot;BitDepth&quot;: &quot;8&quot;,\r\n  &quot;ScanType&quot;: &quot;Progressive&quot;,\r\n  &quot;StreamSize&quot;: &quot;577879629&quot;,\r\n  &quot;Source_StreamSize&quot;: &quot;577914508&quot;,\r\n  &quot;Encoded_Library&quot;: &quot;x264 - core 159&quot;,\r\n  &quot;Encoded_Library_Name&quot;: &quot;x264&quot;,\r\n  &quot;Encoded_Library_Version&quot;: &quot;core 159&quot;,\r\n  &quot;Encoded_Library_Settings&quot;: &quot;cabac=1 / ref=3 / deblock=1:0:0 / analyse=0x3:0x113 / me=hex / subme=7 / psy=1 / psy_rd=1.00:0.00 / mixed_ref=1 / me_range=16 / chroma_me=1 / trellis=1 / 8x8dct=1 / cqm=0 / deadzone=21,11 / fast_pskip=1 / chroma_qp_offset=-2 / threads=12 / lookahead_threads=2 / sliced_threads=0 / nr=0 / decimate=1 / interlaced=0 / bluray_compat=0 / constrained_intra=0 / bframes=3 / b_pyramid=2 / b_adapt=1 / b_bias=0 / direct=1 / weightb=1 / open_gop=0 / weightp=2 / keyint=90 / keyint_min=46 / scenecut=0 / intra_refresh=0 / rc_lookahead=40 / rc=crf / mbtree=1 / crf=23.0 / qcomp=0.60 / qpmin=0 / qpmax=69 / qpstep=4 / vbv_maxrate=4000 / vbv_bufsize=133 / crf_max=27.0 / nal_hrd=none / filler=0 / ip_ratio=1.40 / aq=1:1.00&quot;,\r\n  &quot;extra&quot;: {\r\n    &quot;Source_Delay&quot;: &quot;-67&quot;,\r\n    &quot;Source_Delay_Source&quot;: &quot;Container&quot;,\r\n    &quot;mdhd_Duration&quot;: &quot;1531238&quot;,\r\n    &quot;CodecConfigurationBox&quot;: &quot;avcC&quot;\r\n  }\r\n}\r\n{\r\n  &quot;@type&quot;: &quot;Audio&quot;,\r\n  &quot;StreamOrder&quot;: &quot;1&quot;,\r\n  &quot;ID&quot;: &quot;2&quot;,\r\n  &quot;Format&quot;: &quot;AAC&quot;,\r\n  &quot;Format_AdditionalFeatures&quot;: &quot;LC&quot;,\r\n  &quot;CodecID&quot;: &quot;mp4a-40-2&quot;,\r\n  &quot;Duration&quot;: &quot;1531.263&quot;,\r\n  &quot;BitRate_Mode&quot;: &quot;VBR&quot;,\r\n  &quot;BitRate&quot;: &quot;215289&quot;,\r\n  &quot;BitRate_Maximum&quot;: &quot;427563&quot;,\r\n  &quot;Channels&quot;: &quot;2&quot;,\r\n  &quot;ChannelPositions&quot;: &quot;Front: L R&quot;,\r\n  &quot;ChannelLayout&quot;: &quot;L R&quot;,\r\n  &quot;SamplesPerFrame&quot;: &quot;1024&quot;,\r\n  &quot;SamplingRate&quot;: &quot;44100&quot;,\r\n  &quot;SamplingCount&quot;: &quot;67528698&quot;,\r\n  &quot;FrameRate&quot;: &quot;43.066&quot;,\r\n  &quot;FrameCount&quot;: &quot;65946&quot;,\r\n  &quot;Compression_Mode&quot;: &quot;Lossy&quot;,\r\n  &quot;StreamSize&quot;: &quot;41208085&quot;,\r\n  &quot;StreamSize_Proportion&quot;: &quot;0.06641&quot;\r\n}\r\n```  \r\n\r\n---\r\n\r\n- I want to extract the duration from the json object with key `@type`=`General`. So, I did:\r\n\r\n```bash\r\nmediainfo --Output=JSON &#39;Brazil.mp4&#39; | jq &#39;.media.track[] | select(@type==General) | .Duration&#39;\r\n```\r\n- But this leads to error\r\n\r\n```bash\r\njq: error: General/0 is not defined at &lt;top-level&gt;, line 1:\r\n.media.track[] | select(@type==General) | .Duration                               \r\njq: 1 compile error\r\n```\r\n\r\n- I am suspecting it is because the key begins with `@`. Any suggestions?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71011322/jq-extract-value-of-a-particular-key-using-pattern",
        "title": "JQ: Extract value of a particular Key using pattern"
    },
    {
        "tags": [
            "json",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644180771,
                "creation_date": 1644180771,
                "answer_id": 71011554,
                "question_id": 71011349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would this do what you want?\r\n\r\n~~~sh\r\njq --raw-output &#39;\r\n  to_entries[] | [\r\n    &quot;osd.&quot; + .key,\r\n    ( .value[0]\r\n    | .devices[],\r\n      ( .tags\r\n      | .&quot;ceph.db_device&quot; // &quot;n/a&quot;,\r\n        .&quot;ceph.wal_device&quot; // &quot;n/a&quot;\r\n      )\r\n    )\r\n  ]\r\n  | @tsv\r\n&#39;\r\n~~~\r\n~~~\r\nosd.7\t/dev/sde\t/dev/nvme0n1p5\t/dev/nvme0n1p6\r\nosd.41\t/dev/nvme1n1p13\tn/a\tn/a\r\nosd.9\t/dev/sdf\t/dev/nvme0n1p7\t/dev/nvme0n1p8\r\n~~~\r\n[Demo](https://jqplay.org/s/TZyGcXfV-z)",
                "title": "parsing jq returns null"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644238294,
        "creation_date": 1644179164,
        "last_edit_date": 1644238294,
        "question_id": 71011349,
        "body_markdown": "I have a json output\r\n\r\n    {\r\n        &quot;7&quot;: [\r\n            {\r\n                &quot;devices&quot;: [\r\n                    &quot;/dev/sde&quot;\r\n                ],\r\n                &quot;name&quot;: &quot;osd-block-dcc9b386-529c-451e-9d84-8ccc4091102b&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;ceph.crush_device_class&quot;: &quot;None&quot;,\r\n                    &quot;ceph.db_device&quot;: &quot;/dev/nvme0n1p5&quot;,\r\n                    &quot;ceph.wal_device&quot;: &quot;/dev/nvme0n1p6&quot;,\r\n                },\r\n                &quot;type&quot;: &quot;block&quot;,\r\n                &quot;vg_name&quot;: &quot;ceph-c4de9e90-853e-4569-b04f-8677ef9a8c7a&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/dev/nvme0n1p5&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;PARTUUID&quot;: &quot;69712eb4-be52-4618-ba46-e317d6d3d76e&quot;\r\n                },\r\n                &quot;type&quot;: &quot;db&quot;\r\n            }\r\n        ],\r\n        &quot;41&quot;: [\r\n            {\r\n                &quot;devices&quot;: [\r\n                    &quot;/dev/nvme1n1p13&quot;\r\n                ],\r\n                &quot;name&quot;: &quot;osd-block-97bce07f-ae98-4fdb-83a9-9fa2f35cee60&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;ceph.crush_device_class&quot;: &quot;None&quot;,\r\n                },\r\n                &quot;type&quot;: &quot;block&quot;,\r\n                &quot;vg_name&quot;: &quot;ceph-c1d48671-2a33-4615-95e3-cc1b18783f0c&quot;\r\n            }\r\n        ],\r\n        &quot;9&quot;: [\r\n            {\r\n                &quot;devices&quot;: [\r\n                    &quot;/dev/sdf&quot;\r\n                ],\r\n                &quot;name&quot;: &quot;osd-block-35323eb8-17c1-460d-8cc5-565f549e6991&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;ceph.crush_device_class&quot;: &quot;None&quot;,\r\n                    &quot;ceph.db_device&quot;: &quot;/dev/nvme0n1p7&quot;,\r\n                    &quot;ceph.wal_device&quot;: &quot;/dev/nvme0n1p8&quot;,\r\n                },\r\n                &quot;type&quot;: &quot;block&quot;,\r\n                &quot;vg_name&quot;: &quot;ceph-9488e8b8-ec18-4860-93d3-6a1ad91c698c&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;/dev/nvme0n1p7&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;PARTUUID&quot;: &quot;ef0e9588-2a20-4c2c-8b62-d73945e01322&quot;\r\n                },\r\n                &quot;type&quot;: &quot;db&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nRequired output:\r\n\r\n    osd.7 /dev/sde /dev/nvme0n1p5 /dev/nvme0n1p6\r\n    osd.41 /dev/nvme1n1p13 n/a n/a\r\n    osd.9 /dev/sdf /dev/nvme0n1p7 /dev/nvme0n1p7\r\n\r\n**Problems:**\r\nWhen I try parsing using `jq .[][].devices`, I get null values:\r\n\r\n    $ cat json | jq .[][].devices\r\n    [\r\n      &quot;/dev/sde&quot;\r\n    ]\r\n    null\r\n    [\r\n      &quot;/dev/nvme1n1p13&quot;\r\n    ]\r\n    null\r\n    [\r\n      &quot;/dev/sdf&quot;\r\n    ]\r\n    null\r\n\r\nI can solve it via `jq .[][].devices[]?`.\r\n\r\nHowever, this trick doesn&#39;t help me when I do want to see where there&#39;s no value (to print n/a instead):\r\n\r\n    $ cat json | jq &#39;.[][].tags | .&quot;ceph.db_device&quot;&#39;\r\n    &quot;/dev/nvme0n1p5&quot;\r\n    null\r\n    &quot;/dev/nvme0n1p3&quot;\r\n    null\r\n    null\r\n    &quot;/dev/nvme0n1p7&quot;\r\n    null\r\n\r\nAnd finally, I try to create a table:\r\n\r\n    $ cat json | jq -r &#39;[&quot;osd.&quot;+keys[]], [.[][].devices[]?], [.[][].tags.&quot;ceph.db_device&quot; // &quot;&quot;] | @csv&#39; | column -t -s,\r\n    &quot;osd.7&quot;           &quot;osd.41&quot;          &quot;osd.9&quot;\r\n    &quot;/dev/sde&quot;        &quot;/dev/nvme0n1p13&quot; &quot;/dev/sdf&quot;\r\n    &quot;/dev/nvme0n1p5&quot;  &quot;/dev/nvme0n1p7&quot;\r\n\r\nSo the obvious problem is that the 3rd row doesn&#39;t match the correct values.\r\n\r\nAnd the final problem is how do I transpose it from columns to rows, as detailed in the required output?",
        "link": "https://stackoverflow.com/questions/71011349/parsing-jq-returns-null",
        "title": "parsing jq returns null"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644251133,
                "last_edit_date": 1644251133,
                "creation_date": 1644250572,
                "answer_id": 71021802,
                "question_id": 71021632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This uses `IN` to check for your query strings, and `with_entries` on an array to generate the indeces for the `oid` keys.\r\n\r\n~~~sh\r\njq &#39;\r\n  map({id} + (.identifier | map(select(IN(.system.value; \r\n    &quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;,\r\n    &quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;\r\n  )).value.value) | with_entries(.key |= &quot;oid\\(. + 1)&quot;)))\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;,\r\n    &quot;oid1&quot;: &quot;04374&quot;,\r\n    &quot;oid2&quot;: &quot;INFP3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;,\r\n    &quot;oid1&quot;: &quot;04376&quot;,\r\n    &quot;oid2&quot;: &quot;INF07&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;a1ea574c-438b-443c-ad87-d31d09d581f0&quot;,\r\n    &quot;oid1&quot;: &quot;08096&quot;,\r\n    &quot;oid2&quot;: &quot;INF04&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/-1mQh1AppG)",
                "title": "jq: filter nested array objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644255596,
                "creation_date": 1644255596,
                "answer_id": 71022957,
                "question_id": 71021632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a `ruby` to do that:\r\n\r\n    ruby -r json -e &#39;\r\n    def walk(x, filt)\r\n    \trtr=[]\r\n    \trep=[&quot;uab&quot;, &quot;ub&quot;]\r\n    \tx.each{|e| \r\n    \t\trd={&quot;id&quot;=&gt;e[&quot;id&quot;]}.merge(\r\n    \t\te[&quot;identifier&quot;].\r\n    \t\t\tfilter{|ea| filt.include?(ea[&quot;system&quot;][&quot;value&quot;])}.\r\n    \t\t\tmap.with_index(1){|di, i| [&quot;#{rep[i%2]}&quot;, &quot;#{di[&quot;value&quot;][&quot;value&quot;]}&quot;]}.to_h)\r\n    \t\trtr &lt;&lt; rd\t\t\r\n    \t\t}\r\n    \trtr\r\n    end\r\n    \t\r\n    data=JSON.parse($&lt;.read)\r\n    puts walk(data, [&quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;, &quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;]).to_json\r\n    &#39; file \r\n\r\nPrints:\r\n\r\n    [{&quot;id&quot;:&quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;,&quot;ub&quot;:&quot;04374&quot;,&quot;uab&quot;:&quot;INFP3&quot;},{&quot;id&quot;:&quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;,&quot;ub&quot;:&quot;04376&quot;,&quot;uab&quot;:&quot;INF07&quot;},{&quot;id&quot;:&quot;a1ea574c-438b-443c-ad87-d31d09d581f0&quot;,&quot;ub&quot;:&quot;08096&quot;,&quot;uab&quot;:&quot;INF04&quot;}]",
                "title": "jq: filter nested array objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1644255596,
        "creation_date": 1644249854,
        "last_edit_date": 1644250903,
        "question_id": 71021632,
        "body_markdown": "Here my documents:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;,\r\n    &quot;identifier&quot;: [\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;04374&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;INFP3&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;CBOU035&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;,\r\n    &quot;identifier&quot;: [\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;04376&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;INF07&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;S527918&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;a1ea574c-438b-443c-ad87-d31d09d581f0&quot;,\r\n    &quot;identifier&quot;: [\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;08096&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;INF04&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;value&quot;: &quot;urn:oid:INVENTAT&quot;\r\n        },\r\n        &quot;value&quot;: {\r\n          &quot;value&quot;: &quot;5635132&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI need to filter `.identifier` where `system.value=&quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;`  or `system.value=&quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;` and pick `.value.value`.\r\n\r\nDesired output:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;,\r\n    &quot;oid1&quot;: &quot;04374&quot;,\r\n    &quot;oid2&quot;: &quot;INFP3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;,\r\n    &quot;oid1&quot;: &quot;04376&quot;,\r\n    &quot;oid2&quot;: &quot;INF07&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;a1ea574c-438b-443c-ad87-d31d09d581f0&quot;,\r\n    &quot;oid1&quot;: &quot;08096&quot;,\r\n    &quot;oid2&quot;: &quot;INF04&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve tried:\r\n\r\n```\r\nmap(\r\n    {\r\n        id,\r\n        oid1: select(.identifier?[]?.system.value == &quot;urn:oid:2.16.724.4.9.20.91-INVENTAT&quot;) | .identifier[].value.value,\r\n        oid2: select(.identifier?[]?.system.value == &quot;urn:oid:2.16.724.4.9.20.2-INVENTAT&quot;) | .identifier[].value.value\r\n    }\r\n)\r\n```\r\n\r\nBut output is not what I need: you can find it on [this jqplay](https://jqplay.org/s/wmFEICeuoy).\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/71021632/jq-filter-nested-array-objects",
        "title": "jq: filter nested array objects"
    },
    {
        "tags": [
            "json",
            "jq",
            "activecampaign"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644265666,
                "creation_date": 1644265666,
                "answer_id": 71024968,
                "question_id": 71024899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to get both lists as separate arrays, simply call them one after another, separated by a comma `,`:\r\n~~~\r\n.invoice | .main_roles, .cc_roles | map({ display: .name , value: .name })\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;display&quot;: &quot;Agent&quot;,\r\n    &quot;value&quot;: &quot;Agent&quot;\r\n  },\r\n  {\r\n    &quot;display&quot;: &quot;Customer&quot;,\r\n    &quot;value&quot;: &quot;Customer&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;display&quot;: &quot;Manager&quot;,\r\n    &quot;value&quot;: &quot;Manager&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/yF-Da_vhjS)\r\n\r\nIf you want them combined into one array, add them together using `+`:\r\n~~~\r\n.invoice | .main_roles + .cc_roles | map({ display: .name , value: .name })\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;display&quot;: &quot;Agent&quot;,\r\n    &quot;value&quot;: &quot;Agent&quot;\r\n  },\r\n  {\r\n    &quot;display&quot;: &quot;Customer&quot;,\r\n    &quot;value&quot;: &quot;Customer&quot;\r\n  },\r\n  {\r\n    &quot;display&quot;: &quot;Manager&quot;,\r\n    &quot;value&quot;: &quot;Manager&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/ysBhfdZtjD)",
                "title": "How to get multiple list from one response in App Studio using jq and map? (Active Campaign)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644265666,
        "creation_date": 1644265292,
        "question_id": 71024899,
        "body_markdown": "I have following JSON which I get using API. The json has 2 list, 1- main_roles and 2- cc_roles. Using following code I can get 1 list. But I want to get both list in dropdown(display, value).\r\n\r\nHow can I get both list 1- main_roles and 2- cc_roles in 1 jq using map?\r\n\r\nJSON\r\n\r\n    {\r\n        &quot;invoice&quot;: {\r\n            &quot;invoice_id&quot;: &quot;b494a46396e47726873708f71a71a228ba2782fa&quot;,\r\n            &quot;main_roles&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;Agent&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;Customer&quot;\r\n                }\r\n            ],\r\n            &quot;cc_roles&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;Manager&quot;\r\n                }\r\n            ]        \r\n        }\r\n    }\r\n\r\nJSON Code\r\n-------------\r\n\r\n    &quot;select&quot;: {\r\n      &quot;label&quot;: &quot;Invoice&quot;,\r\n      &quot;form_fields&quot;: [\r\n    \t{\r\n    \t  &quot;label&quot;: &quot;Select Role&quot;,\r\n    \t  &quot;id&quot;: &quot;selectRole&quot;,\r\n    \t  &quot;type&quot;: &quot;dropdown&quot;,\r\n    \t  &quot;required&quot;: true,\r\n    \t  &quot;options&quot;: {\r\n    \t\t&quot;!pipe&quot;: [\r\n    \t\t  {\r\n    \t\t\t&quot;!http&quot;: {\r\n    \t\t\t  &quot;method&quot;: &quot;GET&quot;,\r\n    \t\t\t  &quot;path&quot;: &quot;https://api.test.com/getroles&quot;\r\n    \t\t\t}\r\n    \t\t  },\r\n    \t\t  {\r\n    \t\t\t&quot;!jq&quot;: &quot;.invoice.main_roles | map({ display: .name , value: .name })&quot;\r\n    \t\t  }\r\n    \t\t]\r\n    \t  }\r\n    \t}\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/71024899/how-to-get-multiple-list-from-one-response-in-app-studio-using-jq-and-map-acti",
        "title": "How to get multiple list from one response in App Studio using jq and map? (Active Campaign)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644268315,
                "last_edit_date": 1644268315,
                "creation_date": 1644267612,
                "answer_id": 71025337,
                "question_id": 71025169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If &quot;my documents&quot; is stored in a file called `mine.json` and the &quot;other side&quot; is the contents of a file `others.json`, then `--slurpfile` the others and add them based on a `select`:\r\n\r\n~~~sh\r\njq --slurpfile others others.json &#39;\r\n  . as $mine\r\n  | . + {ids: ($others | map(          \r\n    select(.oid1 == $mine.oid1 and .oid2 == $mine.oid2)\r\n    | {id, info}\r\n  ))}\r\n&#39; mine.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;name1&quot;,\r\n  &quot;oid1&quot;: &quot;oid1-1&quot;,\r\n  &quot;oid2&quot;: &quot;oid2-1&quot;,\r\n  &quot;ids&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;id1&quot;,\r\n      &quot;info&quot;: &quot;info1&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;id2&quot;,\r\n      &quot;info&quot;: &quot;info2&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;name2&quot;,\r\n  &quot;oid1&quot;: &quot;oid1-2&quot;,\r\n  &quot;oid2&quot;: &quot;oid2-2&quot;,\r\n  &quot;ids&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;id3&quot;,\r\n      &quot;info&quot;: &quot;info3&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/BGysVRwxmI) (using an object with fields `mine` and `others` instead of files)\r\n",
                "title": "jq: nesting objects according to two keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644268315,
        "creation_date": 1644266708,
        "question_id": 71025169,
        "body_markdown": "Here my documents:\r\n\r\n```lang-json\r\n{\r\n   &quot;name&quot;:&quot;name1&quot;,\r\n   &quot;oid1&quot;:&quot;oid1-1&quot;,\r\n   &quot;oid2&quot;:&quot;oid2-1&quot;\r\n}{\r\n   &quot;name&quot;:&quot;name2&quot;,\r\n   &quot;oid1&quot;:&quot;oid1-2&quot;,\r\n   &quot;oid2&quot;:&quot;oid2-2&quot;\r\n}\r\n```\r\n\r\nBy other side:\r\n\r\n```lang-json\r\n{\r\n  &quot;id&quot;: &quot;id1&quot;,\r\n  &quot;info&quot;: &quot;info1&quot;,\r\n  &quot;oid1&quot;:&quot;oid1-1&quot;,\r\n  &quot;oid2&quot;:&quot;oid2-1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;id2&quot;,\r\n  &quot;info&quot;: &quot;info2&quot;,\r\n  &quot;oid1&quot;:&quot;oid1-1&quot;,\r\n  &quot;oid2&quot;:&quot;oid2-1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;id3&quot;,\r\n  &quot;info&quot;: &quot;info3&quot;,\r\n  &quot;oid1&quot;:&quot;oid1-2&quot;,\r\n  &quot;oid2&quot;:&quot;oid2-2&quot;\r\n}\r\n```\r\n\r\nI need to nest just above documents into first ones:\r\n\r\n```lang-json\r\n{\r\n   &quot;name&quot;:&quot;name1&quot;,\r\n   &quot;oid1&quot;:&quot;oid1-1&quot;,\r\n   &quot;oid2&quot;:&quot;oid2-1&quot;,\r\n   &quot;ids&quot;:[\r\n      {\r\n         &quot;id&quot;:&quot;id1&quot;,\r\n         &quot;info&quot;:&quot;info1&quot;\r\n      },\r\n      {\r\n         &quot;id&quot;:&quot;id2&quot;,\r\n         &quot;info&quot;:&quot;info2&quot;\r\n      }\r\n   ]\r\n}{\r\n   &quot;name&quot;:&quot;name2&quot;,\r\n   &quot;oid1&quot;:&quot;oid1-2&quot;,\r\n   &quot;oid2&quot;:&quot;oid2-2&quot;,\r\n   &quot;ids&quot;:[\r\n      {\r\n         &quot;id&quot;:&quot;id3&quot;,\r\n         &quot;info&quot;:&quot;info3&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nSo, I need to nest into first documents, which ones `parent.oid1 == nest.oid1 &amp;&amp; parent.oid2 == nest.oid2`.\r\n\r\nI&#39;ve not been to get anything reasonable.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/71025169/jq-nesting-objects-according-to-two-keys",
        "title": "jq: nesting objects according to two keys"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 89455,
                    "reputation": 11388,
                    "user_id": 246801,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/54ac1ed63d1eb6bfc3eb0d89a8c2e135?s=256&d=identicon&r=PG",
                    "display_name": "Zach Young",
                    "link": "https://stackoverflow.com/users/246801/zach-young"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644347236,
                "post_id": 71027805,
                "comment_id": 125581609,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1689685615,
                "last_edit_date": 1689685615,
                "creation_date": 1644286573,
                "answer_id": 71027831,
                "question_id": 71027805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe you were looking for the `IN` (not `in`) function. Also, it takes a stream of elements, not an array.\r\n~~~\r\nmap(IN(&quot;ms&quot;, &quot;is&quot;, &quot;bad&quot;))\r\n~~~\r\n~~~json\r\n[false,true,true]\r\n~~~\r\n[Demo](https://jqplay.org/s/060XvkDHyS)\r\n\r\n---\r\nFrom the [manual](https://stedolan.github.io/jq/manual):\r\n\r\n&gt; ## [in](https://jqlang.github.io/jq/manual/#in)\r\n&gt; The builtin function `in` returns whether or not the input key is in the given object, or the input index corresponds to an element in the given array. It is, essentially, an inversed version of `has`.\r\n\r\n&gt; ## IN\r\n&gt; This builtin outputs `true` if `.` appears in the given stream, otherwise it outputs `false`.",
                "title": "How to correctly use jq&#39;s in() function"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644287012,
                "creation_date": 1644287012,
                "answer_id": 71027862,
                "question_id": 71027805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was using `in()` incorrectly.\r\n\r\nhttps://jqplay.org/s/FJcNTgplG6\r\n\r\n```\r\nfilter:\r\nmap(in([&quot;apple&quot;,&quot;is&quot;,&quot;bad&quot;]))\r\ninput:\r\n[3, 2, 1, 0]\r\noutput:\r\n[\r\n  false,\r\n  true,\r\n  true,\r\n  true\r\n]\r\n```\r\nIt&#39;s testing if the indexes of the filter array are found in the input array.",
                "title": "How to correctly use jq&#39;s in() function"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1689685615,
        "creation_date": 1644286309,
        "question_id": 71027805,
        "body_markdown": "I&#39;m trying to understand `in()` function of `jq`.\r\n\r\nhttps://jqplay.org/s/BR1KbCjP8u\r\n\r\n```\r\nfilter:\r\nmap( in([&quot;ms&quot;, &quot;is&quot;, &quot;bad&quot;]) )\r\ninput:\r\n[&quot;apple&quot;,&quot;is&quot;,&quot;bad&quot;]\r\n```\r\n\r\nI expected the output `[false,true,true]` because for each element of the input array:\r\n\r\n 1. &quot;apple&quot; is not in [&quot;ms&quot;, &quot;is&quot;, &quot;bad&quot;] so false\r\n 2. &quot;is&quot; is in [&quot;ms&quot;, &quot;is&quot;, &quot;bad&quot;] so true\r\n 3. &quot;bad&quot; is in [&quot;ms&quot;, &quot;is&quot;, &quot;bad&quot;] so true\r\n\r\nObviously this is wrong because I get error:\r\n```\r\njq: error (at &lt;stdin&gt;:0): Cannot check whether array has a string key\r\nexit status 5\r\n```\r\nWhat is wrong with this and how to correctly use the `in()` function when passing `[&quot;ms&quot;,&quot;is&quot;,&quot;bad&quot;]` in the filter? I want to check if each element in the input array is found in this list.",
        "link": "https://stackoverflow.com/questions/71027805/how-to-correctly-use-jqs-in-function",
        "title": "How to correctly use jq&#39;s in() function"
    },
    {
        "tags": [
            "json",
            "jq",
            "geojson"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1644298922,
                "creation_date": 1644298922,
                "answer_id": 71029069,
                "question_id": 71029053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could wrap your whole filter into brackets\r\n~~~sh\r\njq &#39;[.features[].properties]&#39; file.geojson\r\n~~~\r\n[Demo](https://jqplay.org/s/IgCPhvDUms)\r\n\r\n\r\nOr take advantage of the fact that `.features` is already an array and just `map` its contents.\r\n~~~sh\r\njq &#39;.features | map(.properties)&#39; file.geojson\r\n~~~\r\n[Demo](https://jqplay.org/s/tD_uYMg7vx)\r\n\r\nBoth output\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;value1&quot;: 4.7557783e-06,\r\n    &quot;value2&quot;: 0\r\n  },\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;value1&quot;: 1.4931199e-05,\r\n    &quot;value2&quot;: 5\r\n  }\r\n]\r\n~~~",
                "title": "Converting GeoJSON into a flat JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1644440948,
        "creation_date": 1644298769,
        "last_edit_date": 1644344278,
        "question_id": 71029053,
        "body_markdown": "Let&#39;s say I have the following GeoJSON file:\r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;name&quot;: &quot;geojson&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;id&quot;: 1,\r\n        &quot;value1&quot;: 4.7557783e-06,\r\n        &quot;value2&quot;: 0\r\n      },\r\n      &quot;geometry&quot;: null\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;id&quot;: 1,\r\n        &quot;value1&quot;: 1.4931199e-05,\r\n        &quot;value2&quot;: 5\r\n      },\r\n      &quot;geometry&quot;: null\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI know that with the line `cat file.geojson | jq &#39;.features[].properties&#39;` I can get the following result:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;value1&quot;: 4.7557783e-06,\r\n  &quot;value2&quot;: 0 \r\n}   \r\n{     \r\n  &quot;id&quot;: 1,\r\n  &quot;value1&quot;: 1.4931199e-05,\r\n  &quot;value2&quot;: 5\r\n}       \r\n```\r\n\r\nHowever, I&#39;d like to have this result inside an array like the following:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;value1&quot;: 4.7557783e-06,\r\n    &quot;value2&quot;: 0\r\n  },\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;value1&quot;: 1.4931199e-05,\r\n    &quot;value2&quot;: 5\r\n  }\r\n]\r\n```\r\n\r\nHow can I add the brackets `[]` and the proper commas `,` with `jq` to form this last flat JSON file?",
        "link": "https://stackoverflow.com/questions/71029053/converting-geojson-into-a-flat-json-with-jq",
        "title": "Converting GeoJSON into a flat JSON with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644311943,
                "last_edit_date": 1644311943,
                "creation_date": 1644311640,
                "answer_id": 71031252,
                "question_id": 71031043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your program input, `reduced_pacient.json` is a stream of three objects. As you have set the `--slurp` flag, the initial context of your script is an array of three elements.\r\n\r\nFirst, you&#39;re calling `reduce_generateId` which by iteration `.[]` decomposes the array into its three items. Thus `reduce_generateId` has three outputs.\r\n\r\nNext, these are fed by pipe into your `reduce_generalPractitioner` function which consequently is run three times. Each run produces your `$dict` once, yielding three times in total.\r\n\r\nRemember: Although your function `reduce_generalPractitioner` has an input parameter, it also has (just like every filter in jq) a general input context (addressed through piping), which determines the value of `.` and subsequently the number of runs.",
                "title": "jq: reduce and map combination"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644312511,
        "creation_date": 1644310638,
        "last_edit_date": 1644312511,
        "question_id": 71031043,
        "body_markdown": "Here my current jq script:\r\n\r\n```\r\ndef reduce_generateId:\r\n    .[] | (. + {generalPractitionerCode: (.UAB_UP + &quot;-&quot; + .UAB_COD_UAB)});\r\n\r\ndef reduce_generalPractitioner($practitionerRole):\r\n    (reduce $practitionerRole[] as $g (\r\n\t\t{};\r\n\t\t.[$g.oid1 + &quot;-&quot; + $g.oid2].generalPractitioner += ($g | [.id])\r\n\t)) as $dict\r\n    | $dict;\r\n\r\nreduce_generateId | reduce_generalPractitioner($generalPractitioner)\r\n```\r\n\r\nMy jq command is:\r\n\r\n```\r\njq -s -f merge-patient.jq --argfile generalPractitioner reduced_ids.json reduced_pacient.json\r\n```\r\n\r\nWhere `reduced_pacient.json`:\r\n\r\n```lang-json\r\n{ &quot;UAB_UP&quot;: &quot;00003&quot;, &quot;UAB_COD_UAB&quot;: &quot;3212&quot;, &quot;INVENTAT&quot;: &quot;02&quot;}\r\n{ &quot;UAB_UP&quot;: &quot;00006&quot;, &quot;UAB_COD_UAB&quot;: &quot;5881&quot;, &quot;INVENTAT&quot;: &quot;102&quot;}\r\n{ &quot;UAB_UP&quot;: &quot;00006&quot;, &quot;UAB_COD_UAB&quot;: &quot;5751&quot;, &quot;INVENTAT&quot;: &quot;102&quot;}\r\n```\r\n\r\nand `reduced_ids.json`:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;,\r\n    &quot;oid1&quot;: &quot;04374&quot;,\r\n    &quot;oid2&quot;: &quot;INFP3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;,\r\n    &quot;oid1&quot;: &quot;04376&quot;,\r\n    &quot;oid2&quot;: &quot;INF07&quot;\r\n  }\r\n]\r\n```\r\n\r\nAs you can see, `redux_generalPractitioner` returns `$dict` straightforwardly. I&#39;m getting this:\r\n\r\n```lang-json\r\n{\r\n  &quot;04374-INFP3&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;\r\n    ]\r\n  },\r\n  &quot;04376-INF07&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;04374-INFP3&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;\r\n    ]\r\n  },\r\n  &quot;04376-INF07&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;04374-INFP3&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;\r\n    ]\r\n  },\r\n  &quot;04376-INF07&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAs you can see, I&#39;m getting `$dict` three times.\r\n\r\nI don&#39;t quite figure out why it&#39;s generating three `$dict` instead of one.\r\n\r\nIf I only perform `reduce_generalPractitioner($generalPractitioner)`, I&#39;m getting:\r\n\r\n```lang-json\r\n{\r\n  &quot;04374-INFP3&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;3e67b455-8cdb-4bc0-a5e1-f90253870fc9&quot;\r\n    ]\r\n  },\r\n  &quot;04376-INF07&quot;: {\r\n    &quot;generalPractitioner&quot;: [\r\n      &quot;0f22e5ff-70bc-457f-bdaf-7afe86d478de&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/71031043/jq-reduce-and-map-combination",
        "title": "jq: reduce and map combination"
    }
]