[
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1525189754,
                "last_edit_date": 1525189754,
                "creation_date": 1525189319,
                "answer_id": 50119471,
                "question_id": 50119067,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `to_entries` / `from_entries`, like this:\r\n\r\n    jq &#39;to_entries|sort_by(.value.size)|from_entries&#39; file.json\r\n\r\n`to_entries` will transform your input object into a list of `key`/`value` pair objects:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;a&quot;,\r\n        &quot;value&quot;: {\r\n          &quot;size&quot;: 3\r\n        }\r\n      },\r\n      ...\r\n      {\r\n        &quot;key&quot;: &quot;c&quot;,\r\n        &quot;value&quot;: {\r\n          &quot;size&quot;: 1\r\n        }\r\n      }\r\n    ]\r\n\r\nThat allows to apply `sort_by(.value.size)` to that list and then convert it back to an object using `from_entries`.",
                "title": "How can you sort a JSON object efficiently using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1525225237,
        "creation_date": 1525187817,
        "last_edit_date": 1525225237,
        "question_id": 50119067,
        "body_markdown": "I&#39;ve got JSON in the format\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;size&quot;:3\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;size&quot;:2\r\n      },\r\n      &quot;c&quot;: {\r\n        &quot;size&quot;:1\r\n      }\r\n    }\r\nI need to sort it by size, e.g.:\r\n\r\n    {\r\n      &quot;c&quot;: {\r\n        &quot;size&quot;: 1\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;size&quot;: 2\r\n      },\r\n      &quot;a&quot;: {\r\n        &quot;size&quot;: 3\r\n      }\r\n    }\r\n\r\nI have found a way to do it, e.g.:\r\n\r\n    . as $in | keys_unsorted | map ({&quot;key&quot;: ., &quot;size&quot; : $in[.].size}) | sort_by(.size) | map(.key | {(.) : $in[.]}) | add\r\n\r\nbut this seems quite complex so I&#39;m hoping there&#39;s a simpler way that I&#39;ve overlooked?",
        "link": "https://stackoverflow.com/questions/50119067/how-can-you-sort-a-json-object-efficiently-using-jq",
        "title": "How can you sort a JSON object efficiently using JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525266098,
                "post_id": 50130304,
                "comment_id": 87288544,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1525339160,
                "last_edit_date": 1525339160,
                "creation_date": 1525335515,
                "answer_id": 50150198,
                "question_id": 50130304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Whenever you are given an array of key/value pairs (the tags here) and you want to extract values by their key, it&#39;ll be easier to map them into an object so you can access them directly. Functions like `from_entries` will work well with this.\r\n\r\nHowever, since you&#39;re also trying to retrieve values not within this tag array, you can approach it a little differently to save some steps. Using `reduce` or `foreach`, you can go through each of the tags and add it to an object that holds all the values you&#39;re interested in. Then you can map the values you want into an array then convert to a csv row.\r\n\r\nSo if your goal is to create rows of `Tags[Name], InstaceId, Tags[Client], Tags[CostCenter]` for each instance, you could do this:\r\n\r\n    # for each instance\r\n    .Reservations[].Instances[]\r\n    # map each instance to an object where we can easily extract the values\r\n      | reduce .Tags[] as $t (\r\n            { InstanceId }; # we want the InstanceId from the instance\r\n            .[$t.Key] = $t.Value # add the values to the object\r\n        )\r\n    # map the desired values to an array\r\n      | [ .Name, .InstanceId, .Client, .CostCenter ]\r\n    # convert to csv\r\n      | @csv\r\n\r\nAnd the good news is, if `Name`, `Client`, or `CostCenter` doesn&#39;t exist in the tag array, or even `InstanceId`, then they&#39;ll just be `null` which becomes empty when converted to csv.",
                "title": "AWS CLI / jq - transforming JSON with tags, and showing information even for non-defined tags"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1525339160,
        "creation_date": 1525249966,
        "last_edit_date": 1525265897,
        "question_id": 50130304,
        "body_markdown": "I&#39;m facing an issue when trying to process output of &#39;aws ec2 describe-instances&#39; command with &#39;jq&#39;, and I really need some help.\r\n\r\nI want to transform JSON output into CSV file with the list of all instances, with\r\ncolumns &#39;Name,InstanceId,Tag-Client,Tag-CostCenter&#39;.\r\n\r\nI&#39;ve been using jq&#39;s select with a command like:\r\n\r\n    aws ec2 describe-instances |\r\n      jq -r &#39;.Reservations[].Instances[]\r\n        | (.Tags[]|select(.Key==&quot;Name&quot;)|.Value) + &quot;,&quot; + .InstanceId + &quot;,&quot; \r\n          + (.Tags[]|select(.Key==&quot;Client&quot;)|.Value) + &quot;,&quot;\r\n          + (.Tags[]|select(.Key==&quot;CostCenter&quot;)|.Value)&#39;\r\n\r\nHowever using selects in this way, only those entries containing all the tags are displayed, not showing those that contain one of the tags only.\r\n\r\nI understand the behavior, which is similar to a grep, but I&#39;m trying to figure out if it&#39;s possible to perform this operation using jq, so in the case that one tag is not defined, would just return string &quot;&quot; and not remove the whole line.\r\n\r\nI&#39;ve found a reference about using &#39;if&#39; clauses in jq ([https://ilya-sher.org/2016/05/11/most-jq-you-will-ever-need/], but wondering in anyone has resolved such case without having to make this logic or splitting the command in different executions.",
        "link": "https://stackoverflow.com/questions/50130304/aws-cli-jq-transforming-json-with-tags-and-showing-information-even-for-non",
        "title": "AWS CLI / jq - transforming JSON with tags, and showing information even for non-defined tags"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1525263446,
                "creation_date": 1525263446,
                "answer_id": 50134486,
                "question_id": 50131945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t worry, **`jq`** alone will do the job:\r\n\r\n    jq &#39;def sub_base($base): if (startswith(&quot;BASE&quot;) | not) then sub($base; &quot;BASE&quot;) else . end;\r\n        map(if .[&quot;ARG&quot;] then ((.ARG[] | select(startswith(&quot;BASE=&quot;)) | split(&quot;=&quot;)[1]) as $base\r\n                | to_entries\r\n                | map(if (.value | type == &quot;string&quot;) then .value |= sub_base($base)\r\n                      else .value |= map(sub_base($base)) end)\r\n                | from_entries)\r\n            else . end)&#39; input.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;DIR&quot;: &quot;BASE/a/b/c&quot;,\r\n        &quot;OUT&quot;: &quot;BASE/x/y/z&quot;,\r\n        &quot;ARG&quot;: [\r\n          &quot;aaa&quot;,\r\n          &quot;bbb&quot;,\r\n          &quot;BASE/a&quot;,\r\n          &quot;BASE=/foo/bar&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;DIR&quot;: &quot;BASE/d/e/f&quot;,\r\n        &quot;OUT&quot;: &quot;BASE/x/y/z&quot;,\r\n        &quot;ARG&quot;: [\r\n          &quot;ccc&quot;,\r\n          &quot;ddd&quot;,\r\n          &quot;BASE/b&quot;,\r\n          &quot;BASE=/foo/baz&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to substitute strings in JSON with jq based on the input"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1525264402,
                "last_edit_date": 1525264402,
                "creation_date": 1525264029,
                "answer_id": 50134648,
                "question_id": 50131945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `jq`:\r\n\r\n    #!/usr/bin/jq -f\r\n\r\n    # fix-base.jq\r\n    def fix_base:\r\n      (.ARG[] | select(startswith(&quot;BASE=&quot;)) | split(&quot;=&quot;)[1]) as $base\r\n      | .DIR?|=&quot;BASE&quot;+ltrimstr($base)\r\n      | .OUT?|=&quot;BASE&quot;+ltrimstr($base)\r\n      | .ARG|=map(if startswith($base) then &quot;BASE&quot;+ltrimstr($base) else . end)\r\n      ;\r\n    \r\n    map(if .ARG? then fix_base  else . end)\r\n\r\nYou can run it like this:\r\n\r\n    jq -f fix-base.jq input.json\r\n\r\nor make it an executable like this:\r\n\r\n    chmod +x fix-base.jq\r\n    ./fix-base.jq input.json",
                "title": "How to substitute strings in JSON with jq based on the input"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1525271263,
                "last_edit_date": 1525271263,
                "creation_date": 1525264935,
                "answer_id": 50134933,
                "question_id": 50131945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some helper functions make the going much easier.  The first is generic and worthy perhaps of your standard library:\r\n\r\n    # Returns the integer index, $i, corresponding to the first element\r\n    # at which f is truthy, else null\r\n    def indexof(f):\r\n      label $out\r\n      | foreach .[] as $x (null; .+1; \r\n          if ($x|f) then (.-1, break $out) else empty end) // null;\r\n\r\n    # Change the string $base to BASE using gsub\r\n    def munge($base):\r\n      if type == &quot;string&quot; and (test(&quot;^BASE=&quot;)|not) then gsub($base; &quot;BASE&quot;)\r\n      elif type==&quot;array&quot; then map(munge($base))\r\n      elif type==&quot;object&quot; then map_values(munge($base))\r\n      else .\r\n      end;\r\n\r\nAnd now the easy part:\r\n\r\n    map(if has(&quot;ARG&quot;) \r\n        then (.ARG|indexof(test(&quot;^BASE=&quot;))) as $ix\r\n        | if $ix\r\n          then (.ARG[$ix]|sub(&quot;^BASE=&quot;;&quot;&quot;)) as $base | munge($base)\r\n          else . end \r\n        else . end )\r\n\r\nSome points to note:\r\n\r\n* You may wish to use `sub` rather than `gsub` in `munge`;\r\n* The above solution assumes you want to make the change in all keys, not just &quot;DIR&quot;, &quot;OUT&quot;, and &quot;ARG&quot;\r\n* The above solution allows specifications of BASE that include one or more occurrences of &quot;=&quot;.\r\n\r\n",
                "title": "How to substitute strings in JSON with jq based on the input"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1525271263,
        "creation_date": 1525255415,
        "last_edit_date": 1525260228,
        "question_id": 50131945,
        "body_markdown": "Given the input in this form\r\n\r\n    [\r\n      {\r\n        &quot;DIR&quot; : &quot;/foo/bar/a/b/c&quot;,\r\n        &quot;OUT&quot; : &quot;/foo/bar/x/y/z&quot;,\r\n        &quot;ARG&quot; : [ &quot;aaa&quot;, &quot;bbb&quot;, &quot;/foo/bar/a&quot;, &quot;BASE=/foo/bar&quot; ]\r\n      },\r\n      {\r\n        &quot;DIR&quot; : &quot;/foo/baz/d/e/f&quot;,\r\n        &quot;OUT&quot; : &quot;/foo/baz/x/y/z&quot;,\r\n        &quot;ARG&quot; : [ &quot;ccc&quot;, &quot;ddd&quot;, &quot;/foo/baz/b&quot;, &quot;BASE=/foo/baz&quot; ]\r\n      },\r\n      { \r\n        &quot;foo&quot; : &quot;bar&quot;\r\n      }\r\n    ]\r\n\r\n\r\nI&#39;m trying to find out how to make jq transform that into this:\r\n\r\n    [\r\n      {\r\n        &quot;DIR&quot; : &quot;BASE/a/b/c&quot;,\r\n        &quot;OUT&quot; : &quot;BASE/x/y/z&quot;,\r\n        &quot;ARG&quot; : [ &quot;aaa&quot;, &quot;bbb&quot;, &quot;BASE/a&quot;, &quot;BASE=/foo/bar&quot; ]\r\n      },\r\n\r\n      {\r\n        &quot;DIR&quot; : &quot;BASE/d/e/f&quot;,\r\n        &quot;OUT&quot; : &quot;BASE/x/y/z&quot;,\r\n        &quot;ARG&quot; : [ &quot;ccc&quot;, &quot;ddd&quot;, &quot;BASE/b&quot;, &quot;BASE=/foo/baz&quot; ]\r\n      },\r\n      { \r\n        &quot;foo&quot; : &quot;bar&quot;\r\n      }\r\n    ]\r\n\r\nIn other words, objects having an `&quot;ARG&quot;` array, containing a string that starts with `&quot;BASE=&quot;` should use the string after `&quot;BASE=&quot;`, e.g. `&quot;/foo&quot;` to substitute other string values that start with &quot;`/foo&quot;` (except the `&quot;BASE=/foo&quot;` which should remain unchanged&quot;)\r\n\r\nI&#39;m not even close to finding a solution myself, and at this point I&#39;m unsure that jq alone will do the job.",
        "link": "https://stackoverflow.com/questions/50131945/how-to-substitute-strings-in-json-with-jq-based-on-the-input",
        "title": "How to substitute strings in JSON with jq based on the input"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1525279493,
                "creation_date": 1525279493,
                "answer_id": 50139662,
                "question_id": 50139278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Straightforwardly (specify all of your conditions within `select` function):\r\n\r\n    jq -c &#39;.b[] | select(.x == &quot;bar&quot; or (.s | endswith(&quot;X&quot;)))&#39; file.json\r\n\r\nThe output:\r\n\r\n    {&quot;x&quot;:&quot;bar&quot;,&quot;s&quot;:&quot;FX&quot;,&quot;f&quot;:[&quot;blorg&quot;,&quot;blarg&quot;,&quot;blurb&quot;],&quot;v&quot;:true}\r\n    {&quot;x&quot;:&quot;bar&quot;,&quot;s&quot;:&quot;EX&quot;,&quot;f&quot;:[&quot;blorg&quot;,&quot;blarg&quot;,&quot;bloob&quot;],&quot;v&quot;:false}\r\n    {&quot;x&quot;:&quot;bar&quot;,&quot;s&quot;:&quot;XT&quot;,&quot;f&quot;:[&quot;blorg&quot;,&quot;blart&quot;,&quot;bloop&quot;],&quot;v&quot;:true}\r\n    {&quot;x&quot;:&quot;bar&quot;,&quot;s&quot;:&quot;IJ&quot;,&quot;f&quot;:[&quot;blorg&quot;,&quot;bleep&quot;,&quot;glarp&quot;],&quot;v&quot;:true}\r\n    {&quot;x&quot;:&quot;foo&quot;,&quot;s&quot;:&quot;IX&quot;,&quot;f&quot;:[&quot;porg&quot;,&quot;parg&quot;,&quot;pork&quot;,&quot;peep&quot;],&quot;v&quot;:true}\r\n\r\n",
                "title": "JQ object selection without endless filter chains"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1525290941,
        "creation_date": 1525278077,
        "last_edit_date": 1525290941,
        "question_id": 50139278,
        "body_markdown": "I&#39;m having difficulty using `jq (1.5)` to parse deeply nested JSON structures, and I feel like I&#39;m using it wrong.  Take this example JSON input:\r\n\r\n    {\r\n     &quot;a&quot;:[],\r\n     &quot;b&quot;:[\r\n      {&quot;x&quot;:&quot;bar&quot;, &quot;s&quot;:&quot;FX&quot;, &quot;f&quot;:[&quot;blorg&quot;,&quot;blarg&quot;,&quot;blurb&quot;], &quot;v&quot;:true},\r\n      {&quot;x&quot;:&quot;bar&quot;, &quot;s&quot;:&quot;EX&quot;, &quot;f&quot;:[&quot;blorg&quot;,&quot;blarg&quot;,&quot;bloob&quot;], &quot;v&quot;:false},\r\n      {&quot;x&quot;:&quot;bar&quot;, &quot;s&quot;:&quot;XT&quot;, &quot;f&quot;:[&quot;blorg&quot;,&quot;blart&quot;,&quot;bloop&quot;], &quot;v&quot;:true},\r\n      {&quot;x&quot;:&quot;bar&quot;, &quot;s&quot;:&quot;IJ&quot;, &quot;f&quot;:[&quot;blorg&quot;,&quot;bleep&quot;,&quot;glarp&quot;], &quot;v&quot;:true},\r\n      {&quot;x&quot;:&quot;foo&quot;, &quot;s&quot;:&quot;IX&quot;, &quot;f&quot;:[&quot;porg&quot;,&quot;parg&quot;,&quot;pork&quot;,&quot;peep&quot;], &quot;v&quot;:true},\r\n      {&quot;x&quot;:&quot;baz&quot;, &quot;s&quot;:&quot;AB&quot;, &quot;f&quot;:[&quot;zing&quot;,&quot;zang&quot;,&quot;zoop&quot;], &quot;v&quot;:false}\r\n      ],\r\n     &quot;c&quot;:[]\r\n    }\r\n\r\n- To extract objects in list `b` where `x` is &quot;bar&quot; is straightforward:\r\n\r\n    `jq &#39;.[&quot;b&quot;][] | select(.x == &quot;bar&quot;)&#39; &lt; file.json`\r\n\r\n- To restrict further to an object with a particular value of `s` is also simple:\r\n\r\n    `jq &#39;.[&quot;b&quot;][] | select(.x == &quot;bar&quot; and .s == &quot;FX&quot;)&#39; &lt; file.json`\r\n\r\nIf I want to apply a regular expression test, though, or any other test that requires a string input (bearing in mind that I still need object outputs), I think I have no choice but to chain filters.  For example ...\r\n\r\n- To restrict to objects where `s` ends in &quot;X&quot;, unfortunately the following isn&#39;t a thing in `jq`:\r\n\r\n    `jq &#39;.[&quot;b&quot;][] | select(.x == &quot;bar&quot; and .s.endswith(&quot;X&quot;))&#39; &lt; file.json`\r\n\r\n    Instead I think I have to do this:\r\n\r\n    `jq &#39;.[&quot;b&quot;][] | select(.x == &quot;bar&quot;) | select(.s | endswith(&quot;X&quot;))&#39; &lt; file.json`\r\n\r\n- Similarly with `s` contains &quot;X&quot;:\r\n\r\n    `jq &#39;.[&quot;b&quot;][] | select(.x == &quot;bar&quot;) | select(.s | test(&quot;X&quot;))&#39; &lt; file.json`\r\n\r\nWhich is fine if I&#39;m always doing boolean `AND`s, but what if I want to do an `OR`?  For example, what is the `jq` program to get objects where `x` is &quot;bar&quot; `OR` `s` ends in &quot;X&quot;?  Does `jq` have an `|OR|` filter?\r\n\r\n    jq &#39;.[&quot;b&quot;][] | select(.x == &quot;bar&quot;) |OR| select(.s | endswith(&quot;X&quot;))&#39; &lt; file.json\r\n\r\nOr am I just doing it wrong?  Am I attempting to reinvent some standard `jq` algorithm for selecting objects?",
        "link": "https://stackoverflow.com/questions/50139278/jq-object-selection-without-endless-filter-chains",
        "title": "JQ object selection without endless filter chains"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1525401501,
                "last_edit_date": 1525401501,
                "creation_date": 1525376487,
                "answer_id": 50162747,
                "question_id": 50162525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are going to invoke jq using `-f template.jq`, then each of the $-variables in template.jq will have to be set *separately* on the command-line, one by one.  In your case, this does not look like a very happy option.\r\n\r\nIf you are stuck with template.jq as it is, then it will be hard slogging, though there are alternatives besides setting the $-variables on the command line.\r\n\r\nPlease see https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine in the jq Cookbook for an alternative to using $-variables.  Consider for example the implications of this illustration of &quot;destructuring&quot;:\r\n\r\n    jq -nc &#39;{a:1,b:2} as {a: $a, b:$b} | [$a,$b]&#39;\r\n    [1,2]  \r\n\r\n  \r\n\r\n## Another alternative\r\nIn your particular case, you could replace all the &quot;$&quot; characters in template.jq with &quot;.&quot;, and then pass in a JSON object with the appropriate keys; e.g. change `$uptime` to .uptime, and then include a key/value pair for `uptime`.  \r\n\r\n",
                "title": "JQ error: is not defined at &lt;top-level&gt; when trying to add values to jq template"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1525401501,
        "creation_date": 1525375518,
        "question_id": 50162525,
        "body_markdown": "I have a .jq template that I want to update values under the samples list, formatted as:\r\n\r\n    {\r\n      &quot;test&quot;: &quot;abc&quot;,\r\n      &quot;p&quot;: &quot;1&quot;,\r\n      &quot;v&quot;: &quot;1.0.0&quot;,\r\n      &quot;samples&quot;: [\r\n        {\r\n          &quot;uptime&quot;: $uptime,\r\n          &quot;curr_connections&quot;: $curr_connections,\r\n          &quot;listen_disabled_num&quot;: $listen_disabled_num,\r\n          &quot;conn_yields&quot;: $conn_yields,\r\n          &quot;cmd_get&quot;: $cmd_get,\r\n          &quot;cmd_set&quot;: $cmd_set,\r\n          &quot;bytes_read&quot;: $bytes_read,\r\n          &quot;bytes_written&quot;: $bytes_writtem,\r\n          &quot;get_hits&quot;: $get_hits,\r\n          &quot;rejected_connections&quot;: $rejected_connections,\r\n          &quot;limit_maxbytes&quot;: $limit_maxbytes,\r\n          &quot;cmd_flush&quot;: $cmd_flush\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nMy shell script to do this is below, I am basically running a command to pull some memcached output stats and want to insert some of the results into the jq template as key/values.\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    JQ=`cat template.jq`\r\n\r\n    SAMPLES=(uptime curr_connections listen_disabled_num conn_yields cmd_get cmd_set cmd_flush bytes_read bytes_written get_hits rejected_connections limit_maxbytes)\r\n\r\n    for metric in ${SAMPLES[*]}\r\n    do\r\n      KEY=$(echo stats | nc $HOST $PORT | grep $metric | awk &#39;{print $2}&#39;)\r\n      VALUE=$(echo stats | nc $HOST $PORT | grep $metric | awk &#39;{print $3}&#39;)\r\n\r\n      echo &quot;Using KEY: $KEY with value: $VALUE&quot;\r\n\r\n      jq -n --argjson $KEY $VALUE -f template.jq\r\n    done\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nNot sure if this is the best way to handle this scenario, but I am getting a ton of errors such as: \r\n\r\n    jq: error: conn_yields/0 is not defined at &lt;top-level&gt;, line 12:\r\n          &quot;conn_yields&quot;: $conn_yields,\r\n    jq: error: cmd_get/0 is not defined at &lt;top-level&gt;, line 13:\r\n          &quot;cmd_get&quot;: $cmd_get,\r\n    jq: error: cmd_set/0 is not defined at &lt;top-level&gt;, line 14:\r\n          &quot;cmd_set&quot;: $cmd_set,",
        "link": "https://stackoverflow.com/questions/50162525/jq-error-is-not-defined-at-top-level-when-trying-to-add-values-to-jq-template",
        "title": "JQ error: is not defined at &lt;top-level&gt; when trying to add values to jq template"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1525430912,
                "creation_date": 1525430912,
                "answer_id": 50173155,
                "question_id": 50172624,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I wonder if the variable `$cred` really holds a string formated in 67 columns, but if that so, `tr` might help to remove the newline and extract the `accessKeyId` using `jq`:\r\n\r\n    \r\n    echo &quot;$cred&quot; | tr -d &#39;\\n&#39;  | jq -r &#39;.creds.accessKeyId&#39;\r\n\r\n",
                "title": "Extract fields from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1525430912,
        "creation_date": 1525429187,
        "question_id": 50172624,
        "body_markdown": "I am trying write a shell script that will get some json from URL and parse the json and extract fields.\r\nThis is what is done so far.\r\n\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    token=$(http POST :3000/signin/frontm user:=&#39;{&quot;email&quot;: &quot;sourav@frontm.com&quot;, &quot;password&quot;: &quot;Hello_789&quot;}&#39; | jq -r &#39;.data.id_token&#39;)   \r\n    cred=$(http POST :3000/auth provider_name:frontm token:$token user:=@/tmp/user.json | jq &#39;{ creds: .creds, userUuid: .user.userId }&#39;)\r\n    \r\n    echo $cred\r\n    access=$(jq -r &quot;&#39;$cred&#39;&quot;)\r\n    echo $access\r\n\r\nSo the output from echo $cred is a json:\r\nEg:\r\n\r\n    { &quot;creds&quot;: { &quot;accessKeyId&quot;: &quot;ASIAJPM3RDAZXEORAQ5Q&quot;, &quot;secretAccessK\r\n    ey&quot;: &quot;krg5GbU6gtQV+a5pz4ChL+ECVJm+wKogjglXOqr6&quot;, &quot;sessionToken&quot;: &quot;Ag\r\n    oGb3JpZ2luEAYaCXVzLWVhc3QtMSKAAmhOg7fedV+sBw+8c45HL9naPjqbC0bwaBxq\r\n    mQ9Kuvnirob8KtTcsiBkJA/OfCTpYNUFaXXYfUPvbmW5UveDJd+32Cb5Ce+3lAOkkL\r\n    aZyWJgvhM1u53WNuMekhcZX7SnlCcaO4e/A9TR74qMOsVptonw5jFB5zjbEI4hFsVX\r\n    UHXtkYMYpSyG+2P2LxWRqTg4XKcg2vT+qrLtiXu3XNK70wuCe0/L4/HjjzlLvChmhe\r\n    TRs8u8ZRcJvSim/j1sLqe85Sl1qrFv/7msCaxUa3gZ3dOcfHliH64+8NHfS1tkaVkS\r\n    iM2x4wxTdZI/SafduFDvGCsltxe9p5zQD0Jb1Qe02ccqpgUIWxAAGgw3NzE5NTYwMD\r\n    EyNDciDOQZkq8t+c7WatNLHyqDBahqpQwxpGsYODIC1Db/M4+PXmuYMdYKLwjv3Df2\r\n    JeTMw2RT1h8M0IOOPvyBWetwB42HLhv5AobIMkNVSw6tpGyZC/bLMGJatptB0hVMBg\r\n    /80VnI7pTPiSjb/LG46bbwlbJevPoorCEEqMZ3MlAJ2Xt2hMmA+sHBRRvV1hlkMnS8\r\n    NW6w9xApSGrD001zdfFkmBbHw+c4vmX+TMT7Bw0bHQZ5FQSpEBOw9M5sNOIoa+G/pP\r\n    p4WoHiYfGHzaXGQe9Iac07Fy36W/WRebZapvF7TWoIpBjAV+IrQKP3ShJdBi3Oa6py\r\n    lGUQysPa3EN0AF/gDuTsdz7TDsErzzUERfQHksK495poG92YoG2/ir8yqTQtUDvshO\r\n    7U4SbFpUrozCYT6vp7++BWnpe+miIRCvjy2spqBqv2RY6lhgC6QPfS/365T+QbSTMc\r\n    R+ZNes0gX/QrEG4q1sMoxyTltL4sXS2Dz9UXywPkg78AWCOr34ii72m/67Gqe1P3KA\r\n    vBe9xF9Hem4H1WbYAqBN76ppyJyG17qK8b2/r71c8rdY+1gYcskV1vUfTQUVCGE0y2\r\n    JXKV2UMFOwoTzy6SFIGcuTeOAHiYPgTkMZ6X7hNjf56ihzBIbhSHaST8U4eNBka8j8\r\n    Y949ilJwz9QO0l1kwdb2+fQSMblHgeYvF1P8HxBSpRA28gKkkXMf73Zk27I3O2DRGb\r\n    lcXS4tKRvan4ASTi4qkdrvVwMT5mwJI4mGIJZSiMJqPxjVh5E9OicFbIOCRcbcIRDE\r\n    mj5t9EvaSbIm4ELBMuyoFjmKJmesE03uFRcHkEXkPBxhkJbQwkJeUxHll5kR1IYzvA\r\n    K2A2EiZqjkhiSJC4NRekEuM+5WowwuWw1wU=&quot; }, &quot;userUuid&quot;: &quot;mugqRKHmTPxk\r\n    obBAtwTmKk&quot; }\r\n\r\nSo basically I am stuck here .. how do i parse this json in $cred further and basically want to get access to say accessKeyId using jq further?\r\n",
        "link": "https://stackoverflow.com/questions/50172624/extract-fields-from-json-using-jq",
        "title": "Extract fields from json using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "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": 1525536374,
                "post_id": 50183399,
                "comment_id": 87399697,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1525472198,
                "last_edit_date": 1525472198,
                "creation_date": 1525470595,
                "answer_id": 50183494,
                "question_id": 50183399,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are sure that the input data does not contain a `,` you can use `join(&quot;,&quot;)`.\r\n\r\nLet&#39;s say you have this input file:\r\n\r\n    {&quot;k1&quot;:&quot;v1&quot;,&quot;k2&quot;:&quot;v2&quot;}\r\n    {&quot;k1&quot;:&quot;v3&quot;,&quot;k2&quot;:&quot;v4&quot;}\r\n    {&quot;k1&quot;:&quot;v5&quot;,&quot;k2&quot;:&quot;v6&quot;}\r\n\r\nYou can use `join` like this:\r\n\r\n    jq -r &#39;values|join(&quot;,&quot;)&#39; input.file\r\n\r\nOutput:\r\n\r\n    v1,v2\r\n    v3,v4\r\n    v5,v6\r\n\r\n",
                "title": "Using jq to convert JSON {&quot;k1&quot;:&quot;v1&quot;,&quot;k2&quot;:&quot;v2&quot;} into CSV: v1,v2"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1525472198,
        "creation_date": 1525470060,
        "last_edit_date": 1525472003,
        "question_id": 50183399,
        "body_markdown": "I have a JSON file `in.txt` with lines like `{&quot;k1&quot;:&quot;v1&quot;,&quot;k2&quot;:&quot;v2&quot;}` and I want to create from it a CSV file `out.txt` with lines `v1,v2`. The JSON file may contain more than 10 key/value pairs, so I prefer a solution that doesn&#39;t require specifying each key in the input command.\r\n\r\nSo far I found this command:\r\n\r\n`jq -r &#39;[.[]] | @csv&#39; in.txt  &gt; out.txt`\r\n\r\nwhich produces output file with lines: `&quot;v1&quot;,&quot;v2&quot;`. How can I get rid of double quotes?\r\n\r\n**update:** I can remove double quotes using `sed` as following, but I&#39;m still interested to find a solution using jq:\r\n\r\n`jq -r &#39;[.[]] | @csv&#39; in.txt | sed -e &#39;s/\\&quot;//g&#39; &gt; out.txt`",
        "link": "https://stackoverflow.com/questions/50183399/using-jq-to-convert-json-k1v1-k2v2-into-csv-v1-v2",
        "title": "Using jq to convert JSON {&quot;k1&quot;:&quot;v1&quot;,&quot;k2&quot;:&quot;v2&quot;} into CSV: v1,v2"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1525614551,
                "creation_date": 1525614551,
                "answer_id": 50200417,
                "question_id": 50198813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` + `mv` approach:\r\n\r\n    jq &#39;map({s, c, o})&#39; emoji.json &gt; tmp_json &amp;&amp; mv tmp_json emoji.json",
                "title": "bulk update local json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1525614551,
        "creation_date": 1525603604,
        "question_id": 50198813,
        "body_markdown": "I have a JSON file name `emoji.json` located in my local mac PC\r\nmy JSON file has this structure\r\n\r\n    \r\n    [\r\n    {\r\n        &quot;name&quot;: &quot;COPYRIGHT SIGN&quot;,\r\n        &quot;unified&quot;: &quot;00A9-FE0F&quot;,\r\n        &quot;non_qualified&quot;: &quot;00A9&quot;,\r\n        &quot;docomo&quot;: &quot;E731&quot;,\r\n        &quot;au&quot;: &quot;E558&quot;,\r\n        &quot;softbank&quot;: &quot;E24E&quot;,\r\n        &quot;google&quot;: &quot;FEB29&quot;,\r\n        &quot;image&quot;: &quot;00a9-fe0f.png&quot;,\r\n        &quot;sheet_x&quot;: 0,\r\n        &quot;sheet_y&quot;: 12,\r\n        &quot;s&quot;: &quot;copyright&quot;,\r\n        &quot;short_names&quot;: [\r\n            &quot;copyright&quot;\r\n        ],\r\n        &quot;text&quot;: null,\r\n        &quot;texts&quot;: null,\r\n        &quot;c&quot;: &quot;Symbols&quot;,\r\n        &quot;o&quot;: 128,\r\n        &quot;added_in&quot;: &quot;1.1&quot;,\r\n        &quot;has_img_twitter&quot;: false,\r\n        &quot;has_img_emojione&quot;: false,\r\n        &quot;has_img_messenger&quot;: false\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;REGISTERED SIGN&quot;,\r\n        &quot;unified&quot;: &quot;00AE-FE0F&quot;,\r\n        &quot;non_qualified&quot;: &quot;00AE&quot;,\r\n        &quot;docomo&quot;: &quot;E736&quot;,\r\n        &quot;au&quot;: &quot;E559&quot;,\r\n        &quot;softbank&quot;: &quot;E24F&quot;,\r\n        &quot;google&quot;: &quot;FEB2D&quot;,\r\n        &quot;image&quot;: &quot;00ae-fe0f.png&quot;,\r\n        &quot;sheet_x&quot;: 0,\r\n        &quot;sheet_y&quot;: 13,\r\n        &quot;s&quot;: &quot;registered&quot;,\r\n        &quot;short_names&quot;: [\r\n            &quot;registered&quot;\r\n        ],\r\n        &quot;text&quot;: null,\r\n        &quot;texts&quot;: null,\r\n        &quot;c&quot;: &quot;Symbols&quot;,\r\n        &quot;o&quot;: 129,\r\n        &quot;added_in&quot;: &quot;1.1&quot;,\r\n        &quot;has_img_twitter&quot;: false,\r\n        &quot;has_img_emojione&quot;: false,\r\n        &quot;has_img_messenger&quot;: false\r\n    }\r\n    ...\r\n    ]\r\n\r\nand i want to remove some unwanted values so the file should became like blow.\r\nand i want to save this file in JSON format in my PC\r\n\r\n    [\r\n      {\r\n        &quot;s&quot;: &quot;copyright&quot;,\r\n        &quot;c&quot;: &quot;Symbols&quot;,\r\n        &quot;o&quot;: 128\r\n      },\r\n      {\r\n        &quot;s&quot;: &quot;registered&quot;,\r\n        &quot;c&quot;: &quot;Symbols&quot;,\r\n        &quot;o&quot;: 129\r\n      }\r\n    ]\r\n\r\n\r\ni know JQ could do that and i check documentation and https://jqplay.org/\r\nand i test and found out `map({ s, c , o })` could do that but i dint find how to input file and export file ",
        "link": "https://stackoverflow.com/questions/50198813/bulk-update-local-json-file-with-jq",
        "title": "bulk update local json file with jq"
    },
    {
        "tags": [
            "json",
            "stream",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1525685111,
                "last_edit_date": 1525685111,
                "creation_date": 1525683624,
                "answer_id": 50210487,
                "question_id": 50210120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq filter produces the desired output when jq is invoked with the -r command-line option:\r\n\r\n    ((.result | keys_unsorted[]) // null) as $key\r\n    | if $key == null then .outcome\r\n      else [.outcome, $key] | join(&quot;_&quot;)\r\n      end\r\n\r\nThere are of course many possible variations, e.g.\r\n\r\n    ((.result | keys_unsorted[]) // null) as $key\r\n    | [.outcome, ($key // empty)]\r\n    | join(&quot;_&quot;)\r\n\r\nor if you want a short one-liner:\r\n\r\n    .outcome + (&quot;_&quot; + (.result | keys_unsorted[]) // null)\r\n\r\nIn any case, the key to simplicity here is to generate the keys of `.result` as a stream.  Handling the &quot;edge case&quot; makes the solution slightly more complicated than it would otherwise be, i.e. `.outcome + &quot;_&quot; + (.result | keys_unsorted[])`\r\n\r\nExample invocation: jq -r -f program.jq input.json\r\n\r\n\r\n\r\n",
                "title": "jq json move object to nested object and iterating over unknown names/numbers of objects"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1525685111,
        "creation_date": 1525682162,
        "last_edit_date": 1525684727,
        "question_id": 50210120,
        "body_markdown": "I&#39;ve been looking over several examples of &#39;jq&#39; parsing of json strings, all very helpful, but not conclusive for my particular problem\r\n\r\nHere&#39;s my input json :\r\n\r\n    {\r\n        &quot;outcome&quot; : &quot;TrBean&quot;,\r\n        &quot;result&quot; : {&quot;TrAct&quot; : {\r\n            &quot;executiontime&quot; : 16938570,\r\n            &quot;invocations&quot; : 133863,\r\n            &quot;waittime&quot; : 4981\r\n        }}\r\n    }\r\n    {\r\n        &quot;outcome&quot; : &quot;WwwBean&quot;,\r\n        &quot;result&quot; : {}\r\n    }\r\n    {\r\n      &quot;outcome&quot;: &quot;CRFeatureBean&quot;,\r\n      &quot;result&quot;: {\r\n        &quot;CRChannels&quot;: {\r\n          &quot;executiontime&quot;: 78127,\r\n          &quot;invocations&quot;: 9983,\r\n          &quot;waittime&quot;: 213\r\n        },\r\n        &quot;getCRChannels&quot;: {\r\n          &quot;executiontime&quot;: 98704,\r\n          &quot;invocations&quot;: 10113,\r\n          &quot;waittime&quot;: 212\r\n        },\r\n        &quot;getCRToMigrate&quot;: {\r\n          &quot;executiontime&quot;: 32,\r\n          &quot;invocations&quot;: 4,\r\n          &quot;waittime&quot;: 0\r\n        },\r\n        &quot;getCRId&quot;: {\r\n          &quot;executiontime&quot;: 28198633,\r\n          &quot;invocations&quot;: 747336,\r\n          &quot;waittime&quot;: 19856\r\n        }\r\n      }\r\n    }\r\n\r\nI&#39;m trying to feed graphite via collectd exec plugin (PUTVAL), so I need info in one line.  I tried with `./jq &#39;.result|to_entries[]|{&quot;method:&quot; .key, &quot;inv&quot;: .value.invocations}|&quot;PUTVAL \\(.method)/invoke:\\(.invokes)&quot;&#39;` ... but I need to have &quot;outcome&quot; in every line too.\r\n\r\nAlso I do not know the amount, nor the names of the result-objects\r\n\r\nSo, I&#39;d like to end up with : \r\n\r\n    TrBean_TrAct\r\n    WwwBean\r\n    CRFeatureBean_CRChannels\r\n    CRFeatureBean_getCRChannels\r\n    CRFeatureBean_getCRToMigrate\r\n    CrFeatureBean_getCRId\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50210120/jq-json-move-object-to-nested-object-and-iterating-over-unknown-names-numbers-of",
        "title": "jq json move object to nested object and iterating over unknown names/numbers of objects"
    },
    {
        "tags": [
            "json",
            "key",
            "glob",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 325025,
                    "reputation": 2863,
                    "user_id": 645957,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5f71bd13b2a69011addb30307142438a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "J. M. Becker",
                    "link": "https://stackoverflow.com/users/645957/j-m-becker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1738773826,
                "post_id": 50224055,
                "comment_id": 140054779,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1525738949,
                "creation_date": 1525738949,
                "answer_id": 50224123,
                "question_id": 50224055,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution to the problem is `to_entries`, as described in the online manual.  With your example data, the following filter produces the output shown below, in accordance with what I understand to be the expectations:\r\n\r\n    .[]\r\n    | select(.Name | test(&quot;ets$&quot;))\r\n    | {Name} + (to_entries | map(select(.key|test(&quot;^Sym&quot;))) | from_entries)\r\n\r\nYou might want to refine the regex tests, and/or make other minor adjustments.\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;Widgets&quot;,\r\n      &quot;SymUS&quot;: &quot;Widg&quot;,\r\n      &quot;SymCN&quot;: &quot;Zyin&quot;,\r\n      &quot;SymJP&quot;: &quot;Kono&quot;\r\n    }\r\n    {\r\n      &quot;Name&quot;: &quot;Blodgets&quot;,\r\n      &quot;SymUS&quot;: &quot;Blodg&quot;,\r\n      &quot;SymAU&quot;: &quot;Blod&quot;,\r\n      &quot;SymJP&quot;: &quot;Kado&quot;\r\n    }",
                "title": "JSON key-globbing"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1525750655,
        "creation_date": 1525738328,
        "last_edit_date": 1525750655,
        "question_id": 50224055,
        "body_markdown": "On the `jq` manual page there are a few examples of output formatting, particularly some shortcuts for when you want to just echo exactly what was in the input JSON.\r\n\r\nWhat if I want to echo exactly what was in the input, but only for keys that match a certain pattern?\r\n\r\nFor example, given input like so ...\r\n\r\n    [\r\n    {&quot;Name&quot;:&quot;Widgets&quot;,&quot;Size&quot;:10,&quot;SymUS&quot;:&quot;Widg&quot;,&quot;SymCN&quot;:&quot;Zyin&quot;,&quot;SymJP&quot;:&quot;Kono&quot;},\r\n    {&quot;Name&quot;:&quot;Blodgets&quot;,&quot;Size&quot;:400,&quot;SymUS&quot;:&quot;Blodg&quot;,&quot;SymAU&quot;:&quot;Blod&quot;,&quot;SymJP&quot;:&quot;Kado&quot;},\r\n    {&quot;Name&quot;:&quot;Fonzes&quot;,&quot;Size&quot;:11,&quot;SymRU&quot;:&quot;Fyet&quot;,&quot;SymBR&quot;:&quot;Foao&quot;}\r\n    ]\r\n\r\nSay I want to select all objects where the `Name` ends in &quot;ets&quot; and then display the `Name` and all attributes of the form `Sym*`.  All I know about those attributes is that there will be one or more per JSON object, and the names have the format `Sym` followed by a two-letter ISO country code.\r\n\r\nI would like to just do this:\r\n\r\n    jq &#39;.[] | select(.Name | endswith(&quot;ets&quot;)) | {Name, Sym*}&#39;\r\n\r\nbut that&#39;s not a thing.\r\n\r\nIs this just not something `jq` is designed to handle in a single operation?  Should I do a first pass through the file to collect all the possible keys and then list them all explicitly via a `slurpfile`?\r\n",
        "link": "https://stackoverflow.com/questions/50224055/json-key-globbing",
        "title": "JSON key-globbing"
    },
    {
        "tags": [
            "json",
            "slice",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525851975,
                "post_id": 50247078,
                "comment_id": 87513456,
                "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": 1525854247,
                "post_id": 50247078,
                "comment_id": 87514702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13533006,
                    "reputation": 11,
                    "user_id": 9762918,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "Roberto",
                    "link": "https://stackoverflow.com/users/9762918/roberto"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525857464,
                "post_id": 50247078,
                "comment_id": 87516640,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13533006,
                    "reputation": 11,
                    "user_id": 9762918,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "Roberto",
                    "link": "https://stackoverflow.com/users/9762918/roberto"
                },
                "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": 1525858197,
                "post_id": 50247078,
                "comment_id": 87517135,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1525885051,
                "creation_date": 1525885051,
                "answer_id": 50258514,
                "question_id": 50247078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you want to take, in turn, the i-th element of the selected arrays.  Using your second example, this could be done like so:\r\n\r\n    range(0; .multiple_value_key|length) as $i\r\n    | . + { multiple_value_key: [.multiple_value_key[$i]],\r\n            any_key_name:       [.any_key_name[$i]] }\r\n          \r\nThe output in compact form:\r\n\r\n    {&quot;key_single&quot;:[&quot;single_value&quot;],&quot;key2&quot;:[&quot;single_value&quot;],&quot;multiple_value_key&quot;:[&quot;value1&quot;],&quot;any_key_name&quot;:[&quot;value4&quot;]}\r\n    {&quot;key_single&quot;:[&quot;single_value&quot;],&quot;key2&quot;:[&quot;single_value&quot;],&quot;multiple_value_key&quot;:[&quot;value2&quot;],&quot;any_key_name&quot;:[&quot;value5&quot;]}\r\n    {&quot;key_single&quot;:[&quot;single_value&quot;],&quot;key2&quot;:[&quot;single_value&quot;],&quot;multiple_value_key&quot;:[&quot;value6&quot;],&quot;any_key_name&quot;:[&quot;value9&quot;]}\r\n    {&quot;key_single&quot;:[&quot;single_value&quot;],&quot;key2&quot;:[&quot;single_value&quot;],&quot;multiple_value_key&quot;:[&quot;value7&quot;],&quot;any_key_name&quot;:[&quot;value10&quot;]}\r\n    {&quot;key_single&quot;:[&quot;single_value&quot;],&quot;key2&quot;:[&quot;single_value&quot;],&quot;multiple_value_key&quot;:[&quot;value8&quot;],&quot;any_key_name&quot;:[&quot;value11&quot;]}\r\n\r\n\r\n",
                "title": "Jq iterating array objects to create new json objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1526164856,
                "last_edit_date": 1526164856,
                "creation_date": 1526154025,
                "answer_id": 50310075,
                "question_id": 50247078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple solution to the problem as described in the &quot;comments&quot;, though the\r\noutput differs slightly from that shown in the Q.\r\n\r\nFor clarity, a helper function is defined for producing the $i-th slice of an object,\r\nthat is, for all array-valued keys with array-length greater than 1,\r\nthe value is replaced by the $i-th item in the array.\r\n\r\n    def slice($i):\r\n        map_values(if (type == &quot;array&quot; and length&gt;1)\r\n                   then [.[$i]]\r\n                   else . end);\r\n\r\nThe solution is then simply:\r\n\r\n    .layers\r\n    | range(0;  [.[] | length] | max) as $i\r\n    | slice($i)\r\n    \r\n    \r\n## Output\r\n\r\n    {\r\n      &quot;frame_time_epoch&quot;: [\r\n        &quot;1525627021.656417000&quot;\r\n      ],\r\n      &quot;ip_src&quot;: [\r\n        &quot;10.10.10.10&quot;\r\n      ],\r\n      &quot;ip_src_host&quot;: [\r\n        &quot;test&quot;\r\n      ],\r\n      &quot;ip_dst&quot;: [\r\n        &quot;10.10.10.11&quot;\r\n      ],\r\n      &quot;ip_dst_host&quot;: [\r\n        &quot;dest_test&quot;\r\n      ],\r\n      &quot;diameter_Event-Timestamp&quot;: [\r\n        &quot;May  6, 2018 19:17:02.000000000 CEST&quot;\r\n      ],\r\n      &quot;diameter_Origin-Host&quot;: [\r\n        &quot;TESTHOST&quot;\r\n      ],\r\n      &quot;diameter_Destination-Host&quot;: [\r\n        &quot;DESTHOST&quot;\r\n      ],\r\n      &quot;diameter_CC-Request-Type&quot;: [\r\n        &quot;2&quot;\r\n      ],\r\n      &quot;diameter_CC-Request-Number&quot;: [\r\n        &quot;10&quot;\r\n      ],\r\n      &quot;diameter_Rating-Group&quot;: [\r\n        &quot;9004&quot;\r\n      ],\r\n      &quot;diameter_Called-Station-Id&quot;: [\r\n        &quot;testing&quot;\r\n      ],\r\n      &quot;diameter_User-Name&quot;: [\r\n        &quot;testuser&quot;\r\n      ],\r\n      &quot;diameter_Subscription-Id-Data&quot;: [\r\n        &quot;66666666666&quot;\r\n      ],\r\n      &quot;gtp_qos_version&quot;: [\r\n        &quot;0x00000008&quot;\r\n      ],\r\n      &quot;gtp_qos_max_dl&quot;: [\r\n        &quot;8640&quot;\r\n      ],\r\n      &quot;diameter_Session-Id&quot;: [\r\n        &quot;test1;sessionID1;test1&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;frame_time_epoch&quot;: [\r\n        &quot;1525627021.656417000&quot;\r\n      ],\r\n      &quot;ip_src&quot;: [\r\n        &quot;10.10.10.10&quot;\r\n      ],\r\n      &quot;ip_src_host&quot;: [\r\n        &quot;test&quot;\r\n      ],\r\n      &quot;ip_dst&quot;: [\r\n        &quot;10.10.10.11&quot;\r\n      ],\r\n      &quot;ip_dst_host&quot;: [\r\n        &quot;dest_test&quot;\r\n      ],\r\n      &quot;diameter_Event-Timestamp&quot;: [\r\n        &quot;May  6, 2018 19:17:02.000000000 CEST&quot;\r\n      ],\r\n      &quot;diameter_Origin-Host&quot;: [\r\n        &quot;TESTHOST&quot;\r\n      ],\r\n      &quot;diameter_Destination-Host&quot;: [\r\n        &quot;DESTHOST&quot;\r\n      ],\r\n      &quot;diameter_CC-Request-Type&quot;: [\r\n        &quot;2&quot;\r\n      ],\r\n      &quot;diameter_CC-Request-Number&quot;: [\r\n        &quot;3&quot;\r\n      ],\r\n      &quot;diameter_Rating-Group&quot;: [\r\n        &quot;9001&quot;\r\n      ],\r\n      &quot;diameter_Called-Station-Id&quot;: [\r\n        &quot;testing&quot;\r\n      ],\r\n      &quot;diameter_User-Name&quot;: [\r\n        &quot;testuser&quot;\r\n      ],\r\n      &quot;diameter_Subscription-Id-Data&quot;: [\r\n        &quot;77777777777&quot;\r\n      ],\r\n      &quot;gtp_qos_version&quot;: [\r\n        &quot;0x00000005&quot;\r\n      ],\r\n      &quot;gtp_qos_max_dl&quot;: [\r\n        &quot;42&quot;\r\n      ],\r\n      &quot;diameter_Session-Id&quot;: [\r\n        &quot;test2;sessionID2;test2&quot;\r\n      ]\r\n    }\r\n    \r\n",
                "title": "Jq iterating array objects to create new json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1527019509,
        "creation_date": 1525848341,
        "last_edit_date": 1527019509,
        "question_id": 50247078,
        "body_markdown": "I&#39;ve been thinking and searching for a long time, but I didn&#39;t find out what I&#39;m looking for. \r\n   I&#39;m using JQ to parse tshark (-ek) json output, but I&#39;m a jq newby \r\n   When a frame is multivalue I have a JSON similar to this:\r\n   \r\n\r\n     {\r\n          &quot;timestamp&quot;: &quot;1525627021656&quot;,\r\n          &quot;layers&quot;: {\r\n            &quot;frame_time_epoch&quot;: [\r\n              &quot;1525627021.656417000&quot;\r\n            ],\r\n            &quot;ip_src&quot;: [\r\n              &quot;10.10.10.10&quot;\r\n            ],\r\n            &quot;ip_src_host&quot;: [\r\n              &quot;test&quot;\r\n            ],\r\n            &quot;ip_dst&quot;: [\r\n              &quot;10.10.10.11&quot;\r\n            ],\r\n            &quot;ip_dst_host&quot;: [\r\n              &quot;dest_test&quot;\r\n            ],\r\n            &quot;diameter_Event-Timestamp&quot;: [\r\n              &quot;May  6, 2018 19:17:02.000000000 CEST&quot;,\r\n              &quot;May  6, 2018 19:17:02.000000000 CEST&quot;\r\n            ],\r\n            &quot;diameter_Origin-Host&quot;: [\r\n              &quot;TESTHOST&quot;,\r\n              &quot;TESTHOST&quot;\r\n            ],\r\n            &quot;diameter_Destination-Host&quot;: [\r\n              &quot;DESTHOST&quot;,\r\n              &quot;DESTHOST&quot;\r\n            ],\r\n            &quot;diameter_CC-Request-Type&quot;: [\r\n              &quot;2&quot;,\r\n              &quot;2&quot;\r\n            ],\r\n            &quot;diameter_CC-Request-Number&quot;: [\r\n              &quot;10&quot;,\r\n              &quot;3&quot;\r\n            ],\r\n            &quot;diameter_Rating-Group&quot;: [\r\n              &quot;9004&quot;,\r\n              &quot;9001&quot;\r\n            ],\r\n            &quot;diameter_Called-Station-Id&quot;: [\r\n              &quot;testing&quot;,\r\n              &quot;testing&quot;\r\n            ],\r\n            &quot;diameter_User-Name&quot;: [\r\n              &quot;testuser&quot;,\r\n              &quot;testuser&quot;\r\n            ],\r\n            &quot;diameter_Subscription-Id-Data&quot;: [\r\n              &quot;66666666666&quot;,\r\n              &quot;77777777777&quot;\r\n            ],\r\n            &quot;gtp_qos_version&quot;: [\r\n              &quot;0x00000008&quot;,\r\n              &quot;0x00000005&quot;\r\n            ],\r\n            &quot;gtp_qos_max_dl&quot;: [\r\n              &quot;8640&quot;,\r\n              &quot;42&quot;\r\n            ],\r\n            &quot;diameter_Session-Id&quot;: [\r\n              &quot;test1;sessionID1;test1&quot;,\r\n              &quot;test2;sessionID2;test2&quot;\r\n            ]\r\n          }\r\n        }\r\n\r\n  As you can see, many keys are array and I want to iterate them to create different json objects in a result like this:\r\n\r\n    {\r\n        &quot;frame_time_epoch&quot;: [\r\n          &quot;1525627021.656417000&quot;\r\n        ],\r\n        &quot;ip_src&quot;: [\r\n          &quot;10.10.10.10&quot;\r\n        ],\r\n        &quot;ip_src_host&quot;: [\r\n          &quot;test&quot;\r\n        ],\r\n        &quot;ip_dst&quot;: [\r\n          &quot;10.10.10.11&quot;\r\n        ],\r\n        &quot;ip_dst_host&quot;: [\r\n          &quot;dest_test&quot;\r\n        ],\r\n        &quot;diameter_Event-Timestamp&quot;: [\r\n          &quot;May  6, 2018 19:17:02.000000000 CEST&quot;\r\n        ],\r\n        &quot;diameter_Origin-Host&quot;: [\r\n          &quot;TESTHOST&quot;\r\n        ],\r\n        &quot;diameter_Destination-Host&quot;: [\r\n          &quot;DESTHOST&quot;\r\n        ],\r\n        &quot;diameter_CC-Request-Type&quot;: [\r\n          &quot;2&quot;\r\n        ],\r\n        &quot;diameter_CC-Request-Number&quot;: [\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;diameter_Rating-Group&quot;: [\r\n          &quot;9001&quot;\r\n        ],\r\n        &quot;diameter_Called-Station-Id&quot;: [\r\n          &quot;testing&quot;\r\n        ],\r\n        &quot;diameter_User-Name&quot;: [\r\n          &quot;testuser&quot;\r\n        ],\r\n        &quot;diameter_Subscription-Id-Data&quot;: [\r\n          &quot;77777777777&quot;\r\n        ],\r\n        &quot;gtp_qos_version&quot;: [\r\n          &quot;0x00000005&quot;\r\n        ],\r\n        &quot;gtp_qos_max_dl&quot;: [\r\n          &quot;42&quot;\r\n        ],\r\n        &quot;diameter_Session-Id&quot;: [\r\n          &quot;test2;sessionID2;test2&quot;\r\n        ]\r\n      }\r\n     {\r\n        &quot;frame_time_epoch&quot;: [\r\n          &quot;1525627021.656417000&quot;\r\n        ],\r\n        &quot;ip_src&quot;: [\r\n          &quot;10.10.10.10&quot;\r\n        ],\r\n        &quot;ip_src_host&quot;: [\r\n          &quot;test&quot;\r\n        ],\r\n        &quot;ip_dst&quot;: [\r\n          &quot;10.10.10.11&quot;\r\n        ],\r\n        &quot;ip_dst_host&quot;: [\r\n          &quot;dest_test&quot;\r\n        ],\r\n        &quot;diameter_Event-Timestamp&quot;: [\r\n          &quot;May  6, 2018 19:17:02.000000000 CEST&quot;\r\n        ],\r\n        &quot;diameter_Origin-Host&quot;: [\r\n          &quot;TESTHOST&quot;\r\n        ],\r\n        &quot;diameter_Destination-Host&quot;: [\r\n          &quot;DESTHOST&quot;\r\n        ],\r\n        &quot;diameter_CC-Request-Type&quot;: [\r\n          &quot;2&quot;\r\n        ],\r\n        &quot;diameter_CC-Request-Number&quot;: [\r\n          &quot;10&quot;\r\n        ],\r\n        &quot;diameter_Rating-Group&quot;: [\r\n          &quot;9004&quot;\r\n        ],\r\n        &quot;diameter_Called-Station-Id&quot;: [\r\n          &quot;testing&quot;\r\n        ],\r\n        &quot;diameter_User-Name&quot;: [\r\n          &quot;testuser&quot;\r\n        ],\r\n        &quot;diameter_Subscription-Id-Data&quot;: [\r\n          &quot;66666666666&quot;\r\n        ],\r\n        &quot;gtp_qos_version&quot;: [\r\n          &quot;0x00000008&quot;\r\n        ],\r\n        &quot;gtp_qos_max_dl&quot;: [\r\n          &quot;8640&quot;\r\n        ],\r\n        &quot;diameter_Session-Id&quot;: [\r\n          &quot;test1;sessionID1;test1&quot;\r\n        ]\r\n      }\r\n\r\nAnother hand made example:\r\nINPUT:\r\n\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value1&quot; , &quot;value2&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value4&quot; ,&quot;value5&quot;]\r\n    }\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value6&quot; , &quot;value7&quot;, &quot;value8&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value9&quot; ,&quot;value10&quot; , &quot;value11&quot;]\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value1&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value4&quot;],\r\n    }\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value2&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value5&quot;],\r\n    }\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value6&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value9&quot;],\r\n    }\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value7&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value10&quot;],\r\n    }\r\n    {\r\n    \t&quot;key_single&quot;: [&quot;single_value&quot;],\r\n    \t&quot;key2&quot;: [&quot;single_value&quot;],\r\n    \t&quot;multiple_value_key&quot;: [&quot;value8&quot;],\r\n    \t&quot;any_key_name&quot;: [&quot;value11&quot;],\r\n    }\r\n\r\n  Could you help Me?\r\n\r\nThanks in advance.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50247078/jq-iterating-array-objects-to-create-new-json-objects",
        "title": "Jq iterating array objects to create new json objects"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525865775,
                "post_id": 50252063,
                "comment_id": 87521994,
                "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": 1525868347,
                "post_id": 50252063,
                "comment_id": 87523593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13534261,
                    "reputation": 71,
                    "user_id": 9763887,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8e87cd51727290055c52ef0219992ec2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user9763887",
                    "link": "https://stackoverflow.com/users/9763887/user9763887"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525871864,
                "post_id": 50252063,
                "comment_id": 87526155,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1525867402,
                "creation_date": 1525867402,
                "answer_id": 50252923,
                "question_id": 50252063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given that you fix the malformed JSON data by closing arrays like this:\r\n\r\n              ...\r\n              &quot;id&quot;: &quot;1.1&quot;,\r\n              &quot;name&quot;: &quot;Auto Body Styles&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nyou can use the following `jq` script:\r\n\r\n    $ jq &#39;.categories[0].categories[0].categories[0],.categories[0].categories[0].categories[1]&#39; file\r\n    {\r\n      &quot;id&quot;: &quot;1.1.1&quot;,\r\n      &quot;name&quot;: &quot;Commercial Trucks&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;1.1.2&quot;,\r\n      &quot;name&quot;: &quot;Convertible&quot;\r\n    }\r\n\r\nThe jq statement selects the first and second array element in these nested arrays.\r\n\r\n",
                "title": "How to parse an array of json object using jq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1525893515,
                "creation_date": 1525893515,
                "answer_id": 50260608,
                "question_id": 50252063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the JSON input has been corrected, the following jq filter seems to meet the requirements, such as they are:\r\n\r\n    .categories[].categories[].categories[]\r\n\r\nThis produces a stream of JSON objects, beginning:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;1.1.1&quot;,\r\n      &quot;name&quot;: &quot;Commercial Trucks&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;1.1.2&quot;,\r\n      &quot;name&quot;: &quot;Convertible&quot;\r\n    }\r\n\r\n",
                "title": "How to parse an array of json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1525893515,
        "creation_date": 1525864600,
        "last_edit_date": 1525866952,
        "question_id": 50252063,
        "body_markdown": "I need to parse a Json file which have a lot of arrays. \r\n\r\n\r\n**This is the json source:**\r\n\r\n\r\n    {\r\n\t&quot;iabVersion&quot;: &quot;IAB_V2&quot;,\r\n\t&quot;categories&quot;: [{\r\n\t\t&quot;categories&quot;: [{\r\n\t\t\t&quot;categories&quot;: [{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.1&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Commercial Trucks&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.2&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Convertible&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.3&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Coupe&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.4&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Crossover&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.5&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Hatchback&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.6&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Microcar&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.7&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Minivan&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.8&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Off-Road Vehicles&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.9&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Pickup Trucks&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.10&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Sedan&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.11&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Station Wagon&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.12&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;SUV&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot;: &quot;1.1.13&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Van&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;id&quot;: &quot;1.1&quot;,\r\n\t\t\t&quot;name&quot;: &quot;Auto Body Styles&quot;\r\n\t\t}\r\n      }\r\n    }\r\n\r\n\r\n\r\n**This is the json requred:**\r\n\r\n\r\n    {\r\n    &quot;id&quot;: &quot;1.1.1&quot;,\r\n    &quot;name&quot;: &quot;Commercial Trucks&quot;\r\n    }\r\n    {\r\n    &quot;id&quot;: &quot;1.1.2&quot;,\r\n    &quot;name&quot;: &quot;Convertible&quot;\r\n    }\r\n\r\n\r\n**How can I parse it via jq?**\r\n\r\n10x:)\r\n",
        "link": "https://stackoverflow.com/questions/50252063/how-to-parse-an-array-of-json-object-using-jq",
        "title": "How to parse an array of json object using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525870355,
                "post_id": 50253817,
                "comment_id": 87525064,
                "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": 1525871099,
                "post_id": 50253817,
                "comment_id": 87525639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8195798,
                    "reputation": 21,
                    "user_id": 6168690,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/D4Nq8.jpg?s=256",
                    "display_name": "Akshatha Nadig",
                    "link": "https://stackoverflow.com/users/6168690/akshatha-nadig"
                },
                "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": 1525872738,
                "post_id": 50253817,
                "comment_id": 87526819,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1525871284,
                "creation_date": 1525871284,
                "answer_id": 50254204,
                "question_id": 50253817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The biggest problem is that you are overwriting your modified file using a copy of the original file at each step. You want the *new* file to be the input for the next iteration of the loop:\r\n\r\n    {\r\n       read   # discard the first line\r\n       readarray -t array\r\n    } &lt; newhostnames.txt\r\n    \r\n    cp demolabconfig.json newdemolabconfig.json\r\n    input=newdemolabconfig.json\r\n\r\n    for((i=0;i&lt;${#array[@]};i++));\r\n    do\r\n        old_nodename=$(jq -r &quot;.lab.racks[].nodes[$i].name&quot; &quot;$input&quot;)\r\n        new_nodename=&quot;${array[i]}&quot;\r\n        if [[ $old_nodename == $new_nodename ]]; then\r\n            continue\r\n        fi\r\n        jq &quot;.lab.racks[].nodes[$i].name=env.NEW_NODENAME&quot; &quot;$input&quot; &gt; tmp.json\r\n        mv tmp.json &quot;$input&quot;\r\n    done",
                "title": "Updating JSON object values dynamically and storing them in a new file in BASH"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526330869,
                "last_edit_date": 1526330869,
                "creation_date": 1525891832,
                "answer_id": 50260215,
                "question_id": 50253817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The goal here should be to call jq as few times as possible.  Accordingly, we present a solution which involves just two calls\r\nto jq, irrespective of the number of &quot;names&quot; in newhostnames.txt.\r\n\r\nFirst let&#39;s suppose input.json contains the following:\r\n\r\n    {&quot;nodes&quot;:[{&quot;name&quot;:&quot;old1&quot;},{&quot;name&quot;:&quot;old2&quot;},{&quot;name&quot;:&quot;old3&quot;}]}\r\n    \r\nLet&#39;s also suppose the follow jq program is in the file program.jq:\r\n\r\n      reduce range(0; $newhostnames | length) as $i (.;\r\n        .nodes[$i].name = $newhostnames[$i])\r\n    \r\nThen the invocation:\r\n\r\n    jq -c --slurpfile newhostnames &lt;(jq -nR inputs newhostnames.txt ) \\\r\n       -f program.jq input.json\r\n\r\nproduces:\r\n\r\n    {&quot;nodes&quot;:[{&quot;name&quot;:&quot;Tom-cat&quot;},{&quot;name&quot;:&quot;Lucky-worm&quot;},{&quot;name&quot;:&quot;Wom-bat&quot;}]}\r\n\r\n(The -c command-line option produces compressed output.)\r\n\r\nIf your shell does not support the above invocation, you could (for example) put the output of `jq -nR inputs newhostnames.txt` in a temporary file.\r\n\r\nOf course the subsidiary task of converting the .txt file into a JSON array or a stream of JSON strings can be accomplished in other ways.\r\n\r\n## Robustification\r\nIf there&#39;s a chance that newhostnames.txt contains unwanted blank lines, then one way to skip them would be to add one line to program.jq so that it would look like this:\r\n\r\n    ($newhostnames | map(select(length&gt;0))) as $newhostnames\r\n    | reduce range(0; $newhostnames | length) as $i (.;\r\n          .nodes[$i].name = $newhostnames[$i])\r\n\r\nNotice that the $-variable name can be reused.\r\n        ",
                "title": "Updating JSON object values dynamically and storing them in a new file in BASH"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1526330869,
        "creation_date": 1525870050,
        "last_edit_date": 1525872661,
        "question_id": 50253817,
        "body_markdown": "I am completely new (an intern with less than two weeks of hands-on experience) to BASH, JSON and jq. But I have been given a task to replace JSON object value from an array iteratively. I have managed to write the following code.\r\n\r\nI am trying to replace the values of the key, &quot;name&quot;, in the json file incrementally to the names in the array stored in another text file. Basically just updating the names of the nodes.\r\n\r\nHere is a snippet of the JSON file to be replaced. The whole file is way too big to be posted here.\r\nBut the path to the key &quot;name&quot; is &quot;.lab.racks[].nodes[].name&quot;\r\n    \r\n        &quot;roles&quot;: [\r\n               &quot;bla bla&quot;,\r\n               &quot;bla bla&quot;\r\n          ],\r\n          &quot;name&quot;: &quot;Node1&quot;,\r\n           &quot;power&quot;: {\r\n           &quot;address&quot;: &quot;10.182.149.145&quot;,\r\n           &quot;type&quot;: &quot;bla bla&quot;,\r\n           &quot;user&quot;: &quot;bla bla&quot;,\r\n           &quot;pass&quot;: &quot;bla bla &quot;\r\n           },\r\n\r\nThe &quot;name&quot;: &quot;Node1&quot; must be replaced as &quot;name&quot;: &quot;Tom-cat&quot;. The name Tom-cat is dynamically generated and changes everytime a Metal as a Service (MaaS) script is run. This name &quot;Tom-cat&quot; and all other new names generated by MaaS is cut (using awk) and stored in a text file newhostnames.txt\r\n\r\nThe textfile looks like this \r\n\r\n    #newhostnames.txt\r\n    Tom-cat\r\n    Lucky-worm\r\n    Wom-bat\r\n\r\nSo the goal is to replace the &quot;name&quot; key from demolabconfig.json with the names stored in the text file.\r\n\r\n    &quot;name&quot;: &quot;Node1&quot; must be replaced as &quot;name&quot;:&quot;Tom-cat&quot;\r\n    ];\r\n    .....\r\n    .....\r\n    ],\r\n    &quot;name&quot;: &quot;Node2&quot; must be replaced as &quot;name&quot;:&quot;Lucky-worm&quot;\r\n    ];\r\n    .....\r\n    .....\r\n    ],\r\n    &quot;name&quot;: &quot;Node3&quot; must be replaced as &quot;name&quot;:&quot;Wom-bat&quot;\r\n\r\nThe indexing is done for the key &quot;nodes&quot;: .lab.racks[].nodes[$i].name\r\n\r\nThe code:\r\n\r\n    readarray -t array &lt; newhostnames.txt\r\n    array=(&quot;${array[@]:1}&quot;)\r\n    array_length=${#array[@]}\r\n    for((i=0;i&lt;${array_length};i++));\r\n    do\r\n        declare -x  NEW_NODENAME\r\n        OLD_NODENAME=$(jq -r &quot;.lab.racks[].nodes[$i].name&quot; demolabconfig.json)\r\n        echo &quot;$OLD_NODENAME&quot;\r\n        NEW_NODENAME=&quot;${array[i]}&quot;\r\n        echo &quot;$NEW_NODENAME&quot;\r\n        jq &quot;.lab.racks[].nodes[$i].name=env.NEW_NODENAME&quot; demolabconfig.json &gt; newdemolabconfig.json\r\n    done\r\n\r\nBut the code only replaces one value in the end for the last $i i.e, the last key_value pair. All other preceding nodes retain the same name as in the original JSON file.\r\n\r\nI have tried by using an if statement to break the loop if the value is already updated so it is not re_written from the old demolabconfig.json file. But that is also not working!\r\n    \r\n    if [[ &quot;$OLD_NODENAME&quot; -ne &quot;$NEWNODENAME&quot; ]]; then\r\n        jq &quot;.lab.racks[].nodes[$i].name=env.NEW_NODENAME&quot; demolabconfig.json &gt; newdemolabconfig.json\r\n    else\r\n        break\r\n    fi\r\n\r\nThis if loop was written with a while loop instead of for. This replaces the last name with null.\r\n\r\nPlease suggest how I can fix this error and improve my code. Thanks :)\r\n ",
        "link": "https://stackoverflow.com/questions/50253817/updating-json-object-values-dynamically-and-storing-them-in-a-new-file-in-bash",
        "title": "Updating JSON object values dynamically and storing them in a new file in BASH"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "regex-negation"
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1525876435,
                "creation_date": 1525876435,
                "answer_id": 50255988,
                "question_id": 50255694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; all those values that do not match a regex\r\n\r\nSounds like `test(_) | not` is what you&#39;re looking for. Assuming you meant to write &quot;first letter must NOT be a capital&quot;, the following filter could be used:\r\n\r\n    map(select(test(&quot;^[A-Z]&quot;)|not))\r\n",
                "title": "jq negative select elements of array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 13,
        "last_activity_date": 1602053357,
        "creation_date": 1525875496,
        "last_edit_date": 1602053357,
        "question_id": 50255694,
        "body_markdown": "Take the data set as lines of arrays with values, e.g.:\r\n\r\n[ &quot;Dog&quot;, &quot;cat&quot;, &quot;Bird&quot;]\r\n\r\nI would like to get an array with all those values that do not match a regex but am unwilling to use negative capture groups (regex is more complicated than that) - so if my criteria would be that first letter must be capital, the output array should be [&quot;cat&quot;]\r\n",
        "link": "https://stackoverflow.com/questions/50255694/jq-negative-select-elements-of-array",
        "title": "jq negative select elements of array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1525881283,
                "creation_date": 1525881283,
                "answer_id": 50257499,
                "question_id": 50257462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had the bar on the wrong side\r\n\r\n`jq &#39;.[] | select(.name==&quot;atlas&quot;) | .id&#39;`",
                "title": "JQ select name shows id"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1525881283,
        "creation_date": 1525881150,
        "question_id": 50257462,
        "body_markdown": "I think this is almost right I&#39;m just missing a piece, if I select `Atlas` I want to display the `Id`\r\n\r\n`echo &quot;${json}&quot; |jq &#39;.[] | select(.name==&quot;atlas&quot; | .id)&#39;`\r\n\r\nJSON\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;atlas&quot;,\r\n        &quot;id&quot;: 2314430,\r\n        &quot;slug&quot;: &quot;atlas&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;privacy&quot;: &quot;closed&quot;,\r\n        &quot;url&quot;: &quot;https://api.github.com/teams/2314430&quot;,\r\n        &quot;members_url&quot;: &quot;https://api.github.com/teams/2314430/members{/member}&quot;,\r\n        &quot;repositories_url&quot;: &quot;https://api.github.com/teams/2314430/repos&quot;,\r\n        &quot;permission&quot;: &quot;pull&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;HAL&quot;,\r\n        &quot;id&quot;: 2318635,\r\n        &quot;slug&quot;: &quot;hal&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;privacy&quot;: &quot;closed&quot;,\r\n        &quot;url&quot;: &quot;https://api.github.com/teams/2318635&quot;,\r\n        &quot;members_url&quot;: &quot;https://api.github.com/teams/2318635/members{/member}&quot;,\r\n        &quot;repositories_url&quot;: &quot;https://api.github.com/teams/2318635/repos&quot;,\r\n        &quot;permission&quot;: &quot;pull&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/50257462/jq-select-name-shows-id",
        "title": "JQ select name shows id"
    },
    {
        "tags": [
            "arrays",
            "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": 1526018308,
                "post_id": 50273045,
                "comment_id": 87587623,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526085956,
                "creation_date": 1526085956,
                "answer_id": 50301893,
                "question_id": 50273045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i think what you want is [Recursive Descent: ..][1]\r\n\r\n    cat car.json | jq -r &#39;.. | [.name?, .id?] | select(length&gt;0) | @tsv&#39;\r\n\r\nto produce something like in your example,\r\n\r\n    cat car.json | jq -r &#39;.. | {name:.name?, id:.id?}&#39;\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#TypesandValues\r\n\r\n",
                "title": "How to extract specific object from JSON with arrays via jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1526085956,
        "creation_date": 1525955402,
        "last_edit_date": 1525981507,
        "question_id": 50273045,
        "body_markdown": "How can I extract only the objects `id` and `name` from this JSON via jq?\r\n\r\n\r\nThe output should be look like the format below. This is just an example for the required output, the real one that I need is to catch the whole values `id` and `name` like in the JSON source.\r\n\r\n**This is the required output:**\r\n\r\n    {\r\n     &quot;name&quot;: &quot;Auto Body Styles&quot;,\r\n          &quot;id&quot;: &quot;1.1&quot;}\r\n    {\r\n              &quot;name&quot;: &quot;Convertible&quot;,\r\n              &quot;id&quot;: &quot;1.1.2&quot;\r\n                     } \r\n\r\n  \r\n\r\n\r\n\r\n**This is the JSON source file:**\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Automotive&quot;,\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Auto Body Styles&quot;,\r\n          &quot;id&quot;: &quot;1.1&quot;,\r\n          &quot;categories&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Commercial Trucks&quot;,\r\n              &quot;id&quot;: &quot;1.1.1&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Convertible&quot;,\r\n              &quot;id&quot;: &quot;1.1.2&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Coupe&quot;,\r\n              &quot;id&quot;: &quot;1.1.3&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Crossover&quot;,\r\n              &quot;id&quot;: &quot;1.1.4&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Hatchback&quot;,\r\n              &quot;id&quot;: &quot;1.1.5&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Microcar&quot;,\r\n              &quot;id&quot;: &quot;1.1.6&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Minivan&quot;,\r\n              &quot;id&quot;: &quot;1.1.7&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Off-Road Vehicles&quot;,\r\n              &quot;id&quot;: &quot;1.1.8&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Pickup Trucks&quot;,\r\n              &quot;id&quot;: &quot;1.1.9&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Sedan&quot;,\r\n              &quot;id&quot;: &quot;1.1.10&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Station Wagon&quot;,\r\n              &quot;id&quot;: &quot;1.1.11&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;SUV&quot;,\r\n              &quot;id&quot;: &quot;1.1.12&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Van&quot;,\r\n              &quot;id&quot;: &quot;1.1.13&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Buying and Selling&quot;,\r\n          &quot;id&quot;: &quot;1.2&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Insurance&quot;,\r\n          &quot;id&quot;: &quot;1.3&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Parts&quot;,\r\n          &quot;id&quot;: &quot;1.4&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Recalls&quot;,\r\n          &quot;id&quot;: &quot;1.5&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Repair&quot;,\r\n          &quot;id&quot;: &quot;1.6&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Safety&quot;,\r\n          &quot;id&quot;: &quot;1.7&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Shows&quot;,\r\n          &quot;id&quot;: &quot;1.8&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Technology&quot;,\r\n          &quot;id&quot;: &quot;1.9&quot;,\r\n          &quot;categories&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Auto Infotainment Technologies&quot;,\r\n              &quot;id&quot;: &quot;1.9.1&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Auto Navigation Systems&quot;,\r\n              &quot;id&quot;: &quot;1.9.2&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Auto Safety Technologies&quot;,\r\n              &quot;id&quot;: &quot;1.9.3&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Auto Type&quot;,\r\n          &quot;id&quot;: &quot;1.10&quot;,\r\n          &quot;categories&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Budget Cars&quot;,\r\n              &quot;id&quot;: &quot;1.10.1&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Certified Pre-Owned Cars&quot;,\r\n              &quot;id&quot;: &quot;1.10.2&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Classic Cars&quot;,\r\n              &quot;id&quot;: &quot;1.10.3&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Concept Cars&quot;,\r\n              &quot;id&quot;: &quot;1.10.4&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Driverless Cars&quot;,\r\n              &quot;id&quot;: &quot;1.10.5&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Green Vehicles&quot;,\r\n              &quot;id&quot;: &quot;1.10.6&quot;\r\n            }\r\n          ]\r\n        } ] }",
        "link": "https://stackoverflow.com/questions/50273045/how-to-extract-specific-object-from-json-with-arrays-via-jq",
        "title": "How to extract specific object from JSON with arrays via jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "d3.js",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7606366,
                    "reputation": 102370,
                    "user_id": 5768908,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/EiTWn.png?s=256",
                    "display_name": "Gerardo Furtado",
                    "link": "https://stackoverflow.com/users/5768908/gerardo-furtado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526014916,
                "post_id": 50285224,
                "comment_id": 87586424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7414567,
                    "reputation": 1139,
                    "user_id": 5640850,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-h0Z1mNHfZfU/AAAAAAAAAAI/AAAAAAAAAKs/QvPFCMDNKCg/s256-rj/photo.jpg",
                    "display_name": "SteveR",
                    "link": "https://stackoverflow.com/users/5640850/stever"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526044396,
                "post_id": 50285224,
                "comment_id": 87602569,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10008894,
                    "reputation": 209,
                    "user_id": 7402323,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/d1dd304c6d6bb622a6639609240fc701?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "FDRH",
                    "link": "https://stackoverflow.com/users/7402323/fdrh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526051615,
                "post_id": 50285224,
                "comment_id": 87607340,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7606366,
                    "reputation": 102370,
                    "user_id": 5768908,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/EiTWn.png?s=256",
                    "display_name": "Gerardo Furtado",
                    "link": "https://stackoverflow.com/users/5768908/gerardo-furtado"
                },
                "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": 1526076606,
                "post_id": 50285224,
                "comment_id": 87618520,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526089713,
                "last_edit_date": 1526089713,
                "creation_date": 1526065826,
                "answer_id": 50298804,
                "question_id": 50285224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a [jq][1] approach that supports unlimited nesting by using recursion.  Since it&#39;s unclear exactly how the `groups` value is to be computed, the following program (program.jq) uses a fixed value. If you can specify an algorithm for determining the value, it should be easy to incorporate it into the program.\r\n\r\nThe key to understanding program.jq is understanding `group_by(f)`, which groups the input array items into an array of arrays.\r\n\r\n### program.jq\r\n\r\n    def gather($supplement):\r\n      group_by(.[0])\r\n      | map( {name: .[0][0]} \r\n             + $supplement +\r\n             {children: (if (.[0]|length) &gt; 2\r\n    \t                 then (map(.[1:]) | gather($supplement))\r\n    \t\t             else map({name:.[1]} + $supplement)\r\n    \t\t             end) } )\r\n      ;\r\n    \r\n    split(&quot;\\n&quot;) | map(split(&quot;,&quot;))\r\n    | .[1:] # skip the headers\r\n    | map(select(length&gt;0))\r\n    | gather({&quot;groups&quot;:[&quot;CS Analyst&quot;, &quot;Cyber Crime&quot;]})\r\n    | .[]\r\n\r\n\r\n###Invocation:\r\n     jq -Rs -f program.jq nested.csv\r\n\r\n### Output:\r\n\r\n    \r\n      {\r\n        &quot;name&quot;: &quot;Networking&quot;,\r\n        &quot;groups&quot;: [\r\n          &quot;CS Analyst&quot;,\r\n          &quot;Cyber Crime&quot;\r\n        ],\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Networking Communications&quot;,\r\n            &quot;groups&quot;: [\r\n              &quot;CS Analyst&quot;,\r\n              &quot;Cyber Crime&quot;\r\n            ],\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Data Transmission&quot;,\r\n                &quot;groups&quot;: [\r\n                  &quot;CS Analyst&quot;,\r\n                  &quot;Cyber Crime&quot;\r\n                ],\r\n                &quot;children&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;Data - Overview&quot;,\r\n                    &quot;groups&quot;: [\r\n                      &quot;CS Analyst&quot;,\r\n                      &quot;Cyber Crime&quot;\r\n                    ]\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;Email&quot;,\r\n                    &quot;groups&quot;: [\r\n                      &quot;CS Analyst&quot;,\r\n                      &quot;Cyber Crime&quot;\r\n                    ]\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;Datagram&quot;,\r\n                    &quot;groups&quot;: [\r\n                      &quot;CS Analyst&quot;,\r\n                      &quot;Cyber Crime&quot;\r\n                    ]\r\n                  }\r\n                ]\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;Networking Models&quot;,\r\n                &quot;groups&quot;: [\r\n                  &quot;CS Analyst&quot;,\r\n                  &quot;Cyber Crime&quot;\r\n                ],\r\n                &quot;children&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;OSI Model&quot;,\r\n                    &quot;groups&quot;: [\r\n                      &quot;CS Analyst&quot;,\r\n                      &quot;Cyber Crime&quot;\r\n                    ]\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;TCP/IP Mode&quot;,\r\n                    &quot;groups&quot;: [\r\n                      &quot;CS Analyst&quot;,\r\n                      &quot;Cyber Crime&quot;\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    \r\n\r\n  [1]: http://stedolan.github.io/jq/",
                "title": "flat CSV to nested JSON tree for D3.js"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1526075909,
                "creation_date": 1526075909,
                "answer_id": 50300797,
                "question_id": 50285224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    var data = [\r\n      &quot;Networking, Networking Communications, Data Transmission, Data-Overview&quot;,\r\n      &quot;Networking, Networking Communications, Data Transmission, Email&quot;,\r\n      &quot;Networking, Networking Communications, Data Transmission, Something&quot;,\r\n      &quot;Networking,  Networking Communications,   Collection Management,   Logs&quot;,\r\n      &quot;Networking,  Networking Communications,   Collection Management,   Backups&quot;,\r\n      &quot;Networking,  Networking Communications,   Collection Management,   Configuration files&quot;,\r\n      &quot;Networking,  Network Architecture,    Architecture Concepts,   Types&quot;,\r\n      &quot;Networking,  Network Architecture,    Architecture Concepts,  Design&quot;,\r\n      &quot;Networking,  Network Architecture,    Network Topologies,  Comm Medias&quot;,\r\n      &quot;Networking,  Network Architecture,    Network Topologies,  Implementations&quot;,\r\n      &quot;Networking,  Network Architecture,    Intranet Extranet,  Zoning&quot;\r\n    ]\r\n    \r\n    var arrayToTree = (finalArray, currentArray) =&gt; {\r\n      var node\r\n    \r\n      currentArray.forEach((name, index) =&gt; {\r\n        const children = index === 0 ? finalArray : node[&#39;children&#39;]\r\n        let newNode = children.find(child =&gt; child.name === name)\r\n        \r\n        if (!newNode) {\r\n          newNode = {\r\n            name,\r\n            ...(\r\n              index &lt; currentArray.length - 1\r\n              ? { children: [] }\r\n              : {}\r\n            )\r\n          }\r\n          \r\n          children.push(newNode)\r\n        }\r\n    \r\n        node = newNode\r\n      })\r\n      \r\n      return finalArray\r\n    }\r\n    \r\n    var finalResult = data.map(row =&gt; row.split(/,\\s+/)).reduce(arrayToTree, [])",
                "title": "flat CSV to nested JSON tree for D3.js"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1526089713,
        "creation_date": 1526014566,
        "last_edit_date": 1526066718,
        "question_id": 50285224,
        "body_markdown": "I have a lot of data in a CSV that I need to convert to nested JSON to use in a D3.js tree.\r\n\r\nHere&#39;s a sample of the CSV data:\r\n\r\n    Domain,Subject,Section,Topic\r\n    Networking,Networking Communications,Data Transmission,Data - Overview\r\n    Networking,Networking Communications,Data Transmission,Email\r\n    Networking,Networking Communications,Data Transmission,Datagram\r\n    Networking,Networking Communications,Networking Models,OSI Model\r\n    Networking,Networking Communications,Networking Models,TCP/IP Mode\r\n\r\n\r\nThis is how the JSON should look:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;Networking&quot;,\r\n        &quot;groups&quot;:[&quot;CS Analyst&quot;, &quot;Cyber Crime&quot;],\r\n        &quot;children&quot;:[\r\n        \t{\r\n        \t\t&quot;name&quot;:&quot;Networking Communications&quot;,\r\n        \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;, &quot;Cyber Crime&quot;],\r\n        \t\t&quot;children&quot;:[\r\n        \t\t\t{\r\n    \t\t    \t\t&quot;name&quot;:&quot;Data Transmission&quot;,\r\n    \t\t    \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;, &quot;Cyber Crime&quot;],\r\n    \t\t    \t\t&quot;children&quot;:[\r\n    \t\t    \t\t\t{\r\n    \t\t\t\t    \t\t&quot;name&quot;:&quot;Data - Overview&quot;,\r\n    \t\t\t\t    \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;, &quot;Cyber Crime&quot;],\r\n    \t\t\t\t    \t},\r\n    \t\t\t\t    \t{\r\n    \t\t\t\t    \t\t&quot;name&quot;:&quot;Email&quot;,\r\n    \t\t\t\t    \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;, &quot;Cyber Crime&quot;],\r\n    \t\t\t\t    \t},\r\n    \t\t\t\t    \t{\r\n    \t\t\t\t    \t\t&quot;name&quot;:&quot;Datagram&quot;,\r\n    \t\t\t\t    \t\t&quot;groups&quot;:[],\r\n    \t\t\t\t    \t}\r\n    \t\t    \t\t]\r\n    \t\t    \t},\r\n    \t\t    \t{\r\n    \t\t    \t\t&quot;name&quot;:&quot;Networking Models&quot;,\r\n    \t\t    \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;],\r\n    \t\t    \t\t&quot;children&quot;:[\r\n    \t\t    \t\t\t{\r\n    \t\t\t\t    \t\t&quot;name&quot;:&quot;OSI Model&quot;,\r\n    \t\t\t\t    \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;],\r\n    \t\t\t\t    \t},\r\n    \t\t\t\t    \t{\r\n    \t\t\t\t    \t\t&quot;name&quot;:&quot;TCP/IP Model&quot;,\r\n    \t\t\t\t    \t\t&quot;groups&quot;:[&quot;CS Analyst&quot;],\r\n    \t\t\t\t    \t}\r\n    \t\t    \t\t]\r\n    \t\t    \t},\r\n    \t\t    \t\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50285224/flat-csv-to-nested-json-tree-for-d3-js",
        "title": "flat CSV to nested JSON tree for D3.js"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1526019805,
                "creation_date": 1526019805,
                "answer_id": 50286182,
                "question_id": 50286044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Answer my own question.\r\n\r\n    cat input.json |jq &#39;.shipping | {us_rate: .us_rate}&#39;",
                "title": "Need have jq output with its key as well"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1526020681,
                "last_edit_date": 1526020681,
                "creation_date": 1526020325,
                "answer_id": 50286310,
                "question_id": 50286044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or just:\r\n\r\n    .shipping | {us_rate}\r\n\r\nusing the abbreviation `{foo}` for `{&quot;foo&quot;: .foo}` when `.foo` is allowed.",
                "title": "Need have jq output with its key as well"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1526165483,
        "creation_date": 1526019065,
        "last_edit_date": 1526165483,
        "question_id": 50286044,
        "body_markdown": "Currently with below json, \r\n\r\n    $ cat input.json\r\n\r\n    {\r\n      &quot;shipping&quot;: {\r\n        &quot;local&quot;: true,\r\n        &quot;us&quot;: true,\r\n        &quot;us_rate&quot;: {\r\n          &quot;amount&quot;: &quot;0.00&quot;,\r\n          &quot;currency&quot;: &quot;USD&quot;,\r\n          &quot;symbol&quot;: &quot;$&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI can simply get the `us_rate`\r\n\r\n    $ cat input.json |jq .shipping.us_rate\r\n    {\r\n      &quot;amount&quot;: &quot;0.00&quot;,\r\n      &quot;currency&quot;: &quot;USD&quot;,\r\n      &quot;symbol&quot;: &quot;$&quot;\r\n    }\r\n\r\nBut I want to include its key as well as: \r\n\r\n    {\r\n      &quot;us_rate&quot;: {\r\n        &quot;amount&quot;: &quot;0.00&quot;,\r\n        &quot;currency&quot;: &quot;USD&quot;,\r\n        &quot;symbol&quot;: &quot;$&quot;\r\n      }\r\n    }\r\n\r\nWhat should I do?\r\n",
        "link": "https://stackoverflow.com/questions/50286044/need-have-jq-output-with-its-key-as-well",
        "title": "Need have jq output with its key as well"
    },
    {
        "tags": [
            "kubernetes",
            "base64",
            "jq",
            "jsonpath",
            "kubectl"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1526020705,
                "creation_date": 1526020705,
                "answer_id": 50286402,
                "question_id": 50286066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sufficiently recent versions of jq have a filter for decoding base64 but it can only be used if the value that was encoded is a valid JSON string.\r\n\r\nAnyway, you could start by trying:\r\n\r\n    .data | map_values(@base64d)",
                "title": "Kubernetes / kubectl print all secrets"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611701420,
                "last_edit_date": 1611701420,
                "creation_date": 1610194169,
                "answer_id": 65642451,
                "question_id": 50286066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need to extract tls certificates and/or keys from a kubernetes secret and you have an older jq version not supporting map_values(@base64d): \r\n\r\n    kubectl get secrets tls-cert -o json | jq &#39;.data&#39; | cut -d &#39;&quot;&#39; -f 4 | tr -d &#39;{}&#39; | base64 --decode\r\n",
                "title": "Kubernetes / kubectl print all secrets"
            },
            {
                "up_vote_count": 27,
                "is_accepted": false,
                "score": 27,
                "last_activity_date": 1649347827,
                "creation_date": 1649347827,
                "answer_id": 71785550,
                "question_id": 50286066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I read this question as asking for how to decode *all secrets* in one go.  I built on the accepted answer to produce a one-liner to do this:\r\n\r\n    kubectl get secrets -o json | jq &#39;.items[] | {name: .metadata.name,data: .data|map_values(@base64d)}&#39;\r\n\r\nThis has the added benefit of listing the name of the secret along with the decoded values for readability.",
                "title": "Kubernetes / kubectl print all secrets"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1670320290,
                "creation_date": 1670320290,
                "answer_id": 74700445,
                "question_id": 50286066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When using the accepted answer you may come across exception\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:96): Cannot iterate over null (null)\r\n\r\n```\r\n\r\nThis might be because some json might not be fully formed, use an additional filter\r\n\r\n```\r\nkubectl get secrets -o json | jq &#39;.items[] |  select(null != .data) | {name: .metadata.name,data: .data|map_values(@base64d)}&#39;\r\n\r\n```\r\n\r\nThe above will ensure to produce expected results",
                "title": "Kubernetes / kubectl print all secrets"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1686764292,
                "creation_date": 1686764292,
                "answer_id": 76476224,
                "question_id": 50286066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Kubernetes get all secretes base64 decode them, and ignore null values. \r\n```\r\n# kubectl get secrets -A -o json | jq &#39;.items[] |  \\\r\nselect(null != .data) | {name: .metadata.name,data: .data|map_values(@base64d)}&#39; \\\r\n&gt; all_secrets_decoded.json\r\n```",
                "title": "Kubernetes / kubectl print all secrets"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1687998491,
                "creation_date": 1687998491,
                "answer_id": 76577431,
                "question_id": 50286066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For my needs I wrote a shell function, a wrapper around jq, that allows me to filter by names and decode secrets. It doesn&#39;t depend on a kubectl version but requires jq in $PATH. It&#39;s quite simple in use:\r\n\r\n    divulge() {\r\n    \t[ -t 0 ] &amp;&amp; [ $# -eq 0 ] &amp;&amp; {\r\n    \t\techo &quot;\\\r\n    Discover kubernetes secrets\r\n    \r\n    Usage:\r\n        kubectl get secrets [NAME] -o json | divulge [OPTIONS] [REGEXP]\r\n    \r\n    Options:\r\n      -g  Global search (find all matches, not just the first)\r\n      -i  Case insensitive search\r\n      -m  Multi line mode (. will match newlines)\r\n      -n  Ignore empty matches\r\n      -p  Both s and m modes are enabled\r\n      -s  Single line mode (^ -&gt; \\A, $ -&gt; \\Z)\r\n      -l  Find longest possible matches\r\n      -x  Extended regex format (ignore whitespace and comments)\r\n    \r\n      -r  Output raw strings, not JSON texts; values are placed between [ and ]\r\n          and marked with the prefix unsafe, if contain at least a whitespace\r\n      -C  Colorize JSON\r\n      -M  Monochrome JSON\r\n    \r\n    Follow the below link to learn more about REGEXP:\r\n    https://jqlang.github.io/jq/manual/#Regularexpressions&quot;\r\n    \t\treturn\r\n    \t}\r\n    \r\n    \tunset DIVULGE_FLAGS DIVULGE_RAW DIVULGE_OPTS\r\n    \r\n    \twhile getopts &#39;:gimnpslxrCM&#39; arg\r\n    \tdo\r\n    \t\tcase &quot;$arg&quot; in\r\n    \t\tg | i | m | n | p | s | l | x )\r\n    \t\t\tDIVULGE_FLAGS=&quot;$DIVULGE_FLAGS$arg&quot; ;;\r\n    \t\tr )\tDIVULGE_RAW=1 ;;\r\n    \t\tC | M )\tDIVULGE_OPTS=&quot;$DIVULGE_OPTS -$arg&quot; ;;\r\n    \t\t* )\techo &quot;Illegal option: -$OPTARG&quot;&gt;&amp;2 ; return 1 ;;\r\n    \t\tesac\r\n    \tdone\r\n    \r\n    \tshift $(( OPTIND-1 ))\r\n    \r\n    \t# shellcheck disable=SC2086\r\n    \tjq $DIVULGE_OPTS \\\r\n    \t--arg regex &quot;$1&quot; \\\r\n    \t--arg flags &quot;$DIVULGE_FLAGS&quot; \\\r\n    \t--arg raw &quot;$DIVULGE_RAW&quot; \\\r\n    \t-r &#39;(.items?[]? // .)\r\n    | .data\r\n    | select(.)\r\n    | with_entries(\r\n    \tselect(\r\n    \t\t.key\r\n    \t\t| test($regex; $flags)\r\n    \t)\r\n    \t| .value |= @base64d\r\n    )\r\n    | (\r\n    \tif $raw == &quot;&quot;\r\n    \tthen\r\n    \t\tselect(. != {})\r\n    \telse\r\n    \t\tto_entries\r\n    \t\t| map(\r\n    \t\t\t(\r\n    \t\t\t\tif .value | test(&quot;\\\\s&quot;)\r\n    \t\t\t\tthen\r\n    \t\t\t\t\t&quot;unsafe &quot;\r\n    \t\t\t\telse\r\n    \t\t\t\t\t&quot;safe   &quot;\r\n    \t\t\t\tend\r\n    \t\t\t) + .key + &quot; [&quot; + .value + &quot;]&quot;\r\n    \t\t)\r\n    \t\t| .[]\r\n    \tend\r\n    )&#39;\r\n    }\r\n\r\nA standalone version can be found by [this link][1].\r\n\r\n\r\n  [1]: https://github.com/ildar-shaimordanov/my-scripts/blob/master/shell/k8s/divulge",
                "title": "Kubernetes / kubectl print all secrets"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 27,
        "last_activity_date": 1687998491,
        "creation_date": 1526019184,
        "last_edit_date": 1526028894,
        "question_id": 50286066,
        "body_markdown": "I would like to use `kubectl` to print out all key-value pairs in my Secrets. I cannot figure out how to do this in one line with the `-o --jsonpath` flag or by piping into `jq`. I could certainly make a script to do this but I feel there must be a better way, given that the kubernetes GUI is pretty straightforward and liberal when it comes to letting you view Secrets.\r\n\r\nSay I create secret like so:\r\n\r\n`kubectl create secret generic testsecret --from-literal=key1=val1 --from-literal=key2=val2`\r\n\r\nNow I can run `kubectl get secret testsecret -o json` to get something like:\r\n\r\n    {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;key1&quot;: &quot;dmFsMQ==&quot;,\r\n            &quot;key2&quot;: &quot;dmFsMg==&quot;\r\n        },\r\n        ...\r\n    }\r\n\r\nI can do something like\r\n\r\n`kubectl get secret testsecret -o jsonpath=&#39;{.data}&#39;` \r\n\r\nor \r\n\r\n`kubectl get secret testsecret -o json | jq &#39;.data&#39;`\r\n\r\nto get my key-value pairs in *non-list* format then I&#39;d have to `base64 --decode` the values.\r\n\r\nWhat is the easiest way to get a clean list of all my key-value pairs? Bonus points for doing this across all Secrets (as opposed to just one specific one, as I did here).",
        "link": "https://stackoverflow.com/questions/50286066/kubernetes-kubectl-print-all-secrets",
        "title": "Kubernetes / kubectl print all secrets"
    },
    {
        "tags": [
            "json",
            "join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1526061761,
                "creation_date": 1526061761,
                "answer_id": 50297886,
                "question_id": 50296326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With foobar.jq as follows:\r\n\r\n    def dict(f):\r\n      reduce .[] as $o ({}; .[$o | f | tostring] = $o ) ;\r\n\r\n    ($bar | dict(.deviceId)) as $dict\r\n    | .Schedule |= map(. + ($dict[.deviceId|tostring] ))\r\n\r\nthe invocation:\r\n\r\n    jq -f foobar.jq --argfile bar bar.json foo.json\r\n\r\nyields the output shown below.\r\n\r\nNotice that the referents in the dictionary contain the full object (including the key/value pair for &quot;deviceId&quot;), but it&#39;s not necessary to `del(.deviceId)` because of the way `+` is defined in jq.\r\n\r\n### Output\r\n\r\n    {\r\n      &quot;Schedule&quot;: [\r\n        {\r\n          &quot;deviceId&quot;: 123,\r\n          &quot;reservationId&quot;: 123456,\r\n          &quot;username&quot;: &quot;jdoe&quot;,\r\n          &quot;a&quot;: {\r\n            &quot;b&quot;: &quot;10.0.0.1&quot;,\r\n            &quot;c&quot;: &quot;hostname1&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;deviceId&quot;: 456,\r\n          &quot;reservationId&quot;: 589114,\r\n          &quot;username&quot;: &quot;jsmith&quot;,\r\n          &quot;a&quot;: {\r\n            &quot;b&quot;: &quot;10.0.0.2&quot;,\r\n            &quot;c&quot;: &quot;hostname2&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;serverTime&quot;: 1522863125.019958\r\n    }\r\n\r\n",
                "title": "Combining JSON by common key-value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1526072639,
        "creation_date": 1526055139,
        "last_edit_date": 1526072639,
        "question_id": 50296326,
        "body_markdown": "I&#39;m currently working through an issue, and can&#39;t seem to figure this one out. Here&#39;s some data so you know what I&#39;m talking about below:\r\n\r\nfoo.json\r\n\r\n    {\r\n        &quot;Schedule&quot;: [\r\n            {\r\n                &quot;deviceId&quot;: 123,\r\n                &quot;reservationId&quot;: 123456,\r\n                &quot;username&quot;: &quot;jdoe&quot;\r\n            },\r\n            {\r\n                &quot;deviceId&quot;: 456,\r\n                &quot;reservationId&quot;: 589114,\r\n                &quot;username&quot;: &quot;jsmith&quot;\r\n            }\r\n        ],\r\n        &quot;serverTime&quot;: 1522863125.019958\r\n    }\r\n\r\nbar.json\r\n\r\n    [\r\n        {\r\n            &quot;a&quot;: {\r\n                &quot;b&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;c&quot;: &quot;hostname1&quot;\r\n            },\r\n            &quot;deviceId&quot;: 123\r\n        },\r\n        {\r\n            &quot;a&quot;: {\r\n                &quot;b&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;c&quot;: &quot;hostname2&quot;\r\n            },\r\n            &quot;deviceId&quot;: 456\r\n        }\r\n    ]\r\n\r\nfoobar.json\r\n\r\n    {\r\n        &quot;Schedule&quot;: [\r\n            {\r\n                &quot;deviceId&quot;: 123,\r\n                &quot;reservationId&quot;: 123456,\r\n                &quot;username&quot;: &quot;jdoe&quot;,\r\n                &quot;a&quot;: {\r\n                    &quot;b&quot;: &quot;10.0.0.1&quot;,\r\n                    &quot;c&quot;: &quot;hostname1&quot;\r\n                }\r\n            }\r\n            },\r\n            {\r\n                &quot;deviceId&quot;: 456,\r\n                &quot;reservationId&quot;: 789101,\r\n                &quot;username&quot;: &quot;jsmith&quot;,\r\n                &quot;a&quot;: {\r\n                    &quot;b&quot;: &quot;10.0.0.2&quot;,\r\n                    &quot;c&quot;: &quot;hostname2&quot;\r\n                }\r\n            }\r\n        ],\r\n        &quot;serverTime&quot;: 1522863125.019958\r\n    }\r\n\r\n\r\nI&#39;m trying to use jq to do this, and had some help from this post: https://github.com/stedolan/jq/issues/1090\r\nThe goal is to be able to combine JSON, using some key as a common point between the documents. The data may be nested any amount of levels.. In this case foo.json has nested data only two levels deep, but needs to be combined with data nested 1 level deep.\r\n\r\nAny and all suggestions would be super helpful. I&#39;m also happy to clarify and answer questions if needed. Thank you!",
        "link": "https://stackoverflow.com/questions/50296326/combining-json-by-common-key-value-pairs",
        "title": "Combining JSON by common key-value pairs"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526092044,
                "last_edit_date": 1526092044,
                "creation_date": 1526091761,
                "answer_id": 50302324,
                "question_id": 50302184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "after some trial and error, it looks like this is one way to do it.\r\n\r\n    cat dep.json | jq &#39;.apps[].dep |= (. + [&quot;b.jar&quot;] | unique)&#39;\r\n\r\n",
                "title": "how to add an element to a list only when it is not exists already if the list is null create one?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1526092904,
                "last_edit_date": 1526092904,
                "creation_date": 1526092002,
                "answer_id": 50302337,
                "question_id": 50302184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the sake of clarity, let&#39;s define a helper function for performing the core task:\r\n\r\n    # It is assumed that the input is an object\r\n    # that either does not have the specified key or\r\n    # that it is array-valued\r\n    def ensure_has($key; $value):\r\n      if has($key) and (.[$key] | index($value)) then .\r\n      else .[$key] += [$value]\r\n      end ;\r\n\r\nThe task can now be accomplished in a straightforward way:\r\n\r\n    .apps |= map(ensure_has(&quot;dep&quot;; &quot;b.jar&quot;))\r\n\r\n### Alternatively ...\r\n\r\n    .apps[] |= ensure_has(&quot;dep&quot;; &quot;b.jar&quot;)",
                "title": "how to add an element to a list only when it is not exists already if the list is null create one?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1526179146,
        "creation_date": 1526089748,
        "last_edit_date": 1526179146,
        "question_id": 50302184,
        "body_markdown": "**input**\r\n\r\n    {\r\n      &quot;apps&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;whatever1&quot;,\r\n          &quot;id&quot;: &quot;ID1&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;whatever2&quot;,\r\n          &quot;id&quot;: &quot;ID2&quot;,\r\n          &quot;dep&quot;: [\r\n            &quot;a.jar&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;whatever3&quot;,\r\n          &quot;id&quot;: &quot;ID3&quot;,\r\n          &quot;dep&quot;: [\r\n            &quot;a.jar&quot;,\r\n            &quot;b.jar&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n**output**\r\n\r\n    {\r\n      &quot;apps&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;whatever1&quot;,\r\n          &quot;id&quot;: &quot;ID1&quot;,\r\n          &quot;dep&quot;: [\r\n            &quot;b.jar&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;whatever2&quot;,\r\n          &quot;id&quot;: &quot;ID2&quot;,\r\n          &quot;dep&quot;: [\r\n            &quot;a.jar&quot;,\r\n            &quot;b.jar&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;whatever3&quot;,\r\n          &quot;id&quot;: &quot;ID3&quot;,\r\n          &quot;dep&quot;: [\r\n            &quot;a.jar&quot;,\r\n            &quot;b.jar&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nin the above example \r\n\r\n - `whatever1` does not have `dep`, so create one.\r\n - `whatever2` has `dep` and does not have `b.jar`, so add `b.jar`\r\n - `whatever3` aready has `dep` and `b.jar` is there so untouched.\r\n\r\nwhat i have tried.\r\n\r\n       # add blindly, whatever3 is not right \r\n       cat dep.json | jq &#39;.apps[].dep += [&quot;b.jar&quot;]&#39;\r\n       # missed one level and whatever3 is gone.\r\n       cat dep.json | jq &#39;.apps | map(select(.dep == null or (.dep | contains([&quot;b.jar&quot;]) | not)))[] | .dep += [&quot;b.jar&quot;]&#39;",
        "link": "https://stackoverflow.com/questions/50302184/how-to-add-an-element-to-a-list-only-when-it-is-not-exists-already-if-the-list-i",
        "title": "how to add an element to a list only when it is not exists already if the list is null create one?"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1526420627,
                "post_id": 50341575,
                "comment_id": 87735801,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1526493788,
                "last_edit_date": 1526493788,
                "creation_date": 1526352730,
                "answer_id": 50341657,
                "question_id": 50341575,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the cost is a function of the input JSON, the approach you&#39;d use would be along the lines of the following filter, which merely adds {&quot;cost&quot;: null}:\r\n\r\n    .aggregations.domains.buckets |= map( . + {cost} )\r\n\r\nIf the cost depends on `key` according to some other criterion, then it would probably be best to construct a JSON dictionary mapping the keys to the cost, and then pass that dictionary in to jq, and combine the results using the technique illustrated at:\r\n\r\nhttps://stackoverflow.com/questions/50296326/combining-json-by-common-key-value-pairs\r\n\r\n## Solution using vals.txt\r\n\r\nprogram.jq:\r\n\r\n    .aggregations.domains.buckets |=\r\n      reduce range(0; $costs|length) as $i (.;\r\n          .[$i] += {cost: $costs[$i]} )\r\n      \r\n\r\nIf you want the cost to be numeric, you&#39;d write:\r\n\r\n    {cost: $costs[$i]|tonumber } )\r\n\r\nInvocation: \r\n\r\n    jq -f program.jq --argfile costs &lt;(jq -Rs &#39;\r\n      split(&quot;\\n&quot;)|map(select(length&gt;0))&#39; vals.txt) input.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;aggregations&quot;: {\r\n        &quot;domains&quot;: {\r\n          &quot;doc_count_error_upper_bound&quot;: 0,\r\n          &quot;sum_other_doc_count&quot;: 0,\r\n          &quot;buckets&quot;: [\r\n            {\r\n              &quot;key&quot;: &quot;other&quot;,\r\n              &quot;doc_count&quot;: 8679,\r\n              &quot;environments&quot;: {\r\n                &quot;value&quot;: 49\r\n              },\r\n              &quot;cost&quot;: &quot;1280.7631275949711&quot;\r\n            },\r\n            {\r\n              &quot;key&quot;: &quot;CREATIVESandPREVIEWS&quot;,\r\n              &quot;doc_count&quot;: 1235,\r\n              &quot;environments&quot;: {\r\n                &quot;value&quot;: 21\r\n              },\r\n              &quot;cost&quot;: &quot;2210.8813614145324&quot;\r\n            },\r\n            {\r\n              &quot;key&quot;: &quot;Integration&quot;,\r\n              &quot;doc_count&quot;: 65,\r\n              &quot;environments&quot;: {\r\n                &quot;value&quot;: 1\r\n              },\r\n              &quot;cost&quot;: &quot;3143.5814890583424&quot;\r\n            },\r\n            {\r\n              &quot;key&quot;: &quot;devops&quot;,\r\n              &quot;doc_count&quot;: 1,\r\n              &quot;environments&quot;: {\r\n                &quot;value&quot;: 1\r\n              },\r\n              &quot;cost&quot;: &quot;836.4116237582436&quot;\r\n            },\r\n            {\r\n              &quot;cost&quot;: &quot;1280.7631275949711&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "jq add a field to array in loop and return whole json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1526493788,
        "creation_date": 1526352119,
        "last_edit_date": 1526353124,
        "question_id": 50341575,
        "body_markdown": "I want to add a field to aggregations.domains.buckets array in below json using jq and return the full json with new fields? I want to add {&quot;cost&quot;:122.45} where cost is dynamically computed for each key..\r\n\r\n    {\r\n       &quot;aggregations&quot;:{\r\n          &quot;domains&quot;:{\r\n             &quot;doc_count_error_upper_bound&quot;:0,\r\n             &quot;sum_other_doc_count&quot;:0,\r\n             &quot;buckets&quot;:[\r\n                {\r\n                   &quot;key&quot;:&quot;other&quot;,\r\n                   &quot;doc_count&quot;:8679,\r\n                   &quot;environments&quot;:{\r\n                      &quot;value&quot;:49\r\n                   }\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;CREATIVESandPREVIEWS&quot;,\r\n                   &quot;doc_count&quot;:1235,\r\n                   &quot;environments&quot;:{\r\n                      &quot;value&quot;:21\r\n                   }\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;Integration&quot;,\r\n                   &quot;doc_count&quot;:65,\r\n                   &quot;environments&quot;:{\r\n                      &quot;value&quot;:1\r\n                   }\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;devops&quot;,\r\n                   &quot;doc_count&quot;:1,\r\n                   &quot;environments&quot;:{\r\n                      &quot;value&quot;:1\r\n                   }\r\n                }\r\n             ]\r\n          }\r\n       }\r\n    }\r\n\r\nHere is my script:\r\n\r\n    #!/bin/bash\r\n    curl -u xx:xx -H &#39;Content-Type: application/json&#39; -XPOST &#39;http://172.21.4.55:9200/log_index-dev-gcecomputeinstances-*/_search?size=0&#39; -o instancesdomainagg.json --data @instancesdomainaggquery.json\r\n    \r\n    var=0\r\n    for domain in $(cat instancesdomainagg.json | jq &#39;.aggregations.domains.buckets[].key&#39; | sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39; | sed -e &#39;s/\\(.*\\)/\\L\\1/&#39;); do\r\n    curl --trace-ascii curl.trace -u xx:xx -H &#39;Content-Type: application/json&#39; -XPOST &#39;http://172.21.4.55:9200/log_index-dev-gcebillingbq-*/_search?size=0&#39; -o bqdomainagg.json --data-binary &#39;{&quot;query&quot;:{&quot;bool&quot;:{&quot;must&quot;:{&quot;term&quot;:{&quot;environment_domain.keyword&quot;:&quot;&#39;&quot;$domain&quot;&#39;&quot;}},&quot;filter&quot;:{&quot;range&quot;:{&quot;usage_end_time.value&quot;:{&quot;from&quot;:&quot;now-1d&quot;,&quot;to&quot;:&quot;now&quot;}}}}},&quot;aggs&quot;:{&quot;cost&quot;:{&quot;sum&quot;:{&quot;field&quot;:&quot;cost&quot;}}}}&#39;\r\n    val=&quot;$(cat bqdomainagg.json | jq &#39;.aggregations.cost.value&#39;)&quot;\r\n    jq &#39;.aggregations.domains.buckets[&#39;&quot;$var&quot;&#39;] |= .+ {&quot;cost&quot;: &quot;&#39;&quot;$val&quot;&#39;&quot;}&#39; instancesdomainagg.json &gt; output.json\r\n    var=$((var+1))\r\n    done\r\n\r\nBut it&#39;s returning json with only last field added. How to dynamically update json?\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/50341575/jq-add-a-field-to-array-in-loop-and-return-whole-json",
        "title": "jq add a field to array in loop and return whole json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526398087,
                "post_id": 50353485,
                "comment_id": 87724195,
                "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": 1526401355,
                "post_id": 50353485,
                "comment_id": 87726237,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 321848,
                    "reputation": 7819,
                    "user_id": 640916,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/WX3vR.png?s=256",
                    "display_name": "djangonaut",
                    "link": "https://stackoverflow.com/users/640916/djangonaut"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1537170412,
                "post_id": 50353485,
                "comment_id": 91670106,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1526396497,
        "creation_date": 1526396497,
        "question_id": 50353485,
        "body_markdown": "I have a large JSON file that is an array of objects, which I would like to split into smaller valid json files. Is it possible to achieve this using jq or any other off-the-shelf tools?\r\n\r\nThe original JSON is in the following format\r\n\r\n[ {...}, {...}, ...]\r\n\r\nGiven this input I would like to produce multiple files which are valid json",
        "link": "https://stackoverflow.com/questions/50353485/split-large-file-size-json-into-multiple-files",
        "title": "Split large file size json into multiple files"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526400685,
                "post_id": 50354598,
                "comment_id": 87725821,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1526401206,
                "creation_date": 1526401206,
                "answer_id": 50354966,
                "question_id": 50354598,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want the &quot;value&quot; value of the *first* &quot;receiving_dns_records&quot; item:\r\n\r\n    jq -r &#39;.receiving_dns_records[0].value&#39;",
                "title": "shell - How to get value from json reponse with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527060328,
        "creation_date": 1526400022,
        "last_edit_date": 1527060328,
        "question_id": 50354598,
        "body_markdown": "I need to get &quot;mxa.mailgun.org&quot; with jq in bash \r\n\r\njson response from curl request to api: \r\n\r\n    {\r\n     &quot;domain&quot;: {\r\n        &quot;created_at&quot;: &quot;Sun, 13 May 2018 09:48:21 GMT&quot;,\r\n        &quot;id&quot;: &quot;5af809e51f4b8b00011ee1aa&quot;,\r\n        &quot;name&quot;: &quot;leadedign.co.uk&quot;,\r\n        &quot;require_tls&quot;: false,\r\n        &quot;skip_verification&quot;: false,\r\n        &quot;smtp_login&quot;: &quot;postmaster@leddesign.co.uk&quot;,\r\n        &quot;smtp_password&quot;: &quot;07d1dee-43f1869c&quot;,\r\n        &quot;spam_action&quot;: &quot;disabled&quot;,\r\n        &quot;state&quot;: &quot;unverified&quot;,\r\n        &quot;type&quot;: &quot;custom&quot;,\r\n        &quot;web_prefix&quot;: &quot;email&quot;,\r\n        &quot;web_scheme&quot;: &quot;http&quot;,\r\n        &quot;wildcard&quot;: false\r\n      },\r\n      &quot;message&quot;: &quot;Domain DNS records have been updated&quot;,\r\n      &quot;receiving_dns_records&quot;: [\r\n        {\r\n          &quot;cached&quot;: [\r\n            &quot;1 leadeesign.co.uk&quot;\r\n          ],\r\n          &quot;priority&quot;: &quot;10&quot;,\r\n          &quot;record_type&quot;: &quot;MX&quot;,\r\n          &quot;valid&quot;: &quot;unknown&quot;,\r\n          &quot;value&quot;: &quot;mxa.mailgun.org&quot;\r\n        },\r\n        {\r\n          &quot;cached&quot;: [\r\n            &quot;1 leaesign.co.uk&quot;\r\n          ],\r\n          &quot;priority&quot;: &quot;10&quot;,\r\n          &quot;record_type&quot;: &quot;MX&quot;,\r\n          &quot;valid&quot;: &quot;unknown&quot;,\r\n          &quot;value&quot;: &quot;mxb.mailgun.org&quot;\r\n        }\r\n      ]\r\n      }\r\n\r\n\r\n\r\nI tried :\r\n\r\n    curl -X PUT -s --user &#39;api:key-1659e3c0faff2c4e96e4&#39; -G  https://api.mailgun.net/v3/domains/leadereign.co.uk/verify -d skip=0 -d limit=3 | jq &#39;.[] | {receiving_dns_records: .[]}&#39;\r\n    \t\r\n    \t\tcurl -X PUT -s --user &#39;api:key-165903eaff2c4e96e4&#39; -G  https://api.mailgun.net/v3/domains/leaderfeign.co.uk/verify -d skip=0 -d limit=3 | jq &#39;.[] | {receiving_dns_records: .[value]}&#39;\r\n\r\nps. domain and api key is changed for security reasons. this curl request wont work.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50354598/shell-how-to-get-value-from-json-reponse-with-jq",
        "title": "shell - How to get value from json reponse with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "parsing",
            "jq",
            "array-merge"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608408776,
                "last_edit_date": 1608408776,
                "creation_date": 1526401675,
                "answer_id": 50355109,
                "question_id": 50354926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should be using `--argjson`; `--arg` interprets its argument as a JSON string. You will also have to modify your jq filter, because simply adding the arrays will result in their concatenation.\r\n\r\nFor further guidance, see e.g. https://stackoverflow.com/questions/50296326/combining-json-by-common-key-value-pairs",
                "title": "JQ - Merge two arrays"
            },
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1526402614,
                "last_edit_date": 1526402614,
                "creation_date": 1526401924,
                "answer_id": 50355185,
                "question_id": 50354926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that 2 input arrays are named as `firstArr` and `secondArr` respectively.\r\n\r\nwith **`group_by()`** (to group objects by the crucial key `&quot;Key&quot;`) and **`map()`** functions:\r\n\r\n    jq --argjson arr1 &quot;$firstArr&quot; --argjson arr2 &quot;$secondArr&quot; -n \\\r\n    &#39;$arr1 + $arr2 | group_by(.Key) | map(.[-1])&#39;\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;Key&quot;: &quot;A B&quot;,\r\n        &quot;Value&quot;: &quot;1 2&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;C D&quot;,\r\n        &quot;Value&quot;: &quot;3 4&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;E F&quot;,\r\n        &quot;Value&quot;: &quot;5 6&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;G H&quot;,\r\n        &quot;Value&quot;: &quot;11 12&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;J K&quot;,\r\n        &quot;Value&quot;: &quot;15 16&quot;\r\n      }\r\n    ]\r\n\r\n\r\n----------\r\nAlternatively and in such particular case, a faster way, you could apply the following trick with **`unique_by()`** function:\r\n\r\n    jq --argjson arr1 &quot;$firstArr&quot; --argjson arr2 &quot;$secondArr&quot; -n &#39;$arr2 + $arr1 | unique_by(.Key)&#39;\r\n\r\n",
                "title": "JQ - Merge two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1608408776,
        "creation_date": 1526401096,
        "last_edit_date": 1526402022,
        "question_id": 50354926,
        "body_markdown": "I&#39;m looking for JQ query that allows me to merge 2 arrays variables (not files) and also take me to overwrite first array with newer value from second array. For example:\r\n\r\n    #!/bin/bash -e\r\n    \r\n    firstArrayVariable=&#39;\r\n        [\r\n            {\r\n                &quot;Key&quot;: &quot;A B&quot;,\r\n                &quot;Value&quot;: &quot;1 2&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;C D&quot;,\r\n                &quot;Value&quot;: &quot;3 4&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;E F&quot;,\r\n                &quot;Value&quot;: &quot;5 6&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;G H&quot;,\r\n                &quot;Value&quot;: &quot;9 10&quot;\r\n            }\r\n        ]\r\n    &#39;\r\n\r\n    secondArrayVariable=&#39;\r\n        [\r\n            {\r\n                &quot;Key&quot;: &quot;A B&quot;,\r\n                &quot;Value&quot;: &quot;1 2&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;C D&quot;,\r\n                &quot;Value&quot;: &quot;3 4&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;G H&quot;,\r\n                &quot;Value&quot;: &quot;11 12&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;J K&quot;,\r\n                &quot;Value&quot;: &quot;15 16&quot;\r\n            }\r\n        ]\r\n    &#39;\r\n\r\n    jq \\\r\n        --compact-output \\\r\n        --raw-output \\\r\n        --arg jqSecondArrayVariable &quot;${secondArrayVariable}&quot; \\\r\n        &#39;. + $jqSecondArrayVariable // empty&#39; \\\r\n    &lt;&lt;&lt; &quot;${firstArrayVariable}&quot;\r\n\r\n\r\nI could not get it to work and I got following error\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:19): array ([{&quot;Key&quot;:&quot;A ...) and string (&quot;\\n    [\\n ...) cannot be added\r\n\r\n**What I expect the result of the merged array is**\r\n\r\n\r\n    [\r\n        {\r\n            &quot;Key&quot;: &quot;A B&quot;,\r\n            &quot;Value&quot;: &quot;1 2&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;C D&quot;,\r\n            &quot;Value&quot;: &quot;3 4&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;E F&quot;,\r\n            &quot;Value&quot;: &quot;5 6&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;G H&quot;,\r\n            &quot;Value&quot;: &quot;11 12&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;J K&quot;,\r\n            &quot;Value&quot;: &quot;15 16&quot;\r\n        }\r\n    ]\r\n\r\n\r\nany helps would be very appreciated!\r\n\r\n**UPDATED**\r\n\r\nI tried to use `--argjson` as @peak suggested, it concatenate array but it could not merge 2 arrays. Result I got now is an array with duplicated objects",
        "link": "https://stackoverflow.com/questions/50354926/jq-merge-two-arrays",
        "title": "JQ - Merge two arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq",
            "data-manipulation"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526423597,
                "creation_date": 1526423597,
                "answer_id": 50360044,
                "question_id": 50359980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach is to use `to_entries` to split your item into a key/value pair, after which each piece can be referred to directly.\r\n\r\n    $ jq &#39;[to_entries[] | .key as $time | .value | .[&quot;time&quot;]=$time]&#39; &lt;&lt;&lt;&quot;$in&quot;\r\n    [\r\n      {\r\n        &quot;foo&quot;: &quot;0.0&quot;,\r\n        &quot;bar&quot;: &quot;90.0&quot;,\r\n        &quot;time&quot;: &quot;2018-05-15T22:00:00Z&quot;\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;0.0&quot;,\r\n        &quot;bar&quot;: &quot;70.0&quot;,\r\n        &quot;time&quot;: &quot;2018-05-15T22:30:00Z&quot;\r\n      }\r\n    ]",
                "title": "How to copy a key into an object using `jq`?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1526424073,
                "creation_date": 1526424073,
                "answer_id": 50360111,
                "question_id": 50359980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slightly more economically:\r\n\r\n    with_entries(.value = ({date: .key} + .value))\r\n\r\nThis emits the object as per the Q.",
                "title": "How to copy a key into an object using `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1526440966,
        "creation_date": 1526423104,
        "last_edit_date": 1526440966,
        "question_id": 50359980,
        "body_markdown": "My input JSON looks like this:\r\n\r\n    {\r\n      &quot;2018-05-15T22:00:00Z&quot;: {\r\n        &quot;foo&quot;: &quot;0.0&quot;,\r\n        &quot;bar&quot;: &quot;90.0&quot;\r\n      },\r\n      &quot;2018-05-15T22:30:00Z&quot;: {\r\n        &quot;foo&quot;: &quot;0.0&quot;,\r\n        &quot;bar&quot;: &quot;70.0&quot;\r\n      }\r\n    }\r\n\r\nAnd I&#39;d like to copy the key (i.e. the datetime) into the object itself to end up with:\r\n\r\n    {\r\n      &quot;2018-05-15T22:00:00Z&quot;: {\r\n        &quot;date&quot;: &quot;2018-05-15T22:00:00Z&quot;,\r\n        &quot;foo&quot;: &quot;0.0&quot;,\r\n        &quot;bar&quot;: &quot;90.0&quot;\r\n      },\r\n      &quot;2018-05-15T22:30:00Z&quot;: {\r\n        &quot;date&quot;: &quot;2018-05-15T22:30:00Z&quot;,\r\n        &quot;foo&quot;: &quot;0.0&quot;,\r\n        &quot;bar&quot;: &quot;70.0&quot;\r\n      }\r\n    }\r\n\r\nI&#39;ll then collapse the outer object to be an array (using `map(.)`) so that the final outcome is that the date has been moved into each of the objects.",
        "link": "https://stackoverflow.com/questions/50359980/how-to-copy-a-key-into-an-object-using-jq",
        "title": "How to copy a key into an object using `jq`?"
    },
    {
        "tags": [
            "json",
            "git",
            "shell",
            "file",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1526567484,
                "creation_date": 1526567484,
                "answer_id": 50394081,
                "question_id": 50393951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "one way is:\r\n\r\n    ..file1.json|..|..|.. &gt;file2.json &amp;&amp; mv file2.json file1.json",
                "title": "How to update some values in a json file and save changes in the same file by jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526571508,
                "last_edit_date": 1526571508,
                "creation_date": 1526568368,
                "answer_id": 50394361,
                "question_id": 50393951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use `sponge` in &quot;moreutils&quot; (https://joeyh.name/code/moreutils/).  See the [jq FAQ][1] for further details and options.\r\n\r\nBy the way, you can compress your pipeline so that there is just one invocation of jq and no invocation of `cat`:\r\n\r\n    &lt; file.json jq &#39;\r\n    .roles[0].version = &quot;new&quot;\r\n    | .version = &quot;new&quot;\r\n    | .archetype_version = &quot;new&quot;&#39; | sponge file.json\r\n\r\nOf course overwriting the input file without first backing it up generally carries some risk, so in many ways a two-step process such as the following is best:\r\n\r\n    mv file.json file.tmp &amp;&amp; &lt; file.tmp jq .... &gt; file.json\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "How to update some values in a json file and save changes in the same file by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1526571508,
        "creation_date": 1526567102,
        "last_edit_date": 1526570411,
        "question_id": 50393951,
        "body_markdown": "I have the following json file :\r\n\r\n    {\r\n      &quot;src&quot;: &quot;ssh://git@bitbucket.org/myrepos/project&quot;,\r\n      &quot;version&quot;: &quot;master&quot;,\r\n      &quot;archetype_version&quot;: &quot;master&quot;,\r\n      &quot;roles&quot;: [\r\n        {\r\n          &quot;src&quot;: &quot;ssh://git@bitbucket.org/myrepos/project&quot;,\r\n          &quot;version&quot;: &quot;master&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to change the version from master to another one, so I do the following command:\r\n\r\n     cat file.json | jq &#39;.roles[0].version = &quot;new&quot;&#39; | jq &#39;.version = &quot;new&quot;&#39; | jq &#39;.archetype_version = &quot;new&quot;&#39; &gt; file2.json\r\n\r\nHow to save the changes to `file.json` not to `file2.json` because I&#39;ll need to use the same file later?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50393951/how-to-update-some-values-in-a-json-file-and-save-changes-in-the-same-file-by-jq",
        "title": "How to update some values in a json file and save changes in the same file by jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4943,
                    "reputation": 3727,
                    "user_id": 7685,
                    "user_type": "registered",
                    "accept_rate": 46,
                    "profile_image": "https://i.sstatic.net/DIkLu.jpg?s=256",
                    "display_name": "Chris Nelson",
                    "link": "https://stackoverflow.com/users/7685/chris-nelson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526587891,
                "post_id": 50399738,
                "comment_id": 87815454,
                "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": 1526592051,
                "post_id": 50399738,
                "comment_id": 87817193,
                "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": 1526592479,
                "post_id": 50399738,
                "comment_id": 87817328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8691704,
                    "reputation": 355,
                    "user_id": 6504406,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4f81e4d521c457e17744acab366782a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jenny",
                    "link": "https://stackoverflow.com/users/6504406/jenny"
                },
                "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": 1526593684,
                "post_id": 50399738,
                "comment_id": 87817749,
                "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": 1526599329,
                "post_id": 50399738,
                "comment_id": 87819311,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8691704,
                    "reputation": 355,
                    "user_id": 6504406,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4f81e4d521c457e17744acab366782a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jenny",
                    "link": "https://stackoverflow.com/users/6504406/jenny"
                },
                "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": 1526611149,
                "post_id": 50399738,
                "comment_id": 87821664,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526611323,
                "post_id": 50399738,
                "comment_id": 87821688,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1526630338,
                "last_edit_date": 1526630338,
                "creation_date": 1526619367,
                "answer_id": 50404017,
                "question_id": 50399738,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an awk script which will handle your example and others like it, but it is NOT robust.  For example, it won&#39;t handle keys with embedded spaces properly.\r\n\r\n  \r\n    awk &#39;\r\n       function ws(line,  s) {\r\n         s=line; sub(/[^ \t].*/, &quot;&quot;, s);\r\n         return s;\r\n       }\r\n    \r\n       # Global: $0\r\n       # print a value with quotation marks, checking for punctuation\r\n       function printit(s,  w) {\r\n         if ( s ~ /^[\\[{]$/ ) { print $0; return}\r\n         w=s; sub(/,$/, &quot;&quot;, w);\r\n         printf &quot;\\&quot;%s\\&quot;&quot;, w;\r\n         if (w != s) {printf &quot;%s&quot;, &quot;,&quot;}\r\n         print &quot;&quot;;\r\n       }\r\n    \r\n       NF==1 &amp;&amp; ($1 ~ /^[][{}],?$/) { print; next }\r\n       NF==2 &amp;&amp; ($2 ~ /^[][{}],?$/) { print; next }\r\n       NF==2 &amp;&amp; ($2 ~ /^[0-9]+,?$/) { print; next } \r\n       NF==2 &amp;&amp; ($2 ~ /^&quot;.*&quot;,?/   ) { print; next } \r\n    \r\n       # key: value\r\n       $1 ~ /^&quot;.*&quot;:$/ {\r\n         printf &quot;%s&quot;, ws($0) $1 &quot; &quot;;\r\n         $1=&quot;&quot;; sub(/^ /,&quot;&quot;,$0); printit($0);\r\n         next;\r\n       }\r\n    \r\n       NF == 1 {\r\n         printf &quot;%s&quot;, ws($0);  # indentation\r\n         printit($1);\r\n         next;\r\n       }\r\n       {print}\r\n    &#39;",
                "title": "Add quotes around non-numeric atomic values in a JSON-like document"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1526630338,
        "creation_date": 1526587580,
        "last_edit_date": 1526628556,
        "question_id": 50399738,
        "body_markdown": "I have a nested JSON-like document in the following format which I am trying to read using python. I am trying to put quotation marks (&quot; &quot;) around the non-numeric atomic values. I tried using python with a regular expression:\r\n\r\n    import re\r\n    valid_json = re.sub(r&#39;(?&lt;={|,)([a-zA-Z][a-zA-Z0-9]*)(?=:)&#39;, r&#39;&quot;\\1&quot;&#39;, \r\n    json_data) \r\n   \r\nThe data file is like : \r\n     \r\n    {\r\n      &quot;Attri1&quot;: 26789381,\r\n      &quot;Attri2&quot;: hjewvbfasnd3672183knsa,\r\n      &quot;Attri9&quot;: 457950,\r\n      &quot;Attri10&quot;: [\r\n        {\r\n          &quot;NestedAtri1&quot;: vwebsn632871yb,\r\n          &quot;NestedAttri2&quot;: [\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: ABB1,\r\n              &quot;A3&quot;: 30,\r\n              &quot;A5&quot;: [\r\n                000,001\r\n              ]\r\n            },\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: ABB1,\r\n              &quot;A3&quot;: 30,\r\n              &quot;A5&quot;: [\r\n                000,001\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;NestedAtri1&quot;: rgdf3423,\r\n          &quot;NestedAttri2&quot;: [\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: C,\r\n              &quot;A3&quot;: 50,\r\n              &quot;A5&quot;: [\r\n                000,001\r\n             ]\r\n            },\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: ABB1,\r\n              &quot;A3&quot;: 30,\r\n              &quot;A5&quot;: [\r\n                000,001\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    \r\n\r\n\r\nThe expected output is with quotes around the values. \r\n\r\n    {\r\n      &quot;Attri1&quot;: 26789381,\r\n      &quot;Attri2&quot;: &quot;hjewvbfasnd3672183knsa&quot;,\r\n      &quot;Attri9&quot;: 457950,\r\n      &quot;Attri10&quot;: [\r\n        {\r\n          &quot;NestedAtri1&quot;: &quot;vwebsn632871yb&quot;,\r\n          &quot;NestedAttri2&quot;: [\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: &quot;ABB1&quot;,\r\n              &quot;A3&quot;: 30,\r\n              &quot;A5&quot;: [\r\n                &quot;000,001&quot;\r\n              ]\r\n            },\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: &quot;ABB1&quot;,\r\n              &quot;A3&quot;: 30,\r\n              &quot;A5&quot;: [\r\n                &quot;000,001&quot;\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;NestedAtri1&quot;: &quot;rgdf3423&quot;,\r\n          &quot;NestedAttri2&quot;: [\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: &quot;C&quot;,\r\n              &quot;A3&quot;: 50,\r\n              &quot;A5&quot;: [\r\n                &quot;000,001&quot;\r\n             ]\r\n            },\r\n            {\r\n              &quot;A1&quot;: 0,\r\n              &quot;A2&quot;: &quot;ABB1&quot;,\r\n              &quot;A3&quot;: 30,\r\n              &quot;A5&quot;: [\r\n                &quot;000,001&quot;\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nIs there any way I can add quotes using python/json or any other libraries. Or can I use jq filters to add quotes. \r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/50399738/add-quotes-around-non-numeric-atomic-values-in-a-json-like-document",
        "title": "Add quotes around non-numeric atomic values in a JSON-like document"
    },
    {
        "tags": [
            "shell",
            "command-line",
            "jq",
            "aws-cli",
            "aws-userpools"
        ],
        "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": 1526647556,
                "post_id": 50406258,
                "comment_id": 87838632,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1526632305,
                "last_edit_date": 1526632305,
                "creation_date": 1526629798,
                "answer_id": 50406367,
                "question_id": 50406258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you output with `--output text`, it will become a text list.\r\n\r\nYou could then use standard Linux tools such as piping it through `| cut -c6-`\r\n\r\nThis will provide character #6 onwards for each line.\r\n\r\nFull command would be something like:\r\n\r\n    aws cognito-idp list-user-pools --max-results 60 --region us-west-2 --query &#39;UserPools[*].[{Names:Name}]&#39; --output text | cut -c6-",
                "title": "How to modify aws cli command output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1526632305,
        "creation_date": 1526629420,
        "question_id": 50406258,
        "body_markdown": "I am using below command **to list the UserPool Names**.\r\n\r\n    aws cognito-idp list-user-pools --max-results 60 --region us-west-2 --query &#39;UserPools[*].{Names:Name}&#39;\r\n\r\nNow my all UserPool Names contains `cust_` as prefix. And i want to remove that from whole list.\r\n\r\nI know i can achieve this using [jq][1].\r\nBut how?\r\n\r\nAny help will be highly appreciated.\r\n\r\nThanks!\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/50406258/how-to-modify-aws-cli-command-output",
        "title": "How to modify aws cli command output"
    },
    {
        "tags": [
            "json",
            "debugging",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1526717470,
                "last_edit_date": 1526717470,
                "creation_date": 1526716941,
                "answer_id": 50423131,
                "question_id": 50419955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To debug small snippets such as yours, you could use https://jsonlint.com,\r\nwhich gives helpful error messages making it easy to pinpoint the problem.\r\n\r\nAs an alternative that also works for large files, you might like to consider [`jq`][1].  With your snippet in the file &quot;input.txt&quot;, the invocation:\r\n\r\n    jq empty input.txt\r\n\r\nproduces the error message:\r\n\r\n&gt;  parse error: Invalid literal at line 2, column 9\r\n\r\nThis amounts to saying that the first key was not properly quoted. \r\n\r\n(Here, `empty` has the effect of suppressing normal output.)\r\n\r\n## Let jq do the walking\r\n\r\nBetter yet, you can save yourself the hassle by letting jq do the work:\r\n\r\n    jq &#39;[{termdata:.}]&#39; original.json\r\n\r\nThis will produce the desired output.  Unless specifically instructed otherwise, jq takes JSON (or a JSON stream) and produces JSON (or a JSON stream).\r\n\r\nYou could also use jq to do more sophisticated transformations with multiple input files.\r\n\r\n  [1]: http://stedolan.github.io/jq/",
                "title": "Trying to turn json array into a field issue"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1526717470,
        "creation_date": 1526682202,
        "last_edit_date": 1526716999,
        "question_id": 50419955,
        "body_markdown": "I have the following JSON which parses OK:\r\nIt is just some term code data that I want to send.\r\n\r\n    [{\r\n\t&quot;TermCode&quot;: 2164,\r\n\t&quot;ACAD_LEVEL_BOT&quot;: &quot;GR&quot;,\r\n\t&quot;ACAD_LEVEL_EOT&quot;: &quot;GR&quot;,\r\n\t&quot;ACAD_CAREER&quot;: &quot;GRAD&quot;,\r\n\t&quot;UA_PRIM_MAJ_PLN&quot;: &quot;DPMDP&quot;,\r\n\t&quot;UA_DEGR_DT&quot;: &quot;1900-01-01&quot;,\r\n\t&quot;UA_PRIM_MJ_PLN_DES&quot;: &quot;Development Practice&quot;,\r\n\t&quot;UA_PRIM_MIN_PLN_D&quot;: &quot;-&quot;,\r\n\t&quot;CUM_GPA&quot;: 3.707,\r\n\t&quot;CUR_GPA&quot;: 4,\r\n\t&quot;TOT_CUMULATIVE&quot;: 300,\r\n\t&quot;UNT_PASSD_PRGRSS&quot;: 10,\r\n\t&quot;UNT_TAKEN_PRGRSS&quot;: 10,\r\n\t&quot;UA_PRIM_MJ_PLN_OWN&quot;: &quot;School of Anthropology&quot;,\r\n\t&quot;ADMIT_TYPE&quot;: &quot;GRD&quot;,\r\n\t&quot;ADMIT_TERM&quot;: &quot;2144&quot;,\r\n\t&quot;UA_FA_ST_RES_DESCR&quot;: &quot;Resident&quot;,\r\n\t&quot;VISA_PERMIT_TYPE&quot;: &quot;-&quot;,\r\n\t&quot;UA_SALT_ROSTER&quot;: &quot;-&quot;,\r\n\t&quot;UA_SALT_STATUS&quot;: &quot;-&quot;,\r\n\t&quot;DEGR_CHKOUT_STAT&quot;: &quot;-&quot;,\r\n\t&quot;EXP_GRAD_TERM&quot;: &quot;-&quot;,\r\n\t&quot;UNT_TRNSFR&quot;: 0,\r\n\t&quot;ACAD_PROG_LD&quot;: &quot;Graduate Degree Seeking&quot;,\r\n\t&quot;TOT_TRNSFR&quot;: 0,\r\n\t&quot;TUITION_RES&quot;: &quot;RES&quot;,\r\n\t&quot;UA_CITIZEN_COUNTRY&quot;: &quot;United States&quot;,\r\n\t&quot;UA_CITIZEN_ST_DESC&quot;: &quot;Citizen&quot;,\r\n\t&quot;ACADEMIC_LOAD&quot;: &quot;F&quot;,\r\n\t&quot;UNT_AUDIT&quot;: 0,\r\n\t&quot;CAMPUS&quot;: &quot;MAIN&quot;,\r\n\t&quot;ACADEMIC_YEAR&quot;: &quot;2016-2017&quot;,\r\n\t&quot;UA_DEGREE_LEVEL&quot;: &quot;Masters&quot;,\r\n\t&quot;ACAD_PROG&quot;: &quot;GDEG&quot;,\r\n\t&quot;UA_SEC_MAJ_PLN&quot;: &quot;-&quot;,\r\n\t&quot;ACAD_ORG&quot;: &quot;0410&quot;,\r\n\t&quot;EFF_START_DT&quot;: &quot;2016-12-18 20:37:08&quot;,\r\n\t&quot;CURRENT_IND&quot;: &quot;N&quot;,\r\n\t&quot;PROG_STATUS&quot;: &quot;AC&quot;,\r\n\t&quot;PROG_ACTION&quot;: &quot;MATR&quot;\r\n\r\n}]\r\n\r\nI want to use this array as a field named term data so I try:\r\n\r\n\r\n    [{\r\n\ttermdata: [{\r\n\t\t&quot;TermCode&quot;: 2164,\r\n\t\t&quot;ACAD_LEVEL_BOT&quot;: &quot;GR&quot;,\r\n\t\t&quot;ACAD_LEVEL_EOT&quot;: &quot;GR&quot;,\r\n\t\t&quot;ACAD_CAREER&quot;: &quot;GRAD&quot;,\r\n\t\t&quot;UA_PRIM_MAJ_PLN&quot;: &quot;DPMDP&quot;,\r\n\t\t&quot;UA_DEGR_DT&quot;: &quot;1900-01-01&quot;,\r\n\t\t&quot;UA_PRIM_MJ_PLN_DES&quot;: &quot;Development Practice&quot;,\r\n\t\t&quot;UA_PRIM_MIN_PLN_D&quot;: &quot;-&quot;,\r\n\t\t&quot;CUM_GPA&quot;: 3.707,\r\n\t\t&quot;CUR_GPA&quot;: 4,\r\n\t\t&quot;TOT_CUMULATIVE&quot;: 300,\r\n\t\t&quot;UNT_PASSD_PRGRSS&quot;: 10,\r\n\t\t&quot;UNT_TAKEN_PRGRSS&quot;: 10,\r\n\t\t&quot;UA_PRIM_MJ_PLN_OWN&quot;: &quot;School of Anthropology&quot;,\r\n\t\t&quot;ADMIT_TYPE&quot;: &quot;GRD&quot;,\r\n\t\t&quot;ADMIT_TERM&quot;: &quot;2144&quot;,\r\n\t\t&quot;UA_FA_ST_RES_DESCR&quot;: &quot;Resident&quot;,\r\n\t\t&quot;VISA_PERMIT_TYPE&quot;: &quot;-&quot;,\r\n\t\t&quot;UA_SALT_ROSTER&quot;: &quot;-&quot;,\r\n\t\t&quot;UA_SALT_STATUS&quot;: &quot;-&quot;,\r\n\t\t&quot;DEGR_CHKOUT_STAT&quot;: &quot;-&quot;,\r\n\t\t&quot;EXP_GRAD_TERM&quot;: &quot;-&quot;,\r\n\t\t&quot;UNT_TRNSFR&quot;: 0,\r\n\t\t&quot;ACAD_PROG_LD&quot;: &quot;Graduate Degree Seeking&quot;,\r\n\t\t&quot;TOT_TRNSFR&quot;: 0,\r\n\t\t&quot;TUITION_RES&quot;: &quot;RES&quot;,\r\n\t\t&quot;UA_CITIZEN_COUNTRY&quot;: &quot;United States&quot;,\r\n\t\t&quot;UA_CITIZEN_ST_DESC&quot;: &quot;Citizen&quot;,\r\n\t\t&quot;ACADEMIC_LOAD&quot;: &quot;F&quot;,\r\n\t\t&quot;UNT_AUDIT&quot;: 0,\r\n\t\t&quot;CAMPUS&quot;: &quot;MAIN&quot;,\r\n\t\t&quot;ACADEMIC_YEAR&quot;: &quot;2016-2017&quot;,\r\n\t\t&quot;UA_DEGREE_LEVEL&quot;: &quot;Masters&quot;,\r\n\t\t&quot;ACAD_PROG&quot;: &quot;GDEG&quot;,\r\n\t\t&quot;UA_SEC_MAJ_PLN&quot;: &quot;-&quot;,\r\n\t\t&quot;ACAD_ORG&quot;: &quot;0410&quot;,\r\n\t\t&quot;EFF_START_DT&quot;: &quot;2016-12-18 20:37:08&quot;,\r\n\t\t&quot;CURRENT_IND&quot;: &quot;N&quot;,\r\n\t\t&quot;PROG_STATUS&quot;: &quot;AC&quot;,\r\n\t\t&quot;PROG_ACTION&quot;: &quot;MATR&quot;\r\n\t}]      }]\r\n\r\nHowever, this doesn&#39;t parse. What is wrong with my syntax?\r\nThere is an error in Stack Overflow that is not letting me end my question here so I have to add more description please down down arrow me I didn&#39;t have a choice. So my next step would be to have json such as:\r\n[{ termdata:jsonarray,coursedata:jsonarray,admitdata:jsonarray}] \r\nAny thoughts on that would be appreciated also.\r\n",
        "link": "https://stackoverflow.com/questions/50419955/trying-to-turn-json-array-into-a-field-issue",
        "title": "Trying to turn json array into a field issue"
    },
    {
        "tags": [
            "json",
            "bash",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1526834967,
                "last_edit_date": 1526834967,
                "creation_date": 1526831822,
                "answer_id": 50436689,
                "question_id": 50436497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Provided $F is a valid jq path expression (i.e., so that `jq -n &quot;$F&quot;` works):\r\n\r\n    jq &quot;$F as \\$v | null | $F |= \\$v&quot; &lt;&lt;&lt; &quot;$O&quot;\r\n\r\n(I included the |= from your solution to show the similarity, but here you could drop the |.)\r\n",
                "title": "jq: How can a nested object be sliced to include the parent-key hierarchy?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1526844084,
        "creation_date": 1526830528,
        "last_edit_date": 1526844084,
        "question_id": 50436497,
        "body_markdown": "Using Bash and jq, if I have a Bash variable filter **F** of the form `.&lt;key1&gt;.&lt;key2&gt;...&lt;keyN&gt;` and I want to slice a Bash variable JSON object **O** so that the result is just that slice of the object including all keys in **F**, how can this be done with jq?\r\n\r\nFor example, suppose:\r\n\r\n    O=&#39;\r\n    {\r\n       &quot;a&quot;:\r\n       {\r\n          &quot;b&quot;:\r\n          {\r\n             &quot;c&quot;: { &quot;p&quot;:1 },\r\n             &quot;x&quot;: 1\r\n          },\r\n          &quot;x&quot;: 2\r\n      },\r\n      &quot;x&quot;: 3\r\n    }&#39;\r\n\r\nThen, doing:\r\n\r\n    F=&#39;.a.b.c&#39;; jq -r &quot;$F&quot; &lt;&lt;&lt;&quot;$O&quot;\r\n\r\nresults in:\r\n\r\n    {\r\n       &quot;p&quot;: 1\r\n    }\r\n\r\nBut, I want the slice to include parent key hierarchy.\r\n\r\n**Inelegant Solution**\r\n\r\nI have come up with a solution, but it involves 2 calls to jq:\r\n\r\n    F=&#39;.a.b.c&#39;; S=&quot;$(jq -r &quot;$F&quot; &lt;&lt;&lt;&quot;$O&quot;); jq --null-input -r &quot;$F |= $S&quot;\r\n\r\nthat results in:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: {\r\n          &quot;c&quot;: {\r\n            &quot;p&quot;: 1\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nThe solution must work for ***any*** valid **O** and **F** Bash variable where **O** stores a JSON object and **F** is a simple filter of key names only as described above. For example:\r\n\r\n    F=&#39;.a.b&#39;; S=&quot;$(jq -r &quot;$F&quot; &lt;&lt;&lt;&quot;$O&quot;)&quot;; jq --null-input -r &quot;$F |= $S&quot;\r\n\r\nresults in:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: {\r\n          &quot;c&quot;: {\r\n            &quot;p&quot;: 1\r\n          },\r\n          &quot;x&quot;: 1\r\n        }\r\n      }\r\n    }\r\n\r\nCan slicing an object with a key-hierarchy filter be done more simply in jq?",
        "link": "https://stackoverflow.com/questions/50436497/jq-how-can-a-nested-object-be-sliced-to-include-the-parent-key-hierarchy",
        "title": "jq: How can a nested object be sliced to include the parent-key hierarchy?"
    },
    {
        "tags": [
            "arrays",
            "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": 1526856008,
                "post_id": 50439331,
                "comment_id": 87894211,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 444490,
                    "reputation": 85,
                    "user_id": 836325,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6ba5d3e9515bcfe094b4eb454d68e14?s=256&d=identicon&r=PG",
                    "display_name": "Jim C",
                    "link": "https://stackoverflow.com/users/836325/jim-c"
                },
                "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": 1526948978,
                "post_id": 50439331,
                "comment_id": 87929886,
                "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": 1526951759,
                "post_id": 50439331,
                "comment_id": 87930387,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 444490,
                    "reputation": 85,
                    "user_id": 836325,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6ba5d3e9515bcfe094b4eb454d68e14?s=256&d=identicon&r=PG",
                    "display_name": "Jim C",
                    "link": "https://stackoverflow.com/users/836325/jim-c"
                },
                "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": 1527001624,
                "post_id": 50439331,
                "comment_id": 87955381,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1527002860,
                "creation_date": 1527002860,
                "answer_id": 50471393,
                "question_id": 50439331,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems that, in essence, you should be using `map` instead of `.[]`.\r\n\r\n\r\n    map(.members\r\n        | map({name: .roomName, state: .state.playbackState, vol: .state.volume}) )\r\n\r\n(Since `map(f)` is just `[.[]|f]`, you could also use the latter form, but writing `map` makes the intention quite clear.)",
                "title": "jq preserving array boundaries"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527002860,
        "creation_date": 1526850110,
        "last_edit_date": 1527001585,
        "question_id": 50439331,
        "body_markdown": "I&#39;ve got an API that reports group membership as an array where each group is an array element that has an array of members.  I want to simplify the data, but not remove the array boundaries.\r\n\r\nWhen there are three groups the API produces this output, call it &#39;3gr.json&#39; : \r\n\r\n    [\r\n       {\r\n          &quot;id&quot; : &quot;000E58D2E9B401400&quot;,\r\n          &quot;members&quot; : [\r\n             {\r\n                &quot;id&quot; : &quot;000E58D2E9B401400&quot;,\r\n                &quot;roomName&quot; : &quot;Room1&quot;,\r\n                &quot;groupState&quot; : {\r\n                   &quot;mute&quot; : false,\r\n                   &quot;volume&quot; : 15\r\n                },\r\n                &quot;state&quot; : {\r\n                   &quot;playbackState&quot; : &quot;STOPPED&quot;,\r\n                   &quot;volume&quot; : 15,\r\n                   &quot;mute&quot; : false\r\n                }\r\n             }\r\n          ]\r\n       },\r\n       {\r\n          &quot;id&quot; : &quot;000E58D2FA0601400&quot;,\r\n          &quot;members&quot; : [\r\n             {\r\n                &quot;state&quot; : {\r\n                   &quot;playbackState&quot; : &quot;STOPPED&quot;,\r\n                   &quot;volume&quot; : 40,\r\n                   &quot;mute&quot; : false\r\n                },\r\n                &quot;id&quot; : &quot;000E58D2FA0601400&quot;,\r\n                &quot;roomName&quot; : &quot;Room2&quot;,\r\n                &quot;groupState&quot; : {\r\n                   &quot;mute&quot; : false,\r\n                   &quot;volume&quot; : 40\r\n                }\r\n             }\r\n          ]\r\n       },\r\n       {\r\n          &quot;id&quot; : &quot;5CAAFD7B8C9801400&quot;,\r\n          &quot;members&quot; : [\r\n             {\r\n                &quot;groupState&quot; : {\r\n                   &quot;mute&quot; : false,\r\n                   &quot;volume&quot; : 15\r\n                },\r\n                &quot;roomName&quot; : &quot;Room3&quot;,\r\n                &quot;id&quot; : &quot;5CAAFD7B8C9801400&quot;,\r\n                &quot;state&quot; : {\r\n                   &quot;mute&quot; : false,\r\n                   &quot;playbackState&quot; : &quot;STOPPED&quot;,\r\n                   &quot;volume&quot; : 15\r\n                }\r\n             }\r\n          ]\r\n       }\r\n    ]\r\n\r\nWhen there is one group the the API produces this output, call it &#39;1gr.json&#39; :\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;000E58D2E9B401400&quot;,\r\n        &quot;members&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;000E58D2E9B401400&quot;,\r\n            &quot;state&quot;: {\r\n              &quot;volume&quot;: 44,\r\n              &quot;mute&quot;: false,\r\n              &quot;playbackState&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n              &quot;equalizer&quot;: {\r\n                &quot;bass&quot;: 2,\r\n                &quot;treble&quot;: 2,\r\n                &quot;loudness&quot;: true\r\n              }\r\n            },\r\n            &quot;roomName&quot;: &quot;Room1&quot;,\r\n            &quot;groupState&quot;: {\r\n              &quot;volume&quot;: 46,\r\n              &quot;mute&quot;: false\r\n            }\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;5CAAFDE9614001400&quot;,\r\n            &quot;state&quot;: {\r\n              &quot;volume&quot;: 54,\r\n              &quot;mute&quot;: false,\r\n              &quot;playbackState&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n              &quot;equalizer&quot;: {\r\n                &quot;bass&quot;: 0,\r\n                &quot;treble&quot;: 0,\r\n                &quot;loudness&quot;: true\r\n              }\r\n            },\r\n            &quot;roomName&quot;: &quot;Room2&quot;,\r\n            &quot;groupState&quot;: {\r\n              &quot;volume&quot;: 65,\r\n              &quot;mute&quot;: false\r\n            }\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;5CAAFD7B8C9801400&quot;,\r\n            &quot;state&quot;: {\r\n              &quot;volume&quot;: 41,\r\n              &quot;mute&quot;: false,\r\n              &quot;playbackState&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n              &quot;equalizer&quot;: {\r\n                &quot;bass&quot;: 0,\r\n                &quot;treble&quot;: 0,\r\n                &quot;loudness&quot;: false\r\n              }\r\n            },\r\n            &quot;roomName&quot;: &quot;Room3&quot;,\r\n            &quot;groupState&quot;: {\r\n              &quot;volume&quot;: 41,\r\n              &quot;mute&quot;: false\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nIf I use `jq` to process this output:\r\n\r\n    jq &#39;.[].members[]|{name: .roomName, state: .state.playbackState, vol: .state.volume}&#39; 3gr.json\r\n\r\nI get this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Room1&quot;,\r\n      &quot;state&quot;: &quot;STOPPED&quot;,\r\n      &quot;vol&quot;: 15\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Room2&quot;,\r\n      &quot;state&quot;: &quot;STOPPED&quot;,\r\n      &quot;vol&quot;: 40\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Room3&quot;,\r\n      &quot;state&quot;: &quot;STOPPED&quot;,\r\n      &quot;vol&quot;: 15\r\n    }\r\n\r\nI get the same structure of the output (in these two examples the values are not important), if I process &#39;1gr.json&#39;:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Room1&quot;,\r\n      &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n      &quot;vol&quot;: 44\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Room2&quot;,\r\n      &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n      &quot;vol&quot;: 54\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;Room3&quot;,\r\n      &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n      &quot;vol&quot;: 41\r\n    }\r\n\r\nWhat I want is for the array boundaries of the group array to be preserved.  I&#39;ve tried adding various combinations of `[ ]` but to no avail. So what I&#39;d like to see is:\r\n\r\n    [\r\n        [\r\n            {\r\n                &quot;name&quot;: &quot;Room1&quot;,\r\n                &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n                &quot;vol&quot;: 44\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;Room2&quot;,\r\n                &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n                &quot;vol&quot;: 54\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;Room3&quot;,\r\n                &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n                &quot;vol&quot;: 41\r\n            }\r\n        ]\r\n    ]\r\n\r\nand\r\n\r\n    [\r\n        [\r\n            {\r\n                &quot;name&quot;: &quot;Room1&quot;,\r\n                &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n                &quot;vol&quot;: 44\r\n            }\r\n        ],\r\n        [\r\n            {\r\n                &quot;name&quot;: &quot;Room2&quot;,\r\n                &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n                &quot;vol&quot;: 54\r\n            }\r\n        ],\r\n        [\r\n            {\r\n                &quot;name&quot;: &quot;Room3&quot;,\r\n                &quot;state&quot;: &quot;PAUSED_PLAYBACK&quot;,\r\n                &quot;vol&quot;: 41\r\n            }\r\n        ]\r\n    ]\r\n\r\n\r\n\r\n     \r\n",
        "link": "https://stackoverflow.com/questions/50439331/jq-preserving-array-boundaries",
        "title": "jq preserving array boundaries"
    },
    {
        "tags": [
            "json",
            "shell",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1526877050,
                "last_edit_date": 1526877050,
                "creation_date": 1526866765,
                "answer_id": 50440962,
                "question_id": 50440891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could pipe to this awk command:\r\n\r\n    awk -F. &#39;!major[$1]++&#39;\r\n\r\nIt uses the period as the field separator and prints every line of which it has never seen the first field, which is the major version.\r\n\r\nIn case the input is not sorted and you have GNU sort, you can use its version sort:\r\n\r\n    sort -rV | awk -F. &#39;!major[$1]++&#39;\r\n\r\nwhere `-V` is for &quot;version sort&quot; and `-r` is for &quot;reverse&quot;.",
                "title": "Pick up the latest releases from each major node version with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1527056498,
                "last_edit_date": 1527056498,
                "creation_date": 1526867502,
                "answer_id": 50441019,
                "question_id": 50440891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you pipe the output of curl into `jq -r` with the following filter, you should get the major versions, irrespective of how the version numbers are ordered in the curl results:\r\n\r\n    map(.name)\r\n    | map(split(&quot;.&quot;) | map(tonumber? // .) )\r\n    | group_by(.[0])\r\n    | map(sort)\r\n    | map( .[-1] | map(tostring) | join(&quot;.&quot;))\r\n    | .[]\r\n\r\n## Variation\r\nIf you want the output sorted as well, simply remove the &quot;v&quot; beforehand, and then tack it on afterwards. In the interests of generality, let&#39;s define a function which will output the most recent release tag for each major release:\r\n\r\n    # Input: an array of &quot;x.y.z...&quot; strings, \r\n    # some or all components of which may be integers\r\n    # Output: a stream of the latest &quot;major&quot; releases\r\n    def majors:\r\n      map( split(&quot;.&quot;) | map(tonumber? // .))\r\n      | group_by(.[0])\r\n      | map(sort[-1])[]\r\n      | map(tostring)\r\n      | join(&quot;.&quot;) ;\r\n    \r\n    map( .name[1:] ) | &quot;v&quot; + majors\r\n\r\n## Typescript\r\n\r\n    $ jq -rf major-version.jq input.json\r\n    v8.11.2\r\n    v9.11.1\r\n    v10.1.0\r\n\r\n",
                "title": "Pick up the latest releases from each major node version with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1527056498,
        "creation_date": 1526866048,
        "last_edit_date": 1526868279,
        "question_id": 50440891,
        "body_markdown": "Are there any smart ways to pick up the latest releases from each major  node version with `jq`? Or do I have to write another wrapper shell script to handle its output? \r\n\r\nWhat I want to get (there are three major versions: v8, v9 and v10) the latest versions:\r\n\r\n    v10.1.0\r\n    v9.11.1\r\n    v8.11.2\r\n\r\nThe release list:\r\n\r\n    $ export repo=&#39;nodejs/node&#39;\r\n    $ curl -s https://api.github.com/repos/${repo}/tags |jq -r &quot;.[].name&quot;\r\n    v10.1.0\r\n    v10.0.0\r\n    v9.11.1\r\n    v9.11.0\r\n    v9.10.1\r\n    v9.10.0\r\n    v9.9.0\r\n    v9.8.0\r\n    v9.7.1\r\n    v9.7.0\r\n    v9.6.1\r\n    v9.6.0\r\n    v9.5.0\r\n    v9.4.0\r\n    v9.3.0\r\n    v9.2.1\r\n    v9.2.0\r\n    v9.1.0\r\n    v9.0.0\r\n    v8.11.2\r\n    v8.11.1\r\n    v8.11.0\r\n    v8.10.0\r\n    v8.9.4\r\n    v8.9.3\r\n    v8.9.2\r\n    v8.9.1\r\n    v8.9.0\r\n    v8.8.1\r\n    v8.8.0",
        "link": "https://stackoverflow.com/questions/50440891/pick-up-the-latest-releases-from-each-major-node-version-with-jq",
        "title": "Pick up the latest releases from each major node version with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1526891528,
                "creation_date": 1526891528,
                "answer_id": 50444815,
                "question_id": 50444732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "OK, figured this out... I needed to wrap the whole filter in single quotes:\r\n\r\n    jq &#39;.&quot;foo.bar&quot;&#39; file.json",
                "title": "Filter attribute names with periods"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1526891695,
                "creation_date": 1526891695,
                "answer_id": 50444854,
                "question_id": 50444732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the command line you need to either escape the quotes or enclose the filter in single quotes. Otherwise, the shell thinks the quotes are there to take the string they enclose as a single word.\r\n\r\nAssuming your JSON is stored in the file `input.json`, the command line should be like:\r\n\r\n     cat input.json | jq .\\&quot;foo.bar\\&quot;\r\n\r\nor:\r\n\r\n    cat input.json | jq &#39;.&quot;foo.bar&quot;&#39;\r\n\r\nFor this simple filter I recommend using the second way (enclose the filter in apostrophes) because it is easier to read and understand.\r\n\r\n",
                "title": "Filter attribute names with periods"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1526891695,
        "creation_date": 1526891127,
        "question_id": 50444732,
        "body_markdown": "How do I access the value of a JSON attribute that contains a period in it&#39;s name on MacOS/ Linux?\r\n\r\nFor example, I have a JSON object which has a root attribute name containing a period. For example:\r\n\r\n    {\r\n        &quot;foo.bar&quot;: {\r\n            &quot;one&quot;: 1,\r\n            &quot;two&quot;: &quot;2&quot;,\r\n            &quot;three&quot;: {\r\n                &quot;a&quot;: &quot;3a&quot;,\r\n                &quot;b&quot;: &quot;3b&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nOn [jqplay.org][1] the filter `.&quot;foo.bar&quot;` successfully extracts the value of the attribute:\r\n\r\n    {\r\n        &quot;one&quot;: 1,\r\n        &quot;two&quot;: &quot;2&quot;,\r\n        &quot;three&quot;: {\r\n            &quot;a&quot;: &quot;3a&quot;,\r\n            &quot;b&quot;: &quot;3b&quot;\r\n        }\r\n    }\r\n\r\nHowever, on MacOS and Linux (jq v1.5) the same input and filter (i.e. `jq .&quot;foo.bar&quot; file.json` produces no output.\r\n\r\nIf I add brackets to the filter (i.e. `.[&quot;foo.bar&quot;]`) I get the following:\r\n\r\n    {\r\n      &quot;foo.bar&quot;: {\r\n        &quot;one&quot;: 1,\r\n        &quot;two&quot;: &quot;2&quot;,\r\n        &quot;three&quot;: {\r\n          &quot;a&quot;: &quot;3a&quot;,\r\n          &quot;b&quot;: &quot;3b&quot;\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;one&quot;: 1,\r\n      &quot;two&quot;: &quot;2&quot;,\r\n      &quot;three&quot;: {\r\n        &quot;a&quot;: &quot;3a&quot;,\r\n        &quot;b&quot;: &quot;3b&quot;\r\n      }\r\n    }\r\n    1\r\n    &quot;2&quot;\r\n    {\r\n      &quot;a&quot;: &quot;3a&quot;,\r\n      &quot;b&quot;: &quot;3b&quot;\r\n    }\r\n    &quot;3a&quot;\r\n    &quot;3b&quot;\r\n\r\n\r\n\r\nHow can I replicate the behaviour from jqplay.org on MacOS/ Linux so I can access attributes with periods in their names?\r\n\r\n\r\n  [1]: https://jqplay.org/\r\n",
        "link": "https://stackoverflow.com/questions/50444732/filter-attribute-names-with-periods",
        "title": "Filter attribute names with periods"
    },
    {
        "tags": [
            "json",
            "jq",
            "jira-rest-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1526935674,
                "last_edit_date": 1526935674,
                "creation_date": 1526919759,
                "answer_id": 50452909,
                "question_id": 50451535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Can this be achieved using jq only? \r\n\r\nYes, jq was designed precisely for this kind of query. In your case, you could use `any`, `select` and `if ... then ... else ... end`, along the lines of:\r\n\r\n    if any(.[]; .objectTypeAttributeId == 911 and\r\n                any(.objectAttributeValues[]; .status.name == &quot;Active&quot;))\r\n    then map(select(.objectTypeAttributeId == 887))\r\n    else &quot;whatever&quot;\r\n    end\r\n\r\n",
                "title": "Parsing JIRA Insights API JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1526935674,
        "creation_date": 1526914801,
        "question_id": 50451535,
        "body_markdown": "So I basically have JSON output from the JIRA Insights API, been digging around and found jq for parsing the JSON.  Struggling to wrap my head around on how parse the following to only return values for the objectTypeAttributeId&#39;s that I am interested in.\r\n\r\nFor Example I&#39;m only interested in the value of objectTypeAttributeId 887 provided that objectTypeAttributeId 911&#39;s name states as active, but then would like to return the name value of another objectTypeAttributeId\r\n\r\nCan this be achieved using jq only?  Or shoudl I be using something else?\r\n\r\nI can filter down to this level which is the &#39;attributes&#39; section of the JSON output and print each value, but struggling to find an example catering for my situation.\r\n\r\n     {\r\n          &quot;id&quot;: 137127,\r\n          &quot;objectTypeAttributeId&quot;: 887,\r\n          &quot;objectAttributeValues&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;false&quot;\r\n            }\r\n          ],\r\n          &quot;objectId&quot;: 9036,\r\n          &quot;position&quot;: 16\r\n        },\r\n        {\r\n          &quot;id&quot;: 137128,\r\n          &quot;objectTypeAttributeId&quot;: 888,\r\n          &quot;objectAttributeValues&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;false&quot;\r\n            }\r\n          ],\r\n          &quot;objectId&quot;: 9036,\r\n          &quot;position&quot;: 17\r\n        },\r\n        {\r\n          &quot;id&quot;: 137296,\r\n          &quot;objectTypeAttributeId&quot;: 911,\r\n          &quot;objectAttributeValues&quot;: [\r\n            {\r\n              &quot;status&quot;: {\r\n                &quot;id&quot;: 1,\r\n                &quot;name&quot;: &quot;Active&quot;,\r\n                &quot;category&quot;: 1\r\n              }\r\n            }\r\n          ],\r\n          &quot;objectId&quot;: 9036,\r\n          &quot;position&quot;: 18\r\n        },",
        "link": "https://stackoverflow.com/questions/50451535/parsing-jira-insights-api-json-using-jq",
        "title": "Parsing JIRA Insights API JSON using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1526954861,
                "creation_date": 1526954861,
                "answer_id": 50458802,
                "question_id": 50458773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq -c`, to emit each result on a separate line. *Don&#39;t* use `-r` when your intended output is JSON, not a raw string.\r\n\r\nI&#39;ve also added some quotes below, which were missing from your code:\r\n\r\n    # for readability, factored out\r\n    args=( -d @- -H &quot;Content-Type: application/json&quot;  )\r\n\r\n    while IFS= read -r value; do\r\n      echo &quot;Read  $value&quot; &gt;&amp;2\r\n      curl &quot;${args[@]}&quot; https://example.com/api/foo &lt;&lt;&lt;&quot;$value&quot;\r\n    done &lt; &lt;(jq -c &#39;.[]&#39; &lt;&quot;$1&quot;)\r\n\r\n",
                "title": "curl json object as POST data from json array file using jq in a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1526954861,
        "creation_date": 1526954581,
        "question_id": 50458773,
        "body_markdown": "Here is my sample test.json file\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;description&quot;: &quot;Some description&quot;,\r\n    \t\t&quot;name&quot;: &quot;Some name&quot;,\r\n    \t\t&quot;summary&quot;: &quot;Some summary. &quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;description&quot;: &quot;Some description&quot;,\r\n    \t\t&quot;name&quot;: &quot;Some name&quot;,\r\n    \t\t&quot;summary&quot;: &quot;Some summary. &quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;description&quot;: &quot;Some description&quot;,\r\n    \t\t&quot;name&quot;: &quot;Some name&quot;,\r\n    \t\t&quot;summary&quot;: &quot;Some summary. &quot;\r\n    \t}\r\n    ]\r\n\r\nHere is the bash script\r\n\r\n    declare -A values=( )\r\n    while IFS= read -r value; do\r\n      echo &quot;Read  $value&quot; &gt;&amp;2\r\n      #echo $value | curl -d @- -H &quot;Content-Type: application/json&quot; https://example.com/api/foo\r\n    done &lt; &lt;(jq -r &#39;.[]&#39; &lt;$1)\r\n\r\nThis is the output that I get\r\n\r\n    Read {\r\n    Read \t&quot;description&quot;: &quot;Some description&quot;,\r\n    Read \t&quot;name&quot;: &quot;Some name&quot;,\r\n    Read \t&quot;summary&quot;: &quot;Some summary. &quot;\r\n    Read }\r\n    Read {\r\n    Read \t&quot;description&quot;: &quot;Some description&quot;,\r\n    Read \t&quot;name&quot;: &quot;Some name&quot;,\r\n    Read \t&quot;summary&quot;: &quot;Some summary. &quot;\r\n    Read }\r\n    Read {\r\n    Read \t&quot;description&quot;: &quot;Some description&quot;,\r\n    Read \t&quot;name&quot;: &quot;Some name&quot;,\r\n    Read \t&quot;summary&quot;: &quot;Some summary. &quot;\r\n    Read }\r\n\r\nI want to use the JSON objects in the file, to POST data to an API using curl.  I would expect the loop to run three times.\r\n\r\nHow do I get entire JSON object (resulting in the loop running 3 times) instead of outputting every single line from the test.json file? ",
        "link": "https://stackoverflow.com/questions/50458773/curl-json-object-as-post-data-from-json-array-file-using-jq-in-a-loop",
        "title": "curl json object as POST data from json array file using jq in a loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526973605,
                "post_id": 50461834,
                "comment_id": 87936880,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6887896,
                    "reputation": 1031,
                    "user_id": 5292423,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/c7f9d01d792f43aa663d6b7603d9cf89?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Joe",
                    "link": "https://stackoverflow.com/users/5292423/joe"
                },
                "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": 1526973707,
                "post_id": 50461834,
                "comment_id": 87936933,
                "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": 1526973812,
                "post_id": 50461834,
                "comment_id": 87937010,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6887896,
                    "reputation": 1031,
                    "user_id": 5292423,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/c7f9d01d792f43aa663d6b7603d9cf89?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Joe",
                    "link": "https://stackoverflow.com/users/5292423/joe"
                },
                "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": 1526974107,
                "post_id": 50461834,
                "comment_id": 87937166,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6887896,
                    "reputation": 1031,
                    "user_id": 5292423,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/c7f9d01d792f43aa663d6b7603d9cf89?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Joe",
                    "link": "https://stackoverflow.com/users/5292423/joe"
                },
                "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": 1526974191,
                "post_id": 50461834,
                "comment_id": 87937222,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1526973608,
                "creation_date": 1526973608,
                "answer_id": 50461954,
                "question_id": 50461834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your backslashes are fine, congratulations! The issue is with the placement of a single pesky space:\r\n\r\n    sed &#39;s/Dipesan pada \\\\\\\\r\\\\\\\\n//g&#39; file.json # bad\r\n    sed &#39;s/Dipesan pada\\\\\\\\r\\\\\\\\n //g&#39; file.json # good\r\n",
                "title": "How to replace double backslash in a JSON text?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526977601,
                "last_edit_date": 1526977601,
                "creation_date": 1526975046,
                "answer_id": 50462353,
                "question_id": 50461834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq` with [update operator][1] and [sub][2] filter, you can do it as below. The slashes need to escaped twice to make it work\r\n\r\n    jq &#39;(.module.data[].fields.createdAt)|=(sub(&quot;Dipesan pada\\\\\\\\r\\\\\\\\n &quot;;&quot;&quot;))&#39; input.json\r\n\r\nAs tested on [jq-play](https://jqplay.org/s/-jl_7ERLpe). This is tested on your JSON input with keys modified to avoid duplication.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Assignment\r\n  [2]: https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE",
                "title": "How to replace double backslash in a JSON text?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1526977601,
        "creation_date": 1526973238,
        "last_edit_date": 1526975899,
        "question_id": 50461834,
        "body_markdown": "I&#39;ve got this json file:\r\n\r\n    {\r\n    \t&quot;module&quot;: {\r\n    \t\t&quot;data&quot;: {\r\n    \t\t\t&quot;orderInfo_203759231000&quot;: {\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;createdAt&quot;: &quot;Dipesan pada\\\\r\\\\n 17 Mei 2018&quot;,\r\n    \t\t\t\t\t&quot;tradeOrderId&quot;: 203759231000\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;orderInfo_203759231000&quot;: {\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;createdAt&quot;: &quot;Dipesan pada\\\\r\\\\n 22 Mei 2018&quot;,\r\n    \t\t\t\t\t&quot;tradeOrderId&quot;: 203759231000\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;orderInfo_203759231000&quot;: {\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;createdAt&quot;: &quot;Dipesan pada\\\\r\\\\n 22 Mei 2018&quot;,\r\n    \t\t\t\t\t&quot;tradeOrderId&quot;: 203759231000\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;orderInfo_203759231000&quot;: {\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;createdAt&quot;: &quot;Dipesan pada\\\\r\\\\n 22 Mei 2018&quot;,\r\n    \t\t\t\t\t&quot;tradeOrderId&quot;: 203759231000\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;orderInfo_203759231000&quot;: {\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;createdAt&quot;: &quot;Dipesan pada\\\\r\\\\n 22 Mei 2018&quot;,\r\n    \t\t\t\t\t&quot;tradeOrderId&quot;: 203759231000\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nand I want to remove `Dipesan pada\\\\r\\\\n ` here&#39;s what I have tried:\r\n\r\n    sed &#39;s/Dipesan pada \\\\\\\\r\\\\\\\\n//g&#39; file.json\r\n\r\nBut it doesn&#39;t work, I want the end result to only be the dates like this:\r\n\r\n    &quot;createdAt&quot;: &quot;17 Mei 2018&quot;,\r\n    &quot;createdAt&quot;: &quot;22 Mei 2018&quot;,\r\n    &quot;createdAt&quot;: &quot;22 Mei 2018&quot;,\r\n    etc...\r\n\r\nHow should I fix it?",
        "link": "https://stackoverflow.com/questions/50461834/how-to-replace-double-backslash-in-a-json-text",
        "title": "How to replace double backslash in a JSON text?"
    },
    {
        "tags": [
            "json",
            "shell",
            "ubuntu",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526989886,
                "post_id": 50466695,
                "comment_id": 87946992,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9518712,
                    "reputation": 13,
                    "user_id": 7074244,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-WYuuGCSQfC4/AAAAAAAAAAI/AAAAAAAAAEw/9NgNwWSudZM/s256-rj/photo.jpg",
                    "display_name": "James Wilson",
                    "link": "https://stackoverflow.com/users/7074244/james-wilson"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526990105,
                "post_id": 50466695,
                "comment_id": 87947125,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526990524,
                "post_id": 50466695,
                "comment_id": 87947352,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526990531,
                "post_id": 50466695,
                "comment_id": 87947356,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1526990958,
                "post_id": 50466695,
                "comment_id": 87947622,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1574450782,
        "creation_date": 1526988937,
        "last_edit_date": 1574450782,
        "question_id": 50466695,
        "body_markdown": "I have a URL \r\nhttp://localhost/status?json\r\n\r\nWhich is PHP-FPM&#39;s status page, it outputs this\r\n\r\n    {  \r\n       &quot;pool&quot;:&quot;www&quot;,\r\n       &quot;process manager&quot;:&quot;dynamic&quot;,\r\n       &quot;start time&quot;:1526919087,\r\n       &quot;start since&quot;:69780,\r\n       &quot;accepted conn&quot;:403320,\r\n       &quot;listen queue&quot;:0,\r\n       &quot;max listen queue&quot;:0,\r\n       &quot;listen queue len&quot;:0,\r\n       &quot;idle processes&quot;:21,\r\n       &quot;active processes&quot;:6,\r\n       &quot;total processes&quot;:27,\r\n       &quot;max active processes&quot;:200,\r\n       &quot;max children reached&quot;:1,\r\n       &quot;slow requests&quot;:0\r\n    }\r\n\r\nI want to turn this JSON into an Array in Bash, so I can do a loop around it to check for stuff, I&#39;ve heard JQ can parse this, but I&#39;m unsure in BASH how I can convert it to a useable array.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/50466695/turning-a-json-object-into-a-bash-array",
        "title": "Turning a JSON object into a BASH array"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "data-extraction"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1527005720,
                "last_edit_date": 1527005720,
                "creation_date": 1527002115,
                "answer_id": 50471156,
                "question_id": 50470951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Invocation: jq -rf totsv.jq input.json\r\n\r\nProgram (totsv.jq):\r\n\r\n    .[]\r\n    | .genes_id as $id\r\n    | .pathways\r\n    | to_entries[]\r\n    | [$id, .key, .value]\r\n    | @tsv\r\n\r\nTSV is a good choice (as is jq)!",
                "title": "Jq: Gather JSON data for each object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527022335,
        "creation_date": 1527001449,
        "last_edit_date": 1527022335,
        "question_id": 50470951,
        "body_markdown": "**I find my title quite unclear, however I do not know how to rewrite it better so feel free to edit it!**\r\n\r\n\r\n----------\r\n**Data**&lt;br&gt;\r\nI have the following (simplified) JSON:\r\n\r\n    [\r\n      {\r\n        &quot;genes_id&quot;: &quot;eco:b0002&quot;,\r\n        &quot;entry_id&quot;: &quot;b0002&quot;,\r\n        &quot;division&quot;: &quot;CDS&quot;,\r\n        &quot;organism&quot;: &quot;Escherichia coli K-12 MG1655&quot;,\r\n        &quot;organism_code&quot;: &quot;eco&quot;,\r\n        &quot;organism_id&quot;: &quot;T00007&quot;,\r\n        &quot;name&quot;: &quot;thrA&quot;,\r\n        &quot;names&quot;: [\r\n          &quot;thrA&quot;\r\n        ],\r\n        &quot;definition&quot;: &quot;(RefSeq) Bifunctional aspartokinase/homoserine dehydrogenase 1&quot;,\r\n        &quot;eclinks&quot;: [\r\n    \r\n        ],\r\n        &quot;orthologs&quot;: {\r\n          &quot;K12524&quot;: &quot;bifunctional aspartokinase / homoserine dehydrogenase 1 [EC:2.7.2.4 1.1.1.3]&quot;\r\n        },\r\n        &quot;pathways&quot;: {\r\n          &quot;eco00260&quot;: &quot;Glycine, serine and threonine metabolism&quot;,\r\n          &quot;eco00261&quot;: &quot;Monobactam biosynthesis&quot;,\r\n          &quot;eco00270&quot;: &quot;Cysteine and methionine metabolism&quot;,\r\n          &quot;eco00300&quot;: &quot;Lysine biosynthesis&quot;,\r\n          &quot;eco01100&quot;: &quot;Metabolic pathways&quot;,\r\n          &quot;eco01110&quot;: &quot;Biosynthesis of secondary metabolites&quot;,\r\n          &quot;eco01120&quot;: &quot;Microbial metabolism in diverse environments&quot;,\r\n          &quot;eco01130&quot;: &quot;Biosynthesis of antibiotics&quot;,\r\n          &quot;eco01230&quot;: &quot;Biosynthesis of amino acids&quot;\r\n        },\r\n        &quot;modules&quot;: {\r\n          &quot;eco_M00016&quot;: &quot;Lysine biosynthesis, succinyl-DAP pathway, aspartate =&gt; lysine&quot;,\r\n          &quot;eco_M00017&quot;: &quot;Methionine biosynthesis, apartate =&gt; homoserine =&gt; methionine&quot;,\r\n          &quot;eco_M00018&quot;: &quot;Threonine biosynthesis, aspartate =&gt; homoserine =&gt; threonine&quot;\r\n        },\r\n        &quot;classes&quot;: [\r\n    \r\n        ],\r\n        &quot;position&quot;: &quot;337..2799&quot;,\r\n        &quot;chromosome&quot;: null,\r\n        &quot;gbposition&quot;: &quot;337..2799&quot;,\r\n        &quot;motifs&quot;: {\r\n          &quot;Pfam&quot;: [\r\n            &quot;Homoserine_dh&quot;,\r\n            &quot;AA_kinase&quot;,\r\n            &quot;NAD_binding_3&quot;,\r\n            &quot;ACT_7&quot;,\r\n            &quot;ACT&quot;,\r\n            &quot;Sacchrp_dh_NADP&quot;\r\n          ]\r\n        },\r\n        &quot;dblinks&quot;: {\r\n          &quot;NCBI-GeneID&quot;: [\r\n            &quot;945803&quot;\r\n          ],\r\n          &quot;NCBI-ProteinID&quot;: [\r\n            &quot;NP_414543&quot;\r\n          ],\r\n          &quot;Pasteur&quot;: [\r\n            &quot;thrA&quot;\r\n          ],\r\n          &quot;RegulonDB&quot;: [\r\n            &quot;ECK120000987&quot;\r\n          ],\r\n          &quot;ECOCYC&quot;: [\r\n            &quot;EG10998&quot;\r\n          ],\r\n          &quot;ASAP&quot;: [\r\n            &quot;ABE-0000008&quot;\r\n          ],\r\n          &quot;UniProt&quot;: [\r\n            &quot;P00561&quot;\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;genes_id&quot;: &quot;eco:b0003&quot;,\r\n        &quot;entry_id&quot;: &quot;b0003&quot;,\r\n        &quot;division&quot;: &quot;CDS&quot;,\r\n        &quot;organism&quot;: &quot;Escherichia coli K-12 MG1655&quot;,\r\n        &quot;organism_code&quot;: &quot;eco&quot;,\r\n        &quot;organism_id&quot;: &quot;T00007&quot;,\r\n        &quot;name&quot;: &quot;thrB&quot;,\r\n        &quot;names&quot;: [\r\n          &quot;thrB&quot;\r\n        ],\r\n        &quot;definition&quot;: &quot;(RefSeq) homoserine kinase&quot;,\r\n        &quot;eclinks&quot;: [\r\n    \r\n        ],\r\n        &quot;orthologs&quot;: {\r\n          &quot;K00872&quot;: &quot;homoserine kinase [EC:2.7.1.39]&quot;\r\n        },\r\n        &quot;pathways&quot;: {\r\n          &quot;eco00260&quot;: &quot;Glycine, serine and threonine metabolism&quot;,\r\n          &quot;eco01100&quot;: &quot;Metabolic pathways&quot;,\r\n          &quot;eco01110&quot;: &quot;Biosynthesis of secondary metabolites&quot;,\r\n          &quot;eco01120&quot;: &quot;Microbial metabolism in diverse environments&quot;,\r\n          &quot;eco01230&quot;: &quot;Biosynthesis of amino acids&quot;\r\n        },\r\n        &quot;modules&quot;: {\r\n          &quot;eco_M00018&quot;: &quot;Threonine biosynthesis, aspartate =&gt; homoserine =&gt; threonine&quot;\r\n        },\r\n        &quot;classes&quot;: [\r\n    \r\n        ],\r\n        &quot;position&quot;: &quot;2801..3733&quot;,\r\n        &quot;chromosome&quot;: null,\r\n        &quot;gbposition&quot;: &quot;2801..3733&quot;,\r\n        &quot;motifs&quot;: {\r\n          &quot;Pfam&quot;: [\r\n            &quot;GHMP_kinases_N&quot;,\r\n            &quot;GHMP_kinases_C&quot;\r\n          ]\r\n        },\r\n        &quot;dblinks&quot;: {\r\n          &quot;NCBI-GeneID&quot;: [\r\n            &quot;947498&quot;\r\n          ],\r\n          &quot;NCBI-ProteinID&quot;: [\r\n            &quot;NP_414544&quot;\r\n          ],\r\n          &quot;Pasteur&quot;: [\r\n            &quot;thrB&quot;\r\n          ],\r\n          &quot;RegulonDB&quot;: [\r\n            &quot;ECK120000988&quot;\r\n          ],\r\n          &quot;ECOCYC&quot;: [\r\n            &quot;EG10999&quot;\r\n          ],\r\n          &quot;ASAP&quot;: [\r\n            &quot;ABE-0000010&quot;\r\n          ],\r\n          &quot;UniProt&quot;: [\r\n            &quot;P00547&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\n**Desired output**&lt;br&gt;\r\nThis is an array of two objects. I&#39;m interested in the `genes_id` and `pathways` for both objects and want to obtain a tab separated file containing the following:\r\n\r\n    eco:b0002\teco00260\tGlycine, serine and threonine metabolism\r\n    eco:b0002\teco00261\tMonobactam biosynthesis\r\n    eco:b0002\teco00270\tCysteine and methionine metabolism\r\n    eco:b0002\teco00300\tLysine biosynthesis\r\n    eco:b0002\teco01100\tMetabolic pathways\r\n    eco:b0002\teco01110\tBiosynthesis of secondary metabolites\r\n    eco:b0002\teco01120\tMicrobial metabolism in diverse environments\r\n    eco:b0002\teco01130\tBiosynthesis of antibiotics\r\n    eco:b0002\teco01230\tBiosynthesis of amino acids\r\n    eco:b0003\teco00260\tGlycine, serine and threonine metabolism\r\n    eco:b0003\teco01100\tMetabolic pathways\r\n    eco:b0003\teco01110\tBiosynthesis of secondary metabolites\r\n    eco:b0003\teco01120\tMicrobial metabolism in diverse environments\r\n    eco:b0003\teco01230\tBiosynthesis of amino acids\r\n\r\n\r\n----------\r\n\r\n**What I found out&lt;br&gt;**\r\nI know it&#39;s possible to extract the data in a format like:\r\n\r\n    eco:b0002: list of pathways and ids\r\n    eco:b0003: list of pathways and ids\r\n\r\nHowever I want to *spread* the pathways out to individual rows as in the above example. I could not find any information on how to do this using jq and therefore doubt whether this is actually possible. Thus, if this is possible how could this be achieved using Jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50470951/jq-gather-json-data-for-each-object",
        "title": "Jq: Gather JSON data for each object"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-extraction"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1527017999,
                "creation_date": 1527017999,
                "answer_id": 50475325,
                "question_id": 50475054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to go digging a little deeper. Feed the values of the object to `select`, and check `.fields.cartItemId`, not just `.cartItemId`.\r\n\r\n    jq &#39;.[] | select(.fields.cartItemId == 2081021134)&#39; input.json",
                "title": "How to match a json value with the jq command?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1527020911,
                "creation_date": 1527020911,
                "answer_id": 50475965,
                "question_id": 50475054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This produces the desired output.  Using `with_entries` makes it easy to retain the keys.\r\n\r\n    with_entries( if .value | has(&quot;fields&quot;) \r\n                  then select(.value.fields.cartItemId == 2081021134)\r\n                  else . end)",
                "title": "How to match a json value with the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1527023252,
        "creation_date": 1527016882,
        "last_edit_date": 1527023252,
        "question_id": 50475054,
        "body_markdown": "I have the following json data:\r\n\r\n    {\r\n    \t&quot;item_i7bfe8f00&quot;: {\r\n    \t\t&quot;id&quot;: &quot;i7bfe8f00&quot;,\r\n    \t\t&quot;tag&quot;: &quot;item&quot;,\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;img&quot;: &quot;https://example.com&quot;,\r\n    \t\t\t&quot;quantity&quot;: {\r\n    \t\t\t\t&quot;qtyPrefix&quot;: &quot;Kuantitas&quot;,\r\n    \t\t\t\t&quot;min&quot;: 1,\r\n    \t\t\t\t&quot;autoOptions&quot;: false,\r\n    \t\t\t\t&quot;quantity&quot;: 5,\r\n    \t\t\t\t&quot;max&quot;: 5,\r\n    \t\t\t\t&quot;editable&quot;: true,\r\n    \t\t\t\t&quot;showIncrDecr&quot;: true,\r\n    \t\t\t\t&quot;showOptions&quot;: false,\r\n    \t\t\t\t&quot;step&quot;: 1\r\n    \t\t\t},\r\n    \t\t\t&quot;sellerName&quot;: &quot;ALL ITEM STORE&quot;,\r\n    \t\t\t&quot;title&quot;: &quot;Xiaomi Redmi 4A Softcase Black&quot;,\r\n    \t\t\t&quot;stockTip&quot;: {},\r\n    \t\t\t&quot;valid&quot;: true,\r\n    \t\t\t&quot;itemId&quot;: &quot;143800088&quot;,\r\n    \t\t\t&quot;operations&quot;: [\r\n    \t\t\t\t&quot;wishlist&quot;,\r\n    \t\t\t\t&quot;delete&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellerId&quot;: &quot;100124080&quot;,\r\n    \t\t\t&quot;price&quot;: {\r\n    \t\t\t\t&quot;price&quot;: 3500,\r\n    \t\t\t\t&quot;currentPrice&quot;: &quot;Rp3.500&quot;,\r\n    \t\t\t\t&quot;originPrice&quot;: &quot;Rp15.000&quot;,\r\n    \t\t\t\t&quot;promotionRatio&quot;: &quot;-77%&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;restriction&quot;: false,\r\n    \t\t\t&quot;isGift&quot;: false,\r\n    \t\t\t&quot;sku&quot;: {\r\n    \t\t\t\t&quot;skuText&quot;: &quot;Softcase, Hitam&quot;,\r\n    \t\t\t\t&quot;productVariant&quot;: &quot;SO908ELAAVYY4AANID-72544754&quot;,\r\n    \t\t\t\t&quot;brandId&quot;: &quot;17818&quot;,\r\n    \t\t\t\t&quot;skuId&quot;: &quot;157608391&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;itemUrl&quot;: &quot;https://example.com&quot;,\r\n    \t\t\t&quot;cartItemId&quot;: 2080280320\r\n    \t\t},\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t},\r\n    \t&quot;item_i7c09dcce&quot;: {\r\n    \t\t&quot;id&quot;: &quot;i7c09dcce&quot;,\r\n    \t\t&quot;tag&quot;: &quot;item&quot;,\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;img&quot;: &quot;https://example.com&quot;,\r\n    \t\t\t&quot;quantity&quot;: {\r\n    \t\t\t\t&quot;qtyPrefix&quot;: &quot;Kuantitas&quot;,\r\n    \t\t\t\t&quot;min&quot;: 1,\r\n    \t\t\t\t&quot;autoOptions&quot;: false,\r\n    \t\t\t\t&quot;quantity&quot;: 1,\r\n    \t\t\t\t&quot;max&quot;: 5,\r\n    \t\t\t\t&quot;editable&quot;: true,\r\n    \t\t\t\t&quot;showIncrDecr&quot;: true,\r\n    \t\t\t\t&quot;showOptions&quot;: false,\r\n    \t\t\t\t&quot;step&quot;: 1\r\n    \t\t\t},\r\n    \t\t\t&quot;sellerName&quot;: &quot;PT. Ecart Services Indonesia&quot;,\r\n    \t\t\t&quot;title&quot;: &quot;Black&quot;,\r\n    \t\t\t&quot;stockTip&quot;: {},\r\n    \t\t\t&quot;valid&quot;: true,\r\n    \t\t\t&quot;itemId&quot;: &quot;345695828&quot;,\r\n    \t\t\t&quot;operations&quot;: [\r\n    \t\t\t\t&quot;wishlist&quot;,\r\n    \t\t\t\t&quot;delete&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellerId&quot;: &quot;100161156&quot;,\r\n    \t\t\t&quot;price&quot;: {\r\n    \t\t\t\t&quot;price&quot;: 2499000,\r\n    \t\t\t\t&quot;currentPrice&quot;: &quot;Rp2.499.000&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;restriction&quot;: false,\r\n    \t\t\t&quot;isGift&quot;: false,\r\n    \t\t\t&quot;sku&quot;: {\r\n    \t\t\t\t&quot;skuText&quot;: &quot;Hitam&quot;,\r\n    \t\t\t\t&quot;productVariant&quot;: &quot;345695828_ID-359330058&quot;,\r\n    \t\t\t\t&quot;brandId&quot;: &quot;21734&quot;,\r\n    \t\t\t\t&quot;skuId&quot;: &quot;359330058&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;itemUrl&quot;: &quot;https://example.com&quot;,\r\n    \t\t\t&quot;cartItemId&quot;: 2081021134\r\n    \t\t},\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t}\r\n    }\r\n\r\nand I want to show the object that only has `&quot;cartItemId&quot;: 2081021134` so the end result should look like this:\r\n\r\n    {\r\n    \t&quot;item_i7c09dcce&quot;: {\r\n    \t\t&quot;id&quot;: &quot;i7c09dcce&quot;,\r\n    \t\t&quot;tag&quot;: &quot;item&quot;,\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;img&quot;: &quot;https://example.com&quot;,\r\n    \t\t\t&quot;quantity&quot;: {\r\n    \t\t\t\t&quot;qtyPrefix&quot;: &quot;Kuantitas&quot;,\r\n    \t\t\t\t&quot;min&quot;: 1,\r\n    \t\t\t\t&quot;autoOptions&quot;: false,\r\n    \t\t\t\t&quot;quantity&quot;: 1,\r\n    \t\t\t\t&quot;max&quot;: 5,\r\n    \t\t\t\t&quot;editable&quot;: true,\r\n    \t\t\t\t&quot;showIncrDecr&quot;: true,\r\n    \t\t\t\t&quot;showOptions&quot;: false,\r\n    \t\t\t\t&quot;step&quot;: 1\r\n    \t\t\t},\r\n    \t\t\t&quot;sellerName&quot;: &quot;PT. Ecart Services Indonesia&quot;,\r\n    \t\t\t&quot;title&quot;: &quot;Black&quot;,\r\n    \t\t\t&quot;stockTip&quot;: {},\r\n    \t\t\t&quot;valid&quot;: true,\r\n    \t\t\t&quot;itemId&quot;: &quot;345695828&quot;,\r\n    \t\t\t&quot;operations&quot;: [\r\n    \t\t\t\t&quot;wishlist&quot;,\r\n    \t\t\t\t&quot;delete&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;sellerId&quot;: &quot;100161156&quot;,\r\n    \t\t\t&quot;price&quot;: {\r\n    \t\t\t\t&quot;price&quot;: 2499000,\r\n    \t\t\t\t&quot;currentPrice&quot;: &quot;Rp2.499.000&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;restriction&quot;: false,\r\n    \t\t\t&quot;isGift&quot;: false,\r\n    \t\t\t&quot;sku&quot;: {\r\n    \t\t\t\t&quot;skuText&quot;: &quot;Hitam&quot;,\r\n    \t\t\t\t&quot;productVariant&quot;: &quot;345695828_ID-359330058&quot;,\r\n    \t\t\t\t&quot;brandId&quot;: &quot;21734&quot;,\r\n    \t\t\t\t&quot;skuId&quot;: &quot;359330058&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;itemUrl&quot;: &quot;https://example.com&quot;,\r\n    \t\t\t&quot;cartItemId&quot;: 2081021134\r\n    \t\t},\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t}\r\n    }\r\n\r\nThis is what I have tried so far :\r\n\r\n    jq &#39;select(.cartItemId==2081021134)&#39; input.json\r\n\r\nbut it returns nothing, how should I fix it ?",
        "link": "https://stackoverflow.com/questions/50475054/how-to-match-a-json-value-with-the-jq-command",
        "title": "How to match a json value with the jq command?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11978801,
                    "reputation": 313,
                    "user_id": 8765205,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/k6uwS.jpg?s=256",
                    "display_name": "marcel.js",
                    "link": "https://stackoverflow.com/users/8765205/marcel-js"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1527104312,
                "post_id": 50495762,
                "comment_id": 88005199,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4596208,
                    "reputation": 1995,
                    "user_id": 3728184,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c5cd351f84cbd8412011d2d8e98e63ea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Markus",
                    "link": "https://stackoverflow.com/users/3728184/markus"
                },
                "reply_to_user": {
                    "account_id": 11978801,
                    "reputation": 313,
                    "user_id": 8765205,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/k6uwS.jpg?s=256",
                    "display_name": "marcel.js",
                    "link": "https://stackoverflow.com/users/8765205/marcel-js"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527113183,
                "post_id": 50495762,
                "comment_id": 88009158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11978801,
                    "reputation": 313,
                    "user_id": 8765205,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/k6uwS.jpg?s=256",
                    "display_name": "marcel.js",
                    "link": "https://stackoverflow.com/users/8765205/marcel-js"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527134443,
                "post_id": 50495762,
                "comment_id": 88014043,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527103637,
                "creation_date": 1527103637,
                "answer_id": 50496095,
                "question_id": 50495762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert the object to an array of key/value pairs first; then you can iterate over that and access the key and associated value in tandem.\r\n\r\n    $ jq &#39;to_entries&#39; tmp.json\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;john&quot;,\r\n        &quot;value&quot;: {\r\n          &quot;age&quot;: 40,\r\n          &quot;nickname&quot;: &quot;jo&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;mary&quot;,\r\n        &quot;value&quot;: {\r\n          &quot;age&quot;: 50,\r\n          &quot;nickname&quot;: &quot;mo&quot;\r\n        }\r\n      }\r\n    ]\r\n    $ jq &#39;to_entries[] | &quot;\\(.key): \\(.value.age)&quot;&#39; tmp.json\r\n    &quot;john: 40&quot;\r\n    &quot;mary: 50&quot;\r\n",
                "title": "How to use jq to extract variable keys and their values from JSON?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1527103848,
                "creation_date": 1527103848,
                "answer_id": 50496145,
                "question_id": 50495762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the particular case you mention, the following filter could be used:\r\n\r\n    to_entries[] | &quot;\\&quot;\\(.key)\\&quot;: \\(.value.age)&quot;\r\n\r\nUsing the -r command-line option (e.g. jq -rf program.jq) with your input produces:\r\n\r\n    &quot;john&quot;: 40\r\n    &quot;mary&quot;: 50\r\n\r\nSee also:\r\n\r\nhttps://stackoverflow.com/questions/48629417/recursive-extraction-of-object-values-and-parent-key-name-using-jq",
                "title": "How to use jq to extract variable keys and their values from JSON?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1527134547,
                "creation_date": 1527134547,
                "answer_id": 50500754,
                "question_id": 50495762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n    to_entries[] | {(.key): .value.age}\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;john&quot;: 40\r\n    }\r\n    {\r\n      &quot;mary&quot;: 50\r\n    }",
                "title": "How to use jq to extract variable keys and their values from JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1527134547,
        "creation_date": 1527102413,
        "question_id": 50495762,
        "body_markdown": "If I have a JSON file with variable key names like this:\r\n\r\n    {   \r\n        &quot;john&quot;: {&quot;age&quot;: 40, &quot;nickname&quot;: &quot;jo&quot;},\r\n        &quot;mary&quot;: {&quot;age&quot;: 50, &quot;nickname&quot;: &quot;mo&quot;}\r\n    }\r\n\r\nHow do I use `jq` to extract the keys with some of their values?\r\n\r\nExample: Extract the names and their ages:\r\n\r\n    &quot;john&quot;: 40\r\n    &quot;mary&quot;: 50\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50495762/how-to-use-jq-to-extract-variable-keys-and-their-values-from-json",
        "title": "How to use jq to extract variable keys and their values from JSON?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527114177,
                "post_id": 50498283,
                "comment_id": 88009466,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1527149485,
                "last_edit_date": 1527149485,
                "creation_date": 1527115532,
                "answer_id": 50498514,
                "question_id": 50498283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You will either need to run jq twice, or to run jq in conjunction with another program to &quot;split&quot; the output of the call to jq.  For example, you could use a pipeline of the form: `jq -c ... | awk ...`\r\n\r\nThe potential disadvantage of the pipeline approach is that if JSON is the final output, it will be JSONL; but obviously that doesn&#39;t apply here.\r\n\r\nThere are many ways to craft such a pipeline.  For example, assuming there are no raw newlines in the CSV:\r\n\r\n    &lt; testJQ.log jq -r &#39;\r\n        &quot;types&quot;,  ([.id,.type] |@csv),\r\n        &quot;groups&quot;, ([.id,.group]|@csv)&#39; |\r\n      awk &#39;NR % 2 == 1 {out=$1; next} {print &gt;&gt; out&quot;.csv&quot;}&#39;\r\n\r\n\r\nOr:\r\n\r\n    &lt; testJQ.log jq -r &#39;([.id,.type],[.id,.group])|@csv&#39; |\r\n        awk &#39;{ out = ((NR % 2) == 1) ? &quot;types&quot; : &quot;groups&quot;; print &gt;&gt; out&quot;.csv&quot;}&#39;\r\n\r\nFor other examples, see e.g.\r\n\r\n* https://stackoverflow.com/questions/49808581/using-jq-how-can-i-split-a-very-large-json-file-into-multiple-files-each-a-spec\r\n\r\n* https://stackoverflow.com/questions/35881458/splitting-chunking-json-files-with-jq-in-bash-or-fish-shell\r\n\r\n* https://stackoverflow.com/questions/44215931/split-json-into-multiple-files\r\n\r\n## Handling raw new-lines\r\nWhether or not you split the CSV into multiple files, there is a potential issue with embedded raw newlines.  One approach is to change &quot;\\n&quot; in JSON strings to &quot;\\\\\\\\n&quot;, e.g.\r\n\r\n    jq -r &#39;([.id,.type],[.id,.group])\r\n           | map(if type == &quot;string&quot; then gsub(&quot;\\n&quot;;&quot;\\\\n&quot;) else . end)\r\n           | @csv&#39;",
                "title": "How to create 2 CSV files from 1 JSON using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1527119923,
                "creation_date": 1527119923,
                "answer_id": 50499059,
                "question_id": 50498283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suppose one way you could hack this up is to output the contents of one file to stdout and the others to stderr and redirect to separate files. Of course you&#39;re limited to two files though.\r\n\r\n    $ &lt;testJQ.log jq -r &#39;([.id,.type]|@csv),([.id,.group]|@csv|stderr|empty)&#39; \\\r\n        1&gt;types.csv 2&gt;groups.csv\r\n\r\n`stderr` outputs to stderr but the value propagates to the output, so you&#39;ll want to follow that up with `empty` to swallow that up.\r\n\r\nPersonally I wouldn&#39;t recommend doing this, I would just write a python script (or other language) to parse this if you needed to output to multiple files.",
                "title": "How to create 2 CSV files from 1 JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1638253356,
        "creation_date": 1527113940,
        "last_edit_date": 1638253356,
        "question_id": 50498283,
        "body_markdown": "I have a lot of rather large JSON logs which need to be imported into several DB tables.\r\nI can easily parse them and create 1 CSV for import.\r\nBut how can I parse the JSON and get 2 different CSV files as output?\r\nSimple (nonsense) example:\r\n\r\ntestJQ.log\r\n\r\n    {&quot;id&quot;:1234,&quot;type&quot;:&quot;A&quot;,&quot;group&quot;:&quot;games&quot;}\r\n    {&quot;id&quot;:5678,&quot;type&quot;:&quot;B&quot;,&quot;group&quot;:&quot;cars&quot;}\r\n\r\nusing \r\n\r\n    cat testJQ.log|jq --raw-output &#39;[.id,.type,.group]|@csv&#39;&gt;testJQ.csv\r\n\r\nI get one file testJQ.csv\r\n\r\n    1234,&quot;A&quot;,&quot;games\r\n    5678,&quot;B&quot;,&quot;cars&quot;\r\n\r\nBut I would like to get this\r\n \r\ntypes.csv\r\n\r\n    1234,&quot;A&quot;\r\n    5678,&quot;B&quot;\r\n\r\ngroups.csv\r\n\r\n    1234,&quot;games&quot;\r\n    5678,&quot;cars&quot;\r\n\r\nCan this be done without having to parse the JSON twice, first time creating the types.csv and second time the groups.csv like this?\r\n\r\n    cat testJQ.log|jq --raw-output &#39;[.id,.type]|@csv&#39;&gt;types.csv\r\n    cat testJQ.log|jq --raw-output &#39;[.id,.group]|@csv&#39;&gt;groups.csv\r\n",
        "link": "https://stackoverflow.com/questions/50498283/how-to-create-2-csv-files-from-1-json-using-jq",
        "title": "How to create 2 CSV files from 1 JSON using JQ"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1527170390,
                "post_id": 50511240,
                "comment_id": 88034812,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527180185,
                "creation_date": 1527180185,
                "answer_id": 50514345,
                "question_id": 50511240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here’s one way:\r\n\r\n    with_entries( if .value|(type==&quot;object&quot; and .identifier == &quot;agent_credentials&quot;)\r\n                  then empty else . end)",
                "title": "Deleting json block using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527432552,
        "creation_date": 1527170264,
        "last_edit_date": 1527432552,
        "question_id": 50511240,
        "body_markdown": "I want to remove an entire JSON block by providing specific value to JQ.\r\n\r\nJSON block:\r\n\r\n    {\r\n      &quot;deployed&quot;: false,\r\n      &quot;identifier&quot;: &quot;agent_credentials&quot;,\r\n      &quot;value&quot;: \r\n    {\r\n      &quot;identity&quot;: &quot;vcap&quot;,\r\n      password&quot;: &quot;&quot;\r\n       }\r\n     },\r\n\r\nAnd I want to remove it by providing value &quot;agent_credentials&quot; to JQ.\r\n\r\nI am trying `del(..|.agent_credentials)` but it doesn&#39;t clear the block.",
        "link": "https://stackoverflow.com/questions/50511240/deleting-json-block-using-jq",
        "title": "Deleting json block using jq"
    },
    {
        "tags": [
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1527213745,
                "last_edit_date": 1527213745,
                "creation_date": 1527189784,
                "answer_id": 50516748,
                "question_id": 50516551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just have to &quot;lift&quot; the iterator (`.results[]`) to the front:\r\n\r\n    .results[] \r\n    | {user: .id, mail: .buyer.email, buyer: .buyer.billing_info.doc_number}\r\n\r\nWith the -c command-line option, this produces:\r\n\r\n    {&quot;user&quot;:111,&quot;mail&quot;:&quot;mail1@mail.com&quot;,&quot;buyer&quot;:&quot;123&quot;}\r\n    {&quot;user&quot;:222,&quot;mail&quot;:&quot;mail2@mail.com&quot;,&quot;buyer&quot;:&quot;456&quot;}\r\n\r\nIt might help to think of `(ARRAY[] | ...)` in jq as being like `for (x in ARRAY) {...}` in other languages.\r\n",
                "title": "jq json array mixed (duplicated) results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1527213745,
        "creation_date": 1527188938,
        "last_edit_date": 1527213591,
        "question_id": 50516551,
        "body_markdown": "I have a JSON array, which I want to extract values from (using jq):\r\n\r\nThis is a reduced example\r\n\r\n    {\r\n      &quot;query&quot;: &quot;&quot;,\r\n      &quot;results&quot;: [\r\n      {\r\n          &quot;id&quot;: 111,\r\n          ...\r\n          &quot;buyer&quot;: {\r\n            &quot;email&quot;: &quot;mail1@mail.com&quot;,\r\n            ...\r\n            &quot;billing_info&quot;: {\r\n              &quot;doc_number&quot;: &quot;123&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: 222,\r\n          ...\r\n          &quot;buyer&quot;: {\r\n            &quot;email&quot;: &quot;mail2@mail.com&quot;,\r\n            ...\r\n            &quot;billing_info&quot;: {\r\n              &quot;doc_number&quot;: &quot;456&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nCurrently, I&#39;m using this filter:\r\n\r\n    {user: .results[].id, mail: .results[].buyer.email, buyer: .results[].buyer.billing_info.doc_number}\r\n\r\nAnd I&#39;m getting a &quot;full join&quot; result. \r\n\r\n    {&quot;user&quot;:111,&quot;mail&quot;:&quot;mail1@mail.com&quot;,&quot;buyer&quot;:&quot;123&quot;}\r\n    {&quot;user&quot;:111,&quot;mail&quot;:&quot;mail1@mail.com&quot;,&quot;buyer&quot;:&quot;456&quot;}\r\n    {&quot;user&quot;:111,&quot;mail&quot;:&quot;mail2@mail.com&quot;,&quot;buyer&quot;:&quot;123&quot;}\r\n    {&quot;user&quot;:111,&quot;mail&quot;:&quot;mail2@mail.com&quot;,&quot;buyer&quot;:&quot;456&quot;}\r\n    {&quot;user&quot;:222,&quot;mail&quot;:&quot;mail1@mail.com&quot;,&quot;buyer&quot;:&quot;123&quot;}\r\n    {&quot;user&quot;:222,&quot;mail&quot;:&quot;mail1@mail.com&quot;,&quot;buyer&quot;:&quot;456&quot;}\r\n    {&quot;user&quot;:222,&quot;mail&quot;:&quot;mail2@mail.com&quot;,&quot;buyer&quot;:&quot;123&quot;}\r\n    {&quot;user&quot;:222,&quot;mail&quot;:&quot;mail2@mail.com&quot;,&quot;buyer&quot;:&quot;456&quot;}\r\n\r\nWhat I want is to filter some fields from the full object. So in this example, I have 2 objects, so I want 2 results:\r\n\r\n    {&quot;user&quot;:111,&quot;mail&quot;:&quot;mail1@mail.com&quot;,&quot;buyer&quot;:&quot;123&quot;}\r\n    {&quot;user&quot;:222,&quot;mail&quot;:&quot;mail2@mail.com&quot;,&quot;buyer&quot;:&quot;456&quot;}\r\n\r\nHere is a snippet from my example:\r\n\r\nhttps://jqplay.org/s/nM1WzWRmnK\r\n\r\nThanks everyone!\r\n",
        "link": "https://stackoverflow.com/questions/50516551/jq-json-array-mixed-duplicated-results",
        "title": "jq json array mixed (duplicated) results"
    },
    {
        "tags": [
            "json",
            "bash",
            "precision",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2612402,
                    "reputation": 3849,
                    "user_id": 2262288,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/edHCD.jpg?s=256",
                    "display_name": "Routhinator",
                    "link": "https://stackoverflow.com/users/2262288/routhinator"
                },
                "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": 1527192780,
                "post_id": 50517393,
                "comment_id": 88047452,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1664162323,
                "last_edit_date": 1664162323,
                "creation_date": 1527193040,
                "answer_id": 50517500,
                "question_id": 50517393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately you&#39;ve run into one of the major limitations of the C-based implementation of jq - numerical precision.  This implementation maps JSON numbers to IEEE 754 64-bit numbers. This is discussed in the [jq FAQ][1] under &quot;Caveats&quot;.\r\n\r\n## Workarounds\r\n\r\n(1) Use gojq, the Go implementation of jq.\r\n\r\n(2) If you don&#39;t want to work with the C implementation of jq,\r\nyou could use the &quot;BigInt&quot; module for jq - https://gist.github.com/pkoppstein/d06a123f30c033195841\r\n\r\nHowever, this works with string representations, so it may be more trouble than its worth for your use case.\r\n\r\nIf you just need addition, you could use this jq def:\r\n\r\n    # The args should be strings representing non-negative integers\r\n    # without a leading &quot;+&quot;:\r\n    def add(num1;num2):\r\n      if (num1|length) &lt; (num2|length) then add(num2;num1)\r\n      else  (num1 | explode | map(.-48) | reverse) as $a1\r\n          | (num2 | explode | map(.-48) | reverse) as $a2\r\n          | reduce range(0; num1|length) as $ix\r\n              ($a2;  # result\r\n               ( $a1[$ix] + .[$ix] ) as $r\r\n               | if $r &gt; 9 # carrying\r\n                 then\r\n                   .[$ix + 1] = ($r / 10 | floor) + \r\n                                (if $ix + 1 &gt;= length then 0 else .[$ix + 1] end )\r\n                   | .[$ix] = $r - ( $r / 10 | floor ) * 10\r\n                 else\r\n                   .[$ix] = $r\r\n                 end )\r\n          | reverse | map(.+48) | implode\r\n      end ;\r\n\r\n### Usage\r\nOne way to use this would be to copy it to a file (say add.jq) in your jq library (e.g. ~/.jq/) \r\nand use `include` to include it, e.g. as illustrated by the following:\r\n\r\n    jq -n  &#39;include &quot;add&quot;; \r\n            add(&quot;448887356515418113&quot;;&quot;448887356515418113&quot;)&#39;\r\n    &quot;897774713030836226&quot;\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ\r\n",
                "title": "JQ subtracts 13 from my integer when it adds it to a second location, but not the first"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1527194453,
                "last_edit_date": 1527194453,
                "creation_date": 1527193314,
                "answer_id": 50517571,
                "question_id": 50517393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, you should not use the numeric type for large numeric strings in JSON for exactly this reason. But if Discord requires an integer - and if it&#39;s able to get the correct unrounded value out of the config with whatever _it&#39;s_ using to parse it - then you need another approach. Perhaps Python?\r\n\r\n\r\n    function updateDiscordConfig {\r\n      echo &quot;Setting Discord configuration...&quot;\r\n      python -c &quot;import json, sys; conf = json.load(sys.stdin); conf[&#39;discord&#39;][&#39;token&#39;]=&#39;$DISCORD_TOKEN&#39;; conf[&#39;discord&#39;][&#39;channels&#39;][&#39;channels&#39;]=&#39;$DISCORD_CHANNEL&#39;;conf[&#39;minecraft&#39;][&#39;dimensions&#39;][&#39;generic&#39;][&#39;discordChannel&#39;]=[$DISCORD_CHANNEL];print(json.dumps(conf));&quot; ${DISCORD_SRCCONFIG} | sponge ${DISCORD_DESTCONFIG}\r\n    }",
                "title": "JQ subtracts 13 from my integer when it adds it to a second location, but not the first"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1664162323,
        "creation_date": 1527192586,
        "last_edit_date": 1527194392,
        "question_id": 50517393,
        "body_markdown": "I have a script that uses Docker env vars to configure a json file on start. The function uses the same ENV var twice in the same JQ command, and in the first location the integer remains as set, and in the second line JQ subtracts 13 (WTF?) from the number. Can anyone explain this? And more importantly how do I prevent this from happening.\r\n\r\n*Note:* In order for the config to be valid, the second instance must be an unquoted integer. Testing shows that quoting the integer results in the expected output, but invalid config.\r\n\r\n\r\nEnv Var\r\n\r\n    DISCORD_CHANNEL=448887356515418113\r\n\r\nBash Function:\r\n\r\n    function updateDiscordConfig {\r\n      echo &quot;Setting Discord configuration...&quot;\r\n      jq &quot;.discord |= . + {\\&quot;token\\&quot;:\\&quot;${DISCORD_TOKEN}\\&quot;} | .discord.channels.channels |= . + {\\&quot;${DISCORD_CHANNEL}\\&quot;: {}} | .minecraft.dimensions.generic |= . + {\\&quot;discordChannel\\&quot;: [${DISCORD_CHANNEL}]}&quot; ${DISCORD_SRCCONFIG} | sponge ${DISCORD_DESTCONFIG}\r\n    }\r\n\r\nOutput:\r\n\r\n    // First output\r\n    &quot;channels&quot;: {\r\n      &quot;448887356515418113&quot;: {}\r\n    }\r\n    \r\n    // Second output\r\n    &quot;discordChannel&quot;: [\r\n        448887356515418100\r\n    ],\r\n\r\n\r\n\r\n*Update*: I&#39;ve replaced the second instance update with a line using sed:\r\n\r\n    function updateDiscordConfig {\r\n      echo &quot;Setting Discord configuration...&quot;\r\n      jq &quot;.discord |= . + {\\&quot;token\\&quot;:\\&quot;${DISCORD_TOKEN}\\&quot;} | .discord.channels.channels |= . + {\\&quot;${DISCORD_CHANNEL}\\&quot;: {}}&quot; ${DISCORD_SRCCONFIG} | sponge ${DISCORD_DESTCONFIG}\r\n      sed -i &quot;/discordChannel/c\\   \\&quot;discordChannel\\&quot; : [${DISCORD_CHANNEL}],&quot; ${DISCORD_DESTCONFIG}\r\n    }",
        "link": "https://stackoverflow.com/questions/50517393/jq-subtracts-13-from-my-integer-when-it-adds-it-to-a-second-location-but-not-th",
        "title": "JQ subtracts 13 from my integer when it adds it to a second location, but not the first"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3650940,
                    "reputation": 2943,
                    "user_id": 3043148,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ac42f98601d3ff53207b7313cc5978e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nurdyguy",
                    "link": "https://stackoverflow.com/users/3043148/nurdyguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527264847,
                "post_id": 50533182,
                "comment_id": 88078383,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1039633,
                    "reputation": 990,
                    "user_id": 1045994,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/78bdcf16d1e031a06460be7cebcbe9bc?s=256&d=identicon&r=PG",
                    "display_name": "mmlb",
                    "link": "https://stackoverflow.com/users/1045994/mmlb"
                },
                "reply_to_user": {
                    "account_id": 3650940,
                    "reputation": 2943,
                    "user_id": 3043148,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ac42f98601d3ff53207b7313cc5978e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nurdyguy",
                    "link": "https://stackoverflow.com/users/3043148/nurdyguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527265255,
                "post_id": 50533182,
                "comment_id": 88078574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3650940,
                    "reputation": 2943,
                    "user_id": 3043148,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ac42f98601d3ff53207b7313cc5978e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nurdyguy",
                    "link": "https://stackoverflow.com/users/3043148/nurdyguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527265400,
                "post_id": 50533182,
                "comment_id": 88078657,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1039633,
                    "reputation": 990,
                    "user_id": 1045994,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/78bdcf16d1e031a06460be7cebcbe9bc?s=256&d=identicon&r=PG",
                    "display_name": "mmlb",
                    "link": "https://stackoverflow.com/users/1045994/mmlb"
                },
                "reply_to_user": {
                    "account_id": 3650940,
                    "reputation": 2943,
                    "user_id": 3043148,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ac42f98601d3ff53207b7313cc5978e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nurdyguy",
                    "link": "https://stackoverflow.com/users/3043148/nurdyguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527266541,
                "post_id": 50533182,
                "comment_id": 88079124,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3650940,
                    "reputation": 2943,
                    "user_id": 3043148,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/ac42f98601d3ff53207b7313cc5978e7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nurdyguy",
                    "link": "https://stackoverflow.com/users/3043148/nurdyguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527266748,
                "post_id": 50533182,
                "comment_id": 88079214,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1527267907,
                "last_edit_date": 1527267907,
                "creation_date": 1527267378,
                "answer_id": 50533807,
                "question_id": 50533182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you are probably looking for `jq` filter as below. The expression `.events[] | select(.id == null)` returns the key to the object where the `id` value is null and `del()` deletes that key/value pair.\r\n\r\n    jq &#39;del(.events[] | select(.id == null))&#39;\r\n\r\nAs a side note, if you just want to delete an element just by index, you could just use as below. The example below deletes the element from index 2, the array actually starts at 0. \r\n\r\n    jq &#39;del( .events[2] )&#39;\r\n\r\nBut remember this way is not recommended for your original problem, since you wouldn&#39;t know which index of your key would contain the null value.",
                "title": "How do I remove elements from array in a JSON object containing a value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527352469,
                "creation_date": 1527352469,
                "answer_id": 50544890,
                "question_id": 50533182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When in doubt (sometimes `del(...)` is a bit tricky), you can always use `map(select(...))`, e.g. in the present case:\r\n\r\n    .events |= map(select(.id != null))\r\n\r\nor perhaps even:\r\n\r\n    .events |= map(select(.id))",
                "title": "How do I remove elements from array in a JSON object containing a value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1527352469,
        "creation_date": 1527264633,
        "last_edit_date": 1527322799,
        "question_id": 50533182,
        "body_markdown": "**Please note that this post is tagged `jq`, I am not trying to do this with javascript at all.**\r\n\r\nI have an object that has an array as one of its fields. I&#39;d like to remove the elements from the object&#39;s array that match a criteria, but keep the object around. I&#39;ve looked around and I&#39;ve only been able to spot snippets of returning *just* the array that happens to have less items now.\r\n\r\nHere&#39;s an example:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;events&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;msg&quot;: &quot;starting&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;msg&quot;: &quot;working on it&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: null,\r\n          &quot;msg&quot;: &quot;done&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nand I&#39;d like to get back the following:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;events&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;msg&quot;: &quot;starting&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;msg&quot;: &quot;working on it&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nNote: Just in case this will affect the answer I&#39;m really only interested in the last element. I plan to build up a new object in a following pipe stage like:\r\n\r\n    jq &#39;$answer | {bar:.foo, event: .events[-1].msg}`\r\n\r\nI have tried both\r\n\r\n    select(.events[].id != null)\r\nand\r\n\r\n    del(.events[], select(.id == null)))\r\nwith no luck.",
        "link": "https://stackoverflow.com/questions/50533182/how-do-i-remove-elements-from-array-in-a-json-object-containing-a-value",
        "title": "How do I remove elements from array in a JSON object containing a value"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1527302311,
                "creation_date": 1527302311,
                "answer_id": 50538836,
                "question_id": 50538810,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq --arg name Richard &#39;.[] | select(.name==$name) | .age&#39; input.json\r\n    &quot;32&quot;\r\n\r\nWhen using jq like this in Windows, the quoting would have to be appropriate for Windows.",
                "title": "Lookup filtering with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565812476,
        "creation_date": 1527302118,
        "last_edit_date": 1565812476,
        "question_id": 50538810,
        "body_markdown": "Giving a JSON string like this, \r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Arthur&quot;,\r\n        &quot;age&quot;: &quot;21&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Richard&quot;,\r\n        &quot;age&quot;: &quot;32&quot;\r\n      }\r\n    ]\r\n\r\nHow to filter by name and get the age?  \r\nE.g., given the name being `&quot;Richard&quot;`, let `jq` return `&quot;32&quot;`. Thx. \r\n",
        "link": "https://stackoverflow.com/questions/50538810/lookup-filtering-with-jq",
        "title": "Lookup filtering with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1527437455,
                "creation_date": 1527437455,
                "answer_id": 50554066,
                "question_id": 50553799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `paths` function to get paths to each of the scalar values, then `getpath` to retrieve the value that path leads to. `$p` records the paths for later use.\r\n\r\n    $ jq -r &#39;paths(scalars) as $p | &quot;\\($p|join(&quot;_&quot;))=\\&quot;\\(getpath($p))\\&quot;&quot;&#39; tmp.json\r\n    data1=&quot;some data&quot;\r\n    data2=&quot;some data&quot;\r\n    key1_data3=&quot;some data&quot;\r\n    key1_data4=&quot;some data&quot;\r\n    key2_data5=&quot;some data&quot;\r\n\r\n(Answer based on information found at https://github.com/stedolan/jq/issues/78.)\r\n\r\n---\r\n\r\nShowing how two of the key steps work in more detail:\r\n\r\n    $ jq -cr &#39;paths(scalars)&#39; tmp.json\r\n    [&quot;data1&quot;]\r\n    [&quot;data2&quot;]\r\n    [&quot;key1&quot;,&quot;data3&quot;]\r\n    [&quot;key1&quot;,&quot;data4&quot;]\r\n    [&quot;key2&quot;,&quot;data5&quot;]\r\n    $ jq -r &#39;paths(scalars) | join(&quot;_&quot;)&#39; tmp.json\r\n    data1\r\n    data2\r\n    key1_data3\r\n    key1_data4\r\n    key2_data5",
                "title": "Get all entries with their respective keys using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527437455,
        "creation_date": 1527435644,
        "question_id": 50553799,
        "body_markdown": "The JSON structure I&#39;d like to process looks like :\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n     &quot;data1&quot;: &quot;some data&quot;,\r\n     &quot;data2&quot;: &quot;some data&quot;,\r\n       &quot;key1&quot;: {\r\n         &quot;data3&quot;: &quot;some data&quot;,\r\n         &quot;data4&quot;: &quot;some data&quot;\r\n       },\r\n       &quot;key2&quot;: {\r\n         &quot;data5&quot;: &quot;some data&quot;\r\n       }\r\n    }\r\nAnd what I would like jq to output (in order to extract and set variables using eval) :\r\n\r\n    data1=&quot;some data&quot;\r\n    data2=&quot;some data&quot;\r\n    key1_data3=&quot;some data&quot;\r\n    key1_data4=&quot;some data&quot;\r\n    key2_data5=&quot;some data&quot;\r\n\r\nI already tried using something like `to_entries` to get `.key` and `.value` (as described [here][1]) but I didn&#39;t have much success parsing it.  \r\nThanks for any help\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/34226370/jq-print-key-and-value-for-each-entry-in-an-object",
        "link": "https://stackoverflow.com/questions/50553799/get-all-entries-with-their-respective-keys-using-jq",
        "title": "Get all entries with their respective keys using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1527469664,
                "creation_date": 1527469664,
                "answer_id": 50557938,
                "question_id": 50557803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries`. Try this:\r\n\r\n    echo &#39;{&quot;Actors&quot;: &quot;Tom,Dick,Mary&quot;}&#39; | jq -r &#39;[.Actors | splits(&quot;,&quot;)] | to_entries | map(&quot;\\(.value) \\(1 + .key)&quot;) | .[]&#39; | column -t -o&quot;   &quot;\r\n\r\nI&#39;ve added `| column -t -o&quot;  &quot;`, i don&#39;t know how to format columns with jq.",
                "title": "Running counter for JSON array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1527482637,
                "last_edit_date": 1527482637,
                "creation_date": 1527473757,
                "answer_id": 50558303,
                "question_id": 50557803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One can produce TSV output with `@tsv`.  With the given input,\r\n\r\n    jq -r &#39;.Actors | split(&quot;,&quot;) | to_entries[] | [.value,.key] | @tsv&#39;\r\n\r\nproduces:\r\n\r\n    Tom\t0\r\n    Dick\t1\r\n    Mary\t2\r\n\r\nIf you want 1-based indexing, replace `.key` by `1 + .key` above.\r\n",
                "title": "Running counter for JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1527672060,
        "creation_date": 1527468188,
        "last_edit_date": 1527672060,
        "question_id": 50557803,
        "body_markdown": "I am using `jq-1.5`. I would like to emit a running counter (ie, index) for a JSON array.\r\n\r\nMy JSON is:\r\n\r\n    {&quot;Actors&quot;: &quot;Tom,Dick,Mary&quot;}\r\n\r\nI am able to split the string into an array using `splits()`:\r\n\r\n    echo &#39;{&quot;Actors&quot;: &quot;Tom,Dick,Mary&quot;}&#39; | jq --raw-output &#39;. | ( .Actors | splits( &quot;,&quot; ) )&#39;\r\n    Tom\r\n    Dick\r\n    Mary\r\n\r\nHow do it create a running counter for each element?  I have tried using the `--arg` but cannot seem to get it to increment.\r\n\r\nI would like to have:\r\n\r\n    Tom    1\r\n    Dick   2\r\n    Mary   3\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50557803/running-counter-for-json-array-using-jq",
        "title": "Running counter for JSON array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1527491473,
                "last_edit_date": 1527491473,
                "creation_date": 1527490661,
                "answer_id": 50560730,
                "question_id": 50560499,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the file name is the name of the property you want to update, you could utilize `input_filename` to select the files. No testing needed, just pass in the files you want to update. Just be aware of the order you pass in the input files.\r\n\r\nMerge the contents of the file as you see fit. To simply replace, just do a plain assignment.\r\n\r\n    $ jq &#39;reduce inputs as $i (.;\r\n        .[input_filename|rtrimstr(&quot;.json&quot;)] = $i.Employes\r\n    )&#39; branches.json branch{1,2}.json\r\n\r\nYour script would just need to be:\r\n\r\n    #!/bin/sh\r\n    #call file with branch name for example ./update.sh branch2\r\n    set -xe\r\n    branchName=$1\r\n    newJson=$(jq &#39;reduce inputs as $i (.; .[input_filename|rtrimstr(&quot;.json&quot;)] = $i.Employees)&#39; branches.json &quot;$branchName.json&quot;)",
                "title": "jq update contents of one file to another as key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527491473,
        "creation_date": 1527489658,
        "last_edit_date": 1527489884,
        "question_id": 50560499,
        "body_markdown": "I am trying to update branches.json.branch2 values from branch2.json.Employes values\r\nUsing jq, How can I merge content of one file to another file\r\nBelow are the files\r\n\r\nI have tried this but it did work, it just prints the original data without updating the details\r\n\r\n    #!/bin/sh\r\n    #call file with branch name for example ./update.sh branch2\r\n    set -xe\r\n    branchName=$1\r\n    fullPath=`pwd`/$1&quot;.json&quot;\r\n    list=$(cat ${fullPath})\r\n    branchDetails=$(echo ${list} | /usr/local/bin/jq -r &#39;.Employes&#39;)\r\n    newJson=$(cat branches.json | \r\n          jq --arg updateKey &quot;$1&quot; --arg updateValue &quot;$branchDetails&quot; &#39;to_entries | \r\n           map(if .key == &quot;$updateKey&quot;\r\n              then . + {&quot;value&quot;:&quot;$updateValue&quot;} \r\n              else . \r\n              end) | \r\n              from_entries&#39;)\r\n\r\necho $newJson &amp;&gt; results.json\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n**branch1.json**\r\n    \r\n\r\n    {\r\n      &quot;Employes&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Ikon&quot;,\r\n          &quot;age&quot;: &quot;30&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;Lenon&quot;,\r\n          &quot;age&quot;: &quot;35&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n**branch2.json**\r\n    \r\n\r\n    {\r\n      &quot;Employes&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Ken&quot;,\r\n          &quot;age&quot;: &quot;40&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;Frank&quot;,\r\n          &quot;age&quot;: &quot;23&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n**brances.json  / results.json fromat**\r\n    \r\n\r\n    {\r\n      &quot;branch1&quot;: [\r\n          {\r\n            &quot;Name&quot;: &quot;Ikon&quot;,\r\n            &quot;age&quot;: &quot;30&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Lenon&quot;,\r\n            &quot;age&quot;: &quot;35&quot;\r\n          }\r\n        ],\r\n      &quot;branch2&quot;: [\r\n          {\r\n            &quot;Name&quot;: &quot;Ken&quot;,\r\n            &quot;age&quot;: &quot;40&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Frank&quot;,\r\n            &quot;age&quot;: &quot;23&quot;\r\n          }\r\n        ]\r\n  }\r\n\r\n\r\nNote: I dont have the list of all the branch files at any given point, so script is responsible only to update the that branch details.",
        "link": "https://stackoverflow.com/questions/50560499/jq-update-contents-of-one-file-to-another-as-key-value",
        "title": "jq update contents of one file to another as key value"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1527504901,
                "post_id": 50562680,
                "comment_id": 88139584,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527587858,
                "last_edit_date": 1527587858,
                "creation_date": 1527538037,
                "answer_id": 50572883,
                "question_id": 50562680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To remove all elements from an array equal to a particular value, you could &quot;subtract&quot; the value(s) from the array:\r\n\r\n    . - [.[1]]\r\n\r\nOtherwise, the usual approach would be to rebuild and filter the array based on the conditions you want.\r\n\r\n    map(select(. != &quot;https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback&quot;))",
                "title": "Remove element from JSON Array based on string match in shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1528200877,
                "creation_date": 1528200877,
                "answer_id": 50699845,
                "question_id": 50562680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am able to make ti work using below method.\r\n\r\n**Find the index of valid string**\r\n\r\n    callback_url_index=$(echo $json_output | jq -r &#39;.UserPoolClient.CallbackURLs | index(&quot;https://test-jdtest.cmxdev.com?oauth=callback&quot;)&#39;);\r\n\r\n**Remove Element based on found index**\r\n\r\n    if [ &quot;$callback_url_index&quot; != null ] ; then\r\n      callbackURLs=$(echo $json_output | jq -r --arg callback_url_index &quot;$callback_url_index&quot; &#39;.UserPoolClient.CallbackURLs | del(.[&#39;$callback_url_index&#39;])&#39;)\r\n\r\nThanks!",
                "title": "Remove element from JSON Array based on string match in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -3,
        "last_activity_date": 1528200877,
        "creation_date": 1527498191,
        "last_edit_date": 1527498320,
        "question_id": 50562680,
        "body_markdown": "I want to remove JSON Element based on the string match if it exist.\r\n\r\nI am using the shell script. \r\n\r\nSample Input:\r\n\r\n    [&quot;https://test-ci.cmxdev.com/dev/AD-885/?oauth=callback&quot;,  \r\n    &quot;https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback&quot;,  \r\n    &quot;https://test-jdtest.cmxdev.com?oauth=callback&quot;,  \r\n    &quot;https://localhost:3000?oauth=callback&quot;]\r\n\r\nSample Output (Removed 2nd element):\r\n\r\n    [&quot;https://test-ci.cmxdev.com/dev/AD-885/?oauth=callback&quot;,   \r\n    &quot;https://test-jdtest.cmxdev.com?oauth=callback&quot;,  \r\n    &quot;https://localhost:3000?oauth=callback&quot;]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50562680/remove-element-from-json-array-based-on-string-match-in-shell-script",
        "title": "Remove element from JSON Array based on string match in shell script"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527520151,
                "post_id": 50569174,
                "comment_id": 88148319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2014876,
                    "reputation": 1159,
                    "user_id": 1802425,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://www.gravatar.com/avatar/7499715a96ce8bc0ba9c3e4586248f75?s=256&d=identicon&r=PG",
                    "display_name": "xaxa",
                    "link": "https://stackoverflow.com/users/1802425/xaxa"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527520418,
                "post_id": 50569174,
                "comment_id": 88148463,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1527525071,
                "creation_date": 1527525071,
                "answer_id": 50570439,
                "question_id": 50569174,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use the -s command-line option:\r\n\r\n    jq -s &#39;.[1].a as $a1 | .[0] | (.a += $a1)&#39;\r\n\r\nSince you don&#39;t care about the non-a keys, an alternative would be:\r\n\r\n    jq -n &#39;{a: (input.a + input.a)}&#39; \r\n\r\nNotice the `-n` option in the line above. \r\n\r\n\r\n",
                "title": "jq merge arrays inside object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1527563602,
        "creation_date": 1527519753,
        "question_id": 50569174,
        "body_markdown": "I have two objects\r\n\r\n    {\r\n        &quot;a&quot;: [\r\n            &quot;1-1&quot;,\r\n            &quot;1-2&quot;\r\n        ],\r\n        ...\r\n    }\r\n\r\nand \r\n\r\n    { \r\n        &quot;a&quot;: [\r\n            &quot;2-1&quot;,\r\n            &quot;2-2&quot;,\r\n            &quot;2-3&quot;\r\n        ],\r\n        ...\r\n    }\r\n\r\nthere are other keys in both objects, but I don&#39;t care for them.\r\n\r\nWhat I want to get is the object where elements of `&quot;a&quot;` will be concatenated:\r\n\r\n    {\r\n        &quot;a&quot;: [\r\n            &quot;1-1&quot;,\r\n            &quot;1-2&quot;,\r\n            &quot;2-1&quot;,\r\n            &quot;2-2&quot;,\r\n            &quot;2-3&quot;\r\n        ],\r\n        ...\r\n    }\r\n\r\nother keys can be replaced/merged/doesn&#39;t matter.\r\n\r\nHow do I do this with `jq`?",
        "link": "https://stackoverflow.com/questions/50569174/jq-merge-arrays-inside-object",
        "title": "jq merge arrays inside object"
    },
    {
        "tags": [
            "bash",
            "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": 3,
                "creation_date": 1527537993,
                "post_id": 50572809,
                "comment_id": 88155281,
                "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": 1527538096,
                "post_id": 50572809,
                "comment_id": 88155316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4691303,
                    "reputation": 1897,
                    "user_id": 3797368,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/bac302417634c1c917911bc208b22573?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MUHAHA",
                    "link": "https://stackoverflow.com/users/3797368/muhaha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527538414,
                "post_id": 50572809,
                "comment_id": 88155420,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527538679,
                "post_id": 50572809,
                "comment_id": 88155520,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4691303,
                    "reputation": 1897,
                    "user_id": 3797368,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/bac302417634c1c917911bc208b22573?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MUHAHA",
                    "link": "https://stackoverflow.com/users/3797368/muhaha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1527538846,
                "post_id": 50572809,
                "comment_id": 88155574,
                "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": 1527539692,
                "post_id": 50572809,
                "comment_id": 88155831,
                "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": 1527540491,
                "post_id": 50572809,
                "comment_id": 88156070,
                "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": 1527540517,
                "post_id": 50572809,
                "comment_id": 88156075,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1527540196,
                "last_edit_date": 1527540196,
                "creation_date": 1527539621,
                "answer_id": 50573141,
                "question_id": 50572809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    #!/bin/bash\r\n    \r\n    list=( http://RESTURL1 http://RESTURL2 )\r\n    \r\n    declare -A hypothetical_data=(\r\n        [http://RESTURL1]=&#39;{&quot;foo&quot;:&quot;Tiger Nixon&quot;,&quot;bar&quot;:&quot;Edinburgh&quot;}&#39;\r\n        [http://RESTURL2]=&#39;{&quot;foo&quot;:&quot;Garrett Winters&quot;,&quot;bar&quot;:&quot;Tokyo&quot;}&#39;\r\n    )\r\n    \r\n    # create the seed file\r\n    result=&quot;result.json&quot;\r\n    echo &#39;{&quot;data&quot;:[]}&#39; &gt; &quot;$result&quot;\r\n        \r\n    for url in &quot;${list[@]}&quot;; do\r\n        # fetch the data.\r\n        json=${hypothetical_data[$url]}\r\n        # would really do: json=$(curl &quot;$url&quot;)\r\n    \r\n        # extract the name (&quot;foo&quot;) and location (&quot;bar&quot;) values\r\n        name=$( jq -r &#39;.foo&#39; &lt;&lt;&lt;&quot;$json&quot; )\r\n        location=$( jq -r &#39;.bar&#39; &lt;&lt;&lt;&quot;$json&quot; )\r\n    \r\n        jq --arg name &quot;$name&quot; \\\r\n           --arg loc &quot;$location&quot; \\\r\n             &#39;.data += [[$name, $loc]]&#39; &quot;$result&quot; | sponge &quot;$result&quot;\r\n    \r\n        # &quot;sponge&quot; is in the &quot;moreutils&quot; package that you may have to install. \r\n        # You can also write that line as:\r\n        #\r\n        # tmp=$(mktemp)\r\n        # jq --arg name &quot;$name&quot; \\\r\n        #    --arg loc &quot;$location&quot; \\\r\n        #      &#39;.data += [[$name, $loc]]&#39; &quot;$result&quot; &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; &quot;$result&quot;\r\n        #                                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\r\n    done\r\n\r\nEnd result:\r\n\r\n    $ cat result.json\r\n    {\r\n      &quot;data&quot;: [\r\n        [\r\n          &quot;Tiger Nixon&quot;,\r\n          &quot;Edinburgh&quot;\r\n        ],\r\n        [\r\n          &quot;Garrett Winters&quot;,\r\n          &quot;Tokyo&quot;\r\n        ]\r\n      ]\r\n    }\r\n\r\n",
                "title": "jq create array and append entry to it"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527539949,
                "last_edit_date": 1527539949,
                "creation_date": 1527539672,
                "answer_id": 50573148,
                "question_id": 50572809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you really need to _write_ the file using jq?\r\n\r\n    list=( http://RESTURL1 http://RESTURL2 )\r\n\r\n    exec &gt; result.json    \r\n\r\n    echo &#39;[&#39;\r\n    \r\n    for p in &quot;${list[@]}&quot;\r\n        data=$(curl &quot;$p&quot;)\r\n        echo &quot;  $(jq -c &#39;[.foo, .bar]&#39; &lt;&lt;&lt; &quot;$data&quot;),&quot;\r\n    done\r\n\r\n    echo &#39;]&#39;",
                "title": "jq create array and append entry to it"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1527540747,
                "last_edit_date": 1527540747,
                "creation_date": 1527540219,
                "answer_id": 50573235,
                "question_id": 50572809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Reusing Glenn&#39;s test framework, but calling `jq` only once for the entire script:\r\n\r\n    list=( http://RESTURL1 http://RESTURL2 )\r\n    \r\n    declare -A hypothetical_data=(\r\n        [http://RESTURL1]=&#39;{&quot;foo&quot;:&quot;Tiger Nixon&quot;,&quot;bar&quot;:&quot;Edinburgh&quot;}&#39;\r\n        [http://RESTURL2]=&#39;{&quot;foo&quot;:&quot;Garrett Winters&quot;,&quot;bar&quot;:&quot;Tokyo&quot;}&#39;\r\n    )\r\n\r\n    for url in &quot;${list[@]}&quot;; do\r\n      echo &quot;${hypothetical_data[$url]}&quot;  # or curl &quot;$url&quot;\r\n    done | jq -n &#39;{&quot;data&quot;: [inputs | [.foo, .bar]]}&#39;\r\n",
                "title": "jq create array and append entry to it"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1527540747,
        "creation_date": 1527537524,
        "last_edit_date": 1527540326,
        "question_id": 50572809,
        "body_markdown": "I want to produce json file with structure like this:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        [\r\n          &quot;Tiger Nixon&quot;,\r\n          &quot;Edinburgh&quot;\r\n        ],\r\n        [\r\n          &quot;Garrett Winters&quot;,\r\n          &quot;Tokyo&quot;\r\n        ]\r\n      ]\r\n    }\r\n\r\n\r\nHere is my bash script:\r\n\r\n    list=( http://RESTURL1 http://RESTURL2 )\r\n    \r\n    jq -n .data[] &gt; result.json ## -&gt; (create empty array data)\r\n    \r\n    for p in $list\r\n    \r\n    VAR1=$(curl $p | jq -r .foo ) ## -&gt; (Tiger Nixon)\r\n    VAR2=$(curl $p | jq -r .bar ) ## -&gt; (Edinburgh)\r\n    \r\n    cat result.json | jq -n --arg a &quot;$VAR1&quot; --arg b &quot;$VAR2&quot;  .data[&quot;$a&quot;,&quot;$b&quot;] &gt;&gt; results.json ## -&gt; (add Tiger Nixon and Edinburgh to .data array)\r\n    \r\n    done\r\n\r\nScript is selfexplaining. Except jq part. I dont know how to handle jq to create json file.\r\n\r\nBasically I want to iterate over list of urls, populate 2 variables and push it to results.json file as entry/per iteration.\r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50572809/jq-create-array-and-append-entry-to-it",
        "title": "jq create array and append entry to it"
    },
    {
        "tags": [
            "linux",
            "permissions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1527636493,
                "post_id": 50594275,
                "comment_id": 88197844,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1527636872,
                "creation_date": 1527636872,
                "answer_id": 50594398,
                "question_id": 50594275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simple fix, just gave user permissions on directory.\r\n\r\nsudo chmod -R 777 /etc/zeppelin/conf",
                "title": "sudo jq query permission denied"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527636872,
        "creation_date": 1527635822,
        "question_id": 50594275,
        "body_markdown": "Im trying to use jq to alter a json file via a script.\r\n\r\nin my terminal im trying to run this, but getting a permission denied error. Im able to change it using a sudo nano manually.\r\n\r\n    sudo jq -c  &#39;.interpreterSettings.&quot;2ANGGHHMQ&quot;.&quot;properties&quot;.&quot;zeppelin.pyspark.python&quot; = &quot;python3&quot;&#39; interpreter.json &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json interpreter.json\r\n\r\n\r\nAny ideas on why?\r\n\r\nThanks,\r\nTim\r\n",
        "link": "https://stackoverflow.com/questions/50594275/sudo-jq-query-permission-denied",
        "title": "sudo jq query permission denied"
    },
    {
        "tags": [
            "json",
            "object",
            "transformation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1527684943,
                "post_id": 50604423,
                "comment_id": 88219871,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527694912,
                "creation_date": 1527694912,
                "answer_id": 50608744,
                "question_id": 50604423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON, and that it is acceptable to apply the transformation wherever it is possible, I’d use `walk`, for simplicity:\r\n\r\n    walk( if type == &quot;object&quot; and has(&quot;b&quot;)\r\n          then .e = .b | del(.b)\r\n          else . end )\r\n\r\nYou might want to check for the existence of .e as well to avoid clobbering it.\r\n\r\nIf your jq does not have `walk` then simply insert its def before the above; for the definition, simply google for: jq “def walk”",
                "title": "How to move element to (new) child?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1527808192,
        "creation_date": 1527682405,
        "last_edit_date": 1527808192,
        "question_id": 50604423,
        "body_markdown": "Consider this document:\r\n\r\n    {&quot;x&quot;: [\r\n        {\r\n\t\t\t&quot;a&quot;: {\r\n\t\t\t\t&quot;b&quot;: [],\r\n\t\t\t\t&quot;c&quot;: 42\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;a&quot;: {\r\n\t\t\t\t&quot;d&quot;: true\r\n\t\t\t}\r\n\t\t}\r\n\t]}\r\n\r\nBut now I need to move all `b`s (that need not exist!) one level down like this:\r\n\r\n    {&quot;x&quot;: [\r\n        {\r\n\t\t\t&quot;a&quot;: {\r\n\t\t\t\t&quot;e&quot;: {\r\n\t\t\t\t\t&quot;b&quot;: []\r\n\t\t\t\t},\r\n\t\t\t\t&quot;c&quot;: 42\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;a&quot;: {\r\n\t\t\t\t&quot;d&quot;: true\r\n\t\t\t}\r\n\t\t}\r\n\t]}\r\n\r\nI&#39;ve seen [the example that does the opposite][1] but I haven&#39;t been able to apply that to my case unfortunately.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/42214984/jq-how-to-move-the-child-members-to-parent",
        "link": "https://stackoverflow.com/questions/50604423/how-to-move-element-to-new-child",
        "title": "How to move element to (new) child?"
    },
    {
        "tags": [
            "json",
            "slice",
            "jq",
            "data-extraction",
            "json-path-expression"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1527747881,
                "last_edit_date": 1527747881,
                "creation_date": 1527732115,
                "answer_id": 50615621,
                "question_id": 50615080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If $paths contains an array of explicit jq paths (such as `[ [&quot;turtles&quot;, 0, &quot;name&quot;], [&quot;cast&quot;]])`, the simplest approach would be to\r\nuse the following filter:\r\n\r\n    . as $in\r\n    | reduce $paths[] as $p (null; setpath($p; $in | getpath($p)))\r\n\r\n## Extended path expressions\r\n\r\nIn order to be able to handle extended path expressions such as [&quot;turtles&quot;, [], &quot;name&quot;], where `[]` is intended to range over the indices of the `turtles` array, we shall define the following helper function:\r\n\r\n    def xpath($ary):\r\n      . as $in\r\n      | if ($ary|length) == 0 then null\r\n        else $ary[0] as $k\r\n        | if $k == []\r\n          then range(0;length) as $i | $in[$i] | xpath($ary[1:]) | [$i] + .\r\n          else .[$k] | xpath($ary[1:]) | [$k] + . \r\n          end\r\n        end\t;\r\n\r\nFor the sake of exposition, let us also define:\r\n\r\n    def paths($ary): $ary[] as $path | xpath($path);\r\n\r\nThen with the given input, the expression:\r\n\r\n    . as $in\r\n    | reduce paths([ [&quot;turtles&quot;, [], &quot;name&quot;], [&quot;cast&quot;]]) as $p \r\n        (null; setpath($p; $in | getpath($p)) )\r\n\r\nproduces the output shown below.\r\n## Using `path`\r\n\r\nIt is worth point out that one way to handle expressions such as &quot;.turtles[].name&quot; would be to use the builtin filter `path/1`.\r\n\r\nFor example:\r\n\r\n    # Emit a stream of paths:\r\n    def paths: path(.turtles[].name), [&quot;cast&quot;];\r\n    \r\n    . as $in\r\n    | reduce paths as $p (null; setpath($p; $in | getpath($p)))\r\n\r\n## Output:\r\n\r\n    {\r\n      &quot;turtles&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Leonardo&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Michelangelo&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Donatello&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Raphael&quot;\r\n        }\r\n      ],\r\n      &quot;cast&quot;: &quot;Megan Fox, Will Arnett, Tyler Perry&quot;\r\n    }\r\n\r\n",
                "title": "How to filter out a JSON based on list of paths in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528133483,
        "creation_date": 1527726715,
        "last_edit_date": 1528133483,
        "question_id": 50615080,
        "body_markdown": "Given an **arbitrary** JSON input:\r\n\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {  \r\n       &quot;id&quot;:&quot;038020&quot;,\r\n       &quot;title&quot;:&quot;Teenage Mutant Ninja Turtles: Out of the Shadows&quot;,\r\n       &quot;turtles&quot;:[  \r\n          {  \r\n             &quot;name&quot;:&quot;Leonardo&quot;,\r\n             &quot;mask&quot;:&quot;blue&quot;\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;Michelangelo&quot;,\r\n             &quot;mask&quot;:&quot;orange&quot;\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;Donatello&quot;,\r\n             &quot;mask&quot;:&quot;purple&quot;\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;Raphael&quot;,\r\n             &quot;mask&quot;:&quot;red&quot;\r\n          }\r\n       ],\r\n       &quot;summary&quot;:&quot;The Turtles continue to live in the shadows and no one knows they were the ones who took down Shredder&quot;,\r\n       &quot;cast&quot;:&quot;Megan Fox, Will Arnett, Tyler Perry&quot;,\r\n       &quot;director&quot;:&quot;Dave Green&quot;\r\n    }\r\n\r\n\r\nAnd an **arbitrary** list of JQ paths like `[&quot;.turtles[].name&quot;, &quot;.cast&quot;, &quot;.does.not.exist&quot;]`, or any similar format\r\n\r\nHow can I create new JSON with only the information contained in the paths of the list?\r\nIn this case the expected result would be:\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {  \r\n       &quot;turtles&quot;:[  \r\n          {  \r\n             &quot;name&quot;:&quot;Leonardo&quot;\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;Michelangelo&quot;\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;Donatello&quot;\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;Raphael&quot;\r\n          }\r\n       ],\r\n       &quot;cast&quot;:&quot;Megan Fox, Will Arnett, Tyler Perry&quot;\r\n    }\r\n\r\nI&#39;ve seen similar solutions in problems like [&quot;removing `null` entries&quot;][1] from a JSON using the [**walk** function present in jq1.5+][2], somewhat along the lines of:\r\n\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    def filter_list(input, list):\r\n     input\r\n     | walk(  \r\n         if type == &quot;object&quot; then\r\n           with_entries( select(.key | IN( list )))\r\n         else\r\n           .\r\n         end); \r\n\r\n    filter_list([.], [.a, .b, .c[].d])\r\n\r\nBut it should take in account the full path in the JSON somehow.\r\n\r\nWhat is the best approach to solve this problem?\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/104\r\n  [2]: https://github.com/stedolan/jq/issues/963",
        "link": "https://stackoverflow.com/questions/50615080/how-to-filter-out-a-json-based-on-list-of-paths-in-jq",
        "title": "How to filter out a JSON based on list of paths in JQ"
    },
    {
        "tags": [
            "json",
            "csv",
            "parsing",
            "converters",
            "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": 3,
                "creation_date": 1527760575,
                "post_id": 50621507,
                "comment_id": 88252680,
                "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": 3,
                "creation_date": 1527770887,
                "post_id": 50621507,
                "comment_id": 88259262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1527760496,
        "creation_date": 1527760496,
        "question_id": 50621507,
        "body_markdown": "I have a file output called file.json. I need to convert this file to a .csv file for better viewing since this is the output of AQL. \n\n    {\n    “results” : [{\n       “file” : ”abc-trip-typ”\n       “path” : “pit/pop/tracker”\n       “type” :  “file”\n       “created” : “2018–05-05:09:00”\n       “properties” : [ {\n            “tracker” :  “file.name”,\n            “value” : “PRN_TY.0.0”\n     },  {\n       “tracker” :  “file.number”\n       “value” : “9”\n     }  ], \n    “stats” : [  {\n        “downloaded” : “2018-05-05:10:00”,\n        “downloads” : 10\n     }  ]\n    }\n\nThere are multiple such fields with same parameters which I need to convert to a CSV format i.e in a .csv file. Would appreciate any sorts of leads for the same. ",
        "link": "https://stackoverflow.com/questions/50621507/convert-json-to-csv-using-jq",
        "title": "Convert JSON to CSV using JQ"
    },
    {
        "tags": [
            "json",
            "csv",
            "parsing",
            "jq",
            "data-extraction"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1527780892,
                "creation_date": 1527780892,
                "answer_id": 50627973,
                "question_id": 50627757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.results[] | .name as $n | .indicators[] | [$n, .type, .indicator] | @csv&#39; file.json\r\n\r\nThe output:\r\n\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/ara.exe&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/ark.exe&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;FileHash-SHA256&quot;,&quot;c9a834dde38c8b559d575ac61046e3a3fada97d2953d902b74cf8d5e51ada30f&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;domain&quot;,&quot;nctrnl.us&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;FileHash-SHA256&quot;,&quot;205def439aeb685d5a9123613e49f59d4cd5ebab9e933a1567a2f2972bda18c3&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;FileHash-SHA256&quot;,&quot;ae7e5a7b34dc216e9da384fcf9868ab2c1a1d731f583f893b2d2d4009da15a4e&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/server/gate.php&quot;\r\n\r\n",
                "title": "How to Extract Data from Arrays Within Arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527800614,
                "last_edit_date": 1527800614,
                "creation_date": 1527781108,
                "answer_id": 50628035,
                "question_id": 50627757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`[.name]` is an array, and so when you pipe it into `.indicators`, you get the error message:\r\n\r\n&gt; Cannot index array with string &quot;indicators&quot;\r\n\r\nThis variation of your query is probably what you intended:\r\n\r\n    .results[]\r\n    | .name as $name \r\n    | .indicators[]\r\n    | [$name, .type, .indicator] | @csv\r\n\r\nThis includes the relevant `.name` on each line:\r\n\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/ara.exe&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/ark.exe&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;FileHash-SHA256&quot;,&quot;c9a834dde38c8b559d575ac61046e3a3fada97d2953d902b74cf8d5e51ada30f&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;domain&quot;,&quot;nctrnl.us&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;FileHash-SHA256&quot;,&quot;205def439aeb685d5a9123613e49f59d4cd5ebab9e933a1567a2f2972bda18c3&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;FileHash-SHA256&quot;,&quot;ae7e5a7b34dc216e9da384fcf9868ab2c1a1d731f583f893b2d2d4009da15a4e&quot;\r\n    &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;,&quot;URL&quot;,&quot;http://nctrnl.us/server/gate.php&quot;",
                "title": "How to Extract Data from Arrays Within Arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527800513,
                "creation_date": 1527800513,
                "answer_id": 50632733,
                "question_id": 50627757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many ways this could be achieved. When grabbing values from child arrays to generate values, I like using `foreach` for this purpose.\r\n\r\n    $ jq -r &#39;.results[] | foreach .indicators[] as $i ({name}; .;\r\n        [.name,$i.type,$i.indicator]\r\n    ) | @csv&#39;",
                "title": "How to Extract Data from Arrays Within Arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1527800614,
        "creation_date": 1527780135,
        "last_edit_date": 1527799913,
        "question_id": 50627757,
        "body_markdown": "I have the JSON:\r\n\r\n    {\r\n      &quot;count&quot;: 6918,\r\n      &quot;next&quot;: &quot;https://otx.alienvault.com/api/v1/pulses/subscribed?limit=50&amp;page=2&quot;,\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;industries&quot;: [],\r\n          &quot;tlp&quot;: &quot;white&quot;,\r\n          &quot;description&quot;: &quot;With the massive ransomware campaigns of 2016 and 2017 taking a backseat to bankers and other malware families, information stealers made up 18% of malicious email payloads in the first part of this year. Proofpoint researchers recently discovered a new stealer, dubbed “Nocturnal Stealer,” most notable as an example of inexpensive commodity malware with significant potential for monetization.\\n\\nOn March 9, a user posted an advertisement for Nocturnal Stealer on an underground forum. The stealer sold for 1500 Rubles, or roughly US$25 at the time of analysis. Nocturnal Stealer is designed to steal the data found within multiple Chromium and Firefox based browsers. It can also steal many popular cryptocurrency wallets as well as any saved FTP passwords within FileZilla. Proofpoint researchers analyzed a sample being dropped in the wild by an unknown loader.&quot;,\r\n          &quot;created&quot;: &quot;2018-05-31T12:25:14.636000&quot;,\r\n          &quot;tags&quot;: [],\r\n          &quot;modified&quot;: &quot;2018-05-31T12:25:14.636000&quot;,\r\n          &quot;author_name&quot;: &quot;AlienVault&quot;,\r\n          &quot;public&quot;: 1,\r\n          &quot;extract_source&quot;: [],\r\n          &quot;references&quot;: [\r\n            &quot;https://www.proofpoint.com/us/threat-insight/post/thief-night-new-nocturnal-stealer-grabs-data-cheap&quot;\r\n          ],\r\n          &quot;targeted_countries&quot;: [],\r\n          &quot;indicators&quot;: [\r\n            {\r\n              &quot;indicator&quot;: &quot;http://nctrnl.us/&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;URL&quot;,\r\n              &quot;id&quot;: 981584318\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;http://nctrnl.us/ara.exe&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;URL&quot;,\r\n              &quot;id&quot;: 981584319\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;http://nctrnl.us/ark.exe&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;URL&quot;,\r\n              &quot;id&quot;: 981584320\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;c9a834dde38c8b559d575ac61046e3a3fada97d2953d902b74cf8d5e51ada30f&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;FileHash-SHA256&quot;,\r\n              &quot;id&quot;: 981584321\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;nctrnl.us&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;domain&quot;,\r\n              &quot;id&quot;: 981584322\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;205def439aeb685d5a9123613e49f59d4cd5ebab9e933a1567a2f2972bda18c3&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;FileHash-SHA256&quot;,\r\n              &quot;id&quot;: 981584323\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;ae7e5a7b34dc216e9da384fcf9868ab2c1a1d731f583f893b2d2d4009da15a4e&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;FileHash-SHA256&quot;,\r\n              &quot;id&quot;: 981584324\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;http://nctrnl.us/server/gate.php&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-05-31T12:25:16&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;URL&quot;,\r\n              &quot;id&quot;: 981584325\r\n            }\r\n          ],\r\n          &quot;more_indicators&quot;: false,\r\n          &quot;revision&quot;: 1,\r\n          &quot;adversary&quot;: &quot;&quot;,\r\n          &quot;id&quot;: &quot;5b0fe9aa8bc6a5498565929a&quot;,\r\n          &quot;name&quot;: &quot;Thief in the night: New Nocturnal Stealer grabs data on the cheap&quot;\r\n        },\r\n        ...\r\n      ]\r\n    }\r\n\r\nThe main array is `results` and I would like to pull the field `name` and then the fields `indicator` and `type` from the `indicators` array.\r\n\r\nI have used the JQ command:\r\n\r\n    $ jq -r &#39;.results[] | [.name] | .indicators[] | [.type, .indicator] | @csv&#39; \\\r\n        &lt; /home/threat-intel/ThreatIntel/AV.json \\\r\n        &gt;&gt; /home/threat-intel/ThreatIntel/AV.csv\r\n\r\nThe command fails saying:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;indicators&quot;\r\n\r\nHow would I pull the `name` field and assign it to each `indicator` in that specific array?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50627757/how-to-extract-data-from-arrays-within-arrays",
        "title": "How to Extract Data from Arrays Within Arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "response",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1527872572,
                "creation_date": 1527872572,
                "answer_id": 50648088,
                "question_id": 50647869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know that the responses are going to be of a specific type (an object vs an array), you could just test for that type.\r\n\r\n    $ &lt;&lt;&lt;&quot;$json&quot; jq &#39;arrays&#39;  # &quot;good&quot; response\r\n    $ &lt;&lt;&lt;&quot;$json&quot; jq &#39;objects&#39; # &quot;bad&quot; response\r\n\r\nYou could add additional checks as needed.",
                "title": "Check if response has error"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527877209,
                "creation_date": 1527877209,
                "answer_id": 50649061,
                "question_id": 50647869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should consider calling jq just once, along the lines:\r\n\r\n     if type == &quot;object&quot; \r\n     then ...\r\n     else ...\r\n     end\r\n\r\n",
                "title": "Check if response has error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1527877209,
        "creation_date": 1527871628,
        "last_edit_date": 1527872005,
        "question_id": 50647869,
        "body_markdown": "I have some web API, which response with JSON, and a shell script, which sends requests with curl and processing JSON with jq.\r\n\r\nResponse structure is the following:\r\n\r\n - Error response: `{ &quot;error&quot;: &quot;error_message&quot; }` - single struct.\r\n - Good response: `[ { &quot;element1&quot;: &quot;value1&quot;, &quot;element2&quot;: &quot;value2&quot;, &quot;element3&quot;: &quot;value3&quot; } ]` - array of structs of 3 elements (fixed amount).\r\n\r\nThe problem is that user may enter some data causing API response with the error. In this case, I won&#39;t be able to process the response as there is another structure. \r\n\r\nI was trying to check if it&#39;s an error  with `echo ${json} | jq &#39;. | select (.| has(&quot;error&quot;)) | has(&quot;error&quot;)&#39;`, but this works only if it&#39;s an error response, if it&#39;s a &quot;good&quot; one - jq fails.\r\n\r\nWhat should I do?",
        "link": "https://stackoverflow.com/questions/50647869/check-if-response-has-error",
        "title": "Check if response has error"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1527879515,
                "creation_date": 1527879515,
                "answer_id": 50649586,
                "question_id": 50649235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The pedestrian way:\r\n\r\n    .[] | .[] | .age\r\n\r\nThe briefer way:\r\n\r\n    .[][].age\r\n\r\nAnother possibility to consider (it has different semantics) would be:\r\n\r\n     .. | .age?\r\n\r\n",
                "title": "Extract values from a json enclosed between [[ ]] array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1527879515,
        "creation_date": 1527877952,
        "question_id": 50649235,
        "body_markdown": "Can someone help me extract values from json like below:\r\n\r\n    [\r\n        [\r\n            {\r\n                &quot;name&quot;: &quot;x&quot;, \r\n                &quot;age&quot;: &quot;y&quot;, \r\n                &quot;class&quot;: &quot;z&quot;\r\n            }\r\n        ]\r\n    ]\r\nI would like to extract `age` from the above json using `jq`",
        "link": "https://stackoverflow.com/questions/50649235/extract-values-from-a-json-enclosed-between-array",
        "title": "Extract values from a json enclosed between [[ ]] array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "curl",
            "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": 1527884608,
                "post_id": 50649937,
                "comment_id": 88311952,
                "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": 1527902611,
                "post_id": 50649937,
                "comment_id": 88316086,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1527951000,
                "last_edit_date": 1527951000,
                "creation_date": 1527882560,
                "answer_id": 50650179,
                "question_id": 50649937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to do two things: one, use the `-s` option so that each separate object becomes an element of a single array. Two, you are trying to index the `Name`, instead of accessing the `Name` attribute of an array element.\r\n\r\n    $ jq -sr &#39;.[].Name&#39; tmp.json\r\n    testuser1\r\n    testuser2\r\n\r\nIf you wanted to refer to a specific element of the stream, you could:\r\n\r\n    $ jq -sr &#39;.[1].Name&#39; tmp.json\r\n    testuser2\r\n\r\nWith that (and assuming none of your names will contain newlines), a proper loop would look like\r\n\r\n    while IFS= read -r name; do\r\n        ...\r\n    done &lt; &lt;(jq -sr &#39;.[].Name&#39; tmp.json)",
                "title": "return specific items in json object using bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527884534,
                "creation_date": 1527884534,
                "answer_id": 50650540,
                "question_id": 50649937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To select only the first name, you need to do the indexing **before** trying to go into the `Name` element:\r\n\r\n    jq -rs &#39;.[0].Name&#39;\r\n\r\nBy contrast, for a loop, the `while read` approach [given by @chepner&#39;s answer](https://stackoverflow.com/a/50650179/14122) is indeed appropriate.",
                "title": "return specific items in json object using bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527959564,
                "last_edit_date": 1527959564,
                "creation_date": 1527932198,
                "answer_id": 50655485,
                "question_id": 50649937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is stream-oriented, so if you want to perform some operation on each object, then it might be sufficient to define that operation in jq, and let jq handle the stream without further ado.\r\n\r\nIf for some reason you need the index of each item in the stream, then you can avoid the `-s` option if your jq has `inputs` (as does jq 1.5).\r\n(Avoiding the `-s` option saves memory.)\r\n\r\nThe following assumes that your jq does have `inputs`; that indexing is 0-based; and that jq is invoked with the -n option.\r\n\r\n## Generating an index\r\n\r\n    foreach inputs as $input (-1; .+1; [., $input])\r\n\r\nThis will produce a stream of [INDEX, ITEM] arrays. You can then tack on further jq filters using jq&#39;s pipe operator (`|`).\r\n\r\n\r\n## Selecting the i-th item from a stream of JSON entities.\r\n\r\nFor the sake of illustrating a suitable method for invoking jq, let&#39;s suppose the stream of JSON entities comes from `curl COMMAND`, and that we want the second item (that is, with index 1).\r\n\r\n### Invocation\r\n\r\n    curl COMMAND | jq --argjson i 1 -n -f program.jq\r\n\r\n(Note the `-n` command-line option!)\r\n\r\n### program.jq\r\n\r\n    def get($i):\r\n      label $done\r\n      | foreach inputs as $input (-1; .+1;\r\n          if $i == . then $input, break $done else empty end);\r\n    \r\n    get($i)\r\n\r\n",
                "title": "return specific items in json object using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1527959564,
        "creation_date": 1527881286,
        "last_edit_date": 1527881673,
        "question_id": 50649937,
        "body_markdown": "I&#39;m trying to take a json response (from a curl command and jq installed on my linux comp) with multiple objects, and edit each one with a for loop. The problem is I don&#39;t understand how to take each {} and convert them into separate objects. For example, my json response is:\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;testuser1&quot;,\r\n      &quot;Username&quot;: &quot;testuser1&quot;,\r\n      &quot;Url&quot;: &quot;www.test1.com&quot;\r\n    }\r\n    {\r\n      &quot;Name&quot;: &quot;testuser2&quot;,\r\n      &quot;Username&quot;: &quot;testuser2&quot;,\r\n      &quot;Url&quot;: &quot;www.test2.com&quot;\r\n    }\r\n\r\nIdeally, I want to refer to each by a number. For example &quot;echo $item | jq &#39;.Name[0]&#39;&quot; for the \r\n\r\n    {\r\n      &quot;Name&quot;: &quot;testuser1&quot;,\r\n      &quot;Username&quot;: &quot;testuser1&quot;,\r\n      &quot;Url&quot;: &quot;www.test1.com&quot;\r\n    }\r\n\r\nWhen I run the command above i get the following error.\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with number\r\n\r\nI would like to run a forloop for each object.",
        "link": "https://stackoverflow.com/questions/50649937/return-specific-items-in-json-object-using-bash",
        "title": "return specific items in json object using bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1527961638,
                "last_edit_date": 1527961638,
                "creation_date": 1527960329,
                "answer_id": 50659425,
                "question_id": 50659384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    id=$(jq -r &#39;.result.id&#39; id.txt)\r\n\r\nOutput to variable `id`:\r\n&lt;pre&gt;\r\nf34fdasdfaa4364adc42b3a57\r\n&lt;/pre&gt;",
                "title": "extract value from json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1527982954,
        "creation_date": 1527960062,
        "last_edit_date": 1527982954,
        "question_id": 50659384,
        "body_markdown": "I have a file outputted from an API, it contains a JSON.\r\n\r\n    {\r\n    \t&quot;result&quot;: {\r\n    \t\t&quot;id&quot;: &quot;f34fdasdfaa4364adc42b3a57&quot;,\r\n    \t\t&quot;modified_on&quot;: &quot;2018-06-02T17:08:17.106435Z&quot;\r\n    \t},\r\n    \t&quot;success&quot;: true\r\n    }\r\n\r\nI need only the value of id (in my case the f34fdasdfaa4364adc42b3a57)\r\n\r\nI would do in bash:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    #Pseudocode\r\n    id=$(grep -Po &#39;&quot;id&quot;:.*?[^\\\\]&quot;,&#39; id.txt)\r\n    # /Pseudocode\r\n    curl -X DELETE &quot;https://www.example.com/delete/$id&quot;\r\n\r\nI did look for previous answer and got this: https://stackoverflow.com/questions/1955505/parsing-json-with-unix-tools\r\n\r\nBut the right answer extract key and value, I would only value (to no manipulate string anymore)\r\n\r\nThank you for your help",
        "link": "https://stackoverflow.com/questions/50659384/extract-value-from-json-file",
        "title": "extract value from json file"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1528121921,
                "post_id": 50678440,
                "comment_id": 88375024,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8862862,
                    "reputation": 2611,
                    "user_id": 6618742,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BlMRi.png?s=256",
                    "display_name": "djuarezg",
                    "link": "https://stackoverflow.com/users/6618742/djuarezg"
                },
                "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": 1528122781,
                "post_id": 50678440,
                "comment_id": 88375610,
                "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": 1528135490,
                "post_id": 50678440,
                "comment_id": 88382378,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1528131698,
                "last_edit_date": 1528131698,
                "creation_date": 1528131006,
                "answer_id": 50685321,
                "question_id": 50678440,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The illustrative output is invalid as JSON and has objects with repeated keys, which is probably not what you actually want, but the following jq program will produce output that is in accordance with the general problem description.  Since you do not seem to have specified the precise grouping criterion, I have taken the error message text after the last &quot;:&quot; as the grouping criterion.  (If, for example, you wanted to consider the text after the first &quot;:&quot;, use &quot;^[^:]*: *&quot; as the regex.)\r\n\r\nThe first step gathers the `.failed_projects` together and applies `to_entries` so that we can readily access the ID and error message text:\r\n\r\n    [.[] | .failed_projects | to_entries[]]\r\n\r\nNext we extract the grouping criterion, and use it to form the groups:\r\n\r\n    | map(.value |= sub(&quot;^.*: *&quot;;&quot;&quot;))\r\n    | group_by(.value)\r\n\r\n\r\nFinally, we transform the groups into JSON objects of the form:\r\n{GROUP: ARRAY_OF_IDs}:\r\n\r\n    | map( .[0].value as $key\r\n           | [.[] | .key] as $value\r\n           | {($key): $value} )\r\n\r\nPutting the above fragments together in a file, program.jq, and using the invocation:\r\n\r\n    jq -f program.jq input.json\r\n\r\nyields the output shown below.  You will evidently want to modify the grouping criterion.  You might also wish to convert the ID strings to JSON numbers, which can be done by `tonumber` or more cautiously\r\n by `(tonumber? // .)`.\r\n\r\nTo understand program.jq, you might like to start with the first fragment, and then add each of the others in turn.  \r\n\r\n## Output\r\n\r\n    [\r\n      {\r\n        &quot;Deadline Exceeded, trace&quot;: [\r\n          &quot;1082&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;TimeoutError)&quot;: [\r\n          &quot;6728&quot;,\r\n          &quot;6747&quot;,\r\n          &quot;6939&quot;,\r\n          &quot;5570&quot;,\r\n          &quot;6103&quot;,\r\n          &quot;6188&quot;,\r\n          &quot;6695&quot;,\r\n          &quot;6721&quot;,\r\n          &quot;2492&quot;,\r\n          &quot;6760&quot;,\r\n          &quot;3060&quot;,\r\n          &quot;6941&quot;,\r\n          &quot;6942&quot;,\r\n          &quot;6947&quot;,\r\n          &quot;7787&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;in `__raise_transport_error&#39;&quot;: [\r\n          &quot;1273&quot;,\r\n          &quot;7201&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;in `run_indexer!&#39;\\&quot;&quot;: [\r\n          &quot;7707&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\n",
                "title": "Getting all results on the same array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528131940,
        "creation_date": 1528107985,
        "last_edit_date": 1528131940,
        "question_id": 50678440,
        "body_markdown": "I have been struggling with these for hours and I am pretty sure there is something I am missing.\r\n\r\nGiven this JSON:\r\n\r\n    [\r\n    {\r\n      &quot;LAST_JOB_POD&quot;:&quot;gitlab-web-65-gwwwh&quot;,\r\n      &quot;STARTED_AT&quot;:&quot;31-05-2018-18:18:48&quot;,\r\n      &quot;FINISHED&quot;:&quot;false&quot;,\r\n      &quot;FIRST_INDEXED&quot;:&quot;0&quot;,\r\n      &quot;LAST_INDEXED&quot;:&quot;3143&quot;,\r\n      &quot;failed_projects&quot;:{\r\n        &quot;1082&quot;: &quot;4:Deadline Exceeded, trace&quot;,\r\n        &quot;1273&quot;: &quot;/opt/gitlab/embedded/lib/ruby/gems/2.3.0/gems/elasticsearch-transport-5.0.3/lib/elasticsearch/transport/transport/base.rb:201:in `__raise_transport_error&#39;&quot;,\r\n        &quot;2492&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;3060&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;LAST_JOB_POD&quot;:&quot;gitlab-web-65-gwwwh&quot;,\r\n      &quot;STARTED_AT&quot;:&quot;31-05-2018-18:18:48&quot;,\r\n      &quot;FINISHED&quot;:&quot;false&quot;,\r\n      &quot;FIRST_INDEXED&quot;:&quot;0&quot;,\r\n      &quot;LAST_INDEXED&quot;:&quot;3143&quot;,\r\n      &quot;failed_projects&quot;:{\r\n        &quot;5570&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6103&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6188&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6695&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6721&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6728&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6747&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;\r\n      }\r\n    },\r\n    { \r\n      &quot;LAST_JOB_POD&quot;:&quot;gitlab-web-65-gwwwh&quot;,\r\n      &quot;STARTED_AT&quot;:&quot;31-05-2018-18:18:48&quot;,\r\n      &quot;FINISHED&quot;:&quot;false&quot;,\r\n      &quot;FIRST_INDEXED&quot;:&quot;0&quot;,\r\n      &quot;LAST_INDEXED&quot;:&quot;3143&quot;,\r\n      &quot;failed_projects&quot;:{\r\n        &quot;6760&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6939&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6941&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6942&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;6947&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;,\r\n        &quot;7201&quot;: &quot;/opt/gitlab/embedded/lib/ruby/gems/2.3.0/gems/elasticsearch-transport-5.0.3/lib/elasticsearch/transport/transport/base.rb:201:in `__raise_transport_error&#39;&quot;,\r\n        &quot;7707&quot;: &quot;, trace - [\\&quot;/opt/gitlab/embedded/service/gitlab-rails/ee/lib/gitlab/elastic/indexer.rb:64:in `run_indexer!&#39;\\&quot;&quot;,\r\n        &quot;7787&quot;: &quot;/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill&#39;: Net::ReadTimeout (Faraday::TimeoutError)&quot;\r\n      }\r\n    }\r\n    ]\r\n\r\nI am currently using `jq` to extract the `failed_projects` entries, but with\r\n \r\n```[] | select(.failed_projects != null) | . as $object | {&quot;failed_projects&quot;}[]```\r\n\r\nI am getting the results in different groups:\r\n\r\n    {\r\n    &quot;1082&quot;: &quot;...&quot;,\r\n    ...\r\n    }\r\n    {\r\n    &quot;5570&quot;: &quot;...&quot;,\r\n    ...\r\n    }\r\n    {\r\n    &quot;6760&quot;: &quot;...&quot;,\r\n    ...\r\n    }\r\n\r\n**What I am trying to accomplish is to group IDs with the same exception. Something such as:**\r\n\r\n    [{\r\n    &quot;Exception&quot;: &quot;ReadTimeout&quot;,\r\n     [{\r\n       &quot;ID&quot;: 2492,\r\n       &quot;ID&quot;: 3060\r\n     }]\r\n    },\r\n    {\r\n    &quot;Exception&quot;: &quot;Deadline Exceeded&quot;,\r\n     [{\r\n       &quot;ID&quot;: 1082\r\n     }]\r\n    }]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50678440/getting-all-results-on-the-same-array",
        "title": "Getting all results on the same array"
    },
    {
        "tags": [
            "json",
            "object",
            "insert",
            "key-value",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1528324299,
                "post_id": 50730050,
                "comment_id": 88468696,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1528326210,
                "post_id": 50730050,
                "comment_id": 88469272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 137305,
                    "reputation": 411,
                    "user_id": 341396,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/gknd2.png?s=256",
                    "display_name": "jonypony3",
                    "link": "https://stackoverflow.com/users/341396/jonypony3"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556051888,
                "post_id": 50730050,
                "comment_id": 98304495,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1528325445,
                "last_edit_date": 1528325445,
                "creation_date": 1528325048,
                "answer_id": 50730629,
                "question_id": 50730050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the help of a helper function, the task becomes trivial:\r\n\r\n    def insert_kv($key; $value; $ix):\r\n      to_entries\r\n      | .[0:$ix] + [{key: $key, value: $value}] + .[$ix:]\r\n      | from_entries;\r\n    \r\n    insert_kv(&quot;cuisine&quot;; &quot;mediterranean&quot;; 1)\r\n    | insert_kv(&quot;meal&quot;; &quot;lunch&quot;; 3)\r\n\r\nYou could (alternatively or in addition) define:\r\n\r\n    def insert_kv($object; $ix):\r\n      to_entries\r\n      | .[0:$ix] + ($object|to_entries) + .[$ix:]\r\n      | from_entries;\r\n\r\n\r\n    ",
                "title": "How to insert fields into a JSON file using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1556052114,
                "creation_date": 1556052114,
                "answer_id": 55819108,
                "question_id": 50730050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Where your json is saved to meals.json, executing the following command will result into exactly what you need.\r\n\r\n    jq &#39;.cusine=&quot;mediteranean&quot;&#39; meals.json",
                "title": "How to insert fields into a JSON file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1556052114,
        "creation_date": 1528321406,
        "last_edit_date": 1528395180,
        "question_id": 50730050,
        "body_markdown": "Let&#39;s say I have a JSON file `recipe.json` containing this:\r\n\r\n    {\r\n                &quot;name&quot;: &quot;Curried Lentils and Rice&quot;,\r\n                &quot;ingredients&quot;: [\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 quart&quot;,\r\n                        &quot;name&quot;: &quot;beef broth&quot;,\r\n                        &quot;type&quot;: &quot;Misc&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 cup&quot;,\r\n                        &quot;name&quot;: &quot;dried green lentils&quot;,\r\n                        &quot;type&quot;: &quot;Misc&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1/2 cup&quot;,\r\n                        &quot;name&quot;: &quot;basmati rice&quot;,\r\n                        &quot;type&quot;: &quot;Misc&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 tsp&quot;,\r\n                        &quot;name&quot;: &quot;curry powder&quot;,\r\n                        &quot;type&quot;: &quot;Condiments&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 tsp&quot;,\r\n                        &quot;name&quot;: &quot;salt&quot;,\r\n                        &quot;type&quot;: &quot;Condiments&quot;\r\n                    }\r\n                ],\r\n                &quot;steps&quot;: [\r\n                    &quot;Bring broth to a low boil.&quot;,\r\n                    &quot;Add curry powder and salt.&quot;,\r\n                    &quot;Cook lentils for 20 minutes.&quot;,\r\n                    &quot;Add rice and simmer for 20 minutes.&quot;,\r\n                    &quot;Enjoy!&quot;\r\n                ],\r\n                &quot;timers&quot;: [\r\n                    0,\r\n                    0,\r\n                    20,\r\n                    20,\r\n                    0\r\n                ],\r\n                &quot;imageURL&quot;: &quot;http://dagzhsfg97k4.cloudfront.net/wp-content/uploads/2012/05/lentils3.jpg&quot;\r\n    }\r\n\r\nAnd I&#39;m trying to **insert** new JSON fields into the file at specific positions in the file, using **jq** such as:\r\n\r\n    &quot;cuisine&quot;: &quot;meditaranean&quot;\r\n\r\nwill become the 2nd entry, and\r\n\r\n    &quot;meal&quot;: &quot;lunch&quot;\r\n\r\nwill become the 4th entry. So the file after the command is like this: \r\n\r\n\r\n    {\r\n                &quot;name&quot;: &quot;Curried Lentils and Rice&quot;,\r\n                &quot;cuisine&quot;: &quot;meditaranean&quot;\r\n                &quot;ingredients&quot;: [\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 quart&quot;,\r\n                        &quot;name&quot;: &quot;beef broth&quot;,\r\n                        &quot;type&quot;: &quot;Misc&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 cup&quot;,\r\n                        &quot;name&quot;: &quot;dried green lentils&quot;,\r\n                        &quot;type&quot;: &quot;Misc&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1/2 cup&quot;,\r\n                        &quot;name&quot;: &quot;basmati rice&quot;,\r\n                        &quot;type&quot;: &quot;Misc&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 tsp&quot;,\r\n                        &quot;name&quot;: &quot;curry powder&quot;,\r\n                        &quot;type&quot;: &quot;Condiments&quot;\r\n                    },\r\n                    {\r\n                        &quot;quantity&quot;: &quot;1 tsp&quot;,\r\n                        &quot;name&quot;: &quot;salt&quot;,\r\n                        &quot;type&quot;: &quot;Condiments&quot;\r\n                    }\r\n                ],\r\n                &quot;meal&quot;: &quot;lunch&quot;\r\n                &quot;steps&quot;: [\r\n                    &quot;Bring broth to a low boil.&quot;,\r\n                    &quot;Add curry powder and salt.&quot;,\r\n                    &quot;Cook lentils for 20 minutes.&quot;,\r\n                    &quot;Add rice and simmer for 20 minutes.&quot;,\r\n                    &quot;Enjoy!&quot;\r\n                ],\r\n                &quot;timers&quot;: [\r\n                    0,\r\n                    0,\r\n                    20,\r\n                    20,\r\n                    0\r\n                ],\r\n                &quot;imageURL&quot;: &quot;http://dagzhsfg97k4.cloudfront.net/wp-content/uploads/2012/05/lentils3.jpg&quot;\r\n    }\r\n\r\nMy question is how to do this with **jq**?\r\n\r\nNote: This [other question][1] addresses performing updates of single fields, while the current question is about inserts. They are as different as orange and yellow bell peppers, which is different! (Don&#39;t make me add a picture of bell peppers to this post, I swear I&#39;ll do it if I have to.)\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/31034746/how-do-i-update-a-single-value-in-a-json-document-using-jq",
        "link": "https://stackoverflow.com/questions/50730050/how-to-insert-fields-into-a-json-file-using-jq",
        "title": "How to insert fields into a JSON file using jq?"
    },
    {
        "tags": [
            "json",
            "sorting",
            "datetime",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 38,
                "is_accepted": true,
                "score": 38,
                "last_activity_date": 1583213516,
                "last_edit_date": 1583213516,
                "creation_date": 1528377457,
                "answer_id": 50742286,
                "question_id": 50741593,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** approach:\r\n\r\n    jq &#39;.[].items |= sort_by(.lastTimestamp)&#39; input.json\r\n\r\nReference: [jq Manual (development version)](https://stedolan.github.io/jq/manual/#sort,sort_by(path_expression))",
                "title": "How can I use jq to sort by datetime field?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 17,
        "last_activity_date": 1583213516,
        "creation_date": 1528375560,
        "last_edit_date": 1528387581,
        "question_id": 50741593,
        "body_markdown": "    [\r\n    {\r\n      &quot;apiVersion&quot;: &quot;v1&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;apiVersion&quot;: &quot;v1&quot;,\r\n          &quot;count&quot;: 603,\r\n          &quot;firstTimestamp&quot;: &quot;2018-06-07T13:07:32Z&quot;,\r\n          &quot;involvedObject&quot;: {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;kind&quot;: &quot;Pod&quot;,\r\n            &quot;name&quot;: &quot;events-db8f675c6-khm4r&quot;,\r\n            &quot;namespace&quot;: &quot;default&quot;,\r\n            &quot;resourceVersion&quot;: &quot;2989590&quot;,\r\n            &quot;uid&quot;: &quot;bd489878-6a53-11e8-9351-0e5486765cbc&quot;\r\n          },\r\n          &quot;kind&quot;: &quot;Event&quot;,\r\n          &quot;lastTimestamp&quot;: &quot;2018-06-07T16:02:52Z&quot;\r\n        }\r\n      ]\r\n    }\r\n    ]\r\n\r\n\r\nHow could I sort all the `items` (there is only one item above - but it&#39;s just an example) by the `.items.lasttimestamp` value, for example the value `&quot;lastTimestamp&quot;: &quot;2018-06-07T11:59:53Z&quot;`?",
        "link": "https://stackoverflow.com/questions/50741593/how-can-i-use-jq-to-sort-by-datetime-field",
        "title": "How can I use jq to sort by datetime field?"
    },
    {
        "tags": [
            "html",
            "awk",
            "sed",
            "jq",
            "sequential"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1528378041,
                "creation_date": 1528378041,
                "answer_id": 50742512,
                "question_id": 50742300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When working with HTML/XML data from the command line - a proper HTML/XML parser should be used. &lt;br&gt;**`xmllint`** is one of such.\r\n\r\n    xmllint --html --xpath &#39;//body/*[self::iframe or self::div[@class=&quot;text&quot;]]&#39; input.html\r\n\r\nThe output:\r\n\r\n    &lt;iframe&gt;&lt;/iframe&gt;&lt;div class=&quot;text&quot;&gt;TEST&lt;/div&gt;",
                "title": "How to cut HTML file (drop anything outside two tags)?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1528652600,
                "creation_date": 1528652600,
                "answer_id": 50786430,
                "question_id": 50742300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that solves the general problem, assuming one wants to select a range of elements based on a &quot;linearization&quot; of the HTML.  This solution uses [`pup`][1] to convert HTML to JSON, and then uses [tag:jq] to perform the linearization, selection, and conversion back to HTML.\r\n\r\n## program.jq\r\n\r\nThe idea is to &quot;linearize&quot; the HTML by recursively hoisting the children to the top-level:\r\n\r\n    # Emit a stream by hoisting .children recursively.\r\n    # It is assumed that the input is an array, \r\n    # and that .children is always an array.\r\n    def hoist:\r\n      .[]\r\n      | if type == &quot;object&quot; and has(&quot;children&quot;)\r\n        then del(.children), (.children | hoist)\r\n        else .\r\n        end;\r\n    \r\n    def indexof(condition):\r\n      label $out\r\n      | foreach .[] as $x (null; .+1;\r\n          if ($x|condition) then .-1, break $out else empty end)\r\n        // null;\r\n    \r\n    # Reconstitute the HTML element\r\n    def toHtml:\r\n      def k: . as $in | (keys_unsorted - [&quot;tag&quot;, &quot;text&quot;])\r\n      | reduce .[] as $k (&quot;&quot;; . + &quot; \\($k)=\\&quot;\\($in[$k])\\&quot;&quot;);\r\n      def t: if .text then .text else &quot;&quot; end;\r\n      &quot;&lt;\\(.tag)\\(k)&gt;\\(t)&lt;/\\(.tag)&gt;&quot;\r\n      ;\r\n    \r\n    # Linearize and then select the desired range of elements\r\n    [hoist]\r\n    | indexof( .tag == &quot;iframe&quot;) as $first\r\n    | indexof( .tag == &quot;div&quot; and .id==&quot;trend&quot;) as $last\r\n    | .[$first:$last]\r\n    | .[]\r\n    | toHtml\r\n   \r\n    \r\n## Invocation:\r\n\r\n    pup &#39;json{}&#39; &lt; input.html | jq -rf program.jq\r\n\r\n## Output:\r\n\r\n    &lt;iframe&gt;&lt;/iframe&gt;\r\n    &lt;div class=&quot;text&quot;&gt;TEST&lt;/div&gt;\r\n\r\n  [1]: https://github.com/ericchiang/pup",
                "title": "How to cut HTML file (drop anything outside two tags)?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1529841308,
        "creation_date": 1528377500,
        "last_edit_date": 1529841308,
        "question_id": 50742300,
        "body_markdown": "When this is my HTML example document:\r\n\r\n    &lt;!DOCTYPE html&gt;\r\n    &lt;html lang=&quot;en&quot;&gt;\r\n      &lt;head&gt;\r\n        &lt;meta charset=&quot;utf-8&quot;&gt;\r\n        &lt;title&gt;title&lt;/title&gt;\r\n      &lt;/head&gt;\r\n      &lt;body&gt;\r\n    \t&lt;iframe&gt;&lt;/iframe&gt;\r\n    \t&lt;div class=&quot;text&quot;&gt;TEST&lt;/div&gt;\r\n    \t&lt;div id=&quot;trend&quot; data-app=&quot;openableBox&quot; class=&quot;box sub-box&quot;&gt;\r\n    \t\t&lt;div class=&quot;box-header&quot;&gt;\r\n    \t\t\t&lt;h1&gt;&lt;span&gt;Highlights&lt;/span&gt;&lt;/h1&gt;\r\n    \t\t&lt;/div&gt;\r\n    \t&lt;/div&gt;\r\n      &lt;/body&gt;\r\n    &lt;/html&gt;\r\n\r\nHow can I extract\r\n\r\n    &lt;iframe&gt;&lt;/iframe&gt;\r\n    &lt;div class=&quot;text&quot;&gt;TEST&lt;/div&gt;\r\n\r\nby dropping everything *before* `&lt;iframe&gt;` and *after* (beginning with)`&lt;div id=&quot;trend&quot;&gt;`?\r\n\r\nThanks if you could help me.",
        "link": "https://stackoverflow.com/questions/50742300/how-to-cut-html-file-drop-anything-outside-two-tags",
        "title": "How to cut HTML file (drop anything outside two tags)?"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq",
            "any"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1528387498,
                "last_edit_date": 1528387498,
                "creation_date": 1528385293,
                "answer_id": 50745045,
                "question_id": 50744629,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `any/2` yields a jq filter that closely matches the description of the problem in English:\r\n\r\n    .rows |= map( if any(.fields[]; .name==&quot;id&quot; and .value==&quot;k1&quot;)\r\n                  then .fields |= map(if .name == &quot;Encoding&quot;\r\n                                      then .value = &quot;oct&quot;\r\n                                      else .\r\n                                      end)\r\n                  else .\r\n                  end )\r\n\r\n## Using when/2\r\n\r\nA slightly less verbose and perhaps clearer solution is possible if we use a handy general-purpose function defined as follows:\r\n\r\n    def when(filter; action): if (filter?) // null then action else . end;\r\n\r\nWe can then write simply:\r\n\r\n    .rows[] |= when( any(.fields[]; .name==&quot;id&quot; and .value==&quot;k1&quot;);\r\n                     .fields |= map( when (.name == &quot;Encoding&quot;;\r\n                                           .value = &quot;oct&quot;)))\r\n\r\n## Caveats\r\n\r\n* You might want to check whether .value == &quot;hex&quot; before changing it to &quot;oct&quot;.\r\n* The above filters could potentially change more than one name/value pair per &quot;row&quot;.",
                "title": "modify nested JSON array with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1528390088,
        "creation_date": 1528384117,
        "last_edit_date": 1528390088,
        "question_id": 50744629,
        "body_markdown": "I would like to use JQ to modify the following JSON input:\r\n\r\n\r\n    {\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;id&quot;,\r\n              &quot;value&quot;: &quot;k1&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;val&quot;,\r\n              &quot;value&quot;: &quot;2340378b211aa3d8f2d7607cbddce883b87b191d0425736641e3d308ea329718&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Encoding&quot;,\r\n              &quot;value&quot;: &quot;hex&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;id&quot;,\r\n              &quot;value&quot;: &quot;k2&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;val&quot;,\r\n              &quot;value&quot;: &quot;2340378b211aa3d8f2d7607cbddce883b87b191d0425736641e3d308ea329718&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Encoding&quot;,\r\n              &quot;value&quot;: &quot;hex&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nso that the `&quot;hex&quot;` value of the `&quot;value&quot;` field with name `&quot;Encoding&quot;` is modified to `&quot;oct&quot;` **only** for the row that contains a field with `.name==&quot;id&quot; and .value==&quot;k1&quot;`.\r\n\r\nHow would I do that? I can `select` a field with `.value==&quot;k1&quot;` etc. but I don&#39;t seem to be able to find a way to &quot;go up the tree&quot; to update the `&quot;Encoding&quot;` field subsequently.\r\n\r\nThe input cannot be expected to have a fixed field/row order.\r\n",
        "link": "https://stackoverflow.com/questions/50744629/modify-nested-json-array-with-jq",
        "title": "modify nested JSON array with JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "membership"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1573082975,
                "last_edit_date": 1573082975,
                "creation_date": 1528408778,
                "answer_id": 50750734,
                "question_id": 50750688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## using `,`\r\n\r\nI don&#39;t know where in https://stedolan.github.io/jq/manual/v1.5/ this is documented. But the answer is in that `jq` does implicit one-to-many and many-to-one munging.\r\n\r\n```\r\njq &#39;.[] | select(.PrivateIpAddress == (&quot;172.31.6.209&quot;,\r\n                                       &quot;172.31.6.229&quot;))\r\n        | .PrivateDnsName&#39; &lt;&lt;EOF\r\n[\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-209.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.209&quot;\r\n    },\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-219.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.219&quot;\r\n    },\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-229.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.229&quot;\r\n    },\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-239.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.239&quot;\r\n    }\r\n]\r\nEOF\r\n```\r\n(the formatting/indenting of code was made to match that of the OP to simplify visual comparison)\r\n\r\n\r\nThe output is:\r\n\r\n    &quot;ip-172-31-6-209.us-west-2.compute.internal&quot;\r\n    &quot;ip-172-31-6-229.us-west-2.compute.internal&quot;\r\n\r\n&quot;Seems like voodoo to me.&quot;\r\n\r\n## using `| IN(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;)`\r\n\r\n**Update:** It&#39;s been 16 months, and I&#39;ve finally learned how to use the `IN` function. Here is a demo that will produce the same results as above.\r\n```\r\ncat &gt; filter.jq &lt;&lt;EOF\r\n# Either of these work in jq &lt; v1.5, but I&#39;ve commented them out since I&#39;m using v1.6\r\n# def IN(s): first( if (s == .) then true else empty end ) // false;\r\n# def IN(s): first(select(s == .)) // false;\r\n\r\n.[] | select(.PrivateIpAddress | IN(&quot;172.31.6.209&quot;,&quot;172.31.6.229&quot;)) | .PrivateDnsName\r\nEOF\r\n\r\njq -f filter.jq &lt;&lt;EOF\r\n[\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-209.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.209&quot;\r\n    },\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-219.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.219&quot;\r\n    },\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-229.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.229&quot;\r\n    },\r\n    {\r\n        &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-239.us-west-2.compute.internal&quot;,\r\n        &quot;PrivateIpAddress&quot;: &quot;172.31.6.239&quot;\r\n    }\r\n]\r\nEOF\r\n```",
                "title": "jq: select where .attribute in list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1528409412,
                "last_edit_date": 1528409412,
                "creation_date": 1528409062,
                "answer_id": 50750775,
                "question_id": 50750688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; But, there is no `in`. \r\n\r\nYou could use `index/1`, as documented in the manual.  Even better would be to use `IN`, which however was only introduced after the release of jq 1.5.  If your jq does not have it, you can use this definition for `IN/1`:\r\n\r\n    # return true or false as . is in the stream s\r\n    def IN(s):\r\n      first( if (s == .) then true else empty end ) // false;\r\n\r\nIf you want to check membership in an array, say $a, simply use `IN( $a[] )`.",
                "title": "jq: select where .attribute in list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 17,
        "last_activity_date": 1573082975,
        "creation_date": 1528408554,
        "last_edit_date": 1530294349,
        "question_id": 50750688,
        "body_markdown": "In python I can do:\r\n\r\n    &gt;&gt;&gt; 5 in [2,4,6]\r\n    False\r\n    &gt;&gt;&gt; 5 in [4,5,6]\r\n    True\r\n\r\nto determine if the give value `5` exists in the list. I want to do the same concept in `jq`. But, there is no `in`. Here is an example with a more realistic data set, and how I can check for 2 values. In my real need I have to check for a few hundred and don&#39;t want to have all those `or`ed together.\r\n\r\n    jq &#39;.[] | select(.PrivateIpAddress == &quot;172.31.6.209&quot;\r\n                     or\r\n                     .PrivateIpAddress == &quot;172.31.6.229&quot;)\r\n            | .PrivateDnsName&#39; &lt;&lt;EOF\r\n    [\r\n        {\r\n            &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-209.us-west-2.compute.internal&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;172.31.6.209&quot;\r\n        },\r\n        {\r\n            &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-219.us-west-2.compute.internal&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;172.31.6.219&quot;\r\n        },\r\n        {\r\n            &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-229.us-west-2.compute.internal&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;172.31.6.229&quot;\r\n        },\r\n        {\r\n            &quot;PrivateDnsName&quot;: &quot;ip-172-31-6-239.us-west-2.compute.internal&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;172.31.6.239&quot;\r\n        }\r\n    ]\r\n    EOF",
        "link": "https://stackoverflow.com/questions/50750688/jq-select-where-attribute-in-list",
        "title": "jq: select where .attribute in list"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2041261,
                    "reputation": 441,
                    "user_id": 1822391,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ca68d9681c4c8ffd41670e8fbcfdeb8b?s=256&d=identicon&r=PG",
                    "display_name": "user1822391",
                    "link": "https://stackoverflow.com/users/1822391/user1822391"
                },
                "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": 1528457034,
                "post_id": 50757496,
                "comment_id": 88526453,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2041261,
                    "reputation": 441,
                    "user_id": 1822391,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ca68d9681c4c8ffd41670e8fbcfdeb8b?s=256&d=identicon&r=PG",
                    "display_name": "user1822391",
                    "link": "https://stackoverflow.com/users/1822391/user1822391"
                },
                "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": 1528457741,
                "post_id": 50757496,
                "comment_id": 88526848,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1528458294,
                "creation_date": 1528458294,
                "answer_id": 50759940,
                "question_id": 50757496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution. I have saved the file in /tmp/1:\r\n\r\n    cat /tmp/1 | jq &quot;[ .stuff | $(cat /tmp/1 | jq -r &#39;.mine[]&#39; | sed &#39;s/^/./;s/$/.name/;&#39; | tr &#39;\\n&#39; &#39;,&#39; | sed &#39;s/,$//&#39;) ]&quot;\r\n\r\nFirst i get the names in `.mine[]`, ie `foo` and `baz`. Then i convert them into `.foo.name, .baz.name` and pass to jq `[ .stuff | $(...) ]`, which results in `[ .stuff | .foo.name, .baz.name ]`.",
                "title": "In jq get array based on another array"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1528461063,
                "last_edit_date": 1528461063,
                "creation_date": 1528458385,
                "answer_id": 50759967,
                "question_id": 50757496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a simple `jq` filter and no other shell processing, do it as below.\r\n\r\n    jq &#39;[.mine[] as $in | .stuff[$in].name]&#39;\r\n\r\nThe logic is basically index the values from `.mine` and for each entry get the equivalent `.name` value in `.stuff`\r\n\r\n[jqplay - URL](https://jqplay.org/s/LRHW9BaX42)\r\n",
                "title": "In jq get array based on another array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1528471882,
        "creation_date": 1528450072,
        "last_edit_date": 1528471882,
        "question_id": 50757496,
        "body_markdown": "I am using **jq v1.5**. Given the input:\r\n\r\n\t{\r\n\t\t&quot;mine&quot;: [\r\n\t\t\t&quot;foo&quot;,\r\n\t\t\t&quot;baz&quot;\r\n\t\t],\r\n\t\t&quot;stuff&quot;: {\r\n\t\t\t&quot;foo&quot;: {\r\n\t\t\t\t&quot;name&quot;: &quot;Foo&quot;\r\n\t\t\t},\r\n\t\t\t&quot;bar&quot;: {\r\n\t\t\t\t&quot;name&quot;: &quot;Bar&quot;\r\n\t\t\t},\r\n\t\t\t&quot;baz&quot;: {\r\n\t\t\t\t&quot;name&quot;: &quot;Baz&quot;\r\n\t\t\t},\r\n\t\t\t&quot;qux&quot;: {\r\n\t\t\t\t&quot;name&quot;: &quot;Qux&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\nHow do I get all the **.stuff.name**s for **.mine**? \r\n\r\nFor example, desired output:\r\n\r\n\t[\r\n\t\t&quot;Baz&quot;,\r\n\t\t&quot;Foo&quot;\r\n\t]\r\n",
        "link": "https://stackoverflow.com/questions/50757496/in-jq-get-array-based-on-another-array",
        "title": "In jq get array based on another array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1528515547,
                "creation_date": 1528515547,
                "answer_id": 50770687,
                "question_id": 50770638,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To clarify, there is no backslash or `n` in the notes field. `\\n` is JSON&#39;s way of encoding a literal linefeed, so the value you should be expecting is:\r\n\r\n    Demo1\r\n    Demo2\r\n\r\nThe issue you&#39;re seeing is because you have split the value on whitespace and created an array. Each value can be accessed by index:\r\n\r\n    $ cat myscript\r\n    data=&#39;[{&quot;id&quot;:1,&quot;notes&quot;:&quot;Demo1\\nDemo2&quot;}]&#39;\r\n    value=($(printf &#39;%s&#39; &quot;$data&quot; | jq -r &#39;.[].notes&#39;))\r\n    echo &quot;The first value was ${value[0]} and the second ${value[1]}&quot;\r\n\r\n    $ bash myscript\r\n    The first value was Demo1 and the second Demo2\r\n\r\nTo instead get it as a simple string, remove the parens from `value=(..)`:\r\n\r\n    $ cat myscript2\r\n    data=&#39;[{&quot;id&quot;:1,&quot;notes&quot;:&quot;Demo1\\nDemo2&quot;}]&#39;\r\n    value=$(printf &#39;%s&#39; &quot;$data&quot; | jq -r &#39;.[].notes&#39;)\r\n    echo &quot;$value&quot;\r\n\r\n    $ bash myscript2\r\n    Demo1\r\n    Demo2\r\n",
                "title": "Extract json response to shell variable using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528515547,
        "creation_date": 1528514886,
        "last_edit_date": 1528515492,
        "question_id": 50770638,
        "body_markdown": "I have a sample json response as shown below which i am trying to parse using jq in shell script.`[{&quot;id&quot;:1,&quot;notes&quot;:&quot;Demo1\\nDemo2&quot;}]`\r\n\r\nThis is the command through which I am trying to access notes in the shell script.\r\n\r\n    value=($(curl $URL | jq -r &#39;.[].notes&#39;)) \r\n\r\nWhen I echo &quot;$value&quot; I only get Demo1. How to get the exact value: Demo1\\nDemo2 ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50770638/extract-json-response-to-shell-variable-using-jq",
        "title": "Extract json response to shell variable using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1782512,
                    "reputation": 824,
                    "user_id": 1624929,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1733d2b5fc3d0bb0ce5340004d2404c1?s=256&d=identicon&r=PG",
                    "display_name": "meisterluk",
                    "link": "https://stackoverflow.com/users/1624929/meisterluk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1528543034,
                "post_id": 50773151,
                "comment_id": 88554431,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6501248,
                    "reputation": 23,
                    "user_id": 5031976,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b434e9f5938f4148240037fdc360411c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abhimanyu Mittal",
                    "link": "https://stackoverflow.com/users/5031976/abhimanyu-mittal"
                },
                "reply_to_user": {
                    "account_id": 1782512,
                    "reputation": 824,
                    "user_id": 1624929,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1733d2b5fc3d0bb0ce5340004d2404c1?s=256&d=identicon&r=PG",
                    "display_name": "meisterluk",
                    "link": "https://stackoverflow.com/users/1624929/meisterluk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1528549272,
                "post_id": 50773151,
                "comment_id": 88555972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1073380,
                    "reputation": 47090,
                    "user_id": 1072112,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa3fecc914da2b7a82696d52729fc237?s=256&d=identicon&r=PG",
                    "display_name": "ghoti",
                    "link": "https://stackoverflow.com/users/1072112/ghoti"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1528555087,
                "post_id": 50773151,
                "comment_id": 88557644,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1528539446,
                "creation_date": 1528539446,
                "answer_id": 50773182,
                "question_id": 50773151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [jq][1] command line tool to interpret JSON data. `uniq -c` counts the number of occurences.\r\n\r\n    % jq .field1 &lt; $INPUTFILE | sort | uniq -c\r\n          1 249443\r\n          1 249447\r\n          1 249448\r\n          2 249449\r\n\r\n(tested with `jq 1.5-1-a5b5cbe` on linux xubuntu 18.04 with zsh)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
                "title": "Get count based on value bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1528690808,
                "last_edit_date": 1528690808,
                "creation_date": 1528558830,
                "answer_id": 50775911,
                "question_id": 50773151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "with `awk`\r\n\r\n    $ awk -F&#39;[,:]&#39; -v OFS=&#39; : &#39; &#39;{a[$2]++} END{for(k in a) print k, a[k]}&#39; file",
                "title": "Get count based on value bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1528652727,
                "last_edit_date": 1528652727,
                "creation_date": 1528564049,
                "answer_id": 50776663,
                "question_id": 50773151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an efficient `jq`-only solution:\r\n\r\n    reduce inputs.field1 as $x ({}; .[$x|tostring] += 1)\r\n    | to_entries[]\r\n    | &quot;\\(.key) : \\(.value)&quot;\r\n\r\nInvocation: `jq -nrf program.jq input.json`\r\n\r\n(Note in particular the `-n` option.)\r\n\r\nOf course if an object-representation of the counts is satisfactory, then\r\none could simply write: \r\n\r\n    jq -n &#39;reduce inputs.field1 as $x ({}; .[$x|tostring] += 1)&#39; input.json",
                "title": "Get count based on value bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1528653094,
                "creation_date": 1528653094,
                "answer_id": 50786496,
                "question_id": 50773151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`datamash`][1] and some shell utils, change the non-data delimiters to squeezed tabs, count field 3, (it&#39;d be field 2, but there&#39;s a leading tab), reverse, then pretty print as per *OP* spec:\r\n\r\n    tr -s &#39;{&quot;:,}&#39; &#39;\\t&#39; &lt; file | datamash -sg 3 count 3 | tac | xargs printf &#39;%s : %s\\n&#39;\r\n\r\nOutput:\r\n\r\n    249449 : 2\r\n    249448 : 1\r\n    249447 : 1\r\n    249443 : 1\r\n\r\n\r\n  [1]: https://savannah.gnu.org/projects/datamash/",
                "title": "Get count based on value bash"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1528690808,
        "creation_date": 1528539222,
        "last_edit_date": 1528652882,
        "question_id": 50773151,
        "body_markdown": "I have data in this format in a file:\r\n\r\n    {&quot;field1&quot;:249449,&quot;field2&quot;:116895,&quot;field3&quot;:1,&quot;field4&quot;:&quot;apple&quot;,&quot;field5&quot;:42,&quot;field6&quot;:&quot;2019-07-01T00:00:10&quot;,&quot;metadata&quot;:&quot;&quot;,&quot;frontend&quot;:&quot;&quot;}\r\n    {&quot;field1&quot;:249448,&quot;field2&quot;:116895,&quot;field3&quot;:1,&quot;field4&quot;:&quot;apple&quot;,&quot;field5&quot;:42,&quot;field6&quot;:&quot;2019-07-01T00:00:10&quot;,&quot;metadata&quot;:&quot;&quot;,&quot;frontend&quot;:&quot;&quot;}\r\n    {&quot;field1&quot;:249447,&quot;field2&quot;:116895,&quot;field3&quot;:1,&quot;field4&quot;:&quot;apple&quot;,&quot;field5&quot;:42,&quot;field6&quot;:&quot;2019-07-01T00:00:10&quot;,&quot;metadata&quot;:&quot;&quot;,&quot;frontend&quot;:&quot;&quot;}\r\n    {&quot;field1&quot;:249443,&quot;field2&quot;:116895,&quot;field3&quot;:1,&quot;field4&quot;:&quot;apple&quot;,&quot;field5&quot;:42,&quot;field6&quot;:&quot;2019-07-01T00:00:10&quot;,&quot;metadata&quot;:&quot;&quot;,&quot;frontend&quot;:&quot;&quot;}\r\n    {&quot;field1&quot;:249449,&quot;field2&quot;:116895,&quot;field3&quot;:1,&quot;field4&quot;:&quot;apple&quot;,&quot;field5&quot;:42,&quot;field6&quot;:&quot;2019-07-01T00:00:10&quot;,&quot;metadata&quot;:&quot;&quot;,&quot;frontend&quot;:&quot;&quot;}\r\n\r\nHere, each entry represents a row. I want to have a count of the rows with respect to the value in field one, like:\r\n\r\n    249449 : 2\r\n    249448 : 1\r\n    249447 : 1\r\n    249443 : 1\r\n\r\nHow can I get that?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50773151/get-count-based-on-value-bash",
        "title": "Get count based on value bash"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8623168,
                    "reputation": 142,
                    "user_id": 6457275,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-i1JSuXknEIM/AAAAAAAAAAI/AAAAAAAABOI/NT7JPJRg9eQ/s256-rj/photo.jpg",
                    "display_name": "Jonathan King",
                    "link": "https://stackoverflow.com/users/6457275/jonathan-king"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1528676441,
                "post_id": 50788939,
                "comment_id": 88584598,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11280798,
                    "reputation": 263,
                    "user_id": 8273311,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4baba85760b79bc222af380ea155309a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tom",
                    "link": "https://stackoverflow.com/users/8273311/tom"
                },
                "reply_to_user": {
                    "account_id": 8623168,
                    "reputation": 142,
                    "user_id": 6457275,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-i1JSuXknEIM/AAAAAAAAAAI/AAAAAAAABOI/NT7JPJRg9eQ/s256-rj/photo.jpg",
                    "display_name": "Jonathan King",
                    "link": "https://stackoverflow.com/users/6457275/jonathan-king"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1528685626,
                "post_id": 50788939,
                "comment_id": 88585941,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1528691597,
                "last_edit_date": 1528691597,
                "creation_date": 1528680563,
                "answer_id": 50789486,
                "question_id": 50788939,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to quote `$value`:\r\n\r\n    echo &quot;$value&quot; | jq -r &#39;.[].id&#39; \r\n    1",
                "title": "Error while parsing JSON response using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528691597,
        "creation_date": 1528673669,
        "question_id": 50788939,
        "body_markdown": "I have a sample json response as shown below which i am trying to parse using jq in shell script.`[{&quot;id&quot;:1,&quot;notes&quot;:&quot;Demo1\\nDemo2&quot;}]`\r\n\r\nI am first storing the entire json response in a shell variable value.\r\n\r\n    value=$(curl $URL )\r\n\r\nI am getting an error when trying to access individual variables\r\n\r\n    idval=$(echo $value | jq -r &#39;.[].id&#39;))\r\n\r\nCan anyone please help resolve the error?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50788939/error-while-parsing-json-response-using-jq",
        "title": "Error while parsing JSON response using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1528753166,
                "creation_date": 1528753166,
                "answer_id": 50806412,
                "question_id": 50806009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "(self-answering after a bit of investigating)\r\n\r\nI think there was no formatting error or change in formatting in the input.\r\n\r\nI don&#39;t know why my query syntax did **not** encounter errors previously (maybe I just did not notice), but it seems that the entries in the &quot;recipes&quot; section often do not contain an &quot;l&quot; attribute, and `jq` will cease processing as soon as it encounters one that does not.\r\n\r\nI also don&#39;t know why `jq` does not generate the same error message for **every** record that lacks that attribute, nor why it waits to the final line of the input to generate the single message.  (Maybe that behavior is documented somewhere.)\r\n\r\nIn any case, I fixed the error (not just the message, but also the failure to display all relevent records) by testing for the presence of the attribute first:\r\n\r\n    jq &#39;.[&quot;recipes&quot;][] | select(has(&quot;l&quot;) and (.l | test(&quot;ill&quot;)))&#39; &lt; jsonfile\r\n",
                "title": "Legal change to JSON input invalidates simple jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528772587,
        "creation_date": 1528751110,
        "last_edit_date": 1528772587,
        "question_id": 50806009,
        "body_markdown": "Another department continually updates a JSON file that I then query.  Its format is three lists of similar-looking dictionaries:\r\n\r\n    {\r\n    &quot;levels&quot;:\r\n    [\r\n    {&quot;a&quot;:1, &quot;b&quot;:False, &quot;c&quot;:&quot;2012&quot;, &quot;d&quot;:&quot;2017&quot;}\r\n    ,{&quot;a&quot;:2, &quot;b&quot;:True,  &quot;c&quot;:&quot;2013&quot;, &quot;d&quot;:&quot;9999&quot;}\r\n    ,...\r\n    ]\r\n    ,&quot;costs&quot;:\r\n    [\r\n    {&quot;e&quot;:12, &quot;f&quot;:&quot;foo&quot;, &quot;g&quot;:&quot;blarg&quot;, &quot;h&quot;:&quot;2015&quot;, &quot;i&quot;:&quot;2018&quot;}\r\n    ,{&quot;e&quot;:-3, &quot;f&quot;:&quot;foo&quot;, &quot;g&quot;:&quot;glorb&quot;, &quot;h&quot;:&quot;2013&quot;, &quot;i&quot;:&quot;9999&quot;}\r\n    ,...\r\n    ]\r\n    ,&quot;recipes&quot;:\r\n    [\r\n    {&quot;j&quot;:&quot;BAZ&quot;, &quot;k&quot;:[&quot;blarg&quot;,&quot;glorb&quot;,&quot;bleeg&quot;], &quot;l&quot;:&quot;dill&quot;, &quot;m&quot;:&quot;2016&quot;, &quot;n&quot;:&quot;2017&quot;}\r\n    ,{&quot;j&quot;:&quot;BAZ&quot;, &quot;k&quot;:[&quot;blarg&quot;,&quot;bleeg&quot;], &quot;l&quot;:&quot;dill&quot;, &quot;m&quot;:&quot;2017&quot;, &quot;n&quot;:&quot;9999&quot;}\r\n    ,...\r\n    ]\r\n    }   # line 3943 (see below)\r\n\r\nRecently, my simple `jq` queries like\r\n\r\n    jq &#39;.[&quot;recipes&quot;][] | select(.l | test(&quot;ill&quot;))&#39; &lt; jsonfile\r\n\r\nstopped returning all of the results they should (e.g. returning only one of the two &quot;dill&quot; lines above) and started printing this error message:\r\n\r\n    jq: error (at &lt;stdin&gt;:3943): null (null) cannot be matched, as it is not a string\r\n\r\nLine 3943 mentioned in the error is the final line of the file.  Queries against the &quot;levels&quot; and &quot;costs&quot; sections of the file continue to work like normal; it&#39;s only the &quot;recipes&quot; section of the file that is breaking, as though `jq` thinks the closing brace of the file is still part of the &quot;recipes&quot; section.\r\n\r\nTo me this suggests there&#39;s been a formatting change or error in the last section of the file.  However, software other than `jq` (e.g. `python`) doesn&#39;t report any problems parsing it.  Before I start going through the input line by line ... does this error message indicate anything obvious to a `jq` expert?\r\n\r\nAlas, I do not keep old versions of the file around for comparison.  (I think I will start today.)",
        "link": "https://stackoverflow.com/questions/50806009/legal-change-to-json-input-invalidates-simple-jq",
        "title": "Legal change to JSON input invalidates simple jq"
    },
    {
        "tags": [
            "templates",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1528870570,
                "last_edit_date": 1528870570,
                "creation_date": 1528781453,
                "answer_id": 50809832,
                "question_id": 50809580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, you never need an initial `.|` as `.` here is just the &quot;identity&quot; filter.\r\n\r\nSecond, it&#39;s important to distinguish between shell variables on the one hand and jq $-variables on the other.  Unless you explicitly tie the two together, they have completely independent lives.  As you discovered, using `--arg MYVAR FOO` sets the jq variable `$MYVAR` to the JSON string `&quot;FOO&quot;`; to reference this variable, you simply write `$MYVAR` in the jq program.  \r\n\r\nIt&#39;s also fine to initialize the jq variable using:\r\n\r\n    --arg MYVAR &quot;${MYVAR}&quot;\r\n\r\nThis sets the jq-variable to the (string) value of the shell variable.\r\n\r\nThird, the names of jq &quot;$-variables&quot; are highly constrained: excluding the initial &quot;$&quot;, they must match the regex: [a-zA-Z_][a-zA-Z_0-9]*\r\n\r\nThus if your real goal is to change occurrences of the JSON string\r\n&quot;${FOO}&quot; with &quot;BAR&quot;, where FOO is to be specified programmatically,\r\nyou will have to adopt a different strategy. This\r\nwould work:\r\n\r\n    echo &#39;{ &quot;name&quot;: &quot;${FOO}&quot; }&#39; |\r\n      jq -c --arg MYVAR FOO --arg MYVALUE BAR &#39;\r\n        if .name == &quot;${\\($MYVAR)}&quot; then .name = $MYVALUE else . end&#39;\r\n\r\nThis produces: {&quot;name&quot;:&quot;BAR&quot;}\r\n\r\n\r\nSee also the section [&quot;Using jq as a template engine&quot;][1] in the [jq Cookbook][2].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine\r\n  [2]: https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "Matching jq var inside curly quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1528876097,
        "creation_date": 1528780012,
        "last_edit_date": 1528876097,
        "question_id": 50809580,
        "body_markdown": "I am trying to replace &quot;${FOO}&quot; with &quot;BAR&quot; (please note: &quot;${FOO}&quot; is NOT a shell variable - this is how it appears in the json, and I have no control over the json)\r\n\r\nThis works:\r\n\r\n    echo &#39;{ &quot;name&quot;: &quot;${FOO}&quot; }&#39; | \\\r\n        jq &#39;.|(select (.name == &quot;${FOO}&quot;) | .name) |= &quot;BAR&quot;&#39;\r\n\r\n    {\r\n      &quot;name&quot;: &quot;BAR&quot;\r\n    }\r\n\r\nHowever, if I want to programatically assign the matching value (`MYVAR=FOO` in this case),I cannot get it to work e.g.\r\n\r\n    echo &#39;{ &quot;name&quot;: &quot;${FOO}&quot; }&#39; | \\\r\n        jq --arg MYVAR FOO &#39;.|(select (.name == &quot;${$MYVAR}&quot;) | .name) |= &quot;BAR&quot;&#39;\r\n    {\r\n      &quot;name&quot;: &quot;${FOO}&quot;\r\n    }\r\n\r\nMy gut feel is that it&#39;s the quotes around the matching string that&#39;s the problem, as this also works:\r\n\r\n    echo &#39;{ &quot;name&quot;: &quot;FOO&quot; }&#39; | \\\r\n        jq --arg MYVAR FOO &#39;.|(select (.name == $MYVAR) | .name) |= &quot;BAR&quot;&#39;\r\n    {\r\n        &quot;name&quot;: &quot;BAR&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/50809580/matching-jq-var-inside-curly-quotes",
        "title": "Matching jq var inside curly quotes"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1528815779,
                "creation_date": 1528815779,
                "answer_id": 50820337,
                "question_id": 50818215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq --slurpfile file2 file2.json \\\r\n    &#39;. + $file2[] | map(to_entries) | flatten \r\n     | group_by(.key) | map(.[-1] | {(.key): .value})&#39; file1.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: 4\r\n      },\r\n      {\r\n        &quot;b&quot;: 5\r\n      },\r\n      {\r\n        &quot;c&quot;: 3\r\n      },\r\n      {\r\n        &quot;d&quot;: 6\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq merge json arrays without duplicates"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1528841443,
                "last_edit_date": 1528841443,
                "creation_date": 1528818593,
                "answer_id": 50821200,
                "question_id": 50818215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This answer has been edited to reflect the change in the Q.]\r\n\r\nThe following solution uses `INDEX/2` as defined in https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\nOne advantage of using `INDEX` is that it avoids using `group_by`, which entails the costs of sorting, which may not be desired in any case.\r\n\r\nIn case your version of jq does not have `INDEX/2`, here is its definition:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\nThis filter (`INDEX/2`) constructs a dictionary, with keys equal to the distinct values of `idx_expr` applied to elements of the stream,\r\nsuch that the value associated with a particular key is the *last* item in the stream mapping to that value.\r\n\r\n    [INDEX( add[] | to_entries; (.[0] | .key) )[]\r\n     | from_entries ]\r\n\r\n\r\nInvocation:\r\n\r\n    jq -scf program.jq file1.json file2.json\r\n\r\nOutput:\r\n\r\n    [{&quot;a&quot;:4,&quot;value&quot;:44},{&quot;b&quot;:5},{&quot;c&quot;:3},{&quot;d&quot;:6}]",
                "title": "jq merge json arrays without duplicates"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1528841443,
        "creation_date": 1528809401,
        "last_edit_date": 1528833885,
        "question_id": 50818215,
        "body_markdown": "I am struggling to merge two JSON arrays with jq, because I would like to remove duplicate keys in merged objects:\r\n\r\n**Edit**: added a second key since the example was too simple.\r\n\r\nfile1.json :\r\n\r\n    [\r\n      {&quot;a&quot;: 1, &quot;value&quot;: 11},\r\n      {&quot;b&quot;: 2},\r\n      {&quot;c&quot;: 3}\r\n    ]\r\n\r\nfile2.json :\r\n\r\n    [\r\n      {&quot;a&quot;: 4, &quot;value&quot;: 44},\r\n      {&quot;b&quot;: 5},\r\n      {&quot;d&quot;: 6}\r\n    ]\r\n\r\nExpected result:\r\n\r\n    [\r\n      {&quot;a&quot;: 4, &quot;value&quot;: 44},\r\n      {&quot;b&quot;: 5},\r\n      {&quot;c&quot;: 3},\r\n      {&quot;d&quot;: 6}\r\n    ]\r\n\r\n`jq add file1.json file2.json` duplicates the keys (I have two objects with key &quot;a&quot; in the array).\r\n\r\nI tried many answers from the web, but everybody has his own use case and none worked directly. The closest is this one: https://stackoverflow.com/questions/50354926/jq-merge-two-arrays\r\nbut I can&#39;t manage to make it work with files instead of string arguments.\r\n\r\nMy last attempt was\r\n\r\n    jq \\\r\n      --slurpfile base file1.json \\\r\n      --slurpfile params file2.json \\\r\n      &#39;$base + $params | unique_by(.Key)&#39;\r\n",
        "link": "https://stackoverflow.com/questions/50818215/jq-merge-json-arrays-without-duplicates",
        "title": "jq merge json arrays without duplicates"
    },
    {
        "tags": [
            "json",
            "bash",
            "docker",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1528836016,
                "creation_date": 1528836016,
                "answer_id": 50825515,
                "question_id": 50824913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;.[] | {(.Name) : [(.Config.ExposedPorts | keys),\r\n                          (.NetworkSettings.Networks | to_entries\r\n                           | map({(.key): .value.IPAddress}) | add)\r\n                         ]\r\n              }&#39; input\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;/prometheus_prometheus_1&quot;: [\r\n        [\r\n          &quot;9090/tcp&quot;\r\n        ],\r\n        {\r\n          &quot;prometheus_internal&quot;: &quot;172.21.0.4&quot;,\r\n          &quot;system-information&quot;: &quot;172.28.0.2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Network IP addresses with jq bash command from docker inspect"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1528836016,
        "creation_date": 1528833297,
        "question_id": 50824913,
        "body_markdown": "I want to process ``docker inspect &lt;container1&gt; &lt;container2&gt;`` out to retrieve via ``jq`` command exposed ports and IPAddresses assigned to defined networks. So far I&#39;ve got ``jq &#39;{(.[].Name): getpath(path(.[].NetworkSettings.Networks)) | .[].IPAddress}&#39;`` which is clearly far from enough.\r\n\r\np.s. I know its easy to write a script that would give such output but I&#39;m curious how to do that using ``jq`` \r\n\r\n**Expected output**\r\n\r\n    {\r\n    \t# .[].Name\r\n    \t&quot;/prometheus_prometheus_1&quot;: [\r\n    \t\t[\r\n    \t\t\t# .[].Config.ExposedPorts\r\n    \t\t\t&quot;9090/tcp&quot;\r\n    \t\t],\r\n    \t\t{\r\n    \t\t\t# key \t= .[].NetworkSettings.Networks.&lt;index&gt;\r\n    \t\t\t# value = .[].NetworkSettings.Networks[].IPAddress\r\n    \t\t\t&quot;prometheus_internal&quot;: &quot;172.21.0.4&quot;,\r\n    \t\t\t&quot;system-information&quot;: &quot;172.28.0.2&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\n**Input:**\r\n\r\n    [\r\n        {\r\n            &quot;Id&quot;: &quot;c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa&quot;,\r\n            &quot;Created&quot;: &quot;2018-06-12T05:33:19.811448302Z&quot;,\r\n            &quot;Path&quot;: &quot;/bin/prometheus&quot;,\r\n            &quot;Args&quot;: [\r\n                &quot;--config.file=/etc/prometheus/prometheus.yml&quot;,\r\n                &quot;--storage.tsdb.path=/prometheus&quot;,\r\n                &quot;--web.console.libraries=/usr/share/prometheus/console_libraries&quot;,\r\n                &quot;--web.console.templates=/usr/share/prometheus/consoles&quot;\r\n            ],\r\n            &quot;State&quot;: {\r\n                &quot;Status&quot;: &quot;running&quot;,\r\n                &quot;Running&quot;: true,\r\n                &quot;Paused&quot;: false,\r\n                &quot;Restarting&quot;: false,\r\n                &quot;OOMKilled&quot;: false,\r\n                &quot;Dead&quot;: false,\r\n                &quot;Pid&quot;: 13217,\r\n                &quot;ExitCode&quot;: 0,\r\n                &quot;Error&quot;: &quot;&quot;,\r\n                &quot;StartedAt&quot;: &quot;2018-06-12T05:33:20.264845701Z&quot;,\r\n                &quot;FinishedAt&quot;: &quot;0001-01-01T00:00:00Z&quot;\r\n            },\r\n            &quot;Image&quot;: &quot;sha256:44a4c1c270dcb5e8caf51e3205fa23343cc903f3823eab53ae204f304d16f62a&quot;,\r\n            &quot;ResolvConfPath&quot;: &quot;/var/lib/docker/containers/c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa/resolv.conf&quot;,\r\n            &quot;HostnamePath&quot;: &quot;/var/lib/docker/containers/c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa/hostname&quot;,\r\n            &quot;HostsPath&quot;: &quot;/var/lib/docker/containers/c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa/hosts&quot;,\r\n            &quot;LogPath&quot;: &quot;/var/lib/docker/containers/c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa/c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa-json.log&quot;,\r\n            &quot;Name&quot;: &quot;/prometheus_prometheus_1&quot;,\r\n            &quot;RestartCount&quot;: 0,\r\n            &quot;Driver&quot;: &quot;overlay2&quot;,\r\n            &quot;Platform&quot;: &quot;linux&quot;,\r\n            &quot;MountLabel&quot;: &quot;&quot;,\r\n            &quot;ProcessLabel&quot;: &quot;&quot;,\r\n            &quot;AppArmorProfile&quot;: &quot;&quot;,\r\n            &quot;ExecIDs&quot;: null,\r\n            &quot;HostConfig&quot;: {\r\n                &quot;Binds&quot;: [\r\n                    &quot;prometheus_prometheus-data:/prometheus:rw&quot;,\r\n                    &quot;/home/sebastian/projects/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml:rw&quot;\r\n                ],\r\n                &quot;ContainerIDFile&quot;: &quot;&quot;,\r\n                &quot;LogConfig&quot;: {\r\n                    &quot;Type&quot;: &quot;json-file&quot;,\r\n                    &quot;Config&quot;: {}\r\n                },\r\n                &quot;NetworkMode&quot;: &quot;prometheus_internal&quot;,\r\n                &quot;PortBindings&quot;: {},\r\n                &quot;RestartPolicy&quot;: {\r\n                    &quot;Name&quot;: &quot;always&quot;,\r\n                    &quot;MaximumRetryCount&quot;: 0\r\n                },\r\n                &quot;AutoRemove&quot;: false,\r\n                &quot;VolumeDriver&quot;: &quot;&quot;,\r\n                &quot;VolumesFrom&quot;: [],\r\n                &quot;CapAdd&quot;: null,\r\n                &quot;CapDrop&quot;: null,\r\n                &quot;Dns&quot;: null,\r\n                &quot;DnsOptions&quot;: null,\r\n                &quot;DnsSearch&quot;: null,\r\n                &quot;ExtraHosts&quot;: null,\r\n                &quot;GroupAdd&quot;: null,\r\n                &quot;IpcMode&quot;: &quot;shareable&quot;,\r\n                &quot;Cgroup&quot;: &quot;&quot;,\r\n                &quot;Links&quot;: null,\r\n                &quot;OomScoreAdj&quot;: 0,\r\n                &quot;PidMode&quot;: &quot;&quot;,\r\n                &quot;Privileged&quot;: false,\r\n                &quot;PublishAllPorts&quot;: false,\r\n                &quot;ReadonlyRootfs&quot;: false,\r\n                &quot;SecurityOpt&quot;: null,\r\n                &quot;UTSMode&quot;: &quot;&quot;,\r\n                &quot;UsernsMode&quot;: &quot;&quot;,\r\n                &quot;ShmSize&quot;: 67108864,\r\n                &quot;Runtime&quot;: &quot;runc&quot;,\r\n                &quot;ConsoleSize&quot;: [\r\n                    0,\r\n                    0\r\n                ],\r\n                &quot;Isolation&quot;: &quot;&quot;,\r\n                &quot;CpuShares&quot;: 0,\r\n                &quot;Memory&quot;: 0,\r\n                &quot;NanoCpus&quot;: 0,\r\n                &quot;CgroupParent&quot;: &quot;&quot;,\r\n                &quot;BlkioWeight&quot;: 0,\r\n                &quot;BlkioWeightDevice&quot;: null,\r\n                &quot;BlkioDeviceReadBps&quot;: null,\r\n                &quot;BlkioDeviceWriteBps&quot;: null,\r\n                &quot;BlkioDeviceReadIOps&quot;: null,\r\n                &quot;BlkioDeviceWriteIOps&quot;: null,\r\n                &quot;CpuPeriod&quot;: 0,\r\n                &quot;CpuQuota&quot;: 0,\r\n                &quot;CpuRealtimePeriod&quot;: 0,\r\n                &quot;CpuRealtimeRuntime&quot;: 0,\r\n                &quot;CpusetCpus&quot;: &quot;&quot;,\r\n                &quot;CpusetMems&quot;: &quot;&quot;,\r\n                &quot;Devices&quot;: null,\r\n                &quot;DeviceCgroupRules&quot;: null,\r\n                &quot;DiskQuota&quot;: 0,\r\n                &quot;KernelMemory&quot;: 0,\r\n                &quot;MemoryReservation&quot;: 0,\r\n                &quot;MemorySwap&quot;: 0,\r\n                &quot;MemorySwappiness&quot;: null,\r\n                &quot;OomKillDisable&quot;: false,\r\n                &quot;PidsLimit&quot;: 0,\r\n                &quot;Ulimits&quot;: null,\r\n                &quot;CpuCount&quot;: 0,\r\n                &quot;CpuPercent&quot;: 0,\r\n                &quot;IOMaximumIOps&quot;: 0,\r\n                &quot;IOMaximumBandwidth&quot;: 0\r\n            },\r\n            &quot;GraphDriver&quot;: {\r\n                &quot;Data&quot;: {\r\n                    &quot;LowerDir&quot;: &quot;/var/lib/docker/overlay2/73c16b0735eb15494741e5b821a9df3be8cebb716219ac206d9ee0042e4166ac-init/diff:/var/lib/docker/overlay2/03c66042305488fea2fe693246e90374743fbb7836ab31e4ee5cdbfbb1c97785/diff:/var/lib/docker/overlay2/80821a00b79334493729e671dfb66cc878aec19fe2d0dfbaf4cde187522b06e8/diff:/var/lib/docker/overlay2/f5071cce5513fb3c465ad883297157271ef48c6f59cd88768068224d850c6903/diff:/var/lib/docker/overlay2/c9a0cc617abb45fbd4572abb41c7281c96bc9d59c109270c7f1ec7a99f5b055b/diff:/var/lib/docker/overlay2/5b425f8a440139a8fdcdd7f7fee8189565e9e00304e96f4cfee86ff6b861e068/diff:/var/lib/docker/overlay2/e85740d997591d2f60bfa61ea0c82a58636bccaaba970e55f12cf0ff24565c70/diff:/var/lib/docker/overlay2/e9c362d971c460b02111122b241888392d77c5b8545ed520c3d74660b16db9b2/diff:/var/lib/docker/overlay2/5001184fc8ddd25204626f419c1530b970cb37f936a196fb1173f2774310085e/diff:/var/lib/docker/overlay2/ed2e676f09a4583f2194e752083a7c95be80131f055891dc39f9fed5560f5a73/diff&quot;,\r\n                    &quot;MergedDir&quot;: &quot;/var/lib/docker/overlay2/73c16b0735eb15494741e5b821a9df3be8cebb716219ac206d9ee0042e4166ac/merged&quot;,\r\n                    &quot;UpperDir&quot;: &quot;/var/lib/docker/overlay2/73c16b0735eb15494741e5b821a9df3be8cebb716219ac206d9ee0042e4166ac/diff&quot;,\r\n                    &quot;WorkDir&quot;: &quot;/var/lib/docker/overlay2/73c16b0735eb15494741e5b821a9df3be8cebb716219ac206d9ee0042e4166ac/work&quot;\r\n                },\r\n                &quot;Name&quot;: &quot;overlay2&quot;\r\n            },\r\n            &quot;Mounts&quot;: [\r\n                {\r\n                    &quot;Type&quot;: &quot;volume&quot;,\r\n                    &quot;Name&quot;: &quot;prometheus_prometheus-data&quot;,\r\n                    &quot;Source&quot;: &quot;/var/lib/docker/volumes/prometheus_prometheus-data/_data&quot;,\r\n                    &quot;Destination&quot;: &quot;/prometheus&quot;,\r\n                    &quot;Driver&quot;: &quot;local&quot;,\r\n                    &quot;Mode&quot;: &quot;rw&quot;,\r\n                    &quot;RW&quot;: true,\r\n                    &quot;Propagation&quot;: &quot;&quot;\r\n                },\r\n                {\r\n                    &quot;Type&quot;: &quot;bind&quot;,\r\n                    &quot;Source&quot;: &quot;/home/sebastian/projects/prometheus/prometheus.yml&quot;,\r\n                    &quot;Destination&quot;: &quot;/etc/prometheus/prometheus.yml&quot;,\r\n                    &quot;Mode&quot;: &quot;rw&quot;,\r\n                    &quot;RW&quot;: true,\r\n                    &quot;Propagation&quot;: &quot;rprivate&quot;\r\n                }\r\n            ],\r\n            &quot;Config&quot;: {\r\n                &quot;Hostname&quot;: &quot;c2f86bce6844&quot;,\r\n                &quot;Domainname&quot;: &quot;&quot;,\r\n                &quot;User&quot;: &quot;nobody&quot;,\r\n                &quot;AttachStdin&quot;: false,\r\n                &quot;AttachStdout&quot;: false,\r\n                &quot;AttachStderr&quot;: false,\r\n                &quot;ExposedPorts&quot;: {\r\n                    &quot;9090/tcp&quot;: {}\r\n                },\r\n                &quot;Tty&quot;: false,\r\n                &quot;OpenStdin&quot;: false,\r\n                &quot;StdinOnce&quot;: false,\r\n                &quot;Env&quot;: [\r\n                    &quot;PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin&quot;\r\n                ],\r\n                &quot;Cmd&quot;: [\r\n                    &quot;--config.file=/etc/prometheus/prometheus.yml&quot;,\r\n                    &quot;--storage.tsdb.path=/prometheus&quot;,\r\n                    &quot;--web.console.libraries=/usr/share/prometheus/console_libraries&quot;,\r\n                    &quot;--web.console.templates=/usr/share/prometheus/consoles&quot;\r\n                ],\r\n                &quot;Image&quot;: &quot;prom/prometheus:v2.3.0&quot;,\r\n                &quot;Volumes&quot;: {\r\n                    &quot;/etc/prometheus/prometheus.yml&quot;: {},\r\n                    &quot;/prometheus&quot;: {}\r\n                },\r\n                &quot;WorkingDir&quot;: &quot;/prometheus&quot;,\r\n                &quot;Entrypoint&quot;: [\r\n                    &quot;/bin/prometheus&quot;\r\n                ],\r\n                &quot;OnBuild&quot;: null,\r\n                &quot;Labels&quot;: {\r\n                    &quot;com.docker.compose.config-hash&quot;: &quot;b8ff39fd239739ae66051752c1b49b0119862b8f21678fb42400c907d25b1c57&quot;,\r\n                    &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n                    &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n                    &quot;com.docker.compose.project&quot;: &quot;prometheus&quot;,\r\n                    &quot;com.docker.compose.service&quot;: &quot;prometheus&quot;,\r\n                    &quot;com.docker.compose.version&quot;: &quot;1.16.1&quot;,\r\n                    &quot;maintainer&quot;: &quot;The Prometheus Authors &lt;prometheus-developers@googlegroups.com&gt;&quot;\r\n                }\r\n            },\r\n            &quot;NetworkSettings&quot;: {\r\n                &quot;Bridge&quot;: &quot;&quot;,\r\n                &quot;SandboxID&quot;: &quot;7be77954d0e6990f565a8526b157236140238cabf0954629598ce3bb9aaae885&quot;,\r\n                &quot;HairpinMode&quot;: false,\r\n                &quot;LinkLocalIPv6Address&quot;: &quot;&quot;,\r\n                &quot;LinkLocalIPv6PrefixLen&quot;: 0,\r\n                &quot;Ports&quot;: {\r\n                    &quot;9090/tcp&quot;: null\r\n                },\r\n                &quot;SandboxKey&quot;: &quot;/var/run/docker/netns/7be77954d0e6&quot;,\r\n                &quot;SecondaryIPAddresses&quot;: null,\r\n                &quot;SecondaryIPv6Addresses&quot;: null,\r\n                &quot;EndpointID&quot;: &quot;&quot;,\r\n                &quot;Gateway&quot;: &quot;&quot;,\r\n                &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n                &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n                &quot;IPAddress&quot;: &quot;&quot;,\r\n                &quot;IPPrefixLen&quot;: 0,\r\n                &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n                &quot;MacAddress&quot;: &quot;&quot;,\r\n                &quot;Networks&quot;: {\r\n                    &quot;prometheus_internal&quot;: {\r\n                        &quot;IPAMConfig&quot;: null,\r\n                        &quot;Links&quot;: null,\r\n                        &quot;Aliases&quot;: [\r\n                            &quot;prometheus&quot;,\r\n                            &quot;c2f86bce6844&quot;\r\n                        ],\r\n                        &quot;NetworkID&quot;: &quot;145c59986c16003f9a3a30e6b671c34b56225d90243fba88fc295c49b4dcfff6&quot;,\r\n                        &quot;EndpointID&quot;: &quot;8e3ac8bd4719ea85358c20a8141c37377dd327265916d41ee5d1db6b7496898c&quot;,\r\n                        &quot;Gateway&quot;: &quot;172.21.0.1&quot;,\r\n                        &quot;IPAddress&quot;: &quot;172.21.0.4&quot;,\r\n                        &quot;IPPrefixLen&quot;: 16,\r\n                        &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n                        &quot;MacAddress&quot;: &quot;02:42:ac:15:00:04&quot;,\r\n                        &quot;DriverOpts&quot;: null\r\n                    },\r\n                    &quot;system-information&quot;: {\r\n                        &quot;IPAMConfig&quot;: null,\r\n                        &quot;Links&quot;: null,\r\n                        &quot;Aliases&quot;: [\r\n                            &quot;prometheus&quot;,\r\n                            &quot;c2f86bce6844&quot;\r\n                        ],\r\n                        &quot;NetworkID&quot;: &quot;f6e67721cb73da7e8d4eacdb709de240014af9af35e66216e6186300c72de330&quot;,\r\n                        &quot;EndpointID&quot;: &quot;2c31369f8175f2b38a5bc966a8306c8f0f11ac4c264e6ce735d00c87b8a6f44f&quot;,\r\n                        &quot;Gateway&quot;: &quot;172.28.0.1&quot;,\r\n                        &quot;IPAddress&quot;: &quot;172.28.0.2&quot;,\r\n                        &quot;IPPrefixLen&quot;: 16,\r\n                        &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n                        &quot;MacAddress&quot;: &quot;02:42:ac:1c:00:02&quot;,\r\n                        &quot;DriverOpts&quot;: null\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    ]",
        "link": "https://stackoverflow.com/questions/50824913/network-ip-addresses-with-jq-bash-command-from-docker-inspect",
        "title": "Network IP addresses with jq bash command from docker inspect"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3889535,
                    "reputation": 20152,
                    "user_id": 3220113,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/10f69140e2a641a9f2f63bc09bc0e32c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Walter A",
                    "link": "https://stackoverflow.com/users/3220113/walter-a"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1528840661,
                "post_id": 50826242,
                "comment_id": 88657531,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3889535,
                    "reputation": 20152,
                    "user_id": 3220113,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/10f69140e2a641a9f2f63bc09bc0e32c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Walter A",
                    "link": "https://stackoverflow.com/users/3220113/walter-a"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1528840856,
                "post_id": 50826242,
                "comment_id": 88657598,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1528842409,
                "creation_date": 1528842409,
                "answer_id": 50826678,
                "question_id": 50826242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample input and days=1524953907, the following query:\r\n\r\n    jq --argjson days $days &#39;\r\n      select(.Timestamp | select(fromdateiso8601 &gt; $days)).servername&#39;\r\n\r\nyields:\r\n\r\n    &quot;xxxxxxxx&quot;\r\n\r\nOne can use `--arg days $days` but then you&#39;d have to convert the string to a number, e.g. by `$days|tonumber`",
                "title": "jq with date and variable issue"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528842409,
        "creation_date": 1528839747,
        "last_edit_date": 1528840520,
        "question_id": 50826242,
        "body_markdown": "The below is running in bash as a script that is invoked manually at the moment.\r\n\r\nI have been banging my head on this for the past few hours. I cannot seem for the life of me to pass a variable into jq no matter what way I do to it. When I set the variable manually without referencing my jq command and echo it, it works. However when it is placed inside my command it does not work.\r\n\r\nI am thinking it has something to do with either the `fromdateiso8601` or the `&lt;` operator is causing an issue. \r\n\r\n`timestamp.json` contains a few hundred of the below in the file. I need to reference every single one and pull out any that older than 45 days. Here is what I have tried.\r\n\r\n    date -d -45days +%s &gt;&gt; 45days.text\r\n    days=$(&lt;45days.text)\r\n    echo $days    \r\n    cat $_fileformated | jq &#39;select(.Timestamp | . == null or fromdateiso8601? &lt; &quot;$days&quot; ) .serverrname&#39; &gt;&gt; $filereport\r\n    cat $_fileformated | jq -r --arg days &quot;$days&quot; &#39;select(.Timestamp | . == null or fromdateiso8601? &lt; &quot;$days&quot; ) .serverrname&#39; &gt;&gt; $filereport\r\n    cat $_fileformated | jq -r --arg days &quot;$days&quot; &#39;select(.Timestamp | . == null or fromdateiso8601? &lt; env.days ) .serverrname&#39; &gt;&gt; $filereport\r\n    cat $_fileformated | days=&quot;$days&quot; jq &#39;select(.Timestamp | . == null or fromdateiso8601? &lt; &#39;env.days&#39; ) .serverrname&#39; &gt;&gt; $filereport    \r\n    {\r\n        &quot;servername&quot;: &quot;xxxxxxxx&quot;,\r\n        &quot;Timestamp&quot;: &quot;2018-06-12T13:41:08Z&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/50826242/jq-with-date-and-variable-issue",
        "title": "jq with date and variable issue"
    },
    {
        "tags": [
            "json",
            "linux",
            "key-value",
            "reduce",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1528904858,
                "last_edit_date": 1528904858,
                "creation_date": 1528893901,
                "answer_id": 50837650,
                "question_id": 50834871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Short **`jq`** approach:\r\n\r\n    jq &#39;reduce to_entries[] as $o ({};\r\n        .[$o.value[1]] += [[$o.value[0], $o.key]])&#39; input.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;a:111&quot;: [\r\n        [\r\n          1,\r\n          &quot;a&quot;\r\n        ],\r\n        [\r\n          2,\r\n          &quot;b&quot;\r\n        ]\r\n      ],\r\n      &quot;a:222&quot;: [\r\n        [\r\n          1,\r\n          &quot;c&quot;\r\n        ]\r\n      ],\r\n      &quot;b:222&quot;: [\r\n        [\r\n          1,\r\n          &quot;d&quot;\r\n        ],\r\n        [\r\n          2,\r\n          &quot;e&quot;\r\n        ]\r\n      ]\r\n    }\r\n\r\n",
                "title": "Swap key and value and accumulate values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1528904858,
        "creation_date": 1528885565,
        "last_edit_date": 1528902281,
        "question_id": 50834871,
        "body_markdown": "I have the following JSON snippet:\r\n    \r\n    {\r\n      &quot;a&quot;: [ 1, &quot;a:111&quot; ],\r\n      &quot;b&quot;: [ 2, &quot;a:111&quot;, &quot;irrelevant&quot; ],\r\n      &quot;c&quot;: [ 1, &quot;a:222&quot; ],\r\n      &quot;d&quot;: [ 1, &quot;b:222&quot; ],\r\n      &quot;e&quot;: [ 2, &quot;b:222&quot;, &quot;irrelevant&quot;]\r\n    }\r\n\r\nand I would like to swap the key with the second value of the array and accumulate keys with the same value, discarding possible values that come after the second one:\r\n\r\n    { &quot;a:111&quot;: [ [ 1, &quot;a&quot; ], [ 2, &quot;b&quot; ] ],\r\n      &quot;a:222&quot;: [ [ 1, &quot;c&quot; ] ],\r\n      &quot;b:222&quot;: [ [ 1, &quot;d&quot; ], [ 2, &quot;e&quot; ] ]\r\n    }\r\n\r\nMy initial solution is the following:\r\n\r\n    echo  &#39;{\r\n          &quot;a&quot;: [ 1, &quot;a:111&quot; ],\r\n          &quot;b&quot;: [ 2, &quot;a:111&quot;, &quot;irrelevant&quot; ],\r\n          &quot;c&quot;: [ 1, &quot;a:222&quot; ],\r\n          &quot;d&quot;: [ 1, &quot;b:222&quot; ],\r\n          &quot;e&quot;: [ 2, &quot;b:222&quot;, &quot;irrelevant&quot;]\r\n        }&#39; \\\r\n    | jq &#39;to_entries\r\n    | map({(.value[1]|tostring) : [[.value[0], .key]]})\r\n    | reduce .[] as $o ({}; reduce ($o|keys)[] as $key (.; .[$key] += $o[$key]))&#39;\r\n\r\nThis produces the needed result but is probably not very robust, hard to read and excessively long. I guess there is a much more readable solution using *with_entries* but it has eluded me for now.",
        "link": "https://stackoverflow.com/questions/50834871/swap-key-and-value-and-accumulate-values",
        "title": "Swap key and value and accumulate values"
    },
    {
        "tags": [
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1528919770,
                "last_edit_date": 1528919770,
                "creation_date": 1528914246,
                "answer_id": 50843860,
                "question_id": 50843611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re just missing some parentheses.  Compare:\r\n\r\n    select((.Threshold|tonumber) &gt; 0 and\r\n           (.Diff|tonumber) &gt; (.Threshold|tonumber))\r\n\r\nOr avoiding the double-conversion:\r\n\r\n    select( (.Threshold|tonumber) as $t\r\n            | $t &gt; 0 and (.Diff|tonumber) &gt; $t )\r\n\r\nYou could also simplify the entire program a bit:\r\n\r\n    .results[]\r\n    | select( ((.Threshold // 0) | tonumber) as $t \r\n              | $t &gt; 0 and (.Diff|tonumber) &gt; $t )\r\n\r\n",
                "title": "Filter objects using multiple conditions including comparing two object fields"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1528977597,
        "creation_date": 1528913258,
        "last_edit_date": 1528977597,
        "question_id": 50843611,
        "body_markdown": "Have a list of JSON object and am trying to filter them based on minimum value check and a comparison between two of its fields.\r\n\r\n    {\r\n      &quot;preview&quot;: false,\r\n      &quot;init_offset&quot;: 0,\r\n      &quot;messages&quot;: [],\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;A&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;B&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Diff&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Threshold&quot;\r\n        }\r\n      ],\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;A&quot;: &quot;foo&quot;,\r\n          &quot;B&quot;: &quot;bar&quot;,\r\n          &quot;Diff&quot;: &quot;1095&quot;,\r\n          &quot;Threshold&quot;: &quot;1200&quot;\r\n        },\r\n        {\r\n          &quot;A&quot;: &quot;baz&quot;,\r\n          &quot;B&quot;: &quot;bux&quot;,\r\n          &quot;Diff&quot;: &quot;81793&quot;,\r\n          &quot;Threshold&quot;: &quot;0&quot;\r\n        },\r\n        {\r\n          &quot;A&quot;: &quot;quux&quot;,\r\n          &quot;B&quot;: &quot;quuz&quot;,\r\n          &quot;Diff&quot;: &quot;194&quot;\r\n        },\r\n        {\r\n          &quot;A&quot;: &quot;moo&quot;,\r\n          &quot;B&quot;: &quot;goo&quot;,\r\n          &quot;Diff&quot;: &quot;5000&quot;,\r\n          &quot;Threshold&quot;: &quot;2000&quot;\r\n        }\r\n     ]\r\n    }\r\n\r\n\r\nClosest I&#39;ve come to is \r\n\r\n    .results\r\n    | map(.Threshold //= &quot;0&quot;)\r\n    | .[]\r\n    | select((.Threshold|tonumber &gt; 0) and \r\n             (.Diff|tonumber &gt; .Threshold|tonumber))\r\n\r\nBut that gives a \r\n\r\n    Cannot index string with string &quot;Threshold&quot;\r\n\r\nerror.\r\n\r\nBasically I want to return all results where Diff is greater than a non-zero Threshold. So in this case:\r\n\r\n    {\r\n      &quot;A&quot;: &quot;moo&quot;,\r\n      &quot;B&quot;: &quot;goo&quot;,\r\n      &quot;Diff&quot;: &quot;5000&quot;,\r\n      &quot;Threshold&quot;: &quot;2000&quot;\r\n    }\r\n\r\nUsing jq 1.5 FWIW.",
        "link": "https://stackoverflow.com/questions/50843611/filter-objects-using-multiple-conditions-including-comparing-two-object-fields",
        "title": "Filter objects using multiple conditions including comparing two object fields"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 521699,
                    "reputation": 812,
                    "user_id": 5798748,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-o20oremx6zQ/AAAAAAAAAAI/AAAAAAAAAdg/xvEd56_YBKc/s256-rj/photo.jpg",
                    "display_name": "Dario Rodriguez",
                    "link": "https://stackoverflow.com/users/5798748/dario-rodriguez"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1528915885,
                "post_id": 50843960,
                "comment_id": 88692051,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1528914955,
                "creation_date": 1528914955,
                "answer_id": 50844054,
                "question_id": 50843960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need to parse JSON, your best bet is to use an actual JSON parser rather than trying to do it with `awk` or similar. The [jq][] tool is great for this:\r\n\r\n    curl cli.fyi/8.8.8.8 | jq -r .data.organization\r\n\r\nThat would give you the bare string:\r\n\r\n    Google LLC\r\n\r\n[jq]: https://stedolan.github.io/jq/",
                "title": "Curl JSON to output only one object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1528915093,
        "creation_date": 1528914604,
        "last_edit_date": 1528915093,
        "question_id": 50843960,
        "body_markdown": "I would like to extract a single values from the output of a json file.\r\n\r\n    curl cli.fyi/8.8.8.8\r\n\r\nOutputs\r\n\r\n    {\r\n    &quot;type&quot;: &quot;IP Address&quot;,\r\n    &quot;data&quot;: {\r\n        &quot;organisation&quot;: &quot;Google LLC&quot;,\r\n        &quot;country&quot;: &quot;United States&quot;,\r\n        &quot;countryCode&quot;: &quot;US&quot;,\r\n        &quot;continent&quot;: &quot;North America&quot;,\r\n        &quot;latitude&quot;: &quot;37.751&quot;,\r\n        &quot;longitude&quot;: &quot;-97.822&quot;\r\n    }\r\n    }\r\n\r\nI can run this:\r\n\r\n    curl cli.fyi/8.8.8.8 2&gt;/dev/null | awk -F&#39;&quot;&#39; &#39;$2==&quot;organisation&quot;&#39;\r\n\r\nand it will output:\r\n\r\n    &quot;organisation&quot;: &quot;Google LLC&quot;,\r\n\r\nHow can I get only `Google LLC` ?",
        "link": "https://stackoverflow.com/questions/50843960/curl-json-to-output-only-one-object",
        "title": "Curl JSON to output only one object"
    },
    {
        "tags": [
            "amazon-web-services",
            "amazon-ec2",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1528922713,
                "last_edit_date": 1528922713,
                "creation_date": 1528921718,
                "answer_id": 50845784,
                "question_id": 50845727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `jq`, use the (**JMESPath**) `query` option of the CLI to extract the values you want.\r\n\r\n    aws ec2 describe-images --owners self --query &#39;Images[*].[ImageId, Name]&#39; --output text\r\n\r\nOutput\r\n\r\n    ami-12345678\tMY-AMI-2018-05\r\n    ami-90123456\tMY-AMI-2018-06",
                "title": "use jq to pull two elements from json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1528923952,
                "creation_date": 1528923952,
                "answer_id": 50846269,
                "question_id": 50845727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the record, here&#39;s how to combine the two jq commands:\r\n\r\n    jq -r &#39;.Images[] | (.ImageId, .Name)&#39;",
                "title": "use jq to pull two elements from json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1528923952,
        "creation_date": 1528921561,
        "last_edit_date": 1528922343,
        "question_id": 50845727,
        "body_markdown": "I need to build a list of our AMIs. I need to get the AMI ID and the AMI Name. How can I do that in one command? \r\n\r\nRight now I can only go: \r\n\r\n    aws ec2 describe-images --owners self --profile=nonprod | jq -r &#39;.Images[].ImageId&#39;\r\n\r\nTo get the AMI ID. Or I can go:\r\n\r\n    aws ec2 describe-images --owners self --profile=nonprod  | jq -r &#39;.Images[].Name&#39;\r\n\r\nTo get the AMI name. But is there a way to get at both elements in a single command?",
        "link": "https://stackoverflow.com/questions/50845727/use-jq-to-pull-two-elements-from-json",
        "title": "use jq to pull two elements from json"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1528951469,
                "creation_date": 1528951469,
                "answer_id": 50849752,
                "question_id": 50849591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea is right, but you _don&#39;t_ need to export the variables/use the environment variables here. Just pass in the arguments and use the internal `jq` logic to import variables from shell. \r\n\r\nThe key here is to access arguments containing `.`, wrap them over `[]`\r\n\r\n    getProperty(){\r\n        jq --arg namearg &quot;$1&quot; &#39;.[$namearg]&#39; &lt; json\r\n    }\r\n\r\nand now call with the args as needed\r\n\r\n    getProperty &quot;first.name&quot;\r\n    &quot;Adam&quot;\r\n    getProperty &quot;last.name&quot;\r\n    &quot;Eve&quot;",
                "title": "How to use environment variable parameter in jq parsing"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1528951469,
        "creation_date": 1528950221,
        "last_edit_date": 1528950345,
        "question_id": 50849591,
        "body_markdown": "In the following bash code, I&#39;m getting null as value instead of actual value. I&#39;m using `jq 1.5` in Linux OS.\r\n\r\n    getProperty(){\r\n        export PROP=$1\r\n        export value_found=`cat my.json | jq &#39;.&quot;env.PROP&quot;&#39;`\r\n        echo &quot;$1 = $value_found&quot;\r\n    }\r\n\r\n    getProperty &quot;first.name&quot;\r\n    getProperty &quot;last.name&quot;\r\n\r\nContents of `my.json`\r\n\r\n    {&quot;first.name&quot;:&quot;Adam&quot;, &quot;last.name&quot;:&quot;Eve&quot;}\r\n\r\nMy program requires to get value for properties selected randomly, so the property name is not known before runtime (hence the reason for trying to use parameters)\r\n",
        "link": "https://stackoverflow.com/questions/50849591/how-to-use-environment-variable-parameter-in-jq-parsing",
        "title": "How to use environment variable parameter in jq parsing"
    },
    {
        "tags": [
            "json",
            "filter",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1529006077,
                "post_id": 50864894,
                "comment_id": 88732433,
                "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": 1529008796,
                "post_id": 50864894,
                "comment_id": 88733624,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13770593,
                    "reputation": 105,
                    "user_id": 9938160,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4fe23560cfd378d511c6faf7552dccd1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lazy_tester",
                    "link": "https://stackoverflow.com/users/9938160/lazy-tester"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529010671,
                "post_id": 50864894,
                "comment_id": 88734374,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13770593,
                    "reputation": 105,
                    "user_id": 9938160,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4fe23560cfd378d511c6faf7552dccd1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lazy_tester",
                    "link": "https://stackoverflow.com/users/9938160/lazy-tester"
                },
                "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": 1529011586,
                "post_id": 50864894,
                "comment_id": 88734733,
                "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": 1529015071,
                "post_id": 50864894,
                "comment_id": 88735736,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1529015114,
                "last_edit_date": 1529015114,
                "creation_date": 1529008371,
                "answer_id": 50865502,
                "question_id": 50864894,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this response, I&#39;m going to assume that you want the output to be valid JSON.  If you want the output to be in some other form, you can simply tack on some additional filters.\r\n\r\nAnyway, the trick is to select the objects, not the keys, like so:\r\n\r\n    .timers\r\n    | with_entries( select(.key|contains(&quot;KeywordA&quot;) ) )\r\n\r\nWith your (modified) input, this produces:\r\n\r\n\r\n    {\r\n      &quot;timerWithAKeywordAPlusBlah&quot;: {\r\n        &quot;count&quot;: 1,\r\n        &quot;max&quot;: 0,\r\n        &quot;min&quot;: 0\r\n      },\r\n      &quot;timerWithAKeywordAPlusBlahBlah&quot;: {\r\n        &quot;count&quot;: 2385,\r\n        &quot;max&quot;: 2,\r\n        &quot;min&quot;: 1\r\n      }\r\n    }\r\n\r\nYou can then extract whatever details are ultimately required.\r\n",
                "title": "How to filter keys by name, then access nested object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1529027143,
        "creation_date": 1529005824,
        "last_edit_date": 1529027143,
        "question_id": 50864894,
        "body_markdown": "Novice jq user here, struggling with the following:\r\n\r\nI have the following json and need to filter keys based on a keyword and print out the whole object (not just the key) or certain key/value pairs. Note the nested object structure of the JSON, which is intentional.\r\n\r\n\r\n    {\r\n      &quot;timers&quot;: {\r\n        &quot;timerWithAKeywordAPlusBlah&quot;: {\r\n          &quot;count&quot;: 1,\r\n          &quot;max&quot;: 0,\r\n          &quot;min&quot;: 0      \r\n        },\r\n        &quot;timerWithAKeywordB&quot;: {\r\n          &quot;count&quot;: 2,\r\n          &quot;max&quot;: 0\r\n        },\r\n        &quot;timerWithAKeywordAPlusBlahBlah&quot;: {\r\n          &quot;count&quot;: 2385,\r\n          &quot;max&quot;: 2,\r\n          &quot;min&quot;: 1         \r\n        }\r\n      }\r\n    }\r\n\r\nDesired output:\r\n\r\n    &quot;timerWithAKeywordAPlusBlah&quot;: {\r\n      &quot;count&quot;: 1,\r\n      &quot;max&quot;: 0,\r\n      &quot;min&quot;: 0\r\n    },\r\n    &quot;timerWithAKeywordAPlusBlahBlah&quot;: {\r\n      &quot;count&quot;: 2385,\r\n      &quot;max&quot;: 2,\r\n      &quot;min&quot;: 1\r\n    }\r\n\r\n*Things I tried:*\r\n\r\nI can print out the key name, but can&#39;t figure out how to access the whole object.\r\n\r\n    cat timers.json| jq &#39;.timers | keys[] | select(contains(&quot;KeywordA&quot;)) &#39;",
        "link": "https://stackoverflow.com/questions/50864894/how-to-filter-keys-by-name-then-access-nested-object-using-jq",
        "title": "How to filter keys by name, then access nested object using jq"
    },
    {
        "tags": [
            "json",
            "regex",
            "bash",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 57,
                "is_accepted": true,
                "score": 57,
                "last_activity_date": 1529031276,
                "last_edit_date": 1529031276,
                "creation_date": 1529028895,
                "answer_id": 50868294,
                "question_id": 50868203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you tacked the following filter onto the one you already have, then you&#39;d get the output shown below:\r\n\r\n    map(select(.Address | test(&quot;^[0-9]&quot;)))\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;Address&quot;: &quot;1 Bridge Rd&quot;\r\n      }\r\n    ]\r\n\r\nFor robustness, you might like to consider adding `?` after the test:\r\n\r\n    map(select(.Address | test(&quot;^[0-9]&quot;)?))\r\n\r\n\r\nOr, you could combine the two calls to `map` in various ways. You might like to consider:\r\n\r\n    .[].payload.address | select(test(&quot;^[0-9]&quot;)?) | {Address: .}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Filter by Regex in JQ"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1602609552,
                "creation_date": 1602609552,
                "answer_id": 64340067,
                "question_id": 50868203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Though the accepted answer works, I find this more readable\r\n\r\n    $\r\n    $ echo &#39;[{&quot;Address&quot;: &quot;The Sq&quot;, &quot;n&quot;: 1}, {&quot;Address&quot;: &quot;1 Bridge Rd&quot;, &quot;n&quot;: 2}]&#39; | \\\r\n      jq &#39;.[] | .Address | select(.|test(&quot;^[0-9]&quot;))&#39;\r\n\r\n    &quot;1 Bridge Rd&quot;\r\n    $\r\n    $ echo &#39;[{&quot;Address&quot;: &quot;The Sq&quot;, &quot;n&quot;: 1}, {&quot;Address&quot;: &quot;1 Bridge Rd&quot;, &quot;n&quot;: 2}]&#39; | \\\r\n      jq &#39;.[] | select(.Address|test(&quot;^[0-9]&quot;))&#39;\r\n\r\n    {\r\n      &quot;Address&quot;: &quot;1 Bridge Rd&quot;,\r\n      &quot;n&quot;: 2\r\n    }\r\n    $\r\n\r\nIf you want to do a little different filtering:\r\n\r\n    $ echo &#39;[{&quot;name&quot;: &quot;john doe&quot;, &quot;sex&quot;: &quot;male&quot;, &quot;age&quot;: 26, &quot;occupation&quot;: &quot;city planner&quot;, &quot;cod&quot;: &quot;asphyxiation&quot;}, {&quot;name&quot;: &quot;jane doe&quot;, &quot;sex&quot;: &quot;male&quot;, &quot;age&quot;: 24, &quot;occupation&quot;: &quot;beautician&quot;, &quot;cod&quot;: &quot;strangulation&quot;}, {&quot;name&quot;: &quot;crispy lips&quot;, &quot;sex&quot;: &quot;male&quot;, &quot;age&quot;: 38, &quot;occupation&quot;: &quot;convicted killer&quot;} ]&#39; &gt; in.json\r\n    $ cat in.json | jq .\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;john doe&quot;,\r\n        &quot;sex&quot;: &quot;male&quot;,\r\n        &quot;age&quot;: 26,\r\n        &quot;occupation&quot;: &quot;city planner&quot;,\r\n        &quot;cod&quot;: &quot;asphyxiation&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;jane doe&quot;,\r\n        &quot;sex&quot;: &quot;male&quot;,\r\n        &quot;age&quot;: 24,\r\n        &quot;occupation&quot;: &quot;beautician&quot;,\r\n        &quot;cod&quot;: &quot;strangulation&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;crispy lips&quot;,\r\n        &quot;sex&quot;: &quot;male&quot;,\r\n        &quot;age&quot;: 38,\r\n        &quot;occupation&quot;: &quot;convicted killer&quot;\r\n      }\r\n    ]\r\n    $\r\n\r\nThen we can do basic regex-filter/transform like this:\r\n\r\n    $ cat in.json | jq &#39;.[] | .name&#39;\r\n    &quot;john doe&quot;\r\n    &quot;jane doe&quot;\r\n    &quot;crispy lips&quot;\r\n    $\r\n    $ cat in.json | jq &#39;.[] | .name | select(.|test(&quot;.*doe&quot;))&#39;\r\n    &quot;john doe&quot;\r\n    &quot;jane doe&quot;\r\n    $\r\n    $ cat in.json | jq &#39;.[] | select(.name|test(&quot;.*doe&quot;))&#39;\r\n    {\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;age&quot;: 26,\r\n      &quot;occupation&quot;: &quot;city planner&quot;,\r\n      &quot;cod&quot;: &quot;asphyxiation&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;age&quot;: 24,\r\n      &quot;occupation&quot;: &quot;beautician&quot;,\r\n      &quot;cod&quot;: &quot;strangulation&quot;\r\n    }\r\n    $ \r\n    $ cat in.json | jq &#39;.[] | select(.name|test(&quot;.*doe&quot;)) | {n: .name, a: .age}&#39;\r\n    {\r\n      &quot;n&quot;: &quot;john doe&quot;,\r\n      &quot;a&quot;: 26\r\n    }\r\n    {\r\n      &quot;n&quot;: &quot;jane doe&quot;,\r\n      &quot;a&quot;: 24\r\n    }\r\n    $ \r\n    $ \r\n\r\n",
                "title": "Filter by Regex in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 43,
        "last_activity_date": 1602609552,
        "creation_date": 1529027829,
        "question_id": 50868203,
        "body_markdown": "    [{\r\n      &quot;Address&quot;: &quot;The Sq&quot;\r\n     },\r\n     {\r\n      &quot;Address&quot;: &quot;1 Bridge Rd&quot;\r\n    }]\r\n\r\nWith the following JSON, how do I write a script using JQ to filter for a regex where i want the result to be only Address&#39;s with numbers as the first character. I build this JSON using \r\n\r\n    map({ Address: .[].payload.address })\r\n\r\nhow do i add to this to filter for the regex expression I want (which is \\A[0-9])",
        "link": "https://stackoverflow.com/questions/50868203/filter-by-regex-in-jq",
        "title": "Filter by Regex in JQ"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "shell",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1529097620,
                "post_id": 50882417,
                "comment_id": 88767788,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529097852,
                "post_id": 50882417,
                "comment_id": 88767857,
                "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": 1529097868,
                "post_id": 50882417,
                "comment_id": 88767863,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "reply_to_user": {
                    "account_id": 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": 1529097920,
                "post_id": 50882417,
                "comment_id": 88767876,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1761886,
                    "reputation": 309,
                    "user_id": 1608773,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a9c4cbe2b414d6e7e1c70f000fecfb8c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sandeep R Venkatesh",
                    "link": "https://stackoverflow.com/users/1608773/sandeep-r-venkatesh"
                },
                "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": 1529098713,
                "post_id": 50882417,
                "comment_id": 88768120,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1761886,
                    "reputation": 309,
                    "user_id": 1608773,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a9c4cbe2b414d6e7e1c70f000fecfb8c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sandeep R Venkatesh",
                    "link": "https://stackoverflow.com/users/1608773/sandeep-r-venkatesh"
                },
                "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": 1529098722,
                "post_id": 50882417,
                "comment_id": 88768124,
                "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": 1529099106,
                "post_id": 50882417,
                "comment_id": 88768231,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1761886,
                    "reputation": 309,
                    "user_id": 1608773,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a9c4cbe2b414d6e7e1c70f000fecfb8c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sandeep R Venkatesh",
                    "link": "https://stackoverflow.com/users/1608773/sandeep-r-venkatesh"
                },
                "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": 1529099495,
                "post_id": 50882417,
                "comment_id": 88768343,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1529097587,
                "creation_date": 1529097587,
                "answer_id": 50882800,
                "question_id": 50882417,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the invocation:\r\n\r\n    $ jq -c &#39;.names |= map(select(test(&quot;^pat_&quot;)|not))&#39; \r\n\r\nproduces:\r\n\r\n    {&quot;names&quot;:[&quot;name1&quot;,&quot;name2&quot;,&quot;name3&quot;]}",
                "title": "Filtering JSON list in shell using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1529121409,
        "creation_date": 1529095420,
        "last_edit_date": 1529121409,
        "question_id": 50882417,
        "body_markdown": "**Input :** \r\n\r\n    { &quot;names&quot; : [&quot;name1&quot;,&quot;name2&quot;,&quot;name3&quot;,&quot;pat_name4&quot;] }\r\n\r\n**Needed output :**\r\n\r\n    { &quot;names&quot; : [&quot;name1&quot;,&quot;name2&quot;,&quot;name3&quot;] }\r\n\r\nCurrently what i have by running command, to filter out all names starting with `pat_`  \r\n\r\n    cat file | jq .names | grep -Ev &#39;^(pat_)&#39;\r\n\r\nis this\r\n\r\n    [&quot;name1&quot;,&quot;name2&quot;,&quot;name3&quot;]\r\n\r\nWas wondering if there is some alteration to the **jq** command that could be done to get in the format needed.",
        "link": "https://stackoverflow.com/questions/50882417/filtering-json-list-in-shell-using-jq",
        "title": "Filtering JSON list in shell using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "converters",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1529127780,
                "last_edit_date": 1529127780,
                "creation_date": 1529127171,
                "answer_id": 50885256,
                "question_id": 50884993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The appropriate approach to solving the problem using jq is essentially the same as would be used using `awk`: for each input line (except the first), parse it and emit the corresponding JSON object.  For the sake of clarity, let&#39;s define a function for handling each of the input lines (read in as a string):\r\n\r\n    def parse:\r\n      [splits(&quot; +&quot;)]\r\n      | {(.[0]) : {type: .[1],\r\n                   input: (.[2] | fromjson),\r\n                   config: { file: .[3],\r\n                               th: .[4] }} };\r\n      \r\n\r\nThe solution is then simply:\r\n\r\n    { dets: [inputs | parse] | add }\r\n\r\nThe appropriate invocation of jq would look like this:\r\n\r\n    jq -R -f program.jq input.txt\r\n\r\nNote that omitting the `-n` command-line option here has the effect of skipping the header line.\r\n\r\nThis invocation will produce the JSON shown below.  Note that the text shown as JSON in the question is strictly speaking not JSON, but since the stated goal is to produce JSON, we&#39;ll leave it at that.\r\n\r\n## Caveats\r\n\r\nThe above solution makes various assumptions, notably:\r\n\r\n1) the fields are &quot;space-separated&quot; in the sense of matching the regex &quot; +&quot;; in particular, it is assumed that the array is presented without any embedded spaces.\r\n2) the &quot;input&quot; field can be parsed using `fromjson`; if there is any doubt about that, then use `(fromjson? // .)` instead.\r\n\r\n## Output\r\n\r\n    {\r\n      &quot;dets&quot;: {\r\n        &quot;S1&quot;: {\r\n          &quot;type&quot;: &quot;class&quot;,\r\n          &quot;input&quot;: [\r\n            12,\r\n            7,\r\n            6,\r\n            19\r\n          ],\r\n          &quot;config&quot;: {\r\n            &quot;file&quot;: &quot;sfile1&quot;,\r\n            &quot;th&quot;: &quot;-10&quot;\r\n          }\r\n        },\r\n        &quot;S2&quot;: {\r\n          &quot;type&quot;: &quot;class&quot;,\r\n          &quot;input&quot;: [\r\n            12,\r\n            7,\r\n            6,\r\n            19\r\n          ],\r\n          &quot;config&quot;: {\r\n            &quot;file&quot;: &quot;sfile2&quot;,\r\n            &quot;th&quot;: &quot;-5&quot;\r\n          }\r\n        },\r\n        &quot;S3&quot;: {\r\n          &quot;type&quot;: &quot;bottom&quot;,\r\n          &quot;input&quot;: [\r\n            12,\r\n            7,\r\n            16\r\n          ],\r\n          &quot;config&quot;: {\r\n            &quot;file&quot;: &quot;sfile3&quot;,\r\n            &quot;th&quot;: &quot;-15&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n",
                "title": "nested json from text input using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529148663,
        "creation_date": 1529123733,
        "last_edit_date": 1529148663,
        "question_id": 50884993,
        "body_markdown": "I have text data which looks like (space separated snippet):\r\nFirst line is the header:\r\n\r\n    name type input file th repeatNumber\r\n    S1 class [12,7,6,19] sfile1 -10 2\r\n    S2 class [12,7,6,19] sfile2 -5 1\r\n    S3 bottom [12,7,16] sfile3 -15 1\r\n\r\nUsing shell script or command line (preferably using jq) want to convert this to one nested json  which would look like:\r\n\r\n    &#39;dets&#39;:{\r\n           &#39;S1&#39;:{\r\n                &#39;type&#39;:&#39;class&#39;,\r\n                &#39;input&#39;: [12,7,6,19],\r\n                &#39;config&#39;:{\r\n                        &#39;file&#39;:&#39;sfile1&#39;,\r\n                         &#39;th&#39;: -10\r\n                        }\r\n                 },\r\n            &#39;S2&#39;:{\r\n                &#39;type&#39;:&#39;class&#39;,\r\n                &#39;input&#39;: [12,7,6,19],\r\n                &#39;config&#39;:{\r\n                        &#39;file&#39;:&#39;sfile2&#39;,\r\n                         &#39;th&#39;: -5\r\n                        }\r\n                 },\r\n            &#39;S3&#39;:{\r\n                &#39;type&#39;:&#39;bottom&#39;,\r\n                &#39;input&#39;: [12,7,16],\r\n                &#39;config&#39;:{\r\n                        &#39;file&#39;:&#39;sfile3&#39;,\r\n                         &#39;th&#39;: -15\r\n                        }\r\n                 }\r\n            }\r\n ",
        "link": "https://stackoverflow.com/questions/50884993/nested-json-from-text-input-using-jq",
        "title": "nested json from text input using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "ini"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 124949,
                    "reputation": 2713,
                    "user_id": 320399,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/72d37732b0310b41834d9fb909d46b15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "blong",
                    "link": "https://stackoverflow.com/users/320399/blong"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1647285221,
                "post_id": 50902634,
                "comment_id": 126328553,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1529297705,
                "creation_date": 1529297705,
                "answer_id": 50902853,
                "question_id": 50902634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To convert an array as shown to the &quot;.ini&quot; format could be accomplished by simply using this jq program:\r\n\r\n\r\n    def kv: to_entries[] | &quot;\\(.key)=\\(.value)&quot;;\r\n    \r\n    .[]\r\n    | to_entries[]\r\n    | &quot;[\\(.key)]&quot;, (.value|kv)\r\n\r\nPutting this in a file, say program.jq, then assuming the JSON shown in the question (minus the &quot;...&quot; part) is in input.json, the following invocation:\r\n\r\n    jq -rf program.jq input.json\r\n\r\nyields the corresponding &quot;.ini&quot; file.\r\n\r\nIf you want to ensure that the program will also handle the case when there is no enclosing array, you could modify the first line in the main program above to test whether the input is an array, so you&#39;d have:\r\n\r\n    if type == &quot;array&quot; then .[] else . end\r\n    | to_entries[]\r\n    | &quot;[\\(.key)]&quot;, (.value|kv)\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Transform json to ini files using jq + bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1531199407,
                "creation_date": 1531199407,
                "answer_id": 51257620,
                "question_id": 50902634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the ultimate goal is to produce several .ini files, then we can reuse `def kv` as defined in the other answer:\r\n\r\n    def kv: to_entries[] | &quot;\\(.key)=\\(.value)&quot;;\r\n\r\nThe driver program would however now be:\r\n\r\n    .[]\r\n    | [to_entries[] | &quot;[\\(.key)]&quot;, (.value|kv)]\r\n    | join(&quot;\\n&quot;)\r\n\r\nRunning jq with this program then yields one JSON string for each item in the array. Using the example, the first such string would be:\r\n\r\n    &quot;[connection]\\nid=br0\\nuuid=ab1dd903-4786-4c7e-a4b4-3339b144d6c7\\nstable-id=\\ntype=bridge\\ninterface-name=br0\\nautoconnect=no\\nautoconnect-priority=0\\nautoconnect-retries=-1\\nauth-retries=-1\\ntimestamp=44444\\nread-only=no\\npermissions=\\nzone=WAN\\nmaster=\\nslave-type=\\nautoconnect-slaves=1\\nsecondaries=\\ngateway-ping-timeout=0\\nmetered=unknown\\nlldp=default\\n[ipv4]\\nmethod=manual\\ndns=192.168.1.1,192.168.2.1\\ndns-search=\\ndns-options= \\ndns-priority=0\\naddresses=192.168.1.3/24\\ngateway=\\nroutes=192.168.10.0/24 192.168.1.1\\nroute-metric=-1\\nroute-table=0\\nignore-auto-routes=no\\nignore-auto-dns=no\\ndhcp-client-id=\\ndhcp-timeout=0\\ndhcp-send-hostname=yes\\ndhcp-hostname=\\ndhcp-fqdn=\\nnever-default=no\\nmay-fail=yes\\ndad-timeout=-1&quot;\r\n\r\n\r\nYou can then iterate over these newline-delimited strings.",
                "title": "Transform json to ini files using jq + bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1531199407,
        "creation_date": 1529295608,
        "last_edit_date": 1529298414,
        "question_id": 50902634,
        "body_markdown": "I&#39;m trying to transform json (array of objects) to ini files:\r\n\r\n    [\r\n      {\r\n        &quot;connection&quot;: {\r\n          &quot;id&quot;: &quot;br0&quot;,\r\n          &quot;uuid&quot;: &quot;ab1dd903-4786-4c7e-a4b4-3339b144d6c7&quot;,\r\n          &quot;stable-id&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;bridge&quot;,\r\n          &quot;interface-name&quot;: &quot;br0&quot;,\r\n          &quot;autoconnect&quot;: &quot;no&quot;,\r\n          &quot;autoconnect-priority&quot;: &quot;0&quot;,\r\n          &quot;autoconnect-retries&quot;: &quot;-1&quot;,\r\n          &quot;auth-retries&quot;: &quot;-1&quot;,\r\n          &quot;timestamp&quot;: &quot;44444&quot;,\r\n          &quot;read-only&quot;: &quot;no&quot;,\r\n          &quot;permissions&quot;: &quot;&quot;,\r\n          &quot;zone&quot;: &quot;WAN&quot;,\r\n          &quot;master&quot;: &quot;&quot;,\r\n          &quot;slave-type&quot;: &quot;&quot;,\r\n          &quot;autoconnect-slaves&quot;: &quot;1&quot;,\r\n          &quot;secondaries&quot;: &quot;&quot;,\r\n          &quot;gateway-ping-timeout&quot;: &quot;0&quot;,\r\n          &quot;metered&quot;: &quot;unknown&quot;,\r\n          &quot;lldp&quot;: &quot;default&quot;\r\n        },\r\n        &quot;ipv4&quot;: {\r\n          &quot;method&quot;: &quot;manual&quot;,\r\n          &quot;dns&quot;: &quot;192.168.1.1,192.168.2.1&quot;,\r\n          &quot;dns-search&quot;: &quot;&quot;,\r\n          &quot;dns-options&quot;: &quot; &quot;,\r\n          &quot;dns-priority&quot;: &quot;0&quot;,\r\n          &quot;addresses&quot;: &quot;192.168.1.3/24&quot;,\r\n          &quot;gateway&quot;: &quot;&quot;,\r\n          &quot;routes&quot;: &quot;192.168.10.0/24 192.168.1.1&quot;,\r\n          &quot;route-metric&quot;: &quot;-1&quot;,\r\n          &quot;route-table&quot;: &quot;0&quot;,\r\n          &quot;ignore-auto-routes&quot;: &quot;no&quot;,\r\n          &quot;ignore-auto-dns&quot;: &quot;no&quot;,\r\n          &quot;dhcp-client-id&quot;: &quot;&quot;,\r\n          &quot;dhcp-timeout&quot;: &quot;0&quot;,\r\n          &quot;dhcp-send-hostname&quot;: &quot;yes&quot;,\r\n          &quot;dhcp-hostname&quot;: &quot;&quot;,\r\n          &quot;dhcp-fqdn&quot;: &quot;&quot;,\r\n          &quot;never-default&quot;: &quot;no&quot;,\r\n          &quot;may-fail&quot;: &quot;yes&quot;,\r\n          &quot;dad-timeout&quot;: &quot;-1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;connection&quot;: {\r\n          ...\r\n        },\r\n      }\r\n    ]\r\n\r\nOR\r\n\r\n      {\r\n        &quot;connection&quot;: {\r\n          ...\r\n        },\r\n      }\r\n\r\n**What i tried to do is:**\r\n\r\n**1. Transform json to strings**\r\n\r\n    data=$(jq -r &#39;def keyValue:  to_entries[] | &quot;[\\(.key)]\\\\n\\(.value | to_entries|map(&quot;\\(.key)=\\(.value)&quot; ) | join(&quot;\\\\n&quot;) )\\\\n&quot;; if type == &quot;array&quot; then keys[] as $k | &quot;\\(.[$k] | .connection.id)=\\(.[$k] | keyValue)&quot; elif type == &quot;object&quot; then &quot;\\(.connection.id)=\\(. | keyValue)&quot; else keys end&#39; /tmp/json)\r\n\r\nProvides:\r\n\r\n    br1=[connection]\\nid=br1\\nuuid=ab1dd903-4786-4c7e-a4b4-3339b144d6c7\\nstable-id=\\ntype=fff\\ninterface-name=br0\\nautoconnect=no\\nautoconnect-priority=0\\nautoconnect-retries=-1\\nauth-retries=-1\\ntimestamp=1525494904\\nread-only=no\\npermissions=\\nzone=WAN\\nmaster=\\nslave-type=\\nautoconnect-slaves=1\\nsecondaries=\\ngateway-ping-timeout=0\\nmetered=unknown\\nlldp=default\\n\r\n    br1=[802-3-ethernet]\\nport=\\nspeed=0\\nduplex=\\nauto-negotiate=no\\nmac-address=\\ncloned-mac-address=\\ngenerate-mac-address-mask=\\nmac-address-blacklist=\\nmtu=1500\\ns390-subchannels=\\ns390-nettype=\\ns390-options=\\nwake-on-lan=default\\nwake-on-lan-password=\\n....\r\n\r\n**2. Walk over strings in bash**\r\n\r\n    while IFS=&quot;=&quot; read -r key value; do [ &quot;$oldkey&quot; = &quot;$key&quot; ] &amp;&amp; echo -en &quot;$value&quot; &gt;&gt; &quot;/tmp/ini/$key&quot; || echo -en &quot;$value&quot; &gt; &quot;/tmp/ini/$key&quot; ; oldkey=&quot;$key&quot;; done &lt;&lt;&lt; &quot;$data&quot;\r\n\r\nGives:\r\n\r\n    [connection]\r\n    id=br1\r\n    uuid=ab1dd903-4786-4c7e-a4b4-3339b144d6c7\r\n    stable-id=\r\n    type=fff\r\n    interface-name=br0\r\n    autoconnect=no\r\n    autoconnect-priority=0\r\n    autoconnect-retries=-1\r\n    auth-retries=-1\r\n    timestamp=1525494904\r\n    read-only=no\r\n    permissions=\r\n    zone=WAN\r\n    master=\r\n    slave-type=\r\n    autoconnect-slaves=1\r\n    secondaries=\r\n    gateway-ping-timeout=0\r\n    metered=unknown\r\n    lldp=default\r\n    [ipv4]\r\n    method=manual\r\n    dns=192.168.1.1,192.168.2.1\r\n    dns-search=\r\n    dns-options= \r\n    dns-priority=0\r\n    addresses=192.168.1.3/24\r\n    gateway=\r\n    routes=192.168.10.0/24 192.168.1.1\r\n    route-metric=-1\r\n    route-table=0\r\n    ignore-auto-routes=no\r\n    ignore-auto-dns=no\r\n    dhcp-client-id=\r\n    dhcp-timeout=0\r\n    dhcp-send-hostname=yes\r\n    dhcp-hostname=\r\n    dhcp-fqdn=\r\n    never-default=no\r\n    may-fail=yes\r\n    dad-timeout=-1\r\n\r\n\r\nI&#39;m almost there! But is there possible to do it more &quot;elegantly&quot; and more performance way, avoiding pipes, external calls, etc.\r\n\r\n**Note:** Moreover, mostly it should be done with jq + bash, because other processing tools like sed, awk is slower than i&#39;ve done, but i do not reject them completely =)\r\n\r\n**P.S.** - Main purpose of this transforming is the fast &quot;bulk operation&quot; to write ini files\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50902634/transform-json-to-ini-files-using-jq-bash",
        "title": "Transform json to ini files using jq + bash"
    },
    {
        "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": 1529326400,
                "post_id": 50909616,
                "comment_id": 88819895,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "reply_to_user": {
                    "account_id": 8361588,
                    "reputation": 1475,
                    "user_id": 6279687,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/QaLOG.jpg?s=256",
                    "display_name": "Abhishek Patil",
                    "link": "https://stackoverflow.com/users/6279687/abhishek-patil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529327800,
                "post_id": 50909616,
                "comment_id": 88820718,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8361588,
                    "reputation": 1475,
                    "user_id": 6279687,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/QaLOG.jpg?s=256",
                    "display_name": "Abhishek Patil",
                    "link": "https://stackoverflow.com/users/6279687/abhishek-patil"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529328260,
                "post_id": 50909616,
                "comment_id": 88821023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5042873,
                    "reputation": 1207,
                    "user_id": 4049723,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/mzpoP.jpg?s=256",
                    "display_name": "Protozoid",
                    "link": "https://stackoverflow.com/users/4049723/protozoid"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529756717,
                "post_id": 50909616,
                "comment_id": 88996003,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662828903,
                "last_edit_date": 1662828903,
                "creation_date": 1529756146,
                "answer_id": 51001074,
                "question_id": 50909616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easy:\r\n\r\n    cat input.json | jq &#39;.x[]&#39;\r\n\r\n* `.x`: get value of `x` property\r\n* `[]`: access array elements\r\n\r\nIf you want it as a valid JSON array, remove the `[]` part: `.x`. `--raw-output`/`-r` outputs top-level strings without quotation marks, e.g.:\r\n\r\n    $ jq &#39;.x&#39; &lt; input.json\r\n    [  \r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n\r\n    $ jq &#39;.x[]&#39; &lt; input.json\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n    &quot;c&quot;\r\n\r\n    $ jq -r &#39;.x[]&#39; &lt; input.json\r\n    a\r\n    b\r\n    c\r\n\r\n[Try it online](https://jqplay.org/s/gHy_uOH0Yi)",
                "title": "List key values of JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662828903,
        "creation_date": 1529325199,
        "last_edit_date": 1529327783,
        "question_id": 50909616,
        "body_markdown": "I have JSON file like the below; I need to list only x or y values only using jq:\r\n\r\n    {  \r\n       &quot;x&quot;:[  \r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n       ],\r\n       &quot;y&quot;:[  \r\n          &quot;d&quot;,\r\n          &quot;e&quot;\r\n       ]\r\n    }\r\n\r\nI need to get only x values like \r\n\r\n    a\r\n    b\r\n    c\r\n\r\nHow can I do that?",
        "link": "https://stackoverflow.com/questions/50909616/list-key-values-of-json-file-using-jq",
        "title": "List key values of JSON file using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1529336738,
                "creation_date": 1529336738,
                "answer_id": 50913141,
                "question_id": 50913090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use parentheses:\r\n\r\n    [.CertificateArn, (.InUseBy | length)]",
                "title": "How do I use jq to find the count of one of multiple output objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1529336738,
        "creation_date": 1529336567,
        "question_id": 50913090,
        "body_markdown": "Looking to find the object count in the InUseBy element.\r\n\r\n    aws acm describe-certificate \\\r\n      --certificate-arn arn:### \\\r\n      | jq -r &#39;.Certificate | [.CertificateArn, .InUseBy] | @tsv&#39;\r\n\r\n\r\n`| length` is what I want to use but I&#39;m unsure how to limit it to just `InUseBy`\r\n\r\n`[.CertificateArn, .InUseBy | length]` applies length to all items, how do I limit it to `InUseBy`",
        "link": "https://stackoverflow.com/questions/50913090/how-do-i-use-jq-to-find-the-count-of-one-of-multiple-output-objects",
        "title": "How do I use jq to find the count of one of multiple output objects"
    },
    {
        "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": 1529357115,
                "post_id": 50917660,
                "comment_id": 88835380,
                "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": 1529357223,
                "post_id": 50917660,
                "comment_id": 88835424,
                "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": 1529358006,
                "post_id": 50917660,
                "comment_id": 88835720,
                "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": 1529409718,
                "post_id": 50917660,
                "comment_id": 88854724,
                "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": 1529410058,
                "post_id": 50917660,
                "comment_id": 88854896,
                "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": 1529410178,
                "post_id": 50917660,
                "comment_id": 88854970,
                "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": 1529410309,
                "post_id": 50917660,
                "comment_id": 88855054,
                "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": 1529410514,
                "post_id": 50917660,
                "comment_id": 88855188,
                "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": 1529411135,
                "post_id": 50917660,
                "comment_id": 88855574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 388012,
                    "reputation": 174,
                    "user_id": 746692,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/b9b34a0235ac6cfce189f73d511c0ec2?s=256&d=identicon&r=PG",
                    "display_name": "phil",
                    "link": "https://stackoverflow.com/users/746692/phil"
                },
                "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": 1529413507,
                "post_id": 50917660,
                "comment_id": 88857210,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 388012,
                    "reputation": 174,
                    "user_id": 746692,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/b9b34a0235ac6cfce189f73d511c0ec2?s=256&d=identicon&r=PG",
                    "display_name": "phil",
                    "link": "https://stackoverflow.com/users/746692/phil"
                },
                "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": 1529413775,
                "post_id": 50917660,
                "comment_id": 88857372,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 388012,
                    "reputation": 174,
                    "user_id": 746692,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/b9b34a0235ac6cfce189f73d511c0ec2?s=256&d=identicon&r=PG",
                    "display_name": "phil",
                    "link": "https://stackoverflow.com/users/746692/phil"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1529419453,
                "post_id": 50917660,
                "comment_id": 88861226,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1529410440,
                "last_edit_date": 1529410440,
                "creation_date": 1529357544,
                "answer_id": 50917766,
                "question_id": 50917660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s say your input format is:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    host_1 1 2 3\r\n    host_2 2 3 4\r\n    host-with-dashes 3 4 5\r\n    host-with-no-addresses\r\n\r\n&lt;sub&gt;...re: edit specifying a different format: Add `@tsv` onto the JQ command producing the existing format to generate this one instead.&lt;/sub&gt;\r\n\r\nIf you want to transform that to the format in question, it might look like:\r\n\r\n    jq -Rn &#39;\r\n    { &quot;hosts&quot;: [inputs |\r\n                split(&quot;\\\\s+&quot;; &quot;g&quot;) |\r\n                select(length &gt; 0 and .[0] != &quot;&quot;) |\r\n                {(.[0]): .[1:]}\r\n               ] | add\r\n    }&#39; &lt;input.txt\r\n\r\nWhich yields as output:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;hosts&quot;: {\r\n        &quot;host_1&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;host_2&quot;: [\r\n          &quot;2&quot;,\r\n          &quot;3&quot;,\r\n          &quot;4&quot;\r\n        ],\r\n        &quot;host-with-dashes&quot;: [\r\n          &quot;3&quot;,\r\n          &quot;4&quot;,\r\n          &quot;5&quot;\r\n        ],\r\n        &quot;host-with-no-addresses&quot;: []\r\n      }\r\n    }",
                "title": "Building new JSON with JQ and bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529413376,
        "creation_date": 1529356978,
        "last_edit_date": 1529413376,
        "question_id": 50917660,
        "body_markdown": "I am trying to create JSON from scratch using bash. \r\n\r\nThe final structure needs to be like:\r\n\r\n    {\r\n      &quot;hosts&quot;: {\r\n        &quot;a_hostname&quot; : {\r\n          &quot;ips&quot; : [\r\n              1,\r\n              2,\r\n              3\r\n          ]\r\n        },\r\n        {...}\r\n      }\r\n    }\r\n\r\n---\r\n\r\nFirst I&#39;m creating an input file with the format:\r\n\r\n    hostname [&quot;1.1.1.1&quot;,&quot;2.2.2.2&quot;]\r\n    host-name2 [&quot;3.3.3.3&quot;,&quot;4.4.4.4&quot;]\r\n\r\nThis is being created by:\r\n\r\n    for host in $( ansible -i hosts all --list-hosts ) ; \\\r\n        do echo -n &quot;${host} &quot; ; \\\r\n        ansible -i hosts $host -m setup | sed &#39;1c {&#39; | jq -r -c &#39;.ansible_facts.ansible_all_ipv4_addresses&#39; ; \\\r\n    done &gt; hosts.txt\r\n\r\nThe key point here is that the IP list/array, is coming from a JSON file and being extracted by jq. This extraction outputs an already valid / quoted JSON array, but as a string in a txt file.\r\n\r\nNext I&#39;m using jq to parse the whole text file into the desired JSON:\r\n\r\n    jq -Rn &#39;\r\n        { &quot;hosts&quot;: [inputs |\r\n            split(&quot;\\\\s+&quot;; &quot;g&quot;) |\r\n            select(length &gt; 0 and .[0] != &quot;&quot;) |\r\n            {(.[0]):\r\n                {ips:.[1]}\r\n            }\r\n        ] | add }\r\n    &#39; &lt; ~/hosts.txt\r\n\r\nThis is almost correct, everything except for the IPs value which is treated as a string and quoted leading to:\r\n\r\n    {\r\n        &quot;hosts&quot;: {\r\n            &quot;hostname1&quot;: {\r\n                &quot;ips&quot;: &quot;[\\&quot;1.1.1.1\\&quot;,\\&quot;2.2.2.2\\&quot;]&quot;\r\n            },\r\n            &quot;host-name2&quot;: {\r\n                &quot;ips&quot;: &quot;[\\&quot;3.3.3.3\\&quot;,\\&quot;4.4.4.4\\&quot;]&quot;\r\n            }\r\n        }\r\n    }\r\n\r\n\r\nI&#39;m now stuck at this final hurdle - how to insert the IPs without causing them to be quoted again.\r\n\r\n---\r\n\r\n**Edit** - quoting solved by using `{ips: .[1] | fromjson }}` instead of `{ips:.[1]}`. \r\nHowever this was completely negated by @CharlesDuffy&#39;s help [suggesting converting to TSV](https://stackoverflow.com/questions/50917660/building-new-json-with-jq-and-bash?noredirect=1#comment88855054_50917660).\r\n\r\n---\r\n\r\n\r\n---\r\nOriginal Q body:\r\n----------\r\n\r\nSo far I&#39;ve got to\r\n\r\n    jq -n {hosts:{}} | \\\r\n    for host in $( ansible -i hosts all --list-hosts ) ; \\\r\n        do jq &quot;.hosts += {$host:{}}&quot; | \\\r\n        jq &quot;.hosts.$host += {ips:[1,2,3]}&quot; ; \\\r\n    done ;\r\n\r\n(`[1,2,3]` is actually coming from a subshell but including it seemed unnecessary as that part works, and made it harder to read)\r\n\r\nThis sort of works, but there seems to be 2 problems.\r\n\r\n1) Final output only has a single host in it containg data from the first host in the list (this persists even if the second problem is bypassed):\r\n\r\n    {\r\n      &quot;hosts&quot;: {\r\n        &quot;host_1&quot;: {\r\n          &quot;ips&quot;: [\r\n            1,\r\n            2,\r\n            3\r\n          ]\r\n        }\r\n      }\r\n    }\r\n2) One of the hostnames has a `-` in it, which causes syntax and compiler errors from jq. I&#39;m stuck going around quote hell trying to get it to be interpreted but also quoted. Help!\r\n\r\nThanks for any input.",
        "link": "https://stackoverflow.com/questions/50917660/building-new-json-with-jq-and-bash",
        "title": "Building new JSON with JQ and bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "nested",
            "jq",
            "data-manipulation"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529363115,
                "creation_date": 1529363115,
                "answer_id": 50918563,
                "question_id": 50917916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found something that I can work with.\r\n\r\nIf I wrap the query with []...\r\n\r\n    cat ranger_v2.json | jq -r &#39;[.[] | {&quot;id&quot;, &quot;access_type&quot;:([.policyItems[].accesses[] | .type])}]&#39;\r\n\r\n... it produces this type of output:\r\n\r\n    [\r\n     {\r\n      &quot;id&quot;: 1,\r\n      &quot;access_type&quot;: [&quot;drop&quot;,&quot;select&quot;]\r\n     },\r\n     {\r\n      &quot;id&quot;: 2,\r\n      &quot;access_type&quot;: [&quot;drop&quot;,&quot;update&quot;]\r\n    }\r\n    ]\r\n\r\nI can then use the following:\r\n\r\n    (if (.&quot;access_type&quot; | length &gt; 0 ) then . else .&quot;access_type&quot; = [&quot;&quot;]  end )]\r\n\r\nand\r\n\r\n    (.&quot;access_type&quot; | @tsv)\r\n\r\nBefore I can convert to @csv and use sed to replace the tab with a pipe.\r\n\r\n    @csv&#39; | sed -e &quot;s/[\\t]\\+/|/g&quot;\r\n\r\nIt may not be the most economical way of getting what I need, but it works for me. (Please let me know if there&#39;s a better way of doing it.)\r\n\r\n    cat ranger_v2.json | jq -r &#39;[.[] | {&quot;id&quot;, &quot;access_type&quot;:([.policyItems[].accesses[] | .type])}] | .[] | [(if (.&quot;access_type&quot; | length &gt; 0 ) then . else .&quot;access_type&quot; = [&quot;&quot;]  end )] | .[] | [.id, (.&quot;access_type&quot; | @tsv)] | @csv&#39;  | sed -e &quot;s/[\\t]\\+/|/g&quot;",
                "title": "JQ - return one array for multiple nested JSON arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1529373005,
                "creation_date": 1529373005,
                "answer_id": 50919600,
                "question_id": 50917916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s start by observing that with your input, the filter:\r\n\r\n    .[]\r\n    | {id, access_type: [.PolicyItems[].accesses[].type]}\r\n     \r\nproduces the two objects:\r\n\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;access_type&quot;: [\r\n        &quot;drop&quot;,\r\n        &quot;select&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;access_type&quot;: [\r\n        &quot;drop&quot;,\r\n        &quot;update&quot;\r\n      ]\r\n    }\r\n\r\nNow it&#39;s a simple matter to tweak the above filter so as to produce the desired format:\r\n\r\n    [.[]\r\n     | {id, access_type: [.PolicyItems[].accesses[].type]}\r\n     | .access_type |= [join(&quot;|&quot;)] ]\r\n\r\nOr equivalently, the one-liner:\r\n\r\n    map({id, access_type: [[.PolicyItems[].accesses[].type] | join(&quot;|&quot;)]})\r\n\r\n\r\n\r\n",
                "title": "JQ - return one array for multiple nested JSON arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1529411919,
        "creation_date": 1529358362,
        "last_edit_date": 1529411919,
        "question_id": 50917916,
        "body_markdown": "I have a JSON structure that has repeated keys per message. I would like to combine these into one array per message.\r\n\r\n    [\r\n\t{\r\n\t\t&quot;id&quot;: 1,\r\n\t\t&quot;PolicyItems&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;accesses&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;isAllowed&quot;: true, \r\n\t\t\t\t\t\t&quot;type&quot;: &quot;drop&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;isAllowed&quot;: true, \r\n\t\t\t\t\t\t&quot;type&quot;: &quot;select&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t], \r\n\t\t\t\t&quot;groups&quot;: [], \r\n\t\t\t\t&quot;users&quot;: [&quot;admin&quot;]\r\n\t\t\t}\r\n\t\t] \r\n\t},\r\n\t{\r\n\t\t&quot;id&quot;: 2,\r\n\t\t&quot;PolicyItems&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;accesses&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;isAllowed&quot;: true, \r\n\t\t\t\t\t\t&quot;type&quot;: &quot;drop&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;isAllowed&quot;: true, \r\n\t\t\t\t\t\t&quot;type&quot;: &quot;update&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t], \r\n\t\t\t\t&quot;groups&quot;: [], \r\n\t\t\t\t&quot;users&quot;: [\r\n\t\t\t\t\t&quot;admin&quot;,\r\n\t\t\t\t\t&quot;admin2&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t] \r\n\r\n\t}]\r\n\r\nI have this:\r\n\r\n    cat ranger_v2.json | jq -r &#39;[.[] | {&quot;id&quot;, &quot;access_type&quot;:(.policyItems[].accesses[] | .type)}]&#39;\r\n\r\nBut this outputs:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;access_type&quot;: &quot;drop&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;access_type&quot;: &quot;select&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;access_type&quot;: &quot;drop&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;access_type&quot;: &quot;update&quot;\r\n      }\r\n    ]\r\n\r\nHowever, what I want is to output:\r\n\r\n      [{\r\n        &quot;id&quot;: 1,\r\n        &quot;access_type&quot;: [&quot;drop|select&quot;]\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;access_type&quot;: [&quot;drop|update&quot;]\r\n      }]\r\n\r\nAny ideas how I could do this? I&#39;m a bit stumped!  \r\n\r\nThe values could be &#39;drop&#39; and &#39;select&#39;, but equally could be anything, so I don&#39;t want to hard code these.\r\n",
        "link": "https://stackoverflow.com/questions/50917916/jq-return-one-array-for-multiple-nested-json-arrays",
        "title": "JQ - return one array for multiple nested JSON arrays"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529394804,
                "creation_date": 1529394804,
                "answer_id": 50923262,
                "question_id": 50922765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could try:\r\n\r\n    jq -r &#39;.Data[] | &quot;\\(.Latitude) \\(.Longitude)&quot;&#39; /usr/location/archive/location_1806181400.json | while read l g; do \r\n      curl &quot;https://maps.googleapis.com/maps/api/geocode/json?latlng=${l},${g}&amp;key=APIKEYHERE&quot;; \r\n    done\r\n\r\nwhich is almost the same as yours, except for the `jq` script and the quoting for the `curl` command.",
                "title": "Parse variables from JSON, then loop through on several url with variables with curl"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1529394933,
                "creation_date": 1529394933,
                "answer_id": 50923297,
                "question_id": 50922765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is with your `jq` filter, you need to do an interpolation logic as below to put the values out in a CSV format, which you can parse out using a shell loop.\r\n\r\n    jq -r &#39;(.Data[] | &quot;\\(.Latitude),\\(.Longitude)&quot;)&#39;\r\n\r\nNow putting this in a loop\r\n\r\n    jq -r &#39;(.Data[] | &quot;\\(.Latitude),\\(.Longitude)&quot;)&#39; /usr/location/archive/location_1806181400.json |\r\n       while IFS=, read -r lat long; do\r\n           curl &quot;https://maps.googleapis.com/maps/api/geocode/json?latlng=${lat},${long}&amp;key=APIKEYHERE&quot;\r\n       done",
                "title": "Parse variables from JSON, then loop through on several url with variables with curl"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1541671323,
        "creation_date": 1529393120,
        "last_edit_date": 1541671323,
        "question_id": 50922765,
        "body_markdown": "I am new to jq. My business problem is the following: I have several GPS location address stored in several JSON.\r\nJSON format is like:\r\n\r\n    {\r\n    \t&quot;Data&quot;: [{\r\n    \t\t&quot;Date&quot;: &quot;2018-06-19T06:02:12+02:00&quot;,\r\n    \t\t&quot;Latitude&quot;: 46.54225,\r\n    \t\t&quot;Longitude&quot;: 17.13874,\r\n    \t\t&quot;Type&quot;: &quot;GPS&quot;,\r\n    \t\t&quot;Speed(mph)&quot;: 0,\r\n    \t\t&quot;Speed(km/h)&quot;: 0,\r\n    \t\t&quot;Direction&quot;: null,\r\n    \t\t&quot;Altitude(ft)&quot;: 406,\r\n    \t\t&quot;Altitude(m)&quot;: 124,\r\n    \t\t&quot;Accuracy&quot;: 50\r\n    \t},\r\n    \t{\r\n    \t\t&quot;Date&quot;: &quot;2018-06-19T06:59:49+02:00&quot;,\r\n    \t\t&quot;Latitude&quot;: 46.53973,\r\n    \t\t&quot;Longitude&quot;: 17.06964,\r\n    \t\t&quot;Type&quot;: &quot;GPS&quot;,\r\n    \t\t&quot;Speed(mph)&quot;: 1,\r\n    \t\t&quot;Speed(km/h)&quot;: 2,\r\n    \t\t&quot;Direction&quot;: 208,\r\n    \t\t&quot;Altitude(ft)&quot;: 377,\r\n    \t\t&quot;Altitude(m)&quot;: 115,\r\n    \t\t&quot;Accuracy&quot;: 10\r\n    \t}]\r\n    }\r\nI want to loop trough on the Latitude and Longitude values, store them in two variables one-by-one, and with these variables I want to call the Google&#39;s reverse geocoding rest API with shell script with every long-lat pair:\r\nhttps://maps.googleapis.com/maps/api/geocode/json?latlng=[VARIABLE1],[VARIABLE2]&amp;key=APIKEYHERE\r\n\r\nIn an other Stackoverflow question, there was a similar question. Thanks to that question, I tried something like this, but obviously the variables are not working properly:\r\n\r\n    &quot;error_message&quot; : &quot;Invalid request. Invalid &#39;latlng&#39; parameter.&quot;,\r\n    &quot;results&quot; : [],\r\n    &quot;status&quot; : &quot;INVALID_REQUEST&quot;\r\n\r\nCode:\r\n\r\n    jq -rc &#39;.Latitude + &quot; &quot; +.Longitude&#39; /usr/location/archive/location_1806181400.json |\r\n    while read -r Latitude Longitude; do\r\n        curl https://maps.googleapis.com/maps/api/geocode/json?latlng=$Latitude,$Longitude&amp;key=APIKEYHERE\r\n    done\r\n",
        "link": "https://stackoverflow.com/questions/50922765/parse-variables-from-json-then-loop-through-on-several-url-with-variables-with",
        "title": "Parse variables from JSON, then loop through on several url with variables with curl"
    },
    {
        "tags": [
            "json",
            "svg",
            "base64",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1529421891,
                "creation_date": 1529421891,
                "answer_id": 50931959,
                "question_id": 50929274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "base64 is a simple serialization algorithm, no loss involved.\r\n\r\nBut then, SVG is already a serialized (XML) string format, encoded in utf-8.  There is no need to use an extra serialization layer, and no problem in storing it in a JSON file, which is also in utf-8 (apart from the need to escape double quotes). If you don&#39;t want to use base64, [data URLs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) (which you might be aiming for, you didn&#39;t say) can also contain plain XML data. Like this:\r\n\r\n    data:image/svg+xml;charset=utf-8,&lt;svg xmlns=&quot;http://www.w3.org/2000/svg&quot;&gt;...&lt;/svg&gt;\r\n\r\n(Make sure to url-excape `#` as `%23`.)\r\n\r\nPerformance is something you need to test for yourself. In a specific use case I decided to use a JSON file containing base64-encoded strings because it was in fact the most performant solution, but that is no precedence you can rely on.",
                "title": "Store an SVG image in JSON or not?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1529479357,
                "last_edit_date": 1529479357,
                "creation_date": 1529472003,
                "answer_id": 50940730,
                "question_id": 50929274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use [jq][1] to encode the contents of the .svg file as a JSON string, e.g.\r\n\r\n    jq -Rs . media.svg\r\n\r\nOf course, you would probably want to use a more complex jq filter to embed the contents of the .svg file in your JSON.\r\n\r\nAs implied by the answers at https://stackoverflow.com/questions/6249664/does-svg-support-embedding-of-bitmap-images you should not need to base64-encode a SVG, but if you do need to base64-encode something, you can use jq&#39;s `@base64` filter.\r\nYou can verify this works for some file (say FILENAME) by decoding the string and comparing with the original.  If your jq has `@based64d`, this can be done by:\r\n\r\n    diff FILENAME &lt;(jq -Rs @base64 FILENAME | jq -r @base64d)\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
                "title": "Store an SVG image in JSON or not?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1715177944,
        "creation_date": 1529413620,
        "last_edit_date": 1715177944,
        "question_id": 50929274,
        "body_markdown": "I do not know if I&#39;m asking in the correct &quot;Stack&quot;, but at the moment I seem to be the most appropriate one. Let me also note if I&#39;m wrong, I&#39;ll immediately move the question to another Stack.\r\n\r\nI need to save a vector image (most likely it will be SVG format). We are considering how to memorize this image. The point is that we prefer to use only a JSON file, which means that you have to convert the SVG image to at least Base64, but is it lossless or not?\r\n\r\nThe alternative would be to save the local path of this SVG image in a field in the JSON file. This image and JSON files should not be sent over the network and conversion from Bas64 to SVG should not be too slow considering a PC environment. Based on your experiences, what do you recommend doing?",
        "link": "https://stackoverflow.com/questions/50929274/store-an-svg-image-in-json-or-not",
        "title": "Store an SVG image in JSON or not?"
    },
    {
        "tags": [
            "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": 1,
                "creation_date": 1529429228,
                "post_id": 50933785,
                "comment_id": 88866343,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12249882,
                    "reputation": 313,
                    "user_id": 8940581,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/709c5ccf59a9189b03278d4c75021f37?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Anil Kumar R",
                    "link": "https://stackoverflow.com/users/8940581/anil-kumar-r"
                },
                "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": 1529430106,
                "post_id": 50933785,
                "comment_id": 88866772,
                "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": 1529430212,
                "post_id": 50933785,
                "comment_id": 88866828,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529430603,
                "creation_date": 1529430603,
                "answer_id": 50934272,
                "question_id": 50933785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you split your inputs into two valid JSON documents, rather than having a JavaScript input which *is not* valid JSON, you could do the following:\r\n\r\n    requiredValue=5\r\n    x=&#39;\r\n    [{&quot;score&quot;:1},\r\n     {&quot;score&quot;:2},\r\n     {&quot;score&quot;:3}]\r\n    &#39;\r\n\r\n    jq -n \\\r\n       --argjson requiredValue &quot;$requiredValue&quot; \\\r\n       --argjson x &quot;$x&quot; &#39;\r\n      [$x[].score | select(. == $requiredValue)] | any\r\n    &#39;",
                "title": "Issue with jq when using in jenkins pipeline"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529431022,
                "creation_date": 1529431022,
                "answer_id": 50934396,
                "question_id": 50933785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following has been tested with bash:\r\n\r\n    requiredValue=5\r\n    \r\n    x=&#39;[\r\n    {&quot;score&quot;:1},\r\n    {&quot;score&quot;:2},\r\n    {&quot;score&quot;:3}\r\n    ]&#39;\r\n    \r\n    jq --argjson requiredValue $requiredValue &#39;\r\n      any(.[].score; . &gt;= $requiredValue)&#39; &lt;&lt;&lt; &quot;$x&quot;\r\n\r\nThe result:\r\n\r\n    false\r\n\r\n",
                "title": "Issue with jq when using in jenkins pipeline"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1529431022,
        "creation_date": 1529428808,
        "last_edit_date": 1529430005,
        "question_id": 50933785,
        "body_markdown": "I am having a JSON object x and a variable requiredValue\r\n\r\n    let requiredValue = 5;\r\n\r\n    let x = [\r\n    {&quot;score&quot;:1},\r\n    {&quot;score&quot;:2},\r\n    {&quot;score&quot;:3}\r\n    }\r\n\r\n\r\nHere using jq first i want to extract all score values and then check if any score value in the object is greater than or equal to requiredValue.\r\n\r\nHere is what I tried \r\n\r\n    jq -r &#39;.[].score | join(&quot;,&quot;) | contains([requiredValue])&#39;\r\n\r\nSuppose if requiredValue is 5 then jq query should return false and if requiredValue is 2 it should return true.",
        "link": "https://stackoverflow.com/questions/50933785/issue-with-jq-when-using-in-jenkins-pipeline",
        "title": "Issue with jq when using in jenkins pipeline"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq",
            "census",
            "hjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8622482,
                    "reputation": 11,
                    "user_id": 6456864,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c3f53d5601dd8d70b7200aeb716e022?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Srid",
                    "link": "https://stackoverflow.com/users/6456864/srid"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529438009,
                "post_id": 50933870,
                "comment_id": 88870555,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8622482,
                    "reputation": 11,
                    "user_id": 6456864,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c3f53d5601dd8d70b7200aeb716e022?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Srid",
                    "link": "https://stackoverflow.com/users/6456864/srid"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529438042,
                "post_id": 50933870,
                "comment_id": 88870567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529470788,
                "last_edit_date": 1529470788,
                "creation_date": 1529469391,
                "answer_id": 50940288,
                "question_id": 50933870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The good news is that tools such as hjson (http://hjson.org/users.html), any-json (https://www.npmjs.com/package/any-json) and\r\njson5 (npm install json5)\r\ncan handle both the top-level quasi-JSON objects, e.g. \r\n\r\n    hjson -j census.2.txt\r\n\r\nor:  \r\n\r\n    any-json --input-format=cson census.2.txt\r\n\r\nor:\r\n\r\n    json5 -c census.2.txt\r\n\r\n\r\nThe not-so-good news is that these three tools can only handle one top-level object at a time.\r\n\r\n## Option 1: split\r\nSo one possibility would be to split the response into two.\r\nThis would be easy if it can be assumed that only the top-level objects\r\nhave an opening brace (`{`)  in column 1.  Under this assumption, there are dozens of possibilities,\r\ne.g. using `split -p &#39;^{&#39;`\r\n\r\n## Option 2: hjson\r\nAnother possibility would be to wrap the response in square brackets, and use `hjson` to convert the pseudo-array into valid JSON.  \r\n\r\nThus if you only want the second object (converted to valid JSON), you could run:\r\n\r\n    (echo &quot;[&quot;; cat census.txt; echo &quot;]&quot;) | hjson -j | jq &#39;.[1]&#39;\r\n\r\nThis uses the wondrous [jq][1] utility, but there are others that can do the job as well.\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
                "title": "How to parse irregular JSON response from US Census API call?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529470847,
        "creation_date": 1529429098,
        "last_edit_date": 1529470847,
        "question_id": 50933870,
        "body_markdown": "The following is the response from a US Census API call. It uses irregular JSON (or simple javascript object) format in the response. In the form of \r\n{ one set of data} { second set of data}. How can one parse the second set, namely the array data that comes after the data: tag in the second { } block. Thank you very much.\r\n\r\n    { &#39;Incorporated Places&#39;: \r\n       [ { OID: 27890266655573,\r\n           STATE: &#39;24&#39;,\r\n           FUNCSTAT: &#39;A&#39;,\r\n           NAME: &#39;Annapolis city&#39;,\r\n           AREAWATER: 2344089,\r\n           LSADC: &#39;25&#39;,\r\n           CENTLON: &#39;-076.5039149&#39;,\r\n           PLACECC: &#39;C1&#39;,\r\n           BASENAME: &#39;Annapolis&#39;,\r\n           INTPTLAT: &#39;+38.9721517&#39;,\r\n           MTFCC: &#39;G4110&#39;,\r\n           PLACE: &#39;01600&#39;,\r\n           CBSAPCI: &#39;N&#39;,\r\n           GEOID: &#39;2401600&#39;,\r\n           PLACENS: &#39;02390562&#39;,\r\n           CENTLAT: &#39;+38.9706625&#39;,\r\n           INTPTLON: &#39;-076.5053318&#39;,\r\n           NECTAPCI: &#39;N&#39;,\r\n           AREALAND: 18668789,\r\n           OBJECTID: 17981 } ],\r\n      Counties: \r\n       [ { OID: 27590266629759,\r\n           STATE: &#39;24&#39;,\r\n           FUNCSTAT: &#39;A&#39;,\r\n           AREAWATER: 448136044,\r\n           NAME: &#39;Anne Arundel County&#39;,\r\n           LSADC: &#39;06&#39;,\r\n           CENTLON: &#39;-076.5675544&#39;,\r\n           BASENAME: &#39;Anne Arundel&#39;,\r\n           INTPTLAT: &#39;+38.9916103&#39;,\r\n           COUNTYCC: &#39;H1&#39;,\r\n           MTFCC: &#39;G4020&#39;,\r\n           COUNTY: &#39;003&#39;,\r\n           GEOID: &#39;24003&#39;,\r\n           CENTLAT: &#39;+38.9939578&#39;,\r\n           INTPTLON: &#39;-076.5607311&#39;,\r\n           AREALAND: 1074250699,\r\n           COUNTYNS: &#39;01710958&#39;,\r\n           OBJECTID: 1026 } ],\r\n      &#39;Census Tracts&#39;: \r\n       [ { OID: 20790266676100,\r\n           STATE: &#39;24&#39;,\r\n           FUNCSTAT: &#39;S&#39;,\r\n           NAME: &#39;Census Tract 7061.01&#39;,\r\n           AREAWATER: 249211,\r\n           LSADC: &#39;CT&#39;,\r\n           CENTLON: &#39;-076.4923901&#39;,\r\n           BASENAME: &#39;7061.01&#39;,\r\n           INTPTLAT: &#39;+38.9772243&#39;,\r\n           MTFCC: &#39;G5020&#39;,\r\n           COUNTY: &#39;003&#39;,\r\n           GEOID: &#39;24003706101&#39;,\r\n           CENTLAT: &#39;+38.9778105&#39;,\r\n           INTPTLON: &#39;-076.4922890&#39;,\r\n           AREALAND: 1216538,\r\n           OBJECTID: 9052,\r\n           TRACT: &#39;706101&#39; } ],\r\n      &#39;2010 Census Blocks&#39;: \r\n       [ { BLKGRP: &#39;2&#39;,\r\n           OID: 210404225273924,\r\n           FUNCSTAT: &#39;S&#39;,\r\n           STATE: &#39;24&#39;,\r\n           AREAWATER: 0,\r\n           NAME: &#39;Block 2014&#39;,\r\n           SUFFIX: &#39;&#39;,\r\n           LSADC: &#39;BK&#39;,\r\n           CENTLON: &#39;-076.4906778&#39;,\r\n           LWBLKTYP: &#39;L&#39;,\r\n           BASENAME: &#39;2014&#39;,\r\n           BLOCK: &#39;2014&#39;,\r\n           INTPTLAT: &#39;+38.9788709&#39;,\r\n           MTFCC: &#39;G5040&#39;,\r\n           COUNTY: &#39;003&#39;,\r\n           GEOID: &#39;240037061012014&#39;,\r\n           CENTLAT: &#39;+38.9788709&#39;,\r\n           INTPTLON: &#39;-076.4906778&#39;,\r\n           AREALAND: 15203,\r\n           OBJECTID: 3877566,\r\n           TRACT: &#39;706101&#39; } ],\r\n      States: \r\n       [ { OID: 27490140608205,\r\n           STATE: &#39;24&#39;,\r\n           FUNCSTAT: &#39;A&#39;,\r\n           NAME: &#39;Maryland&#39;,\r\n           AREAWATER: 6980364276,\r\n           LSADC: &#39;00&#39;,\r\n           CENTLON: &#39;-076.6789663&#39;,\r\n           STUSAB: &#39;MD&#39;,\r\n           BASENAME: &#39;Maryland&#39;,\r\n           INTPTLAT: &#39;+38.9466584&#39;,\r\n           DIVISION: &#39;5&#39;,\r\n           MTFCC: &#39;G4000&#39;,\r\n           STATENS: &#39;01714934&#39;,\r\n           GEOID: &#39;24&#39;,\r\n           CENTLAT: &#39;+38.9463607&#39;,\r\n           INTPTLON: &#39;-076.6744939&#39;,\r\n           REGION: &#39;3&#39;,\r\n           AREALAND: 25150702890,\r\n           OBJECTID: 5 } ] }\r\n    { level: &#39;state&#39;,\r\n      sublevel: true,\r\n      variables: [ &#39;income&#39;, &#39;population&#39;, &#39;C24010_011E&#39;, &#39;education_masters&#39; ],\r\n      year: 2015,\r\n      api: &#39;acs5&#39;,\r\n      lat: 38.9786,\r\n      lng: -76.4911,\r\n      state: &#39;24&#39;,\r\n      county: &#39;003&#39;,\r\n      tract: &#39;706101&#39;,\r\n      blockGroup: &#39;2&#39;,\r\n      place: &#39;01600&#39;,\r\n      place_name: &#39;Annapolis city&#39;,\r\n      data: \r\n       [ { name: &#39;Allegany County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;001&#39;,\r\n           income: &#39;40551&#39;,\r\n           population: &#39;73549&#39;,\r\n           C24010_011E: &#39;1039&#39;,\r\n           education_masters: &#39;3255&#39; },\r\n         { name: &#39;Anne Arundel County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;003&#39;,\r\n           income: &#39;89860&#39;,\r\n           population: &#39;555280&#39;,\r\n           C24010_011E: &#39;9306&#39;,\r\n           education_masters: &#39;45047&#39; },\r\n         { name: &#39;Baltimore County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;005&#39;,\r\n           income: &#39;67095&#39;,\r\n           population: &#39;822959&#39;,\r\n           C24010_011E: &#39;16725&#39;,\r\n           education_masters: &#39;60803&#39; },\r\n         { name: &#39;Calvert County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;009&#39;,\r\n           income: &#39;95828&#39;,\r\n           population: &#39;90114&#39;,\r\n           C24010_011E: &#39;986&#39;,\r\n           education_masters: &#39;5628&#39; },\r\n         { name: &#39;Caroline County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;011&#39;,\r\n           income: &#39;52465&#39;,\r\n           population: &#39;32661&#39;,\r\n           C24010_011E: &#39;328&#39;,\r\n           education_masters: &#39;1011&#39; },\r\n         { name: &#39;Carroll County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;013&#39;,\r\n           income: &#39;85385&#39;,\r\n           population: &#39;167444&#39;,\r\n           C24010_011E: &#39;2977&#39;,\r\n           education_masters: &#39;11030&#39; },\r\n         { name: &#39;Cecil County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;015&#39;,\r\n           income: &#39;66396&#39;,\r\n           population: &#39;101960&#39;,\r\n           C24010_011E: &#39;1421&#39;,\r\n           education_masters: &#39;4239&#39; },\r\n         { name: &#39;Charles County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;017&#39;,\r\n           income: &#39;90607&#39;,\r\n           population: &#39;152754&#39;,\r\n           C24010_011E: &#39;2367&#39;,\r\n           education_masters: &#39;8300&#39; },\r\n         { name: &#39;Dorchester County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;019&#39;,\r\n           income: &#39;47093&#39;,\r\n           population: &#39;32534&#39;,\r\n           C24010_011E: &#39;461&#39;,\r\n           education_masters: &#39;1349&#39; },\r\n         { name: &#39;Frederick County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;021&#39;,\r\n           income: &#39;83700&#39;,\r\n           population: &#39;241373&#39;,\r\n           C24010_011E: &#39;5026&#39;,\r\n           education_masters: &#39;18962&#39; },\r\n         { name: &#39;Garrett County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;023&#39;,\r\n           income: &#39;45432&#39;,\r\n           population: &#39;29813&#39;,\r\n           C24010_011E: &#39;344&#39;,\r\n           education_masters: &#39;1434&#39; },\r\n         { name: &#39;Harford County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;025&#39;,\r\n           income: &#39;80465&#39;,\r\n           population: &#39;248966&#39;,\r\n           C24010_011E: &#39;4243&#39;,\r\n           education_masters: &#39;18132&#39; },\r\n         { name: &#39;Howard County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;027&#39;,\r\n           income: &#39;110238&#39;,\r\n           population: &#39;304115&#39;,\r\n           C24010_011E: &#39;7687&#39;,\r\n           education_masters: &#39;42253&#39; },\r\n         { name: &#39;Kent County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;029&#39;,\r\n           income: &#39;58147&#39;,\r\n           population: &#39;19923&#39;,\r\n           C24010_011E: &#39;261&#39;,\r\n           education_masters: &#39;1189&#39; },\r\n         { name: &#39;Montgomery County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;031&#39;,\r\n           income: &#39;99435&#39;,\r\n           population: &#39;1017859&#39;,\r\n           C24010_011E: &#39;33271&#39;,\r\n           education_masters: &#39;132184&#39; },\r\n         { name: &#39;Prince George\\&#39;s County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;033&#39;,\r\n           income: &#39;74260&#39;,\r\n           population: &#39;892816&#39;,\r\n           C24010_011E: &#39;16164&#39;,\r\n           education_masters: &#39;58017&#39; },\r\n         { name: &#39;Queen Anne\\&#39;s County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;035&#39;,\r\n           income: &#39;85963&#39;,\r\n           population: &#39;48600&#39;,\r\n           C24010_011E: &#39;876&#39;,\r\n           education_masters: &#39;3419&#39; },\r\n         { name: &#39;St. Mary\\&#39;s County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;037&#39;,\r\n           income: &#39;86987&#39;,\r\n           population: &#39;109614&#39;,\r\n           C24010_011E: &#39;1625&#39;,\r\n           education_masters: &#39;7640&#39; },\r\n         { name: &#39;Somerset County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;039&#39;,\r\n           income: &#39;35154&#39;,\r\n           population: &#39;25980&#39;,\r\n           C24010_011E: &#39;208&#39;,\r\n           education_masters: &#39;715&#39; },\r\n         { name: &#39;Talbot County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;041&#39;,\r\n           income: &#39;58228&#39;,\r\n           population: &#39;37799&#39;,\r\n           C24010_011E: &#39;711&#39;,\r\n           education_masters: &#39;2855&#39; },\r\n         { name: &#39;Washington County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;043&#39;,\r\n           income: &#39;56228&#39;,\r\n           population: &#39;149270&#39;,\r\n           C24010_011E: &#39;1861&#39;,\r\n           education_masters: &#39;6313&#39; },\r\n         { name: &#39;Wicomico County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;045&#39;,\r\n           income: &#39;52278&#39;,\r\n           population: &#39;101182&#39;,\r\n           C24010_011E: &#39;1788&#39;,\r\n           education_masters: &#39;5466&#39; },\r\n         { name: &#39;Worcester County, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;047&#39;,\r\n           income: &#39;56773&#39;,\r\n           population: &#39;51519&#39;,\r\n           C24010_011E: &#39;781&#39;,\r\n           education_masters: &#39;3110&#39; },\r\n         { name: &#39;Baltimore city, Maryland&#39;,\r\n           state: &#39;24&#39;,\r\n           county: &#39;510&#39;,\r\n           income: &#39;42241&#39;,\r\n           population: &#39;622454&#39;,\r\n           C24010_011E: &#39;15642&#39;,\r\n           education_masters: &#39;36590&#39; } ] }",
        "link": "https://stackoverflow.com/questions/50933870/how-to-parse-irregular-json-response-from-us-census-api-call",
        "title": "How to parse irregular JSON response from US Census API call?"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "sh",
            "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": 1529444514,
                "post_id": 50937290,
                "comment_id": 88873102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2437868,
                    "reputation": 14606,
                    "user_id": 2127277,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/ciCPW.png?s=256",
                    "display_name": "Dimitri Kopriwa",
                    "link": "https://stackoverflow.com/users/2127277/dimitri-kopriwa"
                },
                "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": 1529444838,
                "post_id": 50937290,
                "comment_id": 88873209,
                "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": 1529444880,
                "post_id": 50937290,
                "comment_id": 88873222,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1529445215,
                "last_edit_date": 1529445215,
                "creation_date": 1529444700,
                "answer_id": 50937352,
                "question_id": 50937290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Transforming your input to your output is as simple as:\r\n\r\n    jq &#39;{&quot;name&quot;: .transitive.scopedName}&#39;\r\n\r\n...and of course you could just reorder things to set `name` *before* deleting `transitive`:\r\n\r\n    jq &#39;.name=.transitive.scopedName | del(.transitive)&#39;\r\n\r\nThat said, if you **really** want to use `del()` first, you can save content in a variable and use it later:\r\n\r\n    jq &#39;\r\n      .transitive as $transitive |\r\n      del(.transitive) |\r\n      .name=$transitive.scopedName\r\n    &#39;",
                "title": "Is it possible with jq to use a deleted value in setting new ones?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529445292,
        "creation_date": 1529444263,
        "last_edit_date": 1529445292,
        "question_id": 50937290,
        "body_markdown": "I am using the bash to json parser [jq](https://stedolan.github.io/jq/)\r\n\r\nConsidering the following command:\r\n\r\n    jq &#39;. * .transitive | del(.transitive) | del(.scope,.scopedName)&#39; package.json &gt; package.github.json$$\r\n\r\nAnd the following **input**:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;navigation&quot;,\r\n      &quot;transitive&quot;: {\r\n        &quot;name&quot;: &quot;navigation&quot;,\r\n        &quot;scope&quot;: &quot;bs&quot;,\r\n        &quot;scopedName&quot;: &quot;@bs/navigation&quot;\r\n      }\r\n    }\r\n\r\nI am trying to get the following **output**:\r\n\r\n\r\n    {\r\n      &quot;name&quot;: &quot;@bs/navigation&quot;\r\n    }\r\n\r\n\r\n\r\nIs there a way before doing the delete of `.scopedName`, to use it&#39;s value to set `.name`?",
        "link": "https://stackoverflow.com/questions/50937290/is-it-possible-with-jq-to-use-a-deleted-value-in-setting-new-ones",
        "title": "Is it possible with jq to use a deleted value in setting new ones?"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1529467507,
                "last_edit_date": 1529467507,
                "creation_date": 1529466320,
                "answer_id": 50939885,
                "question_id": 50939615,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Strictly speaking, the sample &quot;JSON&quot; is not valid JSON. The following assumes that the superfluous commas have been removed.\r\n\r\n2. To obtain the desired linear listing, just hoist the `[]`:  \r\n\r\n    jq -r &#39;.data[] | (.description, .subnet)&#39;\r\n\r\nproduces:\r\n\r\n    THA4\r\n    0.0.0.0\r\n    ALF5\r\n    1.2.3.4\r\n\r\n3. One way to get CSV is to use `@csv`:\r\n\r\n    .data[]\r\n    | [.description, .subnet]\r\n    | @csv\r\n\r\nproduces quoted values:\r\n\r\n    &quot;THA4&quot;,&quot;0.0.0.0&quot;\r\n    &quot;ALF5&quot;,&quot;1.2.3.4&quot;\r\n\r\n4. If you don&#39;t want the individual values to be quoted:\r\n\r\n`.data[] | &quot;\\(.description), \\(.subnet)&quot;`\r\n\r\n\r\n",
                "title": "JQ from curl output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529467507,
        "creation_date": 1529464189,
        "last_edit_date": 1529464990,
        "question_id": 50939615,
        "body_markdown": "I have a json output \r\n\r\n    {\r\n      &quot;code&quot;: 200,\r\n      &quot;success&quot;: true,\r\n      &quot;data&quot;: [{\r\n          &quot;id&quot;: &quot;66&quot;,\r\n          &quot;subnet&quot;: &quot;0.0.0.0&quot;,\r\n          &quot;mask&quot;: &quot;&quot;,\r\n          &quot;sectionId&quot;: &quot;1&quot;,\r\n          &quot;description&quot;: &quot;THA4&quot;,\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;72&quot;,\r\n          &quot;subnet&quot;: &quot;1.2.3.4&quot;,\r\n          &quot;mask&quot;: &quot;&quot;,\r\n          &quot;sectionId&quot;: &quot;1&quot;,\r\n          &quot;description&quot;: &quot;ALF5&quot;,\r\n        },\r\n    ],\r\n    }\r\n\r\nI&#39;d like to have the output like this based on the description and subnet:  \r\n\r\n    THA4  \r\n    0.0.0.0  \r\n    ALF5  \r\n    1.2.3.4\r\n\r\nand want to have like this too:  \r\n\r\n    THA4,0.0.0.0  \r\n    ALF5,1.2.3.4 \r\n\r\n \r\n\r\nWith my query: \r\n\r\n    jq &#39;.data | .[].description,.[].subnet&#39;  \r\n\r\nI can get only like this:  \r\n\r\n    0.0.0.0  \r\n    1.2.3.4  \r\n    THA4  \r\n    ALF5 \r\n\r\n ",
        "link": "https://stackoverflow.com/questions/50939615/jq-from-curl-output",
        "title": "JQ from curl output"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "command-line",
            "count",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529472749,
                "post_id": 50940865,
                "comment_id": 88879429,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13778785,
                    "reputation": 567,
                    "user_id": 9944404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9896c88273e37d7a54ca0db68e391c02?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user49",
                    "link": "https://stackoverflow.com/users/9944404/user49"
                },
                "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": 1529473082,
                "post_id": 50940865,
                "comment_id": 88879581,
                "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": 1529473569,
                "post_id": 50940865,
                "comment_id": 88879757,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13778785,
                    "reputation": 567,
                    "user_id": 9944404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9896c88273e37d7a54ca0db68e391c02?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user49",
                    "link": "https://stackoverflow.com/users/9944404/user49"
                },
                "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": 1529473684,
                "post_id": 50940865,
                "comment_id": 88879794,
                "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": 1529476045,
                "post_id": 50940865,
                "comment_id": 88880735,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1529475475,
                "last_edit_date": 1529475475,
                "creation_date": 1529473714,
                "answer_id": 50941092,
                "question_id": 50940865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The final trailing `[]` in your primary query results in a stream, which is not so good for counting using `length`.  For simplicity, you could go with:\r\n\r\n    map({Animal: .[].payload.animal})\r\n    |   map(select(.Animal))[]   # &lt;--- JUST ONE []\r\n    | flatten\r\n    | map(select(. == &quot;Dog&quot;))\r\n    | length\r\n\r\n## From scratch\r\n\r\nYou might like to consider simply counting the number of occurrences of &quot;Dog&quot; in your original JSON:\r\n\r\n    [.. | strings | select(. == &quot;Dog&quot;)] | length\r\n\r\n## Counting items in a stream\r\n\r\nA more efficient way to count is by counting items in a stream:\r\n\r\n    def count(s): reduce s as $x (0; .+1);\r\n\r\n    count(.. | strings | select(. == &quot;Dog&quot;))\r\n\r\n## Occurrences of &quot;Dog&quot; only when it is in .Pets\r\n\r\n    count(.. | objects | (.Pets // []) | flatten[] | select(.==&quot;Dog&quot;))\r\n",
                "title": "JQ: Count number of times string appears"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529476146,
        "creation_date": 1529472628,
        "last_edit_date": 1529476146,
        "question_id": 50940865,
        "body_markdown": "    map({Animal: .[].payload.animal})\r\n    |\tmap(select(.Animal))[][]\r\n\r\nUsing the following code, I get the following output of my very long JSON:\r\n\r\n    [\r\n      [\r\n        &quot;Dog&quot;,\r\n        &quot;Cat&quot;\r\n      ]\r\n    ]\r\n    [\r\n      [\r\n        &quot;Dog&quot;,\r\n        &quot;Cat&quot;,\r\n        &quot;Bird&quot;\r\n      ]\r\n    ]\r\n\r\nFrom this output, how do I build/add to my JQ command to get the result 2 (the total of occurrences of dogs). I&#39;ve played around (for hours!) with combinations of  add and select statements to try and get the desired output, but have not been able to. Would truly appreciate help on this!\r\n\r\n---\r\nAs requested:\r\n\r\nSample input: \r\n\r\n    [{\r\n\t\t&quot;Data&quot;: {\r\n\t\t\t&quot;IsInUS&quot;: 1,\r\n\t\t\t&quot;Pets&quot;: [\r\n\t\t\t\t[&quot;Dog&quot;, &quot;Cat&quot;, &quot;Bird&quot;]\r\n\t\t\t],\r\n\t\t\t&quot;Favorite Pet&quot;: &quot;Dog&quot;\r\n\t\t},\r\n\t\t&quot;UniqueID&quot;: &quot;1234&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;Data&quot;: {\r\n\t\t\t&quot;IsInUS&quot;: 1,\r\n\t\t\t&quot;Pets&quot;: [\r\n\t\t\t\t[&quot;Dog&quot;, &quot;Cat&quot;, &quot;Bird&quot;]\r\n\t\t\t]\r\n\t\t\t&quot;Favorite Pet&quot;: &quot;Cat&quot;\r\n\t\t},\r\n\t\t&quot;UniqueID&quot;: &quot;234&quot;\r\n\t}]\r\n\r\nSample output: 2 (counting the number of dogs).\r\n\r\ni am looking to count the occurrences of &quot;Dog&quot; only when it is in the &quot;Pets&quot; datafield/key\r\n",
        "link": "https://stackoverflow.com/questions/50940865/jq-count-number-of-times-string-appears",
        "title": "JQ: Count number of times string appears"
    },
    {
        "tags": [
            "json",
            "bash",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1529477442,
                "post_id": 50941820,
                "comment_id": 88881397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1529477479,
                "post_id": 50941820,
                "comment_id": 88881416,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -4,
                "last_activity_date": 1529477304,
                "creation_date": 1529477304,
                "answer_id": 50941894,
                "question_id": 50941820,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you need java implements or any other language?",
                "title": "JQ filtering and map basic: removing null values and transforming text to lowercase"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1529477508,
                "creation_date": 1529477508,
                "answer_id": 50941966,
                "question_id": 50941820,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your example does not seem to agree with your stated requirements, but the following will select the objects for which both .id and .releaseDate are non-null, and convert the ASCII alphabetic characters in the .name value to lowercase:\r\n\r\n    map(select(.id and .releaseDate) | .name |= ascii_downcase)\r\n\r\nYou can easily modify the selection criteria.",
                "title": "JQ filtering and map basic: removing null values and transforming text to lowercase"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1529477508,
        "creation_date": 1529476939,
        "question_id": 50941820,
        "body_markdown": "Sample input:\r\n\r\n      [{\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;18900&quot;,\r\n        &quot;name&quot;: &quot;AUDI&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-12-11&quot;\r\n      },\r\n      {\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;18900&quot;,\r\n        &quot;name&quot;: &quot;FORD&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-12-11&quot;\r\n      }]\r\n\r\nSample Output:\r\n\r\n      [{\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;18900&quot;,\r\n        &quot;name&quot;: &quot;audi&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-12-11&quot;\r\n      }]\r\n\r\nHow do I write a simple line of code in a script to change the name fields to be lowercase values and to filter out objects where id and releaseDate are null?\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/50941820/jq-filtering-and-map-basic-removing-null-values-and-transforming-text-to-lowerc",
        "title": "JQ filtering and map basic: removing null values and transforming text to lowercase"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1529481197,
                "last_edit_date": 1529481197,
                "creation_date": 1529480511,
                "answer_id": 50942836,
                "question_id": 50942755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just have to encode the regex string as a JSON string. This is easy enough to do if you know something about JSON strings, but you could let jq do the walking, e.g. using\r\n\r\n    jq -R . regex.txt\r\n\r\nassuming your regex is in the file regex.txt ",
                "title": "Don&#39;t know how to escape complex regex characters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1529509964,
        "creation_date": 1529480212,
        "last_edit_date": 1529482758,
        "question_id": 50942755,
        "body_markdown": "    .+?sunday.+?&quot;[0-9]:\\d+.+\r\n\r\nI am trying to implement this regex from a regex builder into a test function, but am unfamiliar with how to escape some of the characters for the syntax to work. I am using the regex in a `test(&quot; &quot;)` function\r\n\r\n    map({Row: .[] })\r\n    |\tmap(select(.Row.payload.hours | test(&quot;.+?sunday.+?&quot;[0-9]:\\d+.+&quot;)?))\r\n\r\nIs the line of code giving me the syntax error. ",
        "link": "https://stackoverflow.com/questions/50942755/dont-know-how-to-escape-complex-regex-characters",
        "title": "Don&#39;t know how to escape complex regex characters"
    }
]