[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1553012417,
                "creation_date": 1553012417,
                "answer_id": 55245626,
                "question_id": 55244522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way to do it.\r\n\r\n    jq &#39;reduce .[] as $i ({}; .[$i.id] += ($i|[.time]))&#39;\r\n",
                "title": "Combining related data with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553015950,
                "creation_date": 1553015950,
                "answer_id": 55246667,
                "question_id": 55244522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A functional (`reduce`-free) approach using only jq builtins:\r\n\r\n    group_by(.id)\r\n    | map( {(.[0]|.id): (map([.time]) | add)} )\r\n",
                "title": "Combining related data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1553036957,
        "creation_date": 1553009146,
        "question_id": 55244522,
        "body_markdown": "I&#39;m trying to build up an array of times from a set of JSON data and was hoping to do it with jq without having to write code in another language to do the processing.\r\n\r\nThe Data\r\n\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;abc&quot;,\r\n        &quot;time&quot;: 34\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;def&quot;,\r\n        &quot;time&quot;: 25\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;abc&quot;,\r\n        &quot;time&quot;: 45\r\n    }\r\n]\r\n```\r\n\r\nI&#39;d like to get the output in the format of\r\n\r\n```\r\n{\r\n    &quot;abc&quot;: [ 34, 45 ],\r\n    &quot;def&quot;: [ 25 ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55244522/combining-related-data-with-jq",
        "title": "Combining related data with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1553018275,
                "creation_date": 1553018275,
                "answer_id": 55247262,
                "question_id": 55246560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can be done using [`to_entries`][1] and the `*` operator:\r\n\r\n    jq &#39;to_entries | map({id: .key} * .value)&#39; file.json\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries",
                "title": "jq reshaping data to flat json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1553060472,
        "creation_date": 1553015526,
        "last_edit_date": 1553033204,
        "question_id": 55246560,
        "body_markdown": "I am working with some json data I would like to insert in a SQL database. The data are from from Google Cloud Firestore \r\n\r\nInput :\r\n\r\n    {\r\n      &quot;0&quot;: {\r\n        &quot;filed1&quot;: &quot;xxxx&quot;,\r\n        &quot;field&quot;: &quot;zzzz&quot;\r\n        \r\n      },\r\n      &quot;1&quot;: {\r\n        &quot;field1&quot;: &quot;xxx&quot;,\r\n        &quot;filed2&quot;: &quot;zzz&quot;\r\n      }\r\n    }\r\n\r\nDesired output, I don&#39;t want to store my field in an id body, instead I want to save my id alongside of the others fields as in a flat objet \r\n\r\n    {\r\n      {\r\n        &quot;id&quot;: 0,\r\n        &quot;filed1&quot;: &quot;xxxx&quot;,\r\n        &quot;field&quot;: &quot;zzzz&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;field1&quot;: &quot;xxx&quot;,\r\n        &quot;filed2&quot;: &quot;zzz&quot;\r\n      }\r\n    }\r\n\r\nMany thanks in advance ",
        "link": "https://stackoverflow.com/questions/55246560/jq-reshaping-data-to-flat-json",
        "title": "jq reshaping data to flat json"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1553028631,
                "creation_date": 1553028631,
                "answer_id": 55249764,
                "question_id": 55247622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your invocation of jq can be simplified to:\r\n\r\n    jq -R &#39;\r\n      split(&quot;,&quot;)\r\n      | map(fromjson)\r\n      | {ID: .[0], date: .[1], count: .[2] }&#39;\r\n\r\n\r\n## Generic solution\r\n\r\n    jq -R --argjson header &#39;[&quot;ID&quot;, &quot;date&quot;, &quot;count&quot;]&#39; &#39;\r\n      split(&quot;,&quot;)\r\n      | map(fromjson)\r\n      | [ $header, . ]\r\n      | transpose\r\n      | reduce .[] as $kv ({}; .[$kv[0]] =$kv[1]) &#39;\r\n\r\nIf you want to specify the headers in a file, use the `--argfile` command-line option instead.\r\n",
                "title": "Quoted string in CSV input become double-escaped"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1553049634,
        "creation_date": 1553019570,
        "last_edit_date": 1553049634,
        "question_id": 55247622,
        "body_markdown": "I&#39;m trying to use JQ to process CSV like this which has no column headings:\r\n\r\n    cat &quot;input.csv&quot;\r\n    &quot;12345678901234567890&quot;,&quot;2019-03-19&quot;,12\r\n\r\n**Is there more elegant and readable way to remove escaped quotes for the first and second fields--and overall, to build a stream of objects given such input?**\r\n\r\n----\r\nIdeally I would like to have a reusable script which builds JSON from an artbitrary CSV, given a file and a list of fields in it passed as a command-line argument.\r\n\r\n\r\nCurrent JQ script and output:\r\n\r\n    cat &quot;input.csv&quot; |\r\n    jq \\\r\n      --raw-input &#39;\r\n        . |\r\n        split(&quot;\\n&quot;) |\r\n        map( split(&quot;,&quot;)) |\r\n        .[0] |\r\n\t    {\r\n\t\t  ID: (.[0] | fromjson),\r\n\t\t  date: (.[1] | fromjson),\r\n\t\t  count: (.[2] | tonumber)\r\n\t\t}&#39;\r\n\r\n\t{\r\n\t  &quot;ID&quot;: &quot;12345678901234567890&quot;,\r\n\t  &quot;date&quot;: &quot;2019-03-19&quot;,\r\n\t  &quot;count&quot;: 1\r\n\t}\r\n\r\nOutput of the same script without `| fromjson` used which results in quoted quotes, which I would like to avoid:\r\n\r\n\t{\r\n\t  &quot;ID&quot;: &quot;\\&quot;12345678901234567890\\&quot;&quot;,\r\n\t  &quot;date&quot;: &quot;\\&quot;2019-03-19\\&quot;&quot;,\r\n\t  &quot;count&quot;: 1\r\n\t}\r\n",
        "link": "https://stackoverflow.com/questions/55247622/quoted-string-in-csv-input-become-double-escaped",
        "title": "Quoted string in CSV input become double-escaped"
    },
    {
        "tags": [
            "json",
            "object",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1553041631,
                "last_edit_date": 1553041631,
                "creation_date": 1553040759,
                "answer_id": 55251774,
                "question_id": 55251603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this:\r\n\r\n    jq &#39;.resources[].entity.credentials|select(has(&quot;credhub-ref&quot;))&#39; file.json\r\n",
                "title": "JQ Select Objects Where Inner Key Exists"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1553041627,
                "last_edit_date": 1553041627,
                "creation_date": 1553040774,
                "answer_id": 55251776,
                "question_id": 55251603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it is guaranteed that `credhub-ref` won&#39;t be `null` or `false`, you can use `select(.[&quot;credhub-ref&quot;])`:\r\n\r\n    jq &#39;.resources[].entity.credentials | select(.[&quot;credhub-ref&quot;])&#39; file\r\n\r\nOtherwise refer to @hek2mgl&#39;s answer.",
                "title": "JQ Select Objects Where Inner Key Exists"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1553077722,
        "creation_date": 1553039435,
        "last_edit_date": 1553077722,
        "question_id": 55251603,
        "body_markdown": "I am trying to select credential objects only if key `credhub-ref` exist within them from the following JSON:\r\n\r\n```\r\n{\r\n   &quot;total_results&quot;: 23,\r\n   &quot;total_pages&quot;: 1,\r\n   &quot;prev_url&quot;: null,\r\n   &quot;next_url&quot;: null,\r\n   &quot;resources&quot;: [\r\n      {\r\n         &quot;entity&quot;: {\r\n            &quot;credentials&quot;: {},\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2018-10-15T19:13:57Z&quot;,\r\n               &quot;created_at&quot;: &quot;2018-10-15T19:13:57Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/3&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;entity&quot;: {\r\n            &quot;app_guid&quot;: &quot;sd&quot;,\r\n            &quot;service_instance_guid&quot;: &quot;sd&quot;,\r\n            &quot;credentials&quot;: {\r\n               &quot;hostname&quot;: &quot;w&quot;,\r\n               &quot;port&quot;: 3306\r\n            },\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2018-10-15T19:24:06Z&quot;,\r\n               &quot;created_at&quot;: &quot;2018-10-15T19:24:06Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/3&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;entity&quot;: {\r\n            &quot;credentials&quot;: {\r\n               &quot;credhub-ref&quot;: &quot;ref3&quot;\r\n            },\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2019-03-19T20:07:27Z&quot;,\r\n               &quot;created_at&quot;: &quot;2019-03-19T20:07:27Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/45&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;entity&quot;: {\r\n            &quot;credentials&quot;: {\r\n               &quot;credhub-ref&quot;: &quot;ref4&quot;\r\n            },\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2019-03-19T20:07:27Z&quot;,\r\n               &quot;created_at&quot;: &quot;2019-03-19T20:07:27Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/45&quot;\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\nWhen I use `cat my_bindings_test2.json |  jq &#39;.resources[] | .entity.credentials&#39;` I get:\r\n\r\n```\r\n{}\r\n{\r\n  &quot;hostname&quot;: &quot;w&quot;,\r\n  &quot;port&quot;: 3306\r\n}\r\n{\r\n  &quot;credhub-ref&quot;: &quot;ref3&quot;\r\n}\r\n{\r\n  &quot;credhub-ref&quot;: &quot;ref4&quot;\r\n}\r\n```\r\n\r\nUsing JQ, how would I get the following result?\r\n```\r\n{\r\n  &quot;credhub-ref&quot;: &quot;ref3&quot;\r\n}\r\n{\r\n  &quot;credhub-ref&quot;: &quot;ref4&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55251603/jq-select-objects-where-inner-key-exists",
        "title": "JQ Select Objects Where Inner Key Exists"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "any"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1553053066,
                "creation_date": 1553053066,
                "answer_id": 55253205,
                "question_id": 55252911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution , that \r\n   build a array of boolean from the .tags , and after use **any** to agregate all the booleans  \r\n\r\n    jq &#39;.Tags | map( .Key == &quot;aws:cloudformation:stack-name&quot; ) |  any &#39; ",
                "title": "How to get return true with jq array value"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1553057469,
                "creation_date": 1553057469,
                "answer_id": 55253775,
                "question_id": 55252911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A very efficient solution (both with respect to time and space) is easy thanks to `any/2`:\r\n\r\n    any(.Tags[]; .Key == &quot;aws:cloudformation:stack-name&quot;)\r\n\r\nThis of course evaluates either to `true` or `false`.  If you want `true` or nothing at all, you could tack on `// empty` to the above.",
                "title": "How to get return true with jq array value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583320297,
                "creation_date": 1583320297,
                "answer_id": 60524758,
                "question_id": 55252911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on the previous answer by @peak, as can&#39;t post comments, you can use the &#39;-e&#39; flag to jq to set the exit status so you can easily chain shell commands together. This avoids having to test for the returned string.\r\n\r\n    jq -e &#39;any(.Tags[]; .Key == &quot;aws:cloudformation:stack-name&quot;)&#39; json &gt;/dev/null &amp;&amp; echo &#39;Exists&#39; || echo &#39;Missing&#39;",
                "title": "How to get return true with jq array value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1583320297,
        "creation_date": 1553050769,
        "last_edit_date": 1553088252,
        "question_id": 55252911,
        "body_markdown": "I&#39;m trying to use the following jq command to return a true output, if any of one of the condition is true in the list.  \r\n\r\n    .Tags[] as $t| &quot;aws:cloudformation:stack-name&quot;| IN($t[])   \r\n \r\nInput \r\n\r\n     {\r\n    \t&quot;Tags&quot;: [{\r\n    \t\t\t&quot;Value&quot;: &quot;INF-D-XX-SEC-OPNV-UW1&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;Name&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;INF-D-XX-CFS-StandardInfrastructure-UW1&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;sgOpenVPNAccess&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;UW1&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;Location&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;INF&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;Application&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;D&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;Parent Environment&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;arn:aws:cloudformation:us-west-1:111111:stack/INF-D-XX-CFS-StandardInfrastructure-UW1/1111-11-11e8-96fe-11&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Value&quot;: &quot;OPNV&quot;,\r\n    \t\t\t&quot;Key&quot;: &quot;ResourceType&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nThis gave me a list of returned boolean values back as the following,\r\n\r\n--output--\r\n\r\n    true\r\n    false\r\n    false\r\n    false\r\n    false\r\n    false\r\n    false\r\n\r\nI would like to return a single value `true` if one of the \r\n\r\n    Key=&quot;aws:cloudformation:stack-name&quot; \r\n\r\nis detected and without given me a list of value back.\r\n",
        "link": "https://stackoverflow.com/questions/55252911/how-to-get-return-true-with-jq-array-value",
        "title": "How to get return true with jq array value"
    },
    {
        "tags": [
            "json",
            "duplicates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1553080219,
                "last_edit_date": 1553080219,
                "creation_date": 1553074246,
                "answer_id": 55257487,
                "question_id": 55255302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a straightforward and efficient solution using the generic function:\r\n\r\n    # The given stream is assumed to consist of strings\r\n    def bagof(stream):\r\n      reduce stream as $x ({}; .[$x] += 1);\r\n\r\n`bagof` emits a JSON object that records the number of occurrences of the items in the given `stream`.\r\n\r\nSince the given input consists of a stream of string-valued arrays, we can write:\r\n\r\n    bagof(inputs | .[0])\r\n    | with_entries(select(.value &gt; 1))\r\n    | keys_unsorted\r\n\r\nassuming that jq is invoked with the `-n` command-line option.\r\n\r\nSince the given input is actually the result of some other operations, it should be easy to tweak things so that the above solution could be simplified a bit while still using the given def of `bagof`.\r\n\r\n",
                "title": "identify and list all duplicate items in an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1553080219,
        "creation_date": 1553065956,
        "last_edit_date": 1553080163,
        "question_id": 55255302,
        "body_markdown": "My requirement is 2 parts: \r\n    1 - extract all the IP address from a huge JSON file \r\n    2 - find and show only the duplicate values \r\n \r\n    I am able to achieve the first part but struggling to achieve the 2nd \r\n    part.\r\n\r\nAfter the part1, here is how I get the output \r\n\r\n    [&quot;4.2.1.9&quot;]\r\n    [&quot;4.2.1.1&quot;]\r\n    [&quot;4.2.1.9&quot;]\r\n    [&quot;4.2.1.102&quot;]\r\n    [&quot;4.2.4.131&quot;]\r\n    [&quot;4.2.1.2&quot;]\r\n    [&quot;1.23.39.33&quot;]\r\n    [&quot;1.218.4.4&quot;]\r\n    [&quot;4.2.1.2&quot;]\r\n    [&quot;1.218.1.1&quot;]\r\n    [&quot;4.2.4.19&quot;]\r\n    [&quot;4.2.1.26&quot;]\r\n    [&quot;4.2.4.58&quot;]\r\n    [&quot;4.2.4.13&quot;]\r\n    [&quot;4.2.4.29&quot;]\r\n    [&quot;1.23.39.49&quot;]\r\n    [&quot;1.23.39.241&quot;]\r\n    [&quot;4.2.1.93&quot;]\r\n    [&quot;4.2.4.54&quot;]\r\n    [&quot;4.2.4.12&quot;]\r\n    [&quot;4.2.4.50&quot;]\r\n   \r\nSo, from the above list, how can identify the duplicates and list them. \r\nThank you for the help. \r\n",
        "link": "https://stackoverflow.com/questions/55255302/identify-and-list-all-duplicate-items-in-an-array-using-jq",
        "title": "identify and list all duplicate items in an array using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1553074625,
                "post_id": 55257392,
                "comment_id": 97246542,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1553080015,
                "last_edit_date": 1553080015,
                "creation_date": 1553074688,
                "answer_id": 55257627,
                "question_id": 55257392,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest and perhaps most efficient solution to the problem as stated is:\r\n\r\n    .input_dataobjects |=\r\n      map( if .datatype == &quot;somedatatype1&quot;\r\n           then .name = &quot;sonemewname1&quot;\r\n           else . end )\r\n\r\n",
                "title": "Replacing the value of JSON based on key value pair with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1553108647,
        "creation_date": 1553073944,
        "last_edit_date": 1553085518,
        "question_id": 55257392,
        "body_markdown": "I have a JSON with the following structure\r\n\r\n    {\r\n       &quot;name&quot;: &quot;name&quot;,\r\n       &quot;id&quot;: [\r\n            &quot;abcdef&quot;\r\n       ],\r\n       &quot;input_dataobjects&quot;: [\r\n         {\r\n            &quot;id&quot;: &quot;someid1&quot;,\r\n            &quot;name&quot;: &quot;somename1&quot;,\r\n            &quot;provider&quot;: &quot;someprovider&quot;,\r\n            &quot;datatype&quot;: &quot;somedatatype1&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;some_name2&quot;,\r\n            &quot;datatype&quot;: &quot;some_datatype2&quot;,\r\n            &quot;id&quot;: &quot;some_id2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat I am trying to achieve\r\n\r\nin `input_dataobjects` if `datatype == somedatatype1` then `name = sonemewname1`.\r\n\r\nI can use the index of the input_dataobjects since my json always has the same structure. But is there any different way to achieve it by parsing through the input_dataobjects and find the index to replace? I am using `jq` to do JSON operations.\r\n\r\nI tried with using the index like `.input_dataobjects[0].name=&quot;someting&quot;` because i know the position of the datatype always. ",
        "link": "https://stackoverflow.com/questions/55257392/replacing-the-value-of-json-based-on-key-value-pair-with-jq",
        "title": "Replacing the value of JSON based on key value pair with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1553091162,
                "creation_date": 1553091162,
                "answer_id": 55262827,
                "question_id": 55262718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to JSON-encode the call-to-action first.\r\n\r\n    % jq -c --raw-output &#39;.records[] |\r\n    [.id, .metadata.description, \r\n          .metadata.width,\r\n          .metadata.height,\r\n          .metadata.secondaryColor,\r\n          (.metadata.callToAction|@json),  # convert this field to JSON first\r\n          .parent\r\n    ] | @tsv&#39; tmp.json\r\n    1\t\t0\t0\t#fff\t[{&quot;link&quot;:&quot;/truc.html&quot;,&quot;value&quot;:&quot;nice&quot;,&quot;colors&quot;:{&quot;primary&quot;:&quot;transparent;&quot;,&quot;secondary&quot;:&quot;transparent;&quot;}}]",
                "title": "How to convert a JSON with arrays in tsv with jq keeping the array structure?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1553091556,
                "creation_date": 1553091556,
                "answer_id": 55262978,
                "question_id": 55262718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the stated goal includes &quot;null&quot; in the output, you might like to consider mapping all the selected values using `tojson`, e.g. using `map(tojson)`.  With the sample JSON, this would produce:\r\n\r\n    1\tnull\t0\t0\t&quot;#fff&quot;\t[{&quot;link&quot;:&quot;/truc.html&quot;,&quot;value&quot;:&quot;nice&quot;,&quot;colors&quot;:{&quot;primary&quot;:&quot;transparent;&quot;,&quot;secondary&quot;:&quot;transparent;&quot;}}]\tnull\r\n\r\nNotice, though, that the string `#fff` is quoted.  If you don&#39;t want strings to be quoted in this way, then you might wish to consider:\r\n\r\n    map(if type == &quot;string&quot; then . else tojson end)\r\n",
                "title": "How to convert a JSON with arrays in tsv with jq keeping the array structure?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1553106774,
        "creation_date": 1553090886,
        "last_edit_date": 1553106774,
        "question_id": 55262718,
        "body_markdown": "I need to get the content of a mysql table that has some fields that store data as a JSON array, and ingest it in another database table. I need to use a REST API for that, and it returns the records in JSON. For performance reason, I need that output to be tab tab return. Therefore I use jq&#39;s @tsv.\r\n\r\nThis works greats till it encounters a field that has a JSON array inside, jq then complains &quot;array is not valid in a csv row&quot;. \r\n\r\nHere&#39;s a JSON sample\r\n\r\n    {\r\n    &quot;records&quot;: [\r\n     {\r\n            &quot;id&quot;: 1,\r\n            &quot;metadata&quot;: {\r\n                &quot;description&quot;: null,\r\n                &quot;width&quot;: 0,\r\n                &quot;height&quot;: 0,\r\n                &quot;secondaryColor&quot;: &quot;#fff&quot;,\r\n                &quot;callToAction&quot;: [\r\n                    {\r\n                        &quot;link&quot;: &quot;/truc.html&quot;,\r\n                        &quot;value&quot;: &quot;nice&quot;,\r\n                        &quot;colors&quot;: {\r\n                            &quot;primary&quot;: &quot;transparent;&quot;,\r\n                            &quot;secondary&quot;: &quot;transparent;&quot;\r\n                        }\r\n                    }\r\n                ]\r\n            },\r\n            &quot;parent&quot;: null\r\n        }\r\n            ]\r\n    }\r\n\r\n\r\nI&#39;d like the following result\r\n\r\n    1  null  0  0  #fff  [ { &quot;link&quot;: &quot;/truc.html&quot;, &quot;value&quot;: &quot;nice&quot;, &quot;colors&quot;: { &quot;primary&quot;: &quot;transparent;&quot;, &quot;secondary&quot;: &quot;transparent;&quot; } } ]  null\r\n\r\nso basically I want the array to be intact but just returned in a single row\r\n\r\nSo I wrote this\r\n\r\n    jq -c --raw-output &#39;.records[]|[.id,.metadata.description,.metadata.width,.metadata.height,.metadata.secondaryColor,.metadata.callToAction,.parent]|@tsv\r\n\r\nBut I have the &quot;array  is not valid in a csv row&quot; error\r\n\r\nIs that possible ?\r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/55262718/how-to-convert-a-json-with-arrays-in-tsv-with-jq-keeping-the-array-structure",
        "title": "How to convert a JSON with arrays in tsv with jq keeping the array structure?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51793,
                    "reputation": 5758,
                    "user_id": 154762,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/4d07d8564c1726ca28a6b99e560f0ec7?s=256&d=identicon&r=PG",
                    "display_name": "solarc",
                    "link": "https://stackoverflow.com/users/154762/solarc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553109398,
                "post_id": 55268512,
                "comment_id": 97268225,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6813994,
                    "reputation": 2144,
                    "user_id": 5243291,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://lh3.googleusercontent.com/-PGScbJu5bNM/AAAAAAAAAAI/AAAAAAAAAGA/mlPoagrrqR8/s256-rj/photo.jpg",
                    "display_name": "Vini",
                    "link": "https://stackoverflow.com/users/5243291/vini"
                },
                "reply_to_user": {
                    "account_id": 51793,
                    "reputation": 5758,
                    "user_id": 154762,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/4d07d8564c1726ca28a6b99e560f0ec7?s=256&d=identicon&r=PG",
                    "display_name": "solarc",
                    "link": "https://stackoverflow.com/users/154762/solarc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553110350,
                "post_id": 55268512,
                "comment_id": 97268702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 51793,
                    "reputation": 5758,
                    "user_id": 154762,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/4d07d8564c1726ca28a6b99e560f0ec7?s=256&d=identicon&r=PG",
                    "display_name": "solarc",
                    "link": "https://stackoverflow.com/users/154762/solarc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553112816,
                "post_id": 55268512,
                "comment_id": 97269905,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1553115336,
                "last_edit_date": 1553115336,
                "creation_date": 1553111748,
                "answer_id": 55269170,
                "question_id": 55268512,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be much better to pass $key and $value into jq as illustrated in the following (deliberately minimalist) tweak of your script:\r\n\r\n    #!/bin/bash\r\n    \r\n    while read line\r\n    do\r\n      key=$(echo &quot;$line&quot; |cut -d&#39;:&#39; -f1)\r\n      value=$(echo &quot;$line&quot; |cut -d&#39;:&#39; -f2)\r\n      if [[ ! -z &quot;$value&quot; ]]\r\n      then\r\n         jq --arg key &quot;$key&quot; --arg value &quot;$value&quot; &#39;.parameters |= map( if .name == $key then .default = $value else . end )&#39; cam.json &gt; cam1.json\r\n         mv cam1.json cam.json\r\n    fi\r\n    done &lt; prop.properties\r\n\r\nIt would be still better to avoid the bash loop altogether and do everything with just one invocation of jq.\r\n\r\n## One-pass solution\r\n\r\nThe idea is to create a dictionary ($dict) of key-value pairs, which can easily be done using the builtin filter `INDEX/1`:\r\n\r\n    INDEX(inputs | split(&quot;:&quot;) | select(.[1] | length &gt; 0); .[0])\r\n    | map_values(.[1]) as $dict\r\n    | $cam\r\n    | .parameters |= map( $dict[.name] as $value | if $value then .default = $value else . end )\r\n\r\n## Invocation\r\n\r\nWith the above jq program in `program.jq`:\r\n\r\n    jq -n -R -f program.jq --argfile cam cam.json prop.properties &gt; cam1.json &amp;&amp; mv cam1.json cam.json\r\n\r\nOr using `sponge`:\r\n\r\n    jq -n -R -f program.jq --argfile cam cam.json prop.properties | sponge cam.json\r\n\r\nNote in particular the `-n` option, which is needed because program.jq uses `inputs`.",
                "title": "Replacing key value pair with spaces using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1553115336,
        "creation_date": 1553109071,
        "question_id": 55268512,
        "body_markdown": "I have a properties file and a json file. The property file holds the key value pairs which needs to be replaced in the json. \r\n\r\nWhen the value has no spaces it works as expected, but when the value has spaces, the value is not replaced.\r\n\r\n**Script that replaces the values**\r\n\r\n\t#!bin/bash\r\n\techo hello\r\n\t\r\n\twhile read line;\r\n\tdo\r\n\t#echo $line\r\n\tkey=$(echo &quot;$line&quot; |cut -d&#39;:&#39; -f1)\r\n\t#echo $part1\r\n\tvalue=$(echo &quot;$line&quot; |cut -d&#39;:&#39; -f2)\r\n\tif [[ ! -z $value ]];\r\n\tthen\r\n\tkey=&quot;\\&quot;$key\\&quot;&quot;\r\n\tvalue=&quot;\\&quot;$value\\&quot;&quot;\r\n\techo $key : $value\r\n\tjq &#39;.parameters |= map( if .name == &#39;$key&#39; then .default = &#39;$value&#39; else . end )&#39; cam.json &gt; cam1.json\r\n\tmv cam1.json cam.json\r\n\tfi\r\n\tdone &lt; prop.properties\r\n\r\n**property file**\r\n\r\n\tgit_con_type:something\r\n\tgit_host_fqdn:something again\r\n\tgit_user:something again again\r\n\tgit_user_password:something\r\n\tgit_repo:something\r\n\tgit_repo_user:\r\n\tgit_branch:\r\n\r\n**JSON file**\r\n\r\n    {\r\n\t&quot;name&quot;: &quot;${p:Instance_Name}&quot;,\r\n\t  &quot;parameters&quot;: [\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_con_type&quot;,\r\n\t      &quot;default&quot;: &quot;&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_host_fqdn&quot;,\r\n\t      &quot;default&quot;: &quot;hello&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_user&quot;,\r\n\t      &quot;default&quot;: &quot;&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_user_password&quot;,\r\n\t      &quot;default&quot;: &quot;Passw0rd&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_repo&quot;,\r\n\t      &quot;default&quot;: &quot;lm&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_repo_user&quot;,\r\n\t      &quot;default&quot;: &quot;-Life&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_branch&quot;,\r\n\t      &quot;default&quot;: &quot;master&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    },\r\n\t    {\r\n\t      &quot;name&quot;: &quot;git_clone_dir&quot;,\r\n\t      &quot;default&quot;: &quot;/opt/git&quot;,\r\n\t      &quot;immutable_after_create&quot;: false\r\n\t    }\r\n\t  ]\r\n\t}\r\n\r\n**Error**\r\n\r\n&gt; jq: error: syntax error, unexpected $end, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.parameters |= map( if .name == &quot;git_host_fqdn&quot; then .default = &quot;something\r\njq: error: Possibly unterminated &#39;if&#39; statement at &lt;top-level&gt;, line 1:\r\n.parameters |= map( if .name == &quot;git_host_fqdn&quot; then .default = &quot;something\r\njq: 2 compile errors\r\n\r\n\r\nhow can I make jq accept values with space? I have tried on jqplay with spaces and it works there, but not on the script. ",
        "link": "https://stackoverflow.com/questions/55268512/replacing-key-value-pair-with-spaces-using-jq",
        "title": "Replacing key value pair with spaces using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1553127943,
                "last_edit_date": 1553127943,
                "creation_date": 1553120102,
                "answer_id": 55270952,
                "question_id": 55270878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your problem description indicates you simply want to concatenate the arrays, which can easily be done using the &quot;slurp&quot; command-line option:\r\n\r\n    jq -s add\r\n\r\n## Efficiency\r\n\r\nIf efficiency is an issue, which it might be if the number of input arrays is very large, then you could take advantage of the stream-oriented nature of the input:\r\n\r\n    jq -n &#39;reduce inputs as $in ([]; .+$in)&#39;",
                "title": "How to merge multiple JSON arrays that are present in the same JSON file to single array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1554157058,
        "creation_date": 1553119677,
        "last_edit_date": 1553120152,
        "question_id": 55270878,
        "body_markdown": "I am getting the below-shown example from the python script that I ran. I would like to merge all the arrays to a single array as shown in the output needed below.     \r\nExample:\r\n    \r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;65&quot;,\r\n        &quot;type&quot;: &quot;Rug&quot; \r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;66&quot;,\r\n        &quot;type&quot;: &quot;Rug&quot; \r\n      }\r\n    ][\r\n      {\r\n        &quot;key&quot;: &quot;52&quot;,\r\n        &quot;type&quot;: &quot;A&quot; \r\n      }\r\n    ]\r\n    \r\nNeeded Ouput:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;65&quot;,\r\n        &quot;type&quot;: &quot;Rug&quot; \r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;66&quot;,\r\n        &quot;type&quot;: &quot;Rug&quot; \r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;52&quot;,\r\n        &quot;type&quot;: &quot;A&quot; \r\n      }\r\n    \r\n    ]\r\n      \r\n\r\n",
        "link": "https://stackoverflow.com/questions/55270878/how-to-merge-multiple-json-arrays-that-are-present-in-the-same-json-file-to-sing",
        "title": "How to merge multiple JSON arrays that are present in the same JSON file to single array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1553146487,
                "last_edit_date": 1553146487,
                "creation_date": 1553146318,
                "answer_id": 55274305,
                "question_id": 55273956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to use the `select()` construct to remove the object containing the `.name` field from the JSON structure.\r\n\r\n\r\n    if [[ $(jq &#39;.peerDependencies | length&#39; package.json) = 0 ]]; then\r\n        jq &#39;.sections |= map(select(.name != &quot;Prerequisite&quot;))&#39; docs.json      \r\n    fi\r\n\r\nYou can then use `&gt; newSection.json` to re-direct the modified content of `docs.json` to the new file.",
                "title": "JQ: How to put content of a file within another file under a certain key?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1553146506,
        "creation_date": 1553143801,
        "last_edit_date": 1553146506,
        "question_id": 55273956,
        "body_markdown": "Using **jq**, I want to\r\n\r\n- (1) read the count of keys in `package.json` within `peerDependencies`\r\n- (2) if the count is `0`, remove from `docs.json` when `sections[].name === &#39;prerequesite&#39;` \r\n\r\nThis is how I solved (1):\r\n\r\n    if [[ $(cat package.json | jq &#39;.peerDependencies | length&#39;) = 0 ]]; then\r\n      echo &quot;Remove page prerequesite as no peer dependencies were found&quot;\r\n      # do (2)\r\n    fi\r\n\r\nThis is how I started to solve (2):\r\n\r\n    cat docs.json | jq &#39;.sections[] | select(.name != &quot;Prerequisite&quot;)&#39; &gt; newSection.json\r\n\r\nHow can I put `newSection.json` in my file ?\r\n\r\nOtherwise: \r\n\r\nMy array JSON look like below:\r\n\r\n\r\n    {\r\n        &quot;ignore&quot;: [\r\n          &quot;**/__tests__/**&quot;,\r\n          &quot;**/*.test.{js,jsx,ts,tsx}&quot;,\r\n          &quot;**/*.spec.{js,jsx,ts,tsx}&quot;,\r\n          &quot;**/*.d.ts&quot;\r\n        ],\r\n    \t&quot;sections&quot;: [{\r\n    \t\t&quot;name&quot;: &quot;Introduction&quot;,\r\n    \t\t&quot;content&quot;: &quot;docs/introduction.md&quot;\r\n    \t}, {\r\n    \t\t&quot;name&quot;: &quot;Prerequisite&quot;,\r\n    \t\t&quot;content&quot;: &quot;docs/prerequisite.md&quot;\r\n    \t}]\r\n    }\r\n\r\nI expect to have \r\n\r\n    {\r\n        &quot;ignore&quot;: [\r\n          &quot;**/__tests__/**&quot;,\r\n          &quot;**/*.test.{js,jsx,ts,tsx}&quot;,\r\n          &quot;**/*.spec.{js,jsx,ts,tsx}&quot;,\r\n          &quot;**/*.d.ts&quot;\r\n        ],\r\n    \t&quot;sections&quot;: [{\r\n    \t\t&quot;name&quot;: &quot;Introduction&quot;,\r\n    \t\t&quot;content&quot;: &quot;docs/introduction.md&quot;\r\n    \t}]\r\n    }\r\n\r\n\r\nIn my `tmp.json` file I have: \r\n\r\n\r\n\r\nHow can I remove from the array the section with name `prerequisite` using the command line? \r\n",
        "link": "https://stackoverflow.com/questions/55273956/jq-how-to-put-content-of-a-file-within-another-file-under-a-certain-key",
        "title": "JQ: How to put content of a file within another file under a certain key?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1553163809,
                "last_edit_date": 1553163809,
                "creation_date": 1553162591,
                "answer_id": 55277881,
                "question_id": 55277768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `join` and string interpolation (`\\(...)`):\r\n\r\n    $ jq -r &#39;paths(scalars) as $p | &quot;\\($p|join(&quot;.&quot;))=\\(getpath($p))&quot;&#39; file\r\n    _index=ships\r\n    _type=doc\r\n    _id=c36806c10a96a3968c07c6a222cfc818\r\n    _score=0.057158414\r\n    _source.user_email=admin@example.com\r\n    _source.current_send_date=1552557382\r\n    _source.next_send_date=1570798063\r\n    _source.data_name=atari\r\n    _source.statistics.game_mode=engineer\r\n    _source.statistics.opened_game=0\r\n    _source.statistics.user_score=0\r\n    _source.statistics.space_1.ship_send_priority=10\r\n    _source.statistics.space_1.ssl_required=true\r\n    _source.statistics.space_1.ship_send_delay=15\r\n    _source.statistics.space_1.user_score=0\r\n    _source.statistics.space_1.template1.current_ship_status=sent\r\n    _source.statistics.space_1.template1.current_ship_date=4324242\r\n    _source.statistics.space_1.template1.checked_link_before_clicked=0\r\n    _source.statistics.space_1.template2.current_ship_status=sent\r\n    _source.statistics.space_1.template2.current_ship_date=4324242\r\n    _source.statistics.space_1.template2.checked_payload=0\r\n\r\nActually you don&#39;t even need grep if you have the latest version of jq, try this:\r\n\r\n    (paths(scalars) | select(IN(.[];\r\n        &quot;_index&quot;,\r\n        &quot;current_send_data&quot;,\r\n        &quot;ship_send_delay&quot;,\r\n        &quot;ship_send_priority&quot;,\r\n        &quot;current_ship_status&quot;\r\n    ))) as $p | &quot;\\($p|join(&quot;.&quot;))=\\(getpath($p))&quot;",
                "title": "Extract multiple fields using scalars in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1553163809,
        "creation_date": 1553162209,
        "question_id": 55277768,
        "body_markdown": "I am attempting to select only specific fields from a JSON file and their full path (results comes from Elasticsearch). \r\n\r\nMy JSON file:\r\n\r\n    {\r\n      &quot;_index&quot;: &quot;ships&quot;,\r\n      &quot;_type&quot;: &quot;doc&quot;,\r\n      &quot;_id&quot;: &quot;c36806c10a96a3968c07c6a222cfc818&quot;,\r\n      &quot;_score&quot;: 0.057158414,\r\n      &quot;_source&quot;: {\r\n        &quot;user_email&quot;: &quot;admin@example.com&quot;,\r\n        &quot;current_send_date&quot;: 1552557382,\r\n        &quot;next_send_date&quot;: 1570798063,\r\n        &quot;data_name&quot;: &quot;atari&quot;,\r\n        &quot;statistics&quot;: {\r\n          &quot;game_mode&quot;: &quot;engineer&quot;,\r\n          &quot;opened_game&quot;: 0,\r\n          &quot;user_score&quot;: 0,\r\n          &quot;space_1&quot;: {\r\n            &quot;ship_send_priority&quot;: 10,\r\n            &quot;ssl_required&quot;: &quot;true&quot;,\r\n            &quot;ship_send_delay&quot;: 15,\r\n            &quot;user_score&quot;: 0,\r\n            &quot;template1&quot;: {\r\n              &quot;current_ship_status&quot;: &quot;sent&quot;,\r\n              &quot;current_ship_date&quot;: &quot;4324242&quot;,\r\n              &quot;checked_link_before_clicked&quot;: 0\r\n            },\r\n            &quot;template2&quot;: {\r\n              &quot;current_ship_status&quot;: &quot;sent&quot;,\r\n              &quot;current_ship_date&quot;: &quot;4324242&quot;,\r\n              &quot;checked_payload&quot;: 0\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI am transforming the keys to one liners: \r\n\r\n    &lt;file jq -c &#39;paths(scalars) as $p | [$p, getpath($p)]&#39;\r\n    [[&quot;_index&quot;],&quot;ships&quot;]\r\n    [[&quot;_type&quot;],&quot;doc&quot;]\r\n    [[&quot;_id&quot;],&quot;c36806c10a96a3968c07c6a222cfc818&quot;]\r\n    [[&quot;_score&quot;],0.057158414]\r\n    [[&quot;_source&quot;,&quot;user_email&quot;],&quot;admin@example.com&quot;]\r\n    [[&quot;_source&quot;,&quot;current_send_date&quot;],1552557382]\r\n    [[&quot;_source&quot;,&quot;next_send_date&quot;],1570798063]\r\n    [[&quot;_source&quot;,&quot;data_name&quot;],&quot;atari&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;game_mode&quot;],&quot;engineer&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;opened_game&quot;],0]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;user_score&quot;],0]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;ship_send_priority&quot;],10]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;ssl_required&quot;],&quot;true&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;ship_send_delay&quot;],15]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;user_score&quot;],0]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template1&quot;,&quot;current_ship_status&quot;],&quot;sent&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template1&quot;,&quot;current_ship_date&quot;],&quot;4324242&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template1&quot;,&quot;checked_link_before_clicked&quot;],0]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template2&quot;,&quot;current_ship_status&quot;],&quot;sent&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template2&quot;,&quot;current_ship_date&quot;],&quot;4324242&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template2&quot;,&quot;checked_payload&quot;],0]\r\n\r\nThan I pipe the output to grep to extract all the fields I want: \r\n\r\n\r\n    &lt;file jq -c &#39;paths(scalars) as $p | [$p, getpath($p)]&#39;  | grep -e &#39;&quot;_index&quot;\\|current_send_date\\|current_send_date\\|ship_send_delay\\|ship_send_priority\\|current_ship_status&#39;\r\n    [[&quot;_index&quot;],&quot;ships&quot;]\r\n    [[&quot;_source&quot;,&quot;current_send_date&quot;],1552557382]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;ship_send_priority&quot;],10]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;ship_send_delay&quot;],15]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template1&quot;,&quot;current_ship_status&quot;],&quot;sent&quot;]\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;space_1&quot;,&quot;template2&quot;,&quot;current_ship_status&quot;],&quot;sent&quot;]\r\n\r\n\r\nAt the end I am piping grep&#39;s output to sed and clean the characters I do not need that results whit what I want: \r\n\r\n    &lt;file jq -c &#39;paths(scalars) as $p | [$p, getpath($p)]&#39;  | grep -e &#39;&quot;_index&quot;\\|current_send_date\\|current_send_date\\|ship_send_delay\\|ship_send_priority\\|current_ship_status&#39; | sed -e &#39;s/\\[\\[&quot;//g&#39; -e &#39;s/&quot;,&quot;/./g&#39; -e &#39;s/&quot;],&quot;/=/g&#39; -e &#39;s/&quot;],/=/g&#39; -e &#39;s/]$//g&#39; -e &#39;s/&quot;$//g&#39;\r\n    \r\n    _index=ships\r\n    _source.current_send_date=1552557382\r\n    _source.statistics.space_1.ship_send_priority=10\r\n    _source.statistics.space_1.ship_send_delay=15\r\n    _source.statistics.space_1.template1.current_ship_status=sent\r\n    _source.statistics.space_1.template2.current_ship_status=sent\r\n\r\nI am looking for a better way to at least extract the fields from jq not using grep. I can live with content preparation using SED, but I feel that there must be a better way to get the fields I want not using grep. I believe there must be some select(.mykey|.mykey1|.mykey2) that can accomplish that. ",
        "link": "https://stackoverflow.com/questions/55277768/extract-multiple-fields-using-scalars-in-jq",
        "title": "Extract multiple fields using scalars in jq"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8431806,
                    "reputation": 3,
                    "user_id": 8912473,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7a8fcde569ce09c097e44d22d02e9df6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hamdy.aea",
                    "link": "https://stackoverflow.com/users/8912473/hamdy-aea"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553168705,
                "post_id": 55279736,
                "comment_id": 97289157,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1553185950,
                "creation_date": 1553185950,
                "answer_id": 55285160,
                "question_id": 55279736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option would be to use this invocation of jq:\r\n\r\n    jq &#39;.results.sunrise\r\n    | strptime(&quot;%I:%M:%S %p&quot;)\r\n    | {h: ((.[3] + 1) % 24), m:.[4], s:.[5]}\r\n    | if .h &lt; 12 then &quot;\\(.h):\\(.m):\\(.s) AM&quot;\r\n      elif .h == 12 then &quot;\\(.h):\\(.m):\\(.s) PM&quot;\r\n      else &quot;\\(.h - 12):\\(.m):\\(.s) PM&quot;\r\n      end &#39;\r\n",
                "title": "UTC time readed from a json time change to UTC+1 in the same command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1553202701,
        "creation_date": 1553168690,
        "question_id": 55279736,
        "body_markdown": "I do a curl with this command :\r\n\r\ncurl &quot;https://api.sunrise-sunset.org/json?lat=46.745995&amp;lng=7.122781&amp;date=today&quot; | jq &#39;.results.sunrise&#39;\r\n\r\nthe result is :\r\n\r\n&quot;5:31:51 AM&quot;\r\n\r\nI am living in UTC+1 and I need to add one hour in the same command.\r\n\r\nIf the command don&#39;t work you need to install jq with apt install jq or download it for Windows\r\n",
        "link": "https://stackoverflow.com/questions/55279736/utc-time-readed-from-a-json-time-change-to-utc1-in-the-same-command",
        "title": "UTC time readed from a json time change to UTC+1 in the same command"
    },
    {
        "tags": [
            "shell",
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1633066713,
                "last_edit_date": 1633066713,
                "creation_date": 1553172521,
                "answer_id": 55280823,
                "question_id": 55280071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`keys` is a built-in function in `jq` when given an object, returns its keys in an array. So it is not actually apart of your yaml (not a property) which means you cannot do `services.keys`.\r\n\r\n\r\nTo get the keys you can do the following when using [Python yq][1]:\r\n\r\nWe will get the object of `services` in the first part then we pass it to `keys` which will return a list of keys based on a given object\r\n```\r\ncat docker-compose.yml | yq &#39;.services | keys&#39;\r\n```\r\nOr like this (*without cat and pipe*):\r\n```\r\nyq &#39;.services | keys&#39; docker-compose.yml\r\n```\r\nThe output will be:\r\n```\r\n[\r\n  &quot;apache&quot;,\r\n  &quot;mysql&quot;,\r\n  &quot;php&quot;\r\n]\r\n\r\n```\r\nTo get rid of the brackets:\r\n```\r\nyq &#39;.services | keys[]&#39; docker-compose.yml\r\n```\r\nThe output:\r\n```\r\n&quot;apache&quot;\r\n&quot;mysql&quot;\r\n&quot;php&quot;\r\n\r\n```\r\n\r\nFor more about details you can check [Builtin operators and functions](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions) in `jq`. Note that `yq` is a wrapper for `jq` so the documentation of `jq` would be helpful as the help of `yq` recommends.\r\n\r\n\r\n---\r\n\r\nOn [Go yq][2] you can do\r\n\r\n```\r\nyq e &#39;.services | keys&#39;\r\n```\r\n\r\n\r\n  [1]: https://kislyuk.github.io/yq/\r\n  [2]: https://mikefarah.gitbook.io/yq/",
                "title": "Yq: retrieve object keys names"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1563875283,
                "creation_date": 1563875283,
                "answer_id": 57161324,
                "question_id": 55280071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you just want to list the services from a docker-compose file you could achieve this with a docker-compose command.\r\n\r\n    docker-compose config --services\r\n\r\nNot directly an answer to the question as it is not using yq but maybe it helps ;) ",
                "title": "Yq: retrieve object keys names"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 15,
        "last_activity_date": 1633066713,
        "creation_date": 1553169982,
        "last_edit_date": 1553171973,
        "question_id": 55280071,
        "body_markdown": "I have a YAML file (docker-compose file in my case) that looks like this:\r\n\r\n```\r\nnetworks:\r\n    foo:\r\n      some_opts: &quot;covfefe&quot;\r\n    bar:\r\n      some_opts: &quot;such wow&quot;\r\nservices:\r\n  apache:\r\n    image: &#39;apache:1.0.0&#39;\r\n    restart: always\r\n  mysql:\r\n    image: &#39;mysql:1.0.0&#39;\r\n    restart: always\r\n  php:\r\n    image: &#39;php&#39;\r\n    restart: always\r\n```\r\n\r\nI would like to extract the services name thanks to [`yq`](https://github.com/kislyuk/yq), an equivalent of `jq` but for YAML, to have this output:\r\n\r\n```\r\n&quot;apache&quot;\r\n&quot;mysql&quot;\r\n&quot;php&quot;\r\n```\r\n\r\nCurrently I can achieve it like this:\r\n\r\n```\r\n$ cat docker-compose.yml | yq &#39;.services&#39; | yq &#39;keys[]&#39;\r\n&quot;apache&quot;\r\n&quot;mysql&quot;\r\n&quot;php&quot;\r\n```\r\n\r\nEven if it works, the double piped `yq` seems weird to me. I think I&#39;m doing it wrong. \r\n\r\n**Question:** Is there any way to achieve it with a single `yq` command ?\r\n\r\nI tried this without success, taking inspiration from [this question](https://stackoverflow.com/questions/23118341/how-to-get-key-names-from-json-using-jq):\r\n\r\n```\r\n$ cat docker-compose.yml | yq &#39;.services.keys[]&#39;\r\njq: error: Cannot iterate over null\r\n```",
        "link": "https://stackoverflow.com/questions/55280071/yq-retrieve-object-keys-names",
        "title": "Yq: retrieve object keys names"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1553181018,
                "creation_date": 1553181018,
                "answer_id": 55283594,
                "question_id": 55283016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add an argument as key of an object you must do it this way: \r\n```sh\r\njq --arg v $1 &#39;.cores[$v] = { master_url: &quot;http://master.solr.local:8983/solr/$var&quot;, poll_interval: &quot;00:01:00&quot;}&#39; test.json.tmp &gt; test.json\r\n```\r\n\r\nSo change your script to:\r\n```sh\r\n#/bin/sh!\r\n\r\nvar=$1\r\ncp -f test.json test.json.tmp\r\njq --arg v $1 &#39;.cores[$v] = { master_url: &quot;http://master.solr.local:8983/solr/$var&quot;, poll_interval: &quot;00:01:00&quot;}&#39;  test.json.tmp &gt;test.json\r\nrm test.json.tmp\r\n```\r\n\r\nand run it this way: `./yourscript.sh mykey`",
                "title": "Appending an object in JSON using jq which is triggered by shell with run time arguments"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1554148246,
        "creation_date": 1553179305,
        "last_edit_date": 1554148246,
        "question_id": 55283016,
        "body_markdown": "I am trying to insert objects into JSON file using a shell which contains a jq \r\n\r\nHere is the script shell.sh\r\n\r\n    #/bin/sh!\r\n    cp -f test.json test.json.tmp\r\n    jq &#39;.cores |= . + {&quot;brand3&quot;: &quot;{&quot;, &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand3&quot;, &quot;poll_interval&quot;: &quot;00:01:00&quot;}&#39; test.json.tmp &gt;test.json\r\n    rm test.json.tmp\r\n\r\ntest.json file \r\n\r\n     {\r\n      &quot;cores&quot;: {\r\n        &quot;brand1-nl-nl-live&quot;: {\r\n          &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand1-nl-nl-live&quot;,\r\n          &quot;poll_interval&quot;: &quot;00:01:00&quot;\r\n        },\r\n        &quot;brand2-nl-nl-live&quot;: {\r\n          &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand2-nl-nl-live&quot;,\r\n          &quot;poll_interval&quot;: &quot;00:01:00&quot;\r\n        },\r\n     &quot;brand3-nl-nl-live&quot;: &quot;{&quot;,\r\n        &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand3-nl-nl-live&quot;,\r\n        &quot;poll_interval&quot;: &quot;00:01:00&quot;\r\n      }\r\n    }\r\n\r\nWhich is working but don&#39;t want with quotes and comma &quot;{&quot;,\r\n\r\nNext step is I will be running shell with runtime argumnts command (./shell.sh brand3-nl-nl-live)\r\n\r\nExample: \r\n\r\n    #/bin/sh!\r\n    \r\n    var=$1\r\n    cp -f test.json test.json.tmp\r\n    jq &#39;.cores |= . + {&quot;$var&quot;: &quot;{&quot;, &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/$var&quot;, &quot;poll_interval&quot;: &quot;00:01:00&quot;}&#39; test.json.tmp &gt;test.json\r\n    rm test.json.tmp\r\n\r\nwhich should insert the object in json  \r\n\r\n     {\r\n      &quot;cores&quot;: {\r\n        &quot;brand1-nl-nl-live&quot;: {\r\n          &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand1-nl-nl-live&quot;,\r\n          &quot;poll_interval&quot;: &quot;00:01:00&quot;\r\n        },\r\n        &quot;brand2-nl-nl-live&quot;: {\r\n          &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand2-nl-nl-live&quot;,\r\n          &quot;poll_interval&quot;: &quot;00:01:00&quot;\r\n        },\r\n     &quot;brand3-nl-nl-live&quot;: {\r\n        &quot;master_url&quot;: &quot;http://master.solr.local:8983/solr/brand3-nl-nl-live&quot;,\r\n        &quot;poll_interval&quot;: &quot;00:01:00&quot;\r\n      }\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/55283016/appending-an-object-in-json-using-jq-which-is-triggered-by-shell-with-run-time-a",
        "title": "Appending an object in JSON using jq which is triggered by shell with run time arguments"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1553264264,
                "last_edit_date": 1553264264,
                "creation_date": 1553263282,
                "answer_id": 55301293,
                "question_id": 55300958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just join what the array of strings with `\\\\n` (the sequence of the `\\` character which we need to escape and the `n` character) and use raw-output : \r\n\r\n    jq --raw-output &#39;to_entries | map(&quot;\\(.key) : \\(.value)&quot;) | join(&quot;\\\\n&quot;)&#39;\r\n\r\n\r\nTry it [here](https://jqplay.org/s/OuD_TzOC6n).",
                "title": "map, but with newline characters between keypairs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553266831,
                "last_edit_date": 1553266831,
                "creation_date": 1553263508,
                "answer_id": 55301360,
                "question_id": 55300958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or more efficiently and more simply:\r\n\r\n    jq -r &#39;to_entries[] | &quot;\\(.key) : \\(.value)&quot;&#39;\r\n\r\nThis produces one line per key-value pair. \r\n\r\n## The two-character sequence `\\n` as a join-string\r\n\r\nWith your sample JSON, the invocation: \r\n\r\n     jq -j -r &#39;to_entries[] | &quot;\\(.key) : \\(.value)&quot;, &quot;\\\\n&quot; &#39;\r\n\r\nwould produce:\r\n\r\n\r\n    STACK_NAME : applecakes\\nBACKEND_OR_INTEGRATIONS : integrations\\nPRIORITY : Medium\\n\r\n\r\nNotice the trailing &quot;\\\\n&quot;.",
                "title": "map, but with newline characters between keypairs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1553266831,
        "creation_date": 1553262195,
        "last_edit_date": 1553265304,
        "question_id": 55300958,
        "body_markdown": "Say I have input like \r\n\r\n    {&quot;DESCRIPTION&quot;: &quot;Need to run script to do stuff&quot;, &quot;PRIORITY&quot;: &quot;Medium&quot;}\r\n\r\nbut also get input like \r\n\r\n    {&quot;STACK_NAME&quot;: &quot;applecakes&quot;, &quot;BACKEND_OR_INTEGRATIONS&quot;: &quot;integrations&quot;, &quot;PRIORITY&quot;: &quot;Medium&quot;}\r\n\r\nie, the parameters can be completely different.\r\n\r\nI need to get the output in a format more friendly to send to Jira to make tickets. Specifically, I would like to strip the json formatting away, and insert a `\\n` between each keypair. Here&#39;s what the above samples should look like:\r\n\r\n    DESCRIPTION: Need to run script to do stuff\\nPRIORITY: Medium\r\n\r\n    STACK_NAME: applecakes\\nBACKEND_OR_INTEGRATIONS: integrations\\nPRIORITY: Medium\r\n\r\nThere can be a little flexibility in that if, for example, more spaces were needed or whatever.\r\n\r\nSo far I&#39;ve got this worked out (assuming my input is stored in a variable called `description`\r\n\r\n    echo $description | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot;\r\n\r\nThis works to strip away the JSON formatting, but doesn&#39;t handle newlines. I&#39;m stumped on how to make sure I split only on each keypair, not on say every space or anything equally messy. What do I need to add to include newlines? Is a map even my best choice?",
        "link": "https://stackoverflow.com/questions/55300958/map-but-with-newline-characters-between-keypairs",
        "title": "map, but with newline characters between keypairs"
    },
    {
        "tags": [
            "bash",
            "python",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4230755,
                    "reputation": 7959,
                    "user_id": 3536342,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/M6UB9Fnp.png?s=256",
                    "display_name": "DavidPostill",
                    "link": "https://stackoverflow.com/users/3536342/davidpostill"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1553282597,
                "post_id": 55306538,
                "comment_id": 97341324,
                "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": 1553282755,
                "post_id": 55306538,
                "comment_id": 97341381,
                "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": 1553282946,
                "post_id": 55306538,
                "comment_id": 97341463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2853098,
                    "reputation": 3439,
                    "user_id": 2449857,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jxnCm.jpg?s=256",
                    "display_name": "Jack Deeth",
                    "link": "https://stackoverflow.com/users/2449857/jack-deeth"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553285527,
                "post_id": 55306538,
                "comment_id": 97342608,
                "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": 1553294307,
                "post_id": 55306538,
                "comment_id": 97345429,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1553282607,
        "creation_date": 1553282237,
        "question_id": 55306538,
        "body_markdown": "I have a Python program which prints json objects (from intermittent messages from a game&#39;s API). When I run the program by itself, each message immediately appears in the console output.\r\n\r\n    $ python myprog.py\r\n    {&quot;SG_MSG&quot;:{&quot;obj_id&quot;:&quot;SD748&quot;,&quot;aspect&quot;:&quot;0&quot;,&quot;time&quot;:&quot;42&quot;}}\r\n    {&quot;SG_MSG&quot;:{&quot;obj_id&quot;:&quot;SD748&quot;,&quot;aspect&quot;:&quot;6&quot;,&quot;time&quot;:&quot;75&quot;}}\r\n\r\nBut when I pipe the output into jq, jq outputs nothing for ages, and sporadically spits out a bunch of messages at once:\r\n\r\n    $ python myprog.py | jq .\r\n\r\nI&#39;ve tried prepending each message with the record separator character (ascii 30) and using `jq --seq .` but the result is the same.\r\n\r\nPiping to `od` shows the record separator character is appearing as the jq manual says it should:\r\n\r\n    $ python myprog.py | od -t d1\r\n    … … … 125 125 10 30 123 … …\r\n\r\nwhich is }, }, LF, RS, {\r\n\r\nAnd piping to `od` shows the same behaviour, where no output is shown until a bunch of messages have backed up.\r\n\r\nI&#39;m guessing there&#39;s something elementary about bash I&#39;m overlooking here…?",
        "link": "https://stackoverflow.com/questions/55306538/piped-output-from-python-gets-backed-up",
        "title": "Piped output from Python gets backed up"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1553335995,
                "last_edit_date": 1553335995,
                "creation_date": 1553334878,
                "answer_id": 55312521,
                "question_id": 55312306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `reduce` like this:\r\n\r\n    $ jq -c -n &#39;reduce inputs as $p ({}; .[$p.name] |= { name : $p.name, list : (.list + $p.list) }) | .[]&#39; file\r\n    {&quot;name&quot;:&quot;a&quot;,&quot;list&quot;:[&quot;a1&quot;,&quot;a2&quot;,&quot;a3&quot;,&quot;a4&quot;]}\r\n    {&quot;name&quot;:&quot;b&quot;,&quot;list&quot;:[&quot;b1&quot;,&quot;b2&quot;]}",
                "title": "Concat 2 arrays inside object based on object key/value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553352509,
                "creation_date": 1553352509,
                "answer_id": 55314952,
                "question_id": 55312306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple and efficient solution that uses a common &quot;aggregate by&quot; technique:\r\n\r\n    reduce inputs as $kv ({}; .[$kv.name] += $kv.list)\r\n    | keys_unsorted[] as $k\r\n    | {name: $k, list: .[$k]}\r\n\r\nSince `inputs` has been used here, the -n command-line option of jq should be specified.\r\n\r\n",
                "title": "Concat 2 arrays inside object based on object key/value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1554156243,
        "creation_date": 1553333009,
        "question_id": 55312306,
        "body_markdown": "I have multiple json objects which could be less when i merge the arrays if a object key matches the same value as the next json object. I&#39;m trying to accomplish this with jq.\r\n\r\nI think i have to use group_by(.name) first to group matching keys. I&#39;m also using slurp to first wrap all objects into one big array.\r\n\r\nI don&#39;t have anything working for now.\r\n\r\ngiven:\r\n```json\r\n{\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;list&quot;: [ &quot;a1&quot;, &quot;a2&quot; ]\r\n}\r\n{\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;list&quot;: [ &quot;a3&quot;, &quot;a4&quot; ]\r\n}\r\n{\r\n    &quot;name&quot;: &quot;b&quot;,\r\n    &quot;list&quot;: [ &quot;b1&quot;, &quot;b2&quot; ]\r\n}\r\n```\r\n\r\nshould result in:\r\n```json\r\n{\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;list&quot;: [ &quot;a1&quot;, &quot;a2&quot;, &quot;a3&quot;, &quot;a4&quot; ]\r\n}\r\n{\r\n    &quot;name&quot;: &quot;b&quot;,\r\n    &quot;list&quot;: [ &quot;b1&quot;, &quot;b2&quot; ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55312306/concat-2-arrays-inside-object-based-on-object-key-value",
        "title": "Concat 2 arrays inside object based on object key/value"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 238217,
                    "reputation": 3147,
                    "user_id": 506954,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/f755e811fa7ee3248e22348ebcff909a?s=256&d=identicon&r=PG",
                    "display_name": "extempl",
                    "link": "https://stackoverflow.com/users/506954/extempl"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1553439381,
                "post_id": 55324361,
                "comment_id": 97376215,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1987167,
                    "reputation": 1050,
                    "user_id": 1782056,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/81d02617f96ec790bcae96333d4973f5?s=256&d=identicon&r=PG",
                    "display_name": "Abdul",
                    "link": "https://stackoverflow.com/users/1782056/abdul"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1553451527,
                "post_id": 55324361,
                "comment_id": 97379955,
                "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": 1557610561,
                "post_id": 55324361,
                "comment_id": 98824907,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1557611161,
        "creation_date": 1553434570,
        "question_id": 55324361,
        "body_markdown": "I need to merge two JSON objects based on first object keys\r\n\r\n    object1 = {\r\n     &quot;params&quot; : {\r\n        &quot;type&quot;: [&quot;type1&quot;, &quot;type2&quot;],\r\n        &quot;requeststate&quot;: []\r\n     }        \r\n    }\r\n    \r\n    object2 = {\r\n     &quot;params&quot; : {\r\n        &quot;type&quot;: [&quot;type2&quot;, &quot;type3&quot;, &quot;type4&quot;],\r\n        &quot;requeststate&quot;: [&quot;Original&quot;, &quot;Revised&quot; ],\r\n        &quot;responsestate&quot;: [&quot;Approved&quot; ]\r\n     }        \r\n    }\r\n\r\nI need to merge two object based on first object key and my output should look like below\r\n\r\n    mergedobject = {\r\n     &quot;params&quot; : {\r\n        &quot;type&quot;: [&quot;type1&quot;, &quot;type2&quot;, &quot;type3&quot;, &quot;type4&quot;],\r\n        &quot;requeststate&quot;: [&quot;Original&quot;, &quot;Revised&quot;]\r\n     }        \r\n    }\r\n\r\ni searched for my case and didnt find much details Please let me know is it possible to do with shell script\r\n\r\nMy case involved with morethan 15 params object and I cant declare all the param object . Also it may grow in future and I need handle that if possible.\r\n\r\nPlease comment if you need more details. Thanks for your support\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55324361/merge-json-array-using-shell-script",
        "title": "Merge Json array using shell script"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553548698,
                "creation_date": 1553548698,
                "answer_id": 55346543,
                "question_id": 55346229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a quick and dirty bash script that uses [jq](https://stedolan.github.io/jq/) to extract the URL from the json files, and awk to detect and delete duplicates:\r\n\r\n&lt;!-- language: sh --&gt;\r\n\r\n    #!/bin/bash\r\n    \r\n    rm -f urls-dir1.txt urls-dir2.txt\r\n    \r\n    for file in dir1/*.json; do\r\n        printf &quot;%s\\t%s\\n&quot; &quot;$file&quot; $(jq &#39;.url[0]&#39; &quot;$file&quot;) &gt;&gt; urls-dir1.txt\r\n    done\r\n    for file in dir2/*.json; do\r\n        printf &quot;%s\\t%s\\n&quot; &quot;$file&quot; $(jq &#39;.url[0]&#39; &quot;$file&quot;) &gt;&gt; urls-dir2.txt\r\n    done\r\n    \r\n    awk -F $&#39;\\t&#39; &#39;FNR == NR  { urls[$2] = 1; next }\r\n                  $2 in urls { system(&quot;rm -f \\&quot;&quot; $1 &quot;\\&quot;&quot;) }&#39; urls-dir1.txt urls-dir2.txt\r\n  \r\n    rm -f urls-dir1.txt urls-dir2.txt\r\n\r\nIt assumes that dir2 has the files that are to be deleted as duplicates and the ones in dir1 should be untouched.",
                "title": "Delete duplicate JSON file based on one of the attributes"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1591333917,
                "last_edit_date": 1591333917,
                "creation_date": 1553550254,
                "answer_id": 55346875,
                "question_id": 55346229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq] to get a list of duplicates:\r\n```bash\r\njq -nrj &#39;[\r\n  foreach inputs.url as [$url] ({};\r\n    .[$url] += 1;\r\n    if .[$url] &gt; 1 then input_filename\r\n    else empty end\r\n  )\r\n] | join(&quot;\\u0000&quot;)&#39; /{dir1,dir2}/*.json\r\n```\r\nAnd to remove them, pipe above command&#39;s output to xargs:\r\n```\r\nxargs -0 rm --\r\n```",
                "title": "Delete duplicate JSON file based on one of the attributes"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553550884,
                "creation_date": 1553550884,
                "answer_id": 55346983,
                "question_id": 55346229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following Java approach to achieve this:\r\n\r\n    Set&lt;String&gt; urls = new HashSet&lt;&gt;();\r\n    try (Stream&lt;Path&gt; paths = Files.list(Paths.get(&quot;/path/to/your/folder&quot;))) {\r\n        paths\r\n                .map(path -&gt; new FileInfo(path, extractUrl(path)))\r\n                .filter(info -&gt; info.getUrl() != null)\r\n                .filter(info -&gt; !urls.add(info.getUrl()))\r\n                .forEach(info -&gt; {\r\n                    try {\r\n                        Files.delete(info.getPath());\r\n                    } catch (IOException e) {\r\n                        e.printStackTrace();\r\n                    }\r\n                });\r\n    } catch (IOException e) {\r\n        e.printStackTrace();\r\n    }\r\n\r\nThis uses the following `FileInfo` class:\r\n\r\n    public class FileInfo {\r\n        private Path path;\r\n        private String url;\r\n        // constructor and getter\r\n    }\r\n\r\nFirst of all it reads all files in the given directory and extracts the URL. It filters all duplicates with the help of the `HashSet`. At the end all files containing duplicate URLs are going to be deleted.\r\n\r\nThere are multiple options to extract the `url` from each file:\r\n\r\n_Quick and dirty using a regex:_\r\n\r\n    private String extractUrl(Path path) {\r\n        try {\r\n            String content = String.join(&quot;\\n&quot;, Files.readAllLines(path));\r\n            Pattern pattern = Pattern.compile(&quot;\\&quot;url\\&quot;.+\\\\s+\\&quot;(?&lt;url&gt;[^\\\\s\\&quot;]+)\\&quot;&quot;);\r\n            Matcher matcher = pattern.matcher(content);\r\n            if (matcher.find()) {\r\n                return matcher.group(&quot;url&quot;);\r\n            }\r\n        } catch (IOException e) {\r\n            e.printStackTrace();\r\n        }\r\n        return null;\r\n    }\r\n\r\nA better solution would be using a JsonParser Library like [Jackson](https://github.com/FasterXML/jackson):\r\n\r\n    private String extractUrl(Path path) {\r\n        try (BufferedReader reader = Files.newBufferedReader(path)) {\r\n            ObjectMapper mapper = new ObjectMapper();\r\n            MyObject object = mapper.readValue(reader, MyObject.class);\r\n            return object.getUrls().stream().findFirst().orElse(null);\r\n        } catch (IOException e) {\r\n            e.printStackTrace();\r\n        }\r\n        return null;\r\n    }\r\n\r\nThis uses an Object representation of the file content:\r\n\r\n    public class MyObject {\r\n        @JsonProperty(&quot;url&quot;)\r\n        private List&lt;String&gt; urls;\r\n        // getter and setter\r\n    }\r\n\r\nBut at the end, the most performant solution probably would be to use a shell script.",
                "title": "Delete duplicate JSON file based on one of the attributes"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1553563175,
                "creation_date": 1553563175,
                "answer_id": 55348559,
                "question_id": 55346229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a quick and simple awk script that does all the work from base dir.\r\n\r\nThe awk script named `script1.awk`\r\n```\r\n/https/{\r\n    if ($1 in urlArr) {\r\n        cmd = &quot;rm &quot; FILENAME;\r\n        print cmd;\r\n        //system(cmd);\r\n    } else {\r\n        urlArr[$1] = FILENAME;\r\n    }\r\n}\r\n```\r\n\r\nInitially run the script with the following command:\r\n\r\n`awk -f script1.awk dir{1,}/*.json`\r\n\r\nWhen ready to remove the duplicate json files, just uncomment the 5th line (line containing `system(cmd)`). And run again. \r\n\r\n\r\nHere are some explanations:\r\n\r\n1. The `awk` command runs the script `script1.awk` on all json files in sub directory dir and dir1.\r\n\r\n2. The script traverse each file, extract the URL text having https into variable $1. \r\n\r\n  If variable $1 already exist in associative array urlArr print/remove the file. \r\n\r\n  Else add current file into associative array urlArr.\r\n\r\n\r\nHope you like this simple solution.\r\n\r\n",
                "title": "Delete duplicate JSON file based on one of the attributes"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1666425204,
        "creation_date": 1553547150,
        "last_edit_date": 1666425204,
        "question_id": 55346229,
        "body_markdown": "I have two directories in my linux system, `/dir` and `/dir2`\r\n\r\n\r\n\r\nBoth have more than 4000 JSON files. The JSON content of every file is like\r\n\r\n    {\r\n       &quot;someattribute&quot;:&quot;someValue&quot;,\r\n       &quot;url&quot;:[\r\n          &quot;https://www.someUrl.com/xyz&quot;\r\n       ],\r\n       &quot;someattribute&quot;:&quot;someValue&quot;\r\n    }\r\n\r\nNote that url is an array, but it always contains one element (the url).\r\n\r\nThe url makes the file unique. If there is a file with the same url in `/dir` and `/dir2` then it&#39;s a duplicate and it needs to be deleted.\r\n\r\nI want to automate this operation either using a shell command preferrably. Any opinion how I should go about it?",
        "link": "https://stackoverflow.com/questions/55346229/delete-duplicate-json-file-based-on-one-of-the-attributes",
        "title": "Delete duplicate JSON file based on one of the attributes"
    },
    {
        "tags": [
            "json",
            "object",
            "filter",
            "parent-child",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1553567892,
                "creation_date": 1553567892,
                "answer_id": 55349073,
                "question_id": 55348490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is one of many ways way to get the expected output:\r\n\r\n    jq &#39;.resources[].entity | select(.credentials.&quot;credhub-ref&quot;) | {app_guid, service_instance_guid, credentials}&#39; test.json\r\n\r\nIt will search for `.credentials.credhub-ref` in every `entity` object and will return `app_guid, service_instance_guid, credentials` as object if found.\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;app_guid&quot;: &quot;9c&quot;,\r\n      &quot;service_instance_guid&quot;: &quot;66&quot;,\r\n      &quot;credentials&quot;: {\r\n        &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;app_guid&quot;: &quot;73&quot;,\r\n      &quot;service_instance_guid&quot;: &quot;ae&quot;,\r\n      &quot;credentials&quot;: {\r\n        &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "JQ Select Outer Objects and Child Based on Child"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1554155328,
        "creation_date": 1553562556,
        "question_id": 55348490,
        "body_markdown": "I am trying to select the credentials object and specific parent level objects only if the key credhub-ref exist within the credential object following JSON:\r\n```\r\n{\r\n   &quot;total_results&quot;: 23,\r\n   &quot;total_pages&quot;: 1,\r\n   &quot;prev_url&quot;: null,\r\n   &quot;next_url&quot;: null,\r\n   &quot;resources&quot;: [\r\n      {\r\n         &quot;metadata&quot;: {\r\n            &quot;guid&quot;: &quot;cd&quot;,\r\n            &quot;url&quot;: &quot;/v2/service_bindings/cd&quot;,\r\n            &quot;created_at&quot;: &quot;2019-03-04T21:18:53Z&quot;,\r\n            &quot;updated_at&quot;: &quot;2019-03-04T21:18:53Z&quot;\r\n         },\r\n         &quot;entity&quot;: {\r\n            &quot;app_guid&quot;: &quot;9c&quot;,\r\n            &quot;service_instance_guid&quot;: &quot;66&quot;,\r\n            &quot;credentials&quot;: {\r\n               &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n            },\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2019-03-04T21:18:53Z&quot;,\r\n               &quot;created_at&quot;: &quot;2019-03-04T21:18:53Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/apps/9c&quot;,\r\n            &quot;service_instance_url&quot;: &quot;/v2/service_instances/66&quot;,\r\n            &quot;service_binding_parameters_url&quot;: &quot;/v2/service_bindings/cd&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;metadata&quot;: {\r\n            &quot;guid&quot;: &quot;cd&quot;,\r\n            &quot;url&quot;: &quot;/v2/service_bindings/cd&quot;,\r\n            &quot;created_at&quot;: &quot;2019-03-11T08:49:22Z&quot;,\r\n            &quot;updated_at&quot;: &quot;2019-03-11T08:49:22Z&quot;\r\n         },\r\n         &quot;entity&quot;: {\r\n            &quot;app_guid&quot;: &quot;ea&quot;,\r\n            &quot;service_instance_guid&quot;: &quot;86&quot;,\r\n            &quot;credentials&quot;: {},\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2019-03-11T08:49:22Z&quot;,\r\n               &quot;created_at&quot;: &quot;2019-03-11T08:49:22Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/apps/ea&quot;,\r\n            &quot;service_instance_url&quot;: &quot;/v2/service_instances/86&quot;,\r\n            &quot;service_binding_parameters_url&quot;: &quot;/v2/service_bindings/cd&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;metadata&quot;: {\r\n            &quot;guid&quot;: &quot;e0&quot;,\r\n            &quot;url&quot;: &quot;/v2/service_bindings/e0&quot;,\r\n            &quot;created_at&quot;: &quot;2019-03-19T20:07:25Z&quot;,\r\n            &quot;updated_at&quot;: &quot;2019-03-19T20:07:25Z&quot;\r\n         },\r\n         &quot;entity&quot;: {\r\n            &quot;app_guid&quot;: &quot;73&quot;,\r\n            &quot;service_instance_guid&quot;: &quot;52&quot;,\r\n            &quot;credentials&quot;: {\r\n               &quot;hostname&quot;: &quot;10.13.7.64&quot;,\r\n               &quot;port&quot;: 3306,\r\n               &quot;name&quot;: &quot;cf_52&quot;,\r\n               &quot;username&quot;: &quot;w&quot;,\r\n               &quot;password&quot;: &quot;w&quot;,\r\n               &quot;uri&quot;: &quot;mysql://&quot;,\r\n               &quot;jdbcUrl&quot;: &quot;jdbc:mysql://10.193.78.64:&quot;\r\n            },\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2019-03-19T20:07:25Z&quot;,\r\n               &quot;created_at&quot;: &quot;2019-03-19T20:07:25Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/apps/73&quot;,\r\n            &quot;service_instance_url&quot;: &quot;/v2/service_instances/52&quot;,\r\n            &quot;service_binding_parameters_url&quot;: &quot;/v2/service_bindings/e0&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;metadata&quot;: {\r\n            &quot;guid&quot;: &quot;18&quot;,\r\n            &quot;url&quot;: &quot;/v2/service_bindings/18&quot;,\r\n            &quot;created_at&quot;: &quot;2019-03-19T20:07:27Z&quot;,\r\n            &quot;updated_at&quot;: &quot;2019-03-19T20:07:27Z&quot;\r\n         },\r\n         &quot;entity&quot;: {\r\n            &quot;app_guid&quot;: &quot;73&quot;,\r\n            &quot;service_instance_guid&quot;: &quot;ae&quot;,\r\n            &quot;credentials&quot;: {\r\n               &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n            },\r\n            &quot;binding_options&quot;: {},\r\n            &quot;gateway_data&quot;: null,\r\n            &quot;gateway_name&quot;: &quot;&quot;,\r\n            &quot;syslog_drain_url&quot;: null,\r\n            &quot;volume_mounts&quot;: [],\r\n            &quot;name&quot;: null,\r\n            &quot;last_operation&quot;: {\r\n               &quot;type&quot;: &quot;create&quot;,\r\n               &quot;state&quot;: &quot;succeeded&quot;,\r\n               &quot;description&quot;: &quot;&quot;,\r\n               &quot;updated_at&quot;: &quot;2019-03-19T20:07:27Z&quot;,\r\n               &quot;created_at&quot;: &quot;2019-03-19T20:07:27Z&quot;\r\n            },\r\n            &quot;app_url&quot;: &quot;/v2/apps/73&quot;,\r\n            &quot;service_instance_url&quot;: &quot;/v2/service_instances/aec&quot;,\r\n            &quot;service_binding_parameters_url&quot;: &quot;/v2/service_bindings/18&quot;\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nThe current query only returns the credentials object:\r\n```\r\njq &#39;.resources[].entity.credentials | select(.[&quot;credhub-ref&quot;])&#39; test.json\r\n```\r\nResults in:\r\n```\r\n{\r\n  &quot;credhub-ref&quot;: &quot;/c/42&quot;\r\n}\r\n{\r\n  &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n}\r\n```\r\nI need a query that outputs the parent objects `app_guid` and `service_instance_guid` too like the following:\r\n```\r\n}\r\n   &quot;app_guid&quot;: &quot;9c&quot;,\r\n   &quot;service_instance_guid&quot;: &quot;66&quot;,\r\n   &quot;credentials&quot;: {\r\n      &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n},\r\n{\r\n   &quot;app_guid&quot;: &quot;73&quot;,\r\n   &quot;service_instance_guid&quot;: &quot;ae&quot;,\r\n   &quot;credentials&quot;: {\r\n      &quot;credhub-ref&quot;: &quot;/c/54&quot;\r\n}\r\n```\r\nA few good examples of how this can be done would go a long way for helping me better understand how JQ works.",
        "link": "https://stackoverflow.com/questions/55348490/jq-select-outer-objects-and-child-based-on-child",
        "title": "JQ Select Outer Objects and Child Based on Child"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1553615741,
                "creation_date": 1553615741,
                "answer_id": 55361373,
                "question_id": 55361298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.hits.hits` is an array, so you will need to add `[]` to map over it:\r\n\r\n    .hits.hits[]._source.listaObjeto",
                "title": "&quot;jq: error: Cannot index array with string&quot; getting data from ElasticSearch results with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1553619732,
        "creation_date": 1553615482,
        "last_edit_date": 1553619732,
        "question_id": 55361298,
        "body_markdown": "I trying to get the `listaObjeto` from the json.\r\n\r\nThis is an extract of my json:\r\n\r\n```json\r\n{\r\n  &quot;took&quot;: 42,\r\n  &quot;timed_out&quot;: false,\r\n  &quot;_shards&quot;: {\r\n    &quot;total&quot;: 5,\r\n    &quot;successful&quot;: 5,\r\n    &quot;skipped&quot;: 0,\r\n    &quot;failed&quot;: 0\r\n  },\r\n  &quot;hits&quot;: {\r\n    &quot;total&quot;: 1,\r\n    &quot;max_score&quot;: 11.2367325,\r\n    &quot;hits&quot;: [\r\n      {\r\n        &quot;_index&quot;: &quot;provflogs-2019.03.26&quot;,\r\n        &quot;_type&quot;: &quot;Portal&quot;,\r\n        &quot;_id&quot;: &quot;SQGEumkBYgyBeVm_SiGe&quot;,\r\n        &quot;_score&quot;: 11.2367325,\r\n        &quot;_source&quot;: {\r\n          &quot;siglaSistema&quot;: &quot;SRPO&quot;,\r\n          &quot;dataPesquisa&quot;: &quot;2019-03-26T12:00:25.896-0300&quot;,\r\n          &quot;ipRequisitante&quot;: &quot;104.238.179.249&quot;,\r\n          &quot;listaObjeto&quot;: [\r\n            &quot;UB711395572YP&quot;,\r\n            &quot;OG461051611BR&quot;,\r\n            &quot;RG968790315CN&quot;\r\n          ],\r\n          &quot;loginUsuario&quot;: &quot;USER1&quot;,\r\n          &quot;metodoRequisitado&quot;: &quot;buscaEventos&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nHere is the error I&#39;m getting : \r\n\r\n&gt; jq &#39;.hits.hits._source.listaObjeto&#39; jq: error: Cannot index array with\r\n&gt; string\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55361298/jq-error-cannot-index-array-with-string-getting-data-from-elasticsearch-resu",
        "title": "&quot;jq: error: Cannot index array with string&quot; getting data from ElasticSearch results with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1553756004,
                "last_edit_date": 1553756004,
                "creation_date": 1553696136,
                "answer_id": 55379420,
                "question_id": 55378978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If objects under the array contain **only one** key-value pair each, use `index` to get the index of matching one:\r\n```jq\r\nindex({message:&quot;Validating&quot;})\r\n```\r\nOtherwise:\r\n```\r\nmap(.message == &quot;Validating...&quot;)|index(true)\r\n```\r\nOr use this more efficient function:\r\n```\r\ndef find(condition):\r\n    label $out\r\n    | foreach .[] as $p (-1; . + 1\r\n        if $p | condition\r\n        then ., break $out\r\n        else empty end);\r\n```\r\n\r\nThen use this index for slicing the array:\r\n```\r\n# all leading\r\n.[0:find(.message == &quot;Validating...&quot;)]\r\n\r\n# all trailing\r\n.[find(.message == &quot;Validating...&quot;):]\r\n\r\n# leading three\r\nfind(.message == &quot;Validating...&quot;) as $i | .[if $i &lt; 3 then 0 else $i - 3 end:$i]\r\n\r\n# trailing three\r\nfind(.message == &quot;Validating...&quot;) as $i | .[$k:$k + 4]\r\n\r\n# etc",
                "title": "jq - Print leading and trailing context surrounding each match?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1553756004,
        "creation_date": 1553694931,
        "question_id": 55378978,
        "body_markdown": "Is it possible to print the leading &amp; trailing context of a match in `jq`?\r\n\r\nSay i have the following JSON:\r\n\r\n```JSON\r\n...\r\n[{\r\n  &quot;message&quot;: &quot;Validating...&quot;,\r\n},\r\n{\r\n  &quot;message&quot;: &quot;Validated.&quot;,\r\n},\r\n{\r\n  &quot;message&quot;: &quot;Saving...&quot;,\r\n},\r\n{\r\n  &quot;message&quot;: &quot;Saved.&quot;,\r\n}]\r\n...\r\n```\r\n\r\nI want to be able to match a string where `message==&quot;Validating...&quot;`, then get the the next `n` trailing or leading objects from the match.\r\n\r\nWith `grep`, you have the `-C` option to get the context. Is there anything similar in `jq`?",
        "link": "https://stackoverflow.com/questions/55378978/jq-print-leading-and-trailing-context-surrounding-each-match",
        "title": "jq - Print leading and trailing context surrounding each match?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1553770984,
                "creation_date": 1553770984,
                "answer_id": 55395970,
                "question_id": 55395872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure, you can use the following filter :\r\n\r\n    .id as $id | .name as $name | {payload : [ .items[] | {key:.id, data:{id:$id, name: $name, items:[.]}} ] }\r\n\r\nYou can [try it here](https://jqplay.org/s/zq8CfS2Wab).",
                "title": "jq : mapping array in object to another object while keeping parent keys and adding new ones"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1554111993,
        "creation_date": 1553770678,
        "question_id": 55395872,
        "body_markdown": "I would like to map the following structure \r\n\r\n\r\n    {\r\n        &quot;id&quot; : &quot;OUTER_ID&quot;,\r\n        &quot;name&quot; : &quot;OUTER_NAME&quot;\r\n        &quot;items&quot; : [ \r\n            {   \r\n                &quot;id&quot; : &quot;INNER_ID_1&quot;,\r\n                &quot;name&quot; : &quot;INNER_NAME_1&quot;,\r\n            },\r\n            {   \r\n                &quot;id&quot; : &quot;INNER_ID_2&quot;,\r\n                &quot;name&quot; : &quot;INNER_NAME_2&quot;,\r\n            }\r\n        ]   \r\n    }\r\n\r\n\r\ninto this\r\n\r\n\r\n    {\r\n        &quot;payload&quot;: [\r\n            {   \r\n                &quot;key&quot; : &quot;INNER_NAME_1_KEY&quot;,\r\n                &quot;data&quot; : { \r\n                    &quot;id&quot; : &quot;OUTER_ID&quot;,\r\n                    &quot;name&quot; : &quot;OUTER_NAME&quot;,\r\n                    &quot;items&quot; : [ \r\n                        {   \r\n                            &quot;id&quot; : &quot;INNER_ID_1&quot;,\r\n                            &quot;name&quot; : &quot;INNER_NAME_1&quot;\r\n                        }   \r\n                    ]   \r\n                }   \r\n            },  \r\n            {   \r\n                &quot;key&quot; : &quot;INNER_NAME_2_KEY&quot;,\r\n                &quot;data&quot; : { \r\n                    &quot;id&quot; : &quot;OUTER_ID&quot;,\r\n                    &quot;name&quot; : &quot;OUTER_NAME&quot;,\r\n                    &quot;items&quot; : [ \r\n                        {\r\n                            &quot;id&quot; : &quot;INNER_ID_2&quot;,\r\n                            &quot;name&quot; : &quot;INNER_NAME_2&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nSo, for each item in the initial `items` array, I want to create an entry in the output&#39;s `payload`, i.e I want to map `items[i]` to `payload[i].data.items` while also creating the `payload`, `key` and `data` keys in the output, and setting `payload[i].data.id` and `payload[i].data.name` to the input&#39;s outer `id` and `name`. \r\n\r\nCan this be done with jq?\r\n",
        "link": "https://stackoverflow.com/questions/55395872/jq-mapping-array-in-object-to-another-object-while-keeping-parent-keys-and-add",
        "title": "jq : mapping array in object to another object while keeping parent keys and adding new ones"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556311399,
                "last_edit_date": 1556311399,
                "creation_date": 1553791197,
                "answer_id": 55402813,
                "question_id": 55402677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generate even indices using `range` and use them for slicing the array:\r\n```jq\r\nrange(0;length;2) as $i | .[$i:$i+2] | @csv\r\n```\r\nNote that `-r` option is required for producing proper CSV.\r\n\r\n`.[$i:$i+2]` generates a subarray of length 2, containing the elements  from index `$i` (inclusive) to index `$i+2` (exclusive).",
                "title": "jq - convert an array in a pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1556311399,
        "creation_date": 1553790788,
        "question_id": 55402677,
        "body_markdown": "I have a json array like this:\r\n  \r\n    [&quot;abc&quot;, 0, &quot;cd&quot;, 1]\r\n\r\nI&#39;m struggling to convert this in a csv:\r\n\r\n    &quot;abc&quot;, 0\r\n    &quot;cd&quot;, 1\r\n\r\nIt seems I&#39;m far to find a solution, but I&#39;ve tried with this:\r\n\r\n    jq &#39;[ &quot;abc&quot;,&quot;def&quot;, &quot;cd&quot;, &quot;nc&quot;] | \r\n          to_entries | \r\n          (.[] | select(.key % 2 == 0))as $a, ( .[] | select(.key % 2 != 0) as $b ) | \r\n         [$a, $b] &#39;\r\n\r\nbut this returns to me \r\n\r\n    jq: 1 compile error\r\n\r\nI&#39;m unable to understand how to take two elements for iteration.\r\nAny help with this would be really appreciated",
        "link": "https://stackoverflow.com/questions/55402677/jq-convert-an-array-in-a-pair",
        "title": "jq - convert an array in a pair"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1555710554,
                "last_edit_date": 1555710554,
                "creation_date": 1553796992,
                "answer_id": 55404372,
                "question_id": 55404255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you are misusing the `tonumber` filter.  Based on [the documentation](https://stedolan.github.io/jq/manual/#tonumber) it looks like the syntax would be something like:\r\n\r\n    jq -n -r --arg MSSQL_IP &quot;$mssql_svc_ip&quot; --arg MSSQL_PORT &quot;$mssql_svc_port&quot; &#39;{\r\n        &quot;Datacenter&quot;: &quot;dev&quot;,\r\n        &quot;Node&quot;: &quot;database&quot;,\r\n        &quot;Address&quot;: $MSSQL_IP,\r\n        &quot;Service&quot;: {\r\n            &quot;Service&quot;: &quot;mssql-dev&quot;,\r\n            &quot;Port&quot;: ($MSSQL_PORT|tonumber)\r\n            }\r\n    }&#39;\r\n\r\nAnd indeed, if `$msssql_svc_ip` is `10.43.192.146` and `$mssql_svc_port` is `\r\n1433`, that gets me:\r\n\r\n    {\r\n      &quot;Datacenter&quot;: &quot;dev&quot;,\r\n      &quot;Node&quot;: &quot;database&quot;,\r\n      &quot;Address&quot;: &quot;10.43.192.146&quot;,\r\n      &quot;Service&quot;: {\r\n        &quot;Service&quot;: &quot;mssql-dev&quot;,\r\n        &quot;Port&quot;: 1433\r\n      }\r\n    }\r\n",
                "title": "jq cannot convert string to int in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1553797026,
                "creation_date": 1553797026,
                "answer_id": 55404382,
                "question_id": 55404255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like you need to pass the number in with `--argjson` instead of `--arg`:\r\n\r\n    $ jq -n -r --argjson foo 12 &#39;{&quot;foo&quot;:$foo}&#39;\r\n    {\r\n      &quot;foo&quot;: 12\r\n    }\r\n\r\nThis seems simpler than using `tonumber`",
                "title": "jq cannot convert string to int in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1555710554,
        "creation_date": 1553796537,
        "question_id": 55404255,
        "body_markdown": "I&#39;m working on generating a new JSON payload to update Consul with a MSSQL database service location.\r\n\r\nWhen I call jq like this:\r\n\r\n```bash\r\nmssql_svc_ip=$(kubectl get svc/mssql-linux -o &#39;jsonpath={.spec.clusterIP}&#39;)\r\nmssql_svc_port=$(kubectl get svc/mssql-linux -o &#39;jsonpath={.spec.ports[0].port}&#39;)\r\n\r\njq -n -r --arg MSSQL_IP $mssql_svc_ip --arg MSSQL_PORT $mssql_svc_port &#39;{\r\n    &quot;Datacenter&quot;: &quot;dev&quot;,\r\n    &quot;Node&quot;: &quot;database&quot;,\r\n    &quot;Address&quot;: $MSSQL_IP,\r\n    &quot;Service&quot;: {\r\n        &quot;Service&quot;: &quot;mssql-dev&quot;,\r\n        &quot;Port&quot;: $MSSQL_PORT\r\n        }\r\n}&#39;\r\n```\r\n\r\nIt produces the proper structure:\r\n\r\n```bash\r\n{\r\n  &quot;Datacenter&quot;: &quot;dev&quot;,\r\n  &quot;Node&quot;: &quot;database&quot;,\r\n  &quot;Address&quot;: &quot;10.43.192.146&quot;,\r\n  &quot;Service&quot;: {\r\n    &quot;Service&quot;: &quot;mssql-dev&quot;,\r\n    &quot;Port&quot;: &quot;1433&quot;\r\n  }\r\n}\r\n```\r\n\r\nI need to convert the `Service.Port` field from a string to an integer as that&#39;s what the Consul API requires. I can do that with `tonumber`, like this:\r\n\r\n```bash\r\nmssql_svc_ip=$(kubectl get svc/mssql-linux -o &#39;jsonpath={.spec.clusterIP}&#39;)\r\nmssql_svc_port=$(kubectl get svc/mssql-linux -o &#39;jsonpath={.spec.ports[0].port}&#39;)\r\n\r\njq -n -r --arg MSSQL_IP $mssql_svc_ip --arg MSSQL_PORT $mssql_svc_port &#39;{\r\n    &quot;Datacenter&quot;: &quot;dev&quot;,\r\n    &quot;Node&quot;: &quot;database&quot;,\r\n    &quot;Address&quot;: $MSSQL_IP,\r\n    &quot;Service&quot;: {\r\n        &quot;Service&quot;: &quot;mssql-dev&quot;,\r\n        &quot;Port&quot;: tonumber($MSSQL_PORT)\r\n        }\r\n}&#39;\r\n```\r\n\r\nHowever, when I try and convert the `$MSSQL_PORT` variable to a number, I get this error:\r\n\r\n```bash\r\njq: error: tonumber/1 is not defined at &lt;top-level&gt;, line 7:\r\n        &quot;Port&quot;: tonumber($MSSQL_PORT)                \r\njq: 1 compile error\r\n```\r\n\r\nAt first I thought it was an assignment error and the variables weren&#39;t being passes as arguments properly, but I&#39;ve tried a couple iterations and I still get the same error. What am I doing incorrectly?",
        "link": "https://stackoverflow.com/questions/55404255/jq-cannot-convert-string-to-int-in-bash",
        "title": "jq cannot convert string to int in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1553950001,
                "last_edit_date": 1553950001,
                "creation_date": 1553808406,
                "answer_id": 55407083,
                "question_id": 55406838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`select` `paths` containing `keyword` in their last element, and use `join(&quot;.&quot;)` to generate your desired output.\r\n```jq\r\npaths\r\n| select(.[-1] | type == &quot;string&quot; and contains(&quot;keyword&quot;))\r\n| join(&quot;.&quot;)\r\n```\r\n* `.[-1]` returns the last element of an array,\r\n* `type == &quot;string&quot;` is required because an array index is a number and numbers and strings can&#39;t be checked for their containment.\r\n\r\nYou may want to specify `-r` option.\r\n\r\n---\r\nAs @JeffMercado implicitly suggested you can set the query from command line without touching the script:\r\n```bash\r\njq -r &#39;paths\r\n| select(.[-1] | type == &quot;string&quot; and contains($q))\r\n| join(&quot;.&quot;)&#39; file.json --arg q &#39;keyword&#39;\r\n```",
                "title": "Building json path from JQ using some keyword"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1553895042,
                "creation_date": 1553895042,
                "answer_id": 55425693,
                "question_id": 55406838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can stream the input in, which provides paths and values. You could then inspect the paths and optionally output the values.\r\n\r\n    $ jq --stream --arg pattern &#39;IP&#39; &#39;\r\n    select(length == 2 and any(.[0][] | strings; test($pattern)))\r\n        | &quot;\\(.[0] | join(&quot;.&quot;)): \\(.[1])&quot;\r\n    &#39; input.json\r\n    &quot;status.hostIP: 172.17.0.37&quot;\r\n    &quot;status.podIP: 10.32.0.4&quot;\r\n\r\n",
                "title": "Building json path from JQ using some keyword"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1622666939,
                "creation_date": 1622666939,
                "answer_id": 67812394,
                "question_id": 55406838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "shameless plug  \r\n\r\nhttps://github.com/TomConlin/json_to_paths\r\n\r\nbecause sometime you do not even know the component you want to filter for before you see what is there.\r\n\r\n```bash\r\njson2jqpath.jq file.json \r\n.\r\n.apiVersion\r\n.kind\r\n.metadata\r\n.metadata|.creationTimestamp\r\n.metadata|.labels\r\n.metadata|.labels|.bu\r\n.metadata|.labels|.env\r\n.metadata|.name\r\n.metadata|.namespace\r\n.metadata|.resourceVersion\r\n.metadata|.selfLink\r\n.metadata|.uid\r\n.spec\r\n.spec|.containers\r\n.spec|.containers|.[]\r\n.spec|.containers|.[]|.command\r\n.spec|.containers|.[]|.command|.[]\r\n.spec|.containers|.[]|.image\r\n.spec|.containers|.[]|.imagePullPolicy\r\n.spec|.containers|.[]|.name\r\n.spec|.containers|.[]|.resources\r\n.spec|.containers|.[]|.terminationMessagePath\r\n.spec|.containers|.[]|.terminationMessagePolicy\r\n.spec|.containers|.[]|.volumeMounts\r\n.spec|.containers|.[]|.volumeMounts|.[]\r\n.spec|.containers|.[]|.volumeMounts|.[]|.mountPath\r\n.spec|.containers|.[]|.volumeMounts|.[]|.name\r\n.spec|.containers|.[]|.volumeMounts|.[]|.readOnly\r\n.spec|.dnsPolicy\r\n.spec|.nodeName\r\n.spec|.priority\r\n.spec|.restartPolicy\r\n.spec|.schedulerName\r\n.spec|.securityContext\r\n.spec|.serviceAccount\r\n.spec|.serviceAccountName\r\n.spec|.terminationGracePeriodSeconds\r\n.spec|.tolerations\r\n.spec|.tolerations|.[]\r\n.spec|.tolerations|.[]|.effect\r\n.spec|.tolerations|.[]|.key\r\n.spec|.tolerations|.[]|.operator\r\n.spec|.tolerations|.[]|.tolerationSeconds\r\n.spec|.volumes\r\n.spec|.volumes|.[]\r\n.spec|.volumes|.[]|.name\r\n.spec|.volumes|.[]|.secret\r\n.spec|.volumes|.[]|.secret|.defaultMode\r\n.spec|.volumes|.[]|.secret|.secretName\r\n.status\r\n.status|.conditions\r\n.status|.conditions|.[]\r\n.status|.conditions|.[]|.lastProbeTime\r\n.status|.conditions|.[]|.lastTransitionTime\r\n.status|.conditions|.[]|.status\r\n.status|.conditions|.[]|.type\r\n.status|.containerStatuses\r\n.status|.containerStatuses|.[]\r\n.status|.containerStatuses|.[]|.containerID\r\n.status|.containerStatuses|.[]|.image\r\n.status|.containerStatuses|.[]|.imageID\r\n.status|.containerStatuses|.[]|.lastState\r\n.status|.containerStatuses|.[]|.name\r\n.status|.containerStatuses|.[]|.ready\r\n.status|.containerStatuses|.[]|.restartCount\r\n.status|.containerStatuses|.[]|.state\r\n.status|.containerStatuses|.[]|.state|.running\r\n.status|.containerStatuses|.[]|.state|.running|.startedAt\r\n.status|.hostIP\r\n.status|.phase\r\n.status|.podIP\r\n.status|.qosClass\r\n.status|.startTime\r\n\r\n``` ",
                "title": "Building json path from JQ using some keyword"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1622666939,
        "creation_date": 1553807180,
        "last_edit_date": 1553808080,
        "question_id": 55406838,
        "body_markdown": "I have a deep json. Sometimes, I need to look for the json path for a key containing certain word.  \r\n\r\n    {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;kind&quot;: &quot;Pod&quot;,\r\n        &quot;metadata&quot;: {\r\n            &quot;creationTimestamp&quot;: &quot;2019-03-28T21:09:42Z&quot;,\r\n            &quot;labels&quot;: {\r\n                &quot;bu&quot;: &quot;finance&quot;,\r\n                &quot;env&quot;: &quot;prod&quot;\r\n            },\r\n            &quot;name&quot;: &quot;auth&quot;,\r\n            &quot;namespace&quot;: &quot;default&quot;,\r\n            &quot;resourceVersion&quot;: &quot;2786&quot;,\r\n            &quot;selfLink&quot;: &quot;/api/v1/namespaces/default/pods/auth&quot;,\r\n            &quot;uid&quot;: &quot;ce73565a-519d-11e9-bcb7-0242ac110009&quot;\r\n        },\r\n        &quot;spec&quot;: {\r\n            &quot;containers&quot;: [\r\n                {\r\n                    &quot;command&quot;: [\r\n                        &quot;sleep&quot;,\r\n                        &quot;4800&quot;\r\n                    ],\r\n                    &quot;image&quot;: &quot;busybox&quot;,\r\n                    &quot;imagePullPolicy&quot;: &quot;Always&quot;,\r\n                    &quot;name&quot;: &quot;busybox&quot;,\r\n                    &quot;resources&quot;: {},\r\n                    &quot;terminationMessagePath&quot;: &quot;/dev/termination-log&quot;,\r\n                    &quot;terminationMessagePolicy&quot;: &quot;File&quot;,\r\n                    &quot;volumeMounts&quot;: [\r\n                        {\r\n                            &quot;mountPath&quot;: &quot;/var/run/secrets/kubernetes.io/serviceaccount&quot;,\r\n                            &quot;name&quot;: &quot;default-token-dbpcm&quot;,\r\n                            &quot;readOnly&quot;: true\r\n                        }\r\n                    ]\r\n                }\r\n            ],\r\n            &quot;dnsPolicy&quot;: &quot;ClusterFirst&quot;,\r\n            &quot;nodeName&quot;: &quot;node01&quot;,\r\n            &quot;priority&quot;: 0,\r\n            &quot;restartPolicy&quot;: &quot;Always&quot;,\r\n            &quot;schedulerName&quot;: &quot;default-scheduler&quot;,\r\n            &quot;securityContext&quot;: {},\r\n            &quot;serviceAccount&quot;: &quot;default&quot;,\r\n            &quot;serviceAccountName&quot;: &quot;default&quot;,\r\n            &quot;terminationGracePeriodSeconds&quot;: 30,\r\n            &quot;tolerations&quot;: [\r\n                {\r\n                    &quot;effect&quot;: &quot;NoExecute&quot;,\r\n                    &quot;key&quot;: &quot;node.kubernetes.io/not-ready&quot;,\r\n                    &quot;operator&quot;: &quot;Exists&quot;,\r\n                    &quot;tolerationSeconds&quot;: 300\r\n                },\r\n                {\r\n                    &quot;effect&quot;: &quot;NoExecute&quot;,\r\n                    &quot;key&quot;: &quot;node.kubernetes.io/unreachable&quot;,\r\n                    &quot;operator&quot;: &quot;Exists&quot;,\r\n                    &quot;tolerationSeconds&quot;: 300\r\n                }\r\n            ],\r\n            &quot;volumes&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;default-token-dbpcm&quot;,\r\n                    &quot;secret&quot;: {\r\n                        &quot;defaultMode&quot;: 420,\r\n                        &quot;secretName&quot;: &quot;default-token-dbpcm&quot;\r\n                    }\r\n                }\r\n            ]\r\n        },\r\n        &quot;status&quot;: {\r\n            &quot;conditions&quot;: [\r\n                {\r\n                    &quot;lastProbeTime&quot;: null,\r\n                    &quot;lastTransitionTime&quot;: &quot;2019-03-28T21:09:42Z&quot;,\r\n                    &quot;status&quot;: &quot;True&quot;,\r\n                    &quot;type&quot;: &quot;Initialized&quot;\r\n                },\r\n                {\r\n                    &quot;lastProbeTime&quot;: null,\r\n                    &quot;lastTransitionTime&quot;: &quot;2019-03-28T21:09:50Z&quot;,\r\n                    &quot;status&quot;: &quot;True&quot;,\r\n                    &quot;type&quot;: &quot;Ready&quot;\r\n                },\r\n                {\r\n                    &quot;lastProbeTime&quot;: null,\r\n                    &quot;lastTransitionTime&quot;: null,\r\n                    &quot;status&quot;: &quot;True&quot;,\r\n                    &quot;type&quot;: &quot;ContainersReady&quot;\r\n                },\r\n                {\r\n                    &quot;lastProbeTime&quot;: null,\r\n                    &quot;lastTransitionTime&quot;: &quot;2019-03-28T21:09:42Z&quot;,\r\n                    &quot;status&quot;: &quot;True&quot;,\r\n                    &quot;type&quot;: &quot;PodScheduled&quot;\r\n                }\r\n            ],\r\n            &quot;containerStatuses&quot;: [\r\n                {\r\n                    &quot;containerID&quot;: &quot;docker://b5be8275555ad70939401d658bb4e504b52215b70618ad43c2d0d02c35e1ae27&quot;,\r\n                    &quot;image&quot;: &quot;busybox:latest&quot;,\r\n                    &quot;imageID&quot;: &quot;docker-pullable://busybox@sha256:061ca9704a714ee3e8b80523ec720c64f6209ad3f97c0ff7cb9ec7d19f15149f&quot;,\r\n                    &quot;lastState&quot;: {},\r\n                    &quot;name&quot;: &quot;busybox&quot;,\r\n                    &quot;ready&quot;: true,\r\n                    &quot;restartCount&quot;: 0,\r\n                    &quot;state&quot;: {\r\n                        &quot;running&quot;: {\r\n                            &quot;startedAt&quot;: &quot;2019-03-28T21:09:49Z&quot;\r\n                        }\r\n                    }\r\n                }\r\n            ],\r\n            &quot;hostIP&quot;: &quot;172.17.0.37&quot;,\r\n            &quot;phase&quot;: &quot;Running&quot;,\r\n            &quot;podIP&quot;: &quot;10.32.0.4&quot;,\r\n            &quot;qosClass&quot;: &quot;BestEffort&quot;,\r\n            &quot;startTime&quot;: &quot;2019-03-28T21:09:42Z&quot;\r\n        }\r\n    }\r\n\r\nCurrently If i need the podIP, then I do that this way to find the object which has the search keyword and then I build the path\r\n\r\n    curl myson | jq &quot;[paths]&quot; | grep &quot;IP&quot; --context=10\r\n\r\nIs there any nice shortcut to simplify this? What I really need is - all the paths which could have the matching key.\r\n\r\n    spec.podIP\r\n    spec.hostIP\r\n",
        "link": "https://stackoverflow.com/questions/55406838/building-json-path-from-jq-using-some-keyword",
        "title": "Building json path from JQ using some keyword"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1553882740,
                "post_id": 55423095,
                "comment_id": 97565513,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553884827,
                "creation_date": 1553884827,
                "answer_id": 55423717,
                "question_id": 55423095,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slurp the files in so you can combine them, then update the objects accordingly.\r\n\r\n    $ jq -s &#39;add | .swirl_app = .demo_app + .swirl_app&#39; j{1,2}.json &gt; j3.json\r\n\r\n&lt;!-- --&gt;\r\n\r\n    {\r\n      &quot;catalog&quot;: {\r\n        &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n        &quot;git_commit_number&quot;: &quot;7ff5358b6d919228ae6043f7bb64abd890c6dfe9&quot;,\r\n        &quot;git_repo_name&quot;: &quot;catalog&quot;\r\n      },\r\n      &quot;swirl_components&quot;: {\r\n        &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n        &quot;git_commit_number&quot;: &quot;78ed0b1d0e25a261b89160a037530cf6c594892f&quot;,\r\n        &quot;git_repo_name&quot;: &quot;swirl_components&quot;\r\n      },\r\n      &quot;demo_app&quot;: {\r\n        &quot;git_repo_name&quot;: &quot;demo_app&quot;,\r\n        &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n        &quot;git_commit_number&quot;: &quot;1f227bb19343d19629b302c425adb8f21f4fab5a&quot;\r\n      },\r\n      &quot;swirl_app&quot;: {\r\n        &quot;git_repo_name&quot;: &quot;demo_app&quot;,\r\n        &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n        &quot;git_commit_number&quot;: &quot;1f227bb19343d19629b302c425adb8f21f4fab5a&quot;,\r\n        &quot;version&quot;: &quot;readBuildInfo_311&quot;,\r\n        &quot;image_name&quot;: &quot;/swirl_app:readBuildInfo_311&quot;,\r\n        &quot;date_time&quot;: &quot;Mon Mar 25 05:55:45 UTC 2019&quot;,\r\n        &quot;git_latest_commit&quot;: &quot;4b7bef6970f83e6e7fc04302c8b29d7cfd4a1885&quot;,\r\n        &quot;jenkins_build_url&quot;: &quot;http://10.229.6.14/job/HC_Dev/job/Code-Build/job/swirl_app/311/&quot;,\r\n        &quot;artifactory_path&quot;: &quot;ARTIFACTORY PATH&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Merge one object inside another object of json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1553884827,
        "creation_date": 1553882112,
        "question_id": 55423095,
        "body_markdown": "As I am working first time in shell scripts and json parser i.e. jq library.\r\n\r\nI wanted to merge details one of property of file1 and file2 inside another file3 along with rest of the property details.\r\n\r\n  Was able to merge properties of file1 and file2, but failing as complete details to render within file3.\r\n\r\nBasically failing to assign stored value to particular key property in file3\r\n\r\nj1.json\r\n```\r\n{\r\n  &quot;catalog&quot;: {\r\n    &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n    &quot;git_commit_number&quot;: &quot;7ff5358b6d919228ae6043f7bb64abd890c6dfe9&quot;,\r\n    &quot;git_repo_name&quot;: &quot;catalog&quot;\r\n  },\r\n  &quot;swirl_components&quot;: {\r\n    &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n    &quot;git_commit_number&quot;: &quot;78ed0b1d0e25a261b89160a037530cf6c594892f&quot;,\r\n    &quot;git_repo_name&quot;: &quot;swirl_components&quot;\r\n  },\r\n  &quot;demo_app&quot;: {\r\n    &quot;git_repo_name&quot;: &quot;demo_app&quot;,\r\n    &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n    &quot;git_commit_number&quot;: &quot;1f227bb19343d19629b302c425adb8f21f4fab5a&quot;\r\n  }\r\n}\r\n```\r\nj2.json\r\n```\r\n{\r\n  &quot;swirl_app&quot;: {\r\n    &quot;version&quot;: &quot;readBuildInfo_311&quot;,\r\n    &quot;image_name&quot;: &quot;/swirl_app:readBuildInfo_311&quot;,\r\n    &quot;date_time&quot;: &quot;Mon Mar 25 05:55:45 UTC 2019&quot;,\r\n    &quot;git_latest_commit&quot;: &quot;4b7bef6970f83e6e7fc04302c8b29d7cfd4a1885&quot;,\r\n    &quot;jenkins_build_url&quot;: &quot;http://10.229.6.14/job/HC_Dev/job/Code-Build/job/swirl_app/311/&quot;,\r\n    &quot;artifactory_path&quot;: &quot;ARTIFACTORY PATH&quot;\r\n  }\r\n}\r\n```\r\nOutPut Expected: \r\n```\r\n{\r\n  &quot;catalog&quot;: {\r\n    &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n    &quot;git_commit_number&quot;: &quot;7ff5358b6d919228ae6043f7bb64abd890c6dfe9&quot;,\r\n    &quot;git_repo_name&quot;: &quot;catalog&quot;\r\n  },\r\n  &quot;swirl_components&quot;: {\r\n    &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n    &quot;git_commit_number&quot;: &quot;78ed0b1d0e25a261b89160a037530cf6c594892f&quot;,\r\n    &quot;git_repo_name&quot;: &quot;swirl_components&quot;\r\n  },\r\n  &quot;demo_app&quot;: {\r\n    &quot;git_repo_name&quot;: &quot;demo_app&quot;,\r\n    &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n    &quot;git_commit_number&quot;: &quot;1f227bb19343d19629b302c425adb8f21f4fab5a&quot;\r\n  },\r\n  &quot;swirl_app&quot;: {\r\n    &quot;git_repo_name&quot;: &quot;demo_app&quot;,\r\n  &quot;git_branch_name&quot;: &quot;Release_Sprint1912&quot;,\r\n  &quot;git_commit_number&quot;: &quot;1f227bb19343d19629b302c425adb8f21f4fab5a&quot;,\r\n  &quot;version&quot;: &quot;readBuildInfo_311&quot;,\r\n  &quot;image_name&quot;: &quot;/swirl_app:readBuildInfo_311&quot;,\r\n  &quot;date_time&quot;: &quot;Mon Mar 25 05:55:45 UTC 2019&quot;,\r\n  &quot;git_latest_commit&quot;: &quot;4b7bef6970f83e6e7fc04302c8b29d7cfd4a1885&quot;,\r\n  &quot;jenkins_build_url&quot;: &quot;http://10.229.6.14/job/HC_Dev/job/Code-Build/job/swirl_app/311/&quot;,\r\n  &quot;artifactory_path&quot;: &quot;ARTIFACTORY PATH&quot;\r\n  }\r\n}\r\n```\r\ntried:\r\n```\r\nj1=$(echo jq &quot;.&quot; j1.json) \r\nj2=$(echo jq &quot;.&quot; j2.json)\r\ndemo=$(echo jq &#39;.demo_app&#39; j1.json)\r\njq -s &#39;add&#39; $j1 $j2\r\njq &quot;.swirl_app&quot; j2.json &gt;&gt; swirl.json\r\njq &#39;.demo_app&#39; j1.json &gt;&gt; demo.json\r\njq -s &#39;add&#39; demo.json swirl.json\r\ntotal=$(echo jq -s &#39;add&#39; demo.json swirl.json)\r\n```\r\n\r\nfails or trying to:\r\n```\r\njq &quot;.swirl_app={}&quot; j3.json // makes empty object of &quot;swirl_app&quot;: {}\r\njq &quot;.swirl_app=$total&quot; j3.json // this fails as expect result\r\njq &quot;.swirl_app|=$total&quot; j3.json // this too fails as expected result\r\n```\r\n\r\nMy thoughts:\r\n1) Should we make it array? and then assign value\r\n2) Above variable assign works but incorrectly done?\r\n\r\nFinal:\r\nNeed help over this, to understand what is wrong from my side.",
        "link": "https://stackoverflow.com/questions/55423095/merge-one-object-inside-another-object-of-json-file",
        "title": "Merge one object inside another object of json file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1553898042,
                "creation_date": 1553898042,
                "answer_id": 55426167,
                "question_id": 55425773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well to get your desired result, you could do this:\r\n\r\n    .[].choices[] |= (.label | capture(&quot;^(?&lt;label&gt;.*?) (?&lt;value&gt;[^ ]+)$&quot;))\r\n\r\nTo do that within your function, I&#39;d change it to this:\r\n\r\n    def do_extract:\r\n      if .value == &quot;&quot; then\r\n        (.label | capture(&quot;^(?&lt;label&gt;.*?) (?&lt;value&gt;[^ ]+)$&quot;))\r\n      else\r\n        .\r\n      end;\r\n\r\nThen use it:\r\n\r\n    .[].choices[] |= do_extract",
                "title": "JQ applying function to dict but print surrounding datas"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1554016588,
        "creation_date": 1553895507,
        "question_id": 55425773,
        "body_markdown": "I&#39;d like\r\n```\r\n&quot;1&quot;: {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;type&quot;: &quot;select&quot;,\r\n        &quot;label&quot;: &quot;country :&quot;,\r\n        &quot;choices&quot;: {\r\n          &quot;1&quot;: {\r\n            &quot;label&quot;: &quot;Canada CAN&quot;,\r\n            &quot;value&quot;: &quot;&quot;,\r\n          },\r\n          &quot;2&quot;: {\r\n            &quot;label&quot;: &quot;United States USA&quot;,\r\n            &quot;value&quot;: &quot;&quot;\r\n          }\r\n        }\r\n}\r\n```\r\nto produce\r\n```\r\n&quot;1&quot;: {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;type&quot;: &quot;select&quot;,\r\n        &quot;label&quot;: &quot;country :&quot;,\r\n        &quot;choices&quot;: {\r\n          &quot;1&quot;: {\r\n            &quot;label&quot;: &quot;Canada&quot;,\r\n            &quot;value&quot;: &quot;CAN&quot;,\r\n          },\r\n          &quot;2&quot;: {\r\n            &quot;label&quot;: &quot;United States&quot;,\r\n            &quot;value&quot;: &quot;USA&quot;\r\n          }\r\n        }\r\n}\r\n```\r\n\r\nBy now I have a two-step solution consisting of a sed-like function \r\n```\r\ndef do_extract:\r\nif .value | test(&quot;^$&quot;) then\r\n\t(.value = (.label | capture(&quot;.* (?&lt;code&gt;...)&quot;)).code) | .label = (.label | capture(&quot;(?&lt;name&gt;.*) ...$&quot;).name)\r\nelse\r\n\t.\r\nend;\r\n```\r\nand a direct access to the sub-tree `[].&quot;1&quot;.&quot;choices&quot;|keys_unsorted as $key|map_values(do_extract)` but I have to manually copy-paste the output in place of the original &quot;choices&quot; dict.\r\n\r\nIs there a way to do the function but still print the surrounding datas ?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/55425773/jq-applying-function-to-dict-but-print-surrounding-datas",
        "title": "JQ applying function to dict but print surrounding datas"
    },
    {
        "tags": [
            "bash",
            "variables",
            "jq",
            "substitution"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1553961723,
                "post_id": 55433149,
                "comment_id": 97584029,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user11282051"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553962668,
                "post_id": 55433149,
                "comment_id": 97584261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user11282051"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553963098,
                "post_id": 55433149,
                "comment_id": 97584371,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user11282051"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1553963370,
                "post_id": 55433149,
                "comment_id": 97584441,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1553966989,
                "post_id": 55433149,
                "comment_id": 97585394,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553965333,
                "last_edit_date": 1553965333,
                "creation_date": 1553964268,
                "answer_id": 55433595,
                "question_id": 55433149,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using bash variable within additional single quotes to split the command, and then escaping double-quotes for the actual variable substitution, resolves this.\r\n\r\nExample of working code, using same json as original question.\r\n\r\n```\r\n#!/bin/bash\r\nchkCustomer=101\r\nchkFile=&quot;json-simple.txt&quot;\r\ncompanyToken=$(jq -r &#39;.payload.customerData.&#39;\\&quot;${chkCustomer}\\&quot;&#39;.token&#39; &quot;${chkFile}&quot;)\r\nprintf &quot;%s\\n&quot; &quot;Company token for ${chkCustomer} is ${companyToken}.&quot;\r\n```\r\n\r\nThis method works whether bash variable is itself quoted or not. Without the escape of double-quotes it fails.",
                "title": "Bash variable substitution for jq query always returns null"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1553968213,
                "last_edit_date": 1553968213,
                "creation_date": 1553966456,
                "answer_id": 55433892,
                "question_id": 55433149,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The **safe** way to do this is to pass your variables out-of-band from your code. That is:\r\n\r\n\r\n```\r\n#!/bin/bash\r\nchkCustomer=101\r\nchkFile=&quot;json-simple.txt&quot;\r\n\r\ncompanyToken=$(jq -r --arg chkCustomer &quot;$chkCustomer&quot; \\\r\n               &#39;.payload.customerData[$chkCustomer].token&#39; &quot;$chkFile&quot;)\r\n\r\nprintf &quot;%s\\n&quot; &quot;Company token for ${chkCustomer} is ${companyToken}.&quot;\r\n```\r\n\r\nThe `$chkCustomer` in the single-quoted string is left alone by the shell, and instead interpreted by `jq` itself to refer to the string value passed in via `--arg`.\r\n\r\nThis prevents a value of `chkCustomer` that contains `jq` code from being able to generate output that doesn&#39;t actually conform to the input file&#39;s contents, or -- in the future, when jq adds I/O primitives -- one that performs file I/O and changes contents of your disk.",
                "title": "Bash variable substitution for jq query always returns null"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1553985420,
        "creation_date": 1553961066,
        "last_edit_date": 1553985420,
        "question_id": 55433149,
        "body_markdown": "File export from company system generates json in a structure that I cannot change. When searching through for specific attributes based on variables within bash (v5.0.2), it always returns null when using any element of substitution.\r\nIf I hard code the value to be searched, it works.\r\nHowever, need to be able to use variables to support logic of code and to not have to hard code specifics, especially given 1000&#39;s of records to process.\r\n\r\nUsing the example extract of json below, and the code further below, this shows what I&#39;ve tried based on what I can understand from jq manual.\r\n\r\n```\r\n{\r\n  &quot;status&quot;: true,\r\n  &quot;payload&quot;: {\r\n    &quot;customerData&quot;: {\r\n      &quot;101&quot;: {\r\n        &quot;title&quot;: &quot;A Company&quot;,\r\n        &quot;id&quot;: &quot;101&quot;,\r\n        &quot;storageGroups&quot;: &quot;SHIPPING&quot;,\r\n        &quot;priority&quot;: &quot;4&quot;,\r\n        &quot;originalname&quot;: &quot;A Previous Company&quot;,\r\n        &quot;allowShipping&quot;: true,\r\n        &quot;parentCompany&quot;: &quot;0&quot;,\r\n        &quot;rating&quot;: 0,\r\n        &quot;external&quot;: false,\r\n        &quot;application&quot;: &quot;primary&quot;,\r\n        &quot;applicationName&quot;: &quot;form27&quot;,\r\n        &quot;live&quot;: true,\r\n        &quot;logo&quot;: &quot;http://url&quot;,\r\n        &quot;beta&quot;: false,\r\n        &quot;length&quot;: null,\r\n        &quot;token&quot;: &quot;QSBQcmV2aW91cyBDb21wYW55LzEwMQ==&quot;,\r\n        &quot;active&quot;: &quot;1&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nSimple bash script to evidence approaches tested so far\r\n\r\n```\r\n#!/bin/bash\r\nchkCustomer=101\r\nchkFile=&quot;json-simple.txt&quot;\r\nif [[ ! -s &quot;${chkFile}&quot; ]] ; then exit 1 ; fi\r\ntokenTry1=$(cat &quot;${chkFile}&quot; | jq -r &#39;.payload.customerData.&quot;${chkCustomer}&quot;.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 1 Returned ${tokenTry1}&quot;\r\ntokenTry2=$(cat &quot;${chkFile}&quot; | jq -r &#39;.payload.customerData.&quot;$chkCustomer&quot;.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 2 Returned ${tokenTry2}&quot;\r\ntokenTry3=$(cat &quot;${chkFile}&quot; | jq -r --arg CHK ${chkCustomer} &#39;.payload.customerData.&quot;$CHK&quot;.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 3 Returned ${tokenTry3}&quot;\r\ntokenTry4=$(cat &quot;${chkFile}&quot; | jq -r --arg CHK ${chkCustomer} &#39;.payload.customerData.&quot;env.$CHK&quot;.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 4 Returned ${tokenTry4}&quot;\r\ntokenTry5=$(cat &quot;${chkFile}&quot; | jq -r --arg CHK 101 &#39;.payload.customerData.&quot;$CHK&quot;.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 5 Returned ${tokenTry5}&quot;\r\ntokenTry6=$(cat &quot;${chkFile}&quot; | jq -r &#39;.payload.customerData.101.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 6 Returned ${tokenTry6}&quot;\r\ntokenWorks=$(cat &quot;${chkFile}&quot; | jq -r &#39;.payload.customerData.&quot;101&quot;.token&#39;)\r\nprintf &quot;%s\\n&quot; &quot;Try 7 (works) Returned ${tokenWorks}&quot;\r\n```\r\n\r\nOnly attempt 7 results in a valid response. All rest are either `null` or a failure.\r\n\r\n\r\nOutput of the script against the json is\r\n\r\n```\r\nTry 1 Returned null\r\nTry 2 Returned null\r\nTry 3 Returned null\r\nTry 4 Returned null\r\nTry 5 Returned null\r\njq: error: Invalid numeric literal at EOF at line 1, column 5 (while parsing &#39;.101.&#39;) at &lt;top-level&gt;, line 1:\r\n.payload.customerData.101.token                     \r\njq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.payload.customerData.101.token                     \r\njq: 2 compile errors\r\nTry 6 Returned \r\nTry 7 (works) Returned QSBQcmV2aW91cyBDb21wYW55LzEwMQ==\r\n\r\n```\r\n\r\nWhat I need (or expect) is that I can use a variable and execute a jq query to get a result.\r\n\r\nI&#39;m sure I&#39;m missing something mindbogglingly obvious, but I cannot fathom this. Looking at other questions I&#39;ve found here on SO, none have yet helped.",
        "link": "https://stackoverflow.com/questions/55433149/bash-variable-substitution-for-jq-query-always-returns-null",
        "title": "Bash variable substitution for jq query always returns null"
    },
    {
        "tags": [
            "json",
            "web-scraping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1554061157,
                "creation_date": 1554061157,
                "answer_id": 55444718,
                "question_id": 55444476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may use `level` property value as a key:\r\n\r\n    $ curl -s http://taxonomy.jgi-psf.org/tax/tax_id/48479 | jq &#39;.[] | .[&quot;\\(.level)&quot;].name&#39;\r\n    &quot;environmental samples&quot;",
                "title": "Using jq to get a value, then using that value as a key to get another value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1554154794,
        "creation_date": 1554059553,
        "last_edit_date": 1554062291,
        "question_id": 55444476,
        "body_markdown": "I have several hundred taxonomic IDs, and I am using `curl` and `jq` to extract relevant values from http://taxonomy.jgi-psf.org/tax/accession.\r\n\r\nIs there a way to pipe jq to itself so I can use the value of &quot;level&quot; as the key to another query?\r\n\r\nFor this example, I would like to combine these two commands into one:\r\n\r\n    $ curl -s http://taxonomy.jgi-psf.org/tax/tax_id/48479 | jq &#39;.[] | .level&#39;\r\n\r\n**&quot;no rank&quot;**\r\n\r\n    $ curl -s http://taxonomy.jgi-psf.org/tax/tax_id/48479 | jq &#39;.[] | .&quot;no rank&quot;.name&#39;\r\n\r\n**&quot;environmental samples&quot;**\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55444476/using-jq-to-get-a-value-then-using-that-value-as-a-key-to-get-another-value",
        "title": "Using jq to get a value, then using that value as a key to get another value"
    },
    {
        "tags": [
            "json",
            "pipe",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554071087,
                "last_edit_date": 1554071087,
                "creation_date": 1554069984,
                "answer_id": 55445890,
                "question_id": 55445669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than doing this within jq, as [jq cannot use program as filter yet](https://github.com/stedolan/jq/issues/1614), you can do it outside it:\r\n\r\n    jq -j --slurp &#39;map(.pubKey) | join(&quot;&gt;&quot;)&#39; seq.json | xargs --delimiter=&gt; -n1 --no-run-if-empty -i sh -c &#39;echo &quot;{}&quot; | openssl rsa -pubin -noout -modulus&#39;\r\n\r\nNotes:\r\n\r\n1. Your sample input is multiple object instead of an array of objects, so `--slurp` is used. If it is not the case you will need to remove this flag.\r\n2. `pubKey` cannot have &#39;&gt;&#39; in it, so I used it as an delimiter. This assumes your data comes from trusty source and won&#39;t blow your system up.\r\n",
                "title": "How to pipe each jq filter output to an external command?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1554072142,
                "last_edit_date": 1554072142,
                "creation_date": 1554071121,
                "answer_id": 55446019,
                "question_id": 55445669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An implementation that&#39;s careful not to execute data as code might look like:\r\n\r\n```\r\nwhile IFS= read -r -d &#39;&#39; chunk; do\r\n  openssl rsa -pubin -noout -modulus &lt;&lt;&lt;&quot;$chunk&quot;\r\ndone &lt; &lt;(jq -j &#39;(.pubKey, &quot;\\u0000&quot;)&#39; seq.json)\r\n```\r\n\r\n- The `while read` idiom is documented in detail in [BashFAQ #1](http://mywiki.wooledge.org/BashFAQ/001)\r\n- The use of [process substitution](https://wiki.bash-hackers.org/syntax/expansion/proc_subst) (the `&lt;(...)` syntax) is for reasons described in [BashFAQ #24](http://mywiki.wooledge.org/BashFAQ/024).\r\n- The use of the `-d` argument to `read`, the `-j` argument to `jq`, and the use of `&quot;\\u0000&quot;` inside the JSON uses NUL delimiters to separate extracted data items. These are used because NULs are the only character which can&#39;t be represented inside C strings; thus, they can be used to represent delimiters between any data item which a C program can store in a string. See [stedolan/jq#1271](https://github.com/stedolan/jq/issues/1271) for history behind this feature in jq.",
                "title": "How to pipe each jq filter output to an external command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1554072142,
        "creation_date": 1554068164,
        "question_id": 55445669,
        "body_markdown": "I have a large file with a sequence of `JSON` objects.  Each object has a value that I want to extract and run through an external program.  How do you instruct `jq` to do this?\r\n\r\nFor example, if I have the following `JSON` file:\r\n```json\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;corp&quot;: &quot;Slate Rocks&quot;,\r\n  &quot;pubKey&quot;: &quot;-----BEGIN PUBLIC KEY-----\\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBAMBUAZGIzQsPO1PXgjdCJUxcZNc6Y4FY\\ncVC+JxZIUfaz0WkLI7H4tiKCsd+2F+3Xf+hObSbdoUi1UuT5uzpsda8CAQM=\\n-----END PUBLIC KEY-----&quot;,\r\n  &quot;update&quot;: &quot;2018-12-10&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;corp&quot;: &quot;Pi-ryte&quot;,\r\n  &quot;pubKey&quot;: &quot;-----BEGIN PUBLIC KEY-----\\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBALzXcOJvZz2UFPDJphTm++Ho9t+lkTQf\\nxH0nSp7lbfCHL5Y5YbnD7pgbD/e/PGIHt+cch3foOlUyH+b0Ht53ZO0CAQM=\\n-----END PUBLIC KEY-----&quot;,\r\n  &quot;update&quot;: &quot;2019-03-14&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 3,\r\n  &quot;corp&quot;: &quot;Marble Dreams&quot;,\r\n  &quot;pubKey&quot;: &quot;-----BEGIN PUBLIC KEY-----\\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBAN1L9v8ZbpJ1/GMlNOfGFjQhhO2KTKpj\\nOfp97CDUdCAQ6wzLjagGKbySC16/MpnAvoPUmYEtTRtbdH/rdMGdvd8CAQM=\\n-----END PUBLIC KEY-----&quot;,\r\n  &quot;update&quot;: &quot;2018-12-17&quot;\r\n}\r\n```\r\nand I want to output the RSA public key moduli, I need to execute `openssl` for each `&quot;pubKey&quot;` value.\r\n\r\nThis only works for the first `&quot;pubKey&quot;`:\r\n```bash\r\n$ jq -r &#39;.pubKey&#39; seq.json | openssl rsa -pubin -noout -modulus\r\nModulus=C054019188CD0B0F3B53D7823742254C5C64D73A6381587150BE27164851F6B3D1690B23B1F8B62282B1DFB617EDD77FE84E6D26DDA148B552E4F9BB3A6C75AF\r\n```\r\nIs there something like:\r\n```bash\r\n$ jq -r &#39;.pubKey | system(&quot;openssl rsa -pubin -noout -modulus&quot;)&#39; seq.json\r\n```\r\nor\r\n```bash\r\n$ jq -r &#39;.pubKey as $pk | system(&quot;openssl rsa -pubin -noout -modulus -in $pk&quot;)&#39; seq.json\r\n```",
        "link": "https://stackoverflow.com/questions/55445669/how-to-pipe-each-jq-filter-output-to-an-external-command",
        "title": "How to pipe each jq filter output to an external command?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554092930,
                "creation_date": 1554092930,
                "answer_id": 55448117,
                "question_id": 55447931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea seems about right, but you missed out mentioning the top-level paths after `.data[]`, it should have been\r\n\r\n    jq --arg instance &quot;Remaining Capacity % &quot; \\\r\n         &#39;.data[].batList[].dataDict[] | select(.name == $instance ).value&#39; json",
                "title": "How to select an element with jq in a nested JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554094316,
                "creation_date": 1554094316,
                "answer_id": 55448280,
                "question_id": 55447931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative to Inian&#39;s answer is to use the select-contains recipe, e.g.:  \r\n\r\n    jq -r &#39;.[].batList[].dataDict[] | select(.name|contains(&quot;Remaining&quot;)).value&#39; file\r\n\r\nWhile no better in this example, it is handy to remember especially if you need to find a bunch of values, e.g. `contains(&quot;Battery&quot;)` would return three results.    ",
                "title": "How to select an element with jq in a nested JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1554153845,
        "creation_date": 1554091184,
        "question_id": 55447931,
        "body_markdown": "I have input like this:\r\n```\r\n&quot;data&quot;: [{\r\n        &quot;id&quot;: 111585,\r\n        &quot;name&quot;: &quot;Inverter&quot;,\r\n        &quot;batList&quot;: [{\r\n            &quot;name&quot;: &quot;Battery1&quot;,\r\n            &quot;dataDict&quot;: [{\r\n                &quot;key&quot;: &quot;b1_1&quot;,\r\n                &quot;name&quot;: &quot;Battery V.&quot;,\r\n                &quot;value&quot;: 57.63,\r\n                &quot;unit&quot;: &quot;V&quot;\r\n            }, {\r\n                &quot;key&quot;: &quot;b1_2&quot;,\r\n                &quot;name&quot;: &quot;Battery I.&quot;,\r\n                &quot;value&quot;: -0.10,\r\n                &quot;unit&quot;: &quot;A&quot;\r\n            }, {\r\n                &quot;key&quot;: &quot;b1_3&quot;,\r\n                &quot;name&quot;: &quot;Battery P.&quot;,\r\n                &quot;value&quot;: -6,\r\n                &quot;unit&quot;: &quot;W&quot;\r\n            }, {\r\n                &quot;key&quot;: &quot;b1_4&quot;,\r\n                &quot;name&quot;: &quot;Inner T.&quot;,\r\n                &quot;value&quot;: 25,\r\n                &quot;unit&quot;: &quot;℃&quot;\r\n            }, {\r\n                &quot;key&quot;: &quot;b1_5&quot;,\r\n                &quot;name&quot;: &quot;Remaining Capacity % &quot;,\r\n                &quot;value&quot;: 99,\r\n                &quot;unit&quot;: &quot;%&quot;\r\n            }]\r\n        }]\r\n    }],\r\n```\r\nfrom which I want to extract the &#39;value&#39; property (i.e. 99) for &quot;Remaining Capacity % &quot;.\r\n\r\nMy best amateurish but well searched attempt is\r\n```\r\njq --arg instance &quot;Remaining Capacity % &quot; &#39;.data | .[] | select(.name == $instance) | .value&#39;)\r\n```\r\nbut I get an empty result. Any help with this nested intransigence would be much appreciated.",
        "link": "https://stackoverflow.com/questions/55447931/how-to-select-an-element-with-jq-in-a-nested-json",
        "title": "How to select an element with jq in a nested JSON"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1554135347,
                "creation_date": 1554135347,
                "answer_id": 55459474,
                "question_id": 55459393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do something like below. This basically checks inside `LIST`, to see if any of the objects&#39; value is `NO` and get its `CPU` value.\r\n\r\n    jq &#39;.LIST[] | select(.Tags[].Value == &quot;NO&quot;)? | .CPU&#39;\r\n",
                "title": "jq how to get a return value based on condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1555420825,
        "creation_date": 1554135035,
        "last_edit_date": 1555420825,
        "question_id": 55459393,
        "body_markdown": "So I&#39;m trying to figure out how to get the `&quot;CPU&quot;` value based on the condition from the value from `&quot;Tags&quot;`...`&quot;Value&quot;`\r\n\r\nSo I want to print the `&quot;CPU&quot;` value if the value within the Tags is `NO`\r\nThe return value on this example would be: `&quot;Identifier-0002&quot;`\r\n\r\nHere is the data:\r\n\r\n    {\r\n      &quot;LIST&quot;: [\r\n        {\r\n          &quot;CPU&quot;: &quot;Identifier-0002&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Family&quot;,\r\n              &quot;Value&quot;: &quot;X&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;Available&quot;,\r\n              &quot;Value&quot;: &quot;NO&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;CPU&quot;: &quot;Identifier-0001&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Family&quot;,\r\n              &quot;Value&quot;: &quot;X&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;Available&quot;,\r\n              &quot;Value&quot;: &quot;YES&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nAny ideas ?\r\n\r\nThanks !",
        "link": "https://stackoverflow.com/questions/55459393/jq-how-to-get-a-return-value-based-on-condition",
        "title": "jq how to get a return value based on condition"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4566643,
                    "reputation": 1125,
                    "user_id": 3707494,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/joABE.jpg?s=256",
                    "display_name": "Edwin",
                    "link": "https://stackoverflow.com/users/3707494/edwin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554181750,
                "post_id": 55466748,
                "comment_id": 97645826,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15656571,
                    "reputation": 5,
                    "user_id": 11296745,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b59be28f4f9aaaba11dae0a6d2457402?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "elpidio.valdes",
                    "link": "https://stackoverflow.com/users/11296745/elpidio-valdes"
                },
                "reply_to_user": {
                    "account_id": 4566643,
                    "reputation": 1125,
                    "user_id": 3707494,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/joABE.jpg?s=256",
                    "display_name": "Edwin",
                    "link": "https://stackoverflow.com/users/3707494/edwin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554183552,
                "post_id": 55466748,
                "comment_id": 97646373,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4566643,
                    "reputation": 1125,
                    "user_id": 3707494,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/joABE.jpg?s=256",
                    "display_name": "Edwin",
                    "link": "https://stackoverflow.com/users/3707494/edwin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554185435,
                "post_id": 55466748,
                "comment_id": 97647075,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1555777820,
                "last_edit_date": 1555777820,
                "creation_date": 1554181581,
                "answer_id": 55467294,
                "question_id": 55466748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have changed my requirements to fit a more complex form. To add a user to any of these groups&#39; users this is what I did:\r\n\r\n    jq &#39;. |= map( if ( .group==&quot;abc&quot;) then .users+=[&quot;final.answer&quot;,] else . end)&#39; source.json\r\n\r\nwhich produced a result\r\n\r\n    [\r\n        {\r\n            &quot;group&quot;: &quot;abc&quot;,\r\n            &quot;users&quot;: [\r\n                &quot;user1&quot;,\r\n                &quot;user2&quot;,\r\n                &quot;final.answer&quot;\r\n            ]\r\n        },\r\n        {\r\n            &quot;group&quot;: &quot;def&quot;,\r\n            &quot;users&quot;: [\r\n                &quot;user4&quot;,\r\n                &quot;user5&quot;\r\n            ]\r\n        }\r\n    ]\r\n",
                "title": "modify nested object but maintain the full object after"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1555777820,
        "creation_date": 1554177436,
        "question_id": 55466748,
        "body_markdown": "I need to modify an element --an array-- (e.g.: &quot;group-xyz&quot;) within a nested object in a JSON tree using JQ but once that&#39;s done then I need the entire object back with the modified data.\r\n\r\nThe goal is to update a JSON tree and save it in full.\r\ne.g.: add array element, empty array, etc.\r\n\r\n    {\r\n      &quot;group-abc&quot;: {&quot;users&quot;: [&quot;tina.turner&quot;]},\r\n      &quot;group-def&quot;: {&quot;users&quot;: [&quot;someone.else&quot;]},\r\n      &quot;group-xyz&quot;: {&quot;users&quot;: [&quot;that.thing&quot;]\r\n    }\r\n\r\nThen I am interested in returning an object like this:\r\n\r\n    {\r\n      &quot;group-abc&quot;: {&quot;users&quot;: [&quot;tina.turner&quot;]},\r\n      &quot;group-def&quot;: {&quot;users&quot;: []},\r\n      &quot;group-xyz&quot;: {&quot;users&quot;: [&quot;that.thing&quot;,&quot;well.done&quot;]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55466748/modify-nested-object-but-maintain-the-full-object-after",
        "title": "modify nested object but maintain the full object after"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554271277,
                "last_edit_date": 1554271277,
                "creation_date": 1554196988,
                "answer_id": 55471198,
                "question_id": 55470725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your existing approach define the filter definition in single quotes, to preserve the _literal_ value and not to lose quotes or force any unnecessary variable expansion by the shell. Foe e.g. `&quot;$var&quot;` expands to a value stored in the place-holder `var`, but `&#39;$var&#39;` is stored as a plain string.\r\n\r\n    SEARCH=&#39;.[] | select(.notes[] | select(.body|contains(&quot;[SOMETEXT]&quot;)))&#39;\r\n    jq &quot;$SEARCH&quot; json\r\n\r\nRemember that you need to always escape double-quotes nested inside one other for it to be preserved. You are much better-off using an array and use the quoted expansion of type `array[*]` to produce a single word string to use as the filter. Any other ways using the shell variable would probably probably involve word-splitting/quote-removal done by the shell before even passing to the `jq` command.\r\n\r\nWith the array expansion the quotes are preserved and the only thing you need to ensure is _not_ to modify the input field separator `IFS` value from its default.\r\n\r\n    ary=(&#39;.[]&#39; &#39;|&#39; &#39;select(.notes[] | select(.body|contains(&quot;[SOMETEXT]&quot;)))&#39;)\r\n    jq &quot;${ary[*]}&quot; json\r\n\r\n",
                "title": "Is it possible to have a dynamic selector in jq using shell variables?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1554271277,
        "creation_date": 1554195530,
        "question_id": 55470725,
        "body_markdown": "I am curious if it is possible to have a shell variable like:\r\n```bash\r\nSEARCH=&quot;.[] | select(.notes[] | select(.body|contains(&quot;[SOMETEXT]&quot;)))&quot;\r\n```\r\nand use that variable in a `jq` selection, like:\r\n```bash\r\njq &#39;${SEARCH}&#39; input.json\r\n```\r\n\r\nFor reference / testing the following JSON kan be used:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 74892374923,\r\n    &quot;notes&quot;: [\r\n      {\r\n        &quot;id&quot;: 8902348023,\r\n        &quot;body&quot;: &quot;Some normal text&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 8094328420,\r\n        &quot;body&quot;: &quot;Some more normal text&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 729384872903,\r\n    &quot;notes&quot;: [\r\n      {\r\n        &quot;id&quot;: 0983012,\r\n        &quot;body&quot;: &quot;Some more more normal text [SOMETEXT]&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 89023432,\r\n        &quot;body&quot;: &quot;Some more more more normal text&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/55470725/is-it-possible-to-have-a-dynamic-selector-in-jq-using-shell-variables",
        "title": "Is it possible to have a dynamic selector in jq using shell variables?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1554279132,
                "last_edit_date": 1554279132,
                "creation_date": 1554276668,
                "answer_id": 55489436,
                "question_id": 55489052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a way to do it:\r\n\r\n    jq -r &#39;.[]|.ASGname as $g|.instance_AZs|group_by(.)[]|&quot;\\($g).\\(.[0]).\\(length)&quot;&#39; file.json",
                "title": "Count grouped members of JSON array with jq 1.3 with inline output"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1554286533,
                "last_edit_date": 1554286533,
                "creation_date": 1554277380,
                "answer_id": 55489652,
                "question_id": 55489052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\n.[]\r\n| .ASGname as $p\r\n| reduce .instance_AZs[] as $k ({}; .[$k]+=1)\r\n| keys_unsorted[] as $k\r\n| &quot;\\($p).\\($k).\\(.[$k])&quot;\r\n```\r\n\r\nreduce `instance_AZs` to an object where unique array elements are keys to their repetition counts in the array, use it for producing desired output.\r\n\r\nor, if you insist on doing this your way, pipe groups to an interpolated string instead of `map`, i.e refer to @hek2mgl&#39;s answer.",
                "title": "Count grouped members of JSON array with jq 1.3 with inline output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1554286533,
        "creation_date": 1554275288,
        "question_id": 55489052,
        "body_markdown": "I have a JSON file:\r\n```\r\n[\r\n  {\r\n    &quot;instance_AZs&quot;: [\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1a&quot;,\r\n        &quot;us-east-1a&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1a&quot;,\r\n        &quot;us-east-1a&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1a&quot;,\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1b&quot;\r\n    ],\r\n    &quot;ASGname&quot;: &quot;myapp&quot;\r\n  }\r\n]\r\n```\r\n\r\nDesired output is:\r\n```\r\nmyapp.us-east-1a.5\r\nmyapp.us-east-1b.7\r\nmyapp.us-east-1c.6\r\n```\r\n\r\nAs far as I can go with jq 1.3 syntax, I wrote this code:\r\n```\r\ncat file.json | jq -r &#39;.[] | .ASGname, (.instance_AZs | group_by(.) | map(. | length , (. | unique ) [] ))&#39;\r\n```\r\n\r\nWhich produce an output:\r\n```\r\nmyapp\r\n[\r\n  5,\r\n  &quot;us-east-1a&quot;,\r\n  7,\r\n  &quot;us-east-1b&quot;,\r\n  6,\r\n  &quot;us-east-1c&quot;\r\n]\r\n```\r\n\r\nCan you please advice how to generate desired output?",
        "link": "https://stackoverflow.com/questions/55489052/count-grouped-members-of-json-array-with-jq-1-3-with-inline-output",
        "title": "Count grouped members of JSON array with jq 1.3 with inline output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554283186,
                "last_edit_date": 1554283186,
                "creation_date": 1554282853,
                "answer_id": 55491399,
                "question_id": 55491067,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You only have to move one character:\r\n\r\n```\r\n[.player_container | .[] | { user_id: .[]}]\r\n```\r\n\r\nWhile your version creates a separate array for each output of `.player_container | .[]`, this will collect everything into one array.",
                "title": "JQ: Merging different objects into a new array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1554283186,
        "creation_date": 1554281877,
        "question_id": 55491067,
        "body_markdown": "I use jq 1.5 in a Windows enviroment to modify json files. \r\nHi have following json file:\r\n\r\n    {&quot;player_container&quot;:{&quot;74016&quot;:[&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;],&quot;74002&quot;:[&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;ta81a928e0624295b01499d7035d0308&quot;,&quot;tdd4e222600d42f9954b0be0448da0b1&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;],&quot;74007&quot;:[&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;],&quot;74009&quot;:[&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;kcb810a423dd4e179027f0feaae9ea60&quot;,&quot;None&quot;],&quot;74012&quot;:[&quot;x720ed571876471fab173ba05f71e4b3&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;],&quot;74013&quot;:[&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;],&quot;74014&quot;:[&quot;vd86094b5a6e448f8c416d6fe75bec7c&quot;,&quot;None&quot;,&quot;None&quot;,&quot;h6ef696cf767464f9c367150fdb29fe4&quot;,&quot;None&quot;,&quot;g77b124cd46b41399c3db219ac0a76bd&quot;,&quot;None&quot;,&quot;None&quot;],&quot;74015&quot;:[&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;,&quot;None&quot;]}}\r\n\r\nIn the object player_container are different objects (the &quot;name&quot; of the object and the number objects differs from time to time).\r\nI use following jq command actually to join them into a new array:\r\n\r\n    .player_container | .[] | [{ user_id: .[]}]\r\nBut it generates different json Arrays and not one. What i need looks like:\r\n\r\n \r\n\r\n       [\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;ta81a928e0624295b01499d7035d0308&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;tdd4e222600d42f9954b0be0448da0b1&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;kcb810a423dd4e179027f0feaae9ea60&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;x720ed571876471fab173ba05f71e4b3&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;vd86094b5a6e448f8c416d6fe75bec7c&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;h6ef696cf767464f9c367150fdb29fe4&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;g77b124cd46b41399c3db219ac0a76bd&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      },\r\n      {\r\n        &quot;user_id&quot;: &quot;None&quot;\r\n      }\r\n    ]\r\n\r\nAny tips?\r\n\r\nBR\r\nTimo\r\n",
        "link": "https://stackoverflow.com/questions/55491067/jq-merging-different-objects-into-a-new-array",
        "title": "JQ: Merging different objects into a new array"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554301599,
                "last_edit_date": 1554301599,
                "creation_date": 1554300333,
                "answer_id": 55497103,
                "question_id": 55496843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "assuming `items` array always has one element, make use of `--stream` option;\r\n```\r\nreduce (inputs|select(length == 2)) as $p\r\n({}; .[$p[0]|map(strings)|join(&quot;_&quot;)] = $p[1])\r\n```\r\nsince `inputs` is used, `-n` option is also required.",
                "title": "Flatten nested dictionary to list of key:value pair"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554304141,
                "last_edit_date": 1554304141,
                "creation_date": 1554300391,
                "answer_id": 55497133,
                "question_id": 55496843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [pandas][1], specifically [json_normalize][2]\r\n\r\n\r\n\r\n    from pandas.io.json import json_normalize\r\n\r\n    d = {\r\n    \t&quot;items&quot; : [\r\n    \t\t{\r\n    \t\t\t&quot;address&quot; : {\r\n    \t\t\t\t&quot;address_line_1&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;address_line_2&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;care_of&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;country&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;locality&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;po_box&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;postal_code&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;premises&quot; : &quot;string&quot;,\r\n    \t\t\t\t&quot;region&quot; : &quot;string&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;address_snippet&quot; : &quot;string&quot;,\r\n    \t\t\t&quot;appointment_count&quot; : &quot;integer&quot;,\r\n    \t\t\t&quot;date_of_birth&quot; : {\r\n    \t\t\t\t&quot;month&quot; : &quot;integer&quot;,\r\n    \t\t\t\t&quot;year&quot; : &quot;integer&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;description&quot; : &quot;string&quot;,\r\n    \t\t\t&quot;description_identifiers&quot; : [\r\n    \t\t\t\t&quot;integer&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;kind&quot; : &quot;string&quot;,\r\n    \t\t\t&quot;links&quot; : {\r\n    \t\t\t\t&quot;self&quot; : &quot;string&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;matches&quot; : [\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;address_snippet&quot; : [\r\n    \t\t\t\t\t\t&quot;integer&quot;\r\n    \t\t\t\t\t],\r\n    \t\t\t\t\t&quot;snippet&quot; : [\r\n    \t\t\t\t\t\t&quot;integer&quot;\r\n    \t\t\t\t\t],\r\n    \t\t\t\t\t&quot;title&quot; : [\r\n    \t\t\t\t\t\t&quot;integer&quot;\r\n    \t\t\t\t\t]\r\n    \t\t\t\t}\r\n    \t\t\t],\r\n    \t\t\t&quot;snippet&quot; : &quot;string&quot;,\r\n    \t\t\t&quot;title&quot; : &quot;string&quot;\r\n    \t\t}\r\n    \t],\r\n    \t&quot;items_per_page&quot; : &quot;integer&quot;,\r\n    \t&quot;kind&quot; : &quot;string&quot;,\r\n    \t&quot;start_index&quot; : &quot;integer&quot;,\r\n    \t&quot;total_results&quot; : &quot;integer&quot;\r\n    }\r\n    \r\n    \r\n    x = json_normalize(d[&#39;items&#39;], sep=&quot;_&quot;)\r\n    print(x.to_string())\r\n    # print(x.keys()) # handy, as you may get &quot;lost&quot; with many keys\r\n    # x.to_dict(\r\n\r\n----------\r\n\r\n     address_address_line_1 address_address_line_2 address_care_of address_country address_locality address_po_box address_postal_code address_premises address_region address_snippet appointment_count date_of_birth_month date_of_birth_year description description_identifiers    kind links_self                                            matches snippet   title\r\n    0                 string                 string          string          string           string         string              string           string         string          string           integer             integer            integer      string               [integer]  string     string  [{&#39;address_snippet&#39;: [&#39;integer&#39;], &#39;snippet&#39;: [...  string  string\r\n\r\n\r\n----------\r\nNotes:\r\n\r\n1. You can reuse `json_normalize` to flatten further nested elements (lists) as needed.\r\n2. I normally un-flatten all objects into new dataframes first and then merge everything into a new `master_df` with all `keys` flattened. Hope it makes sense to you, otherwise please comment.\r\n\r\n  [1]: https://pandas.pydata.org/\r\n  [2]: https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.io.json.json_normalize.html",
                "title": "Flatten nested dictionary to list of key:value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1554304141,
        "creation_date": 1554299554,
        "question_id": 55496843,
        "body_markdown": "I am querying company house API for an anti-corruption investigation and I get results in a nested JSON which can be seen [here](https://developer.companieshouse.gov.uk/api/docs/search-overview/OfficerSearch-resource.html). I would like to transform this dictionary into a simple `{key:value, key:value}` format, where if I have nested objects or lists the keys merge in the flattened key string.\r\n\r\nThe problem is also that some items returned by the API might not necessarily have all the key:value pairs, as some of these are optional. **If the key:value pair is absent then I&#39;d like to insert an `NA`.**\r\n\r\nHere&#39;s the JSON at its fullest - some query results might not have all these entries though.  \r\n\r\n    {\r\n       &quot;items&quot; : [\r\n          {\r\n             &quot;address&quot; : {\r\n                &quot;address_line_1&quot; : &quot;string&quot;,\r\n                &quot;address_line_2&quot; : &quot;string&quot;,\r\n                &quot;care_of&quot; : &quot;string&quot;,\r\n                &quot;country&quot; : &quot;string&quot;,\r\n                &quot;locality&quot; : &quot;string&quot;,\r\n                &quot;po_box&quot; : &quot;string&quot;,\r\n                &quot;postal_code&quot; : &quot;string&quot;,\r\n                &quot;premises&quot; : &quot;string&quot;,\r\n                &quot;region&quot; : &quot;string&quot;\r\n             },\r\n             &quot;address_snippet&quot; : &quot;string&quot;,\r\n             &quot;appointment_count&quot; : &quot;integer&quot;,\r\n             &quot;date_of_birth&quot; : {\r\n                &quot;month&quot; : &quot;integer&quot;,\r\n                &quot;year&quot; : &quot;integer&quot;\r\n             },\r\n             &quot;description&quot; : &quot;string&quot;,\r\n             &quot;description_identifiers&quot; : [\r\n                &quot;integer&quot;\r\n             ],\r\n             &quot;kind&quot; : &quot;string&quot;,\r\n             &quot;links&quot; : {\r\n                &quot;self&quot; : &quot;string&quot;\r\n             },\r\n             &quot;matches&quot; : [\r\n                {\r\n                   &quot;address_snippet&quot; : [\r\n                      &quot;integer&quot;\r\n                   ],\r\n                   &quot;snippet&quot; : [\r\n                      &quot;integer&quot;\r\n                   ],\r\n                   &quot;title&quot; : [\r\n                      &quot;integer&quot;\r\n                   ]\r\n                }\r\n             ],\r\n             &quot;snippet&quot; : &quot;string&quot;,\r\n             &quot;title&quot; : &quot;string&quot;\r\n          }\r\n       ],\r\n       &quot;items_per_page&quot; : &quot;integer&quot;,\r\n       &quot;kind&quot; : &quot;string&quot;,\r\n       &quot;start_index&quot; : &quot;integer&quot;,\r\n       &quot;total_results&quot; : &quot;integer&quot;\r\n    }\r\n\r\nReusing some old JQ code I managed to get to creating two lists one containing all keys and one containing all values (see jqplay [here](https://jqplay.org/s/XcUok7HXWT)). \r\n\r\nHere&#39;s an example for just a bit of the dictionary, to get the idea: \r\n\r\n   \r\n\r\n    {\r\n       &quot;items_address_address_line_1&quot; : &quot;string&quot;,\r\n       &quot;items_address_address_line_2&quot; : &quot;string&quot;\r\n       &quot;items_address_care_of&quot; : &quot;string&quot;,\r\n       &quot;items_address_country&quot; : &quot;string&quot;,\r\n       &quot;items_address_locality&quot; : &quot;string&quot;,\r\n       &quot;items_address_po_box&quot; : &quot;string&quot;,\r\n       &quot;items_address_postal_code&quot; : &quot;string&quot;,\r\n       &quot;items_address_premises&quot; : &quot;string&quot;,\r\n       &quot;items_address_region&quot; : &quot;string&quot;\r\n       }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55496843/flatten-nested-dictionary-to-list-of-keyvalue-pair",
        "title": "Flatten nested dictionary to list of key:value pair"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1554355133,
                "last_edit_date": 1554355133,
                "creation_date": 1554307791,
                "answer_id": 55499685,
                "question_id": 55499300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--stream` would overcomplicate this task, use `--null-input/-n` option in conjunction with `reduce` instead.\r\n```jq\r\n{a: &quot;xxx&quot;, b: 123}\r\n| .domains = (reduce (inputs|select(.query_type == &quot;A&quot;).resp_name) as $d\r\n  ({}; . + {($d): null}) | keys_unsorted | map(.[:-1]))\r\n```\r\nKeeping domains in an object as keys instead of an array makes this script even more efficient in terms of memory consumption and cpu time; in jq, *Objects are added by merging, that is, inserting all the key-value pairs from both objects into a single combined object. If both objects contain a value for the same key, the object on the right of the `+` wins.* Thus no need to `unique`.\r\n\r\nTrimming the last char off (`.[:-1]`) all `resp_name`s slows down the process as well, performing `map(.[:-1])` on resulting array instead is more efficient.\r\n\r\nSee it on [jqplay](https://jqplay.org/s/tmbvmX-axL).",
                "title": "Handle a very large input file without slurp"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1554355133,
        "creation_date": 1554306612,
        "last_edit_date": 1554313740,
        "question_id": 55499300,
        "body_markdown": "I am working with JSON output from a tool (massdns) that is formatted as follows:\r\n\r\n```javascript\r\n{&quot;query_name&quot;:&quot;1eaff.example.com.&quot;,&quot;query_type&quot;:&quot;A&quot;,&quot;resp_name&quot;:&quot;ns02.example.com.&quot;,&quot;resp_type&quot;:&quot;A&quot;,&quot;data&quot;:&quot;&lt;ip&gt;&quot;}\r\n{&quot;query_name&quot;:&quot;1cf0e.example.com.&quot;,&quot;query_type&quot;:&quot;A&quot;,&quot;resp_name&quot;:&quot;ns01.example.com.&quot;,&quot;resp_type&quot;:&quot;A&quot;,&quot;data&quot;:&quot;&lt;ip&gt;&quot;}\r\n{&quot;query_name&quot;:&quot;1cf0e.example.com.&quot;,&quot;query_type&quot;:&quot;A&quot;,&quot;resp_name&quot;:&quot;ns02.example.com.&quot;,&quot;resp_type&quot;:&quot;A&quot;,&quot;data&quot;:&quot;&lt;ip&gt;&quot;}\r\n{&quot;query_name&quot;:&quot;1fwsjz2f4ok1ot2hh2illyd1-wpengine.example.com.&quot;,&quot;query_type&quot;:&quot;A&quot;,&quot;resp_name&quot;:&quot;ns01.example.com.&quot;,&quot;resp_type&quot;:&quot;A&quot;,&quot;data&quot;:&quot;&lt;ip&gt;&quot;}\r\n{&quot;query_name&quot;:&quot;1fwsjz2f4ok1ot2hh2illyd1-wpengine.example.com.&quot;,&quot;query_type&quot;:&quot;A&quot;,&quot;resp_name&quot;:&quot;ns02.example.com.&quot;,&quot;resp_type&quot;:&quot;A&quot;,&quot;data&quot;:&quot;&lt;ip&gt;&quot;}\r\n{&quot;query_name&quot;:&quot;1a811.example.com.&quot;,&quot;query_type&quot;:&quot;A&quot;,&quot;resp_name&quot;:&quot;ns01.example.com.&quot;,&quot;resp_type&quot;:&quot;A&quot;,&quot;data&quot;:&quot;&lt;ip&gt;&quot;}\r\n````\r\n\r\nI am able to use `jq` with slurp (`-s`) to beautifully output the results in the format I need:\r\n```\r\njq -s &#39;{ a: &quot;xxx&quot;, &quot;b&quot;: 123, domains: map(select(.resp_type==&quot;A&quot;) | .resp_name[:-1] ) | unique }&#39;\r\n```\r\n\r\nThis yields a JSON string like:\r\n```\r\n{\r\n  &quot;a&quot;: &quot;xxx&quot;,\r\n  &quot;b&quot;: 123,\r\n  &quot;domains&quot;: [\r\n    &quot;ns01.example.com&quot;,\r\n    &quot;ns02.example.com&quot;\r\n  ]\r\n}\r\n```\r\n\r\n(See [JQPlay example here][1].)\r\n\r\nMy problem occurs when my input scales to hundreds of thousands of lines (GBs of data), in which case slurp becomes too memory-consuming, and `jq` exits with an error.\r\n\r\nI have discovered the `--stream` option, which allows handling large inputs, but am struggling to find a way to obtain the same output. Is there a way to use `--stream` (and not `--slurp`) to get the wanted output for a very large input file with `jq`?\r\n\r\n  [1]: https://jqplay.org/s/MdvCSywoMI",
        "link": "https://stackoverflow.com/questions/55499300/handle-a-very-large-input-file-without-slurp",
        "title": "Handle a very large input file without slurp"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1554368431,
                "post_id": 55511484,
                "comment_id": 97728725,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1436014,
                    "reputation": 201171,
                    "user_id": 1630171,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oIS66.png?s=256",
                    "display_name": "Ansgar Wiechers",
                    "link": "https://stackoverflow.com/users/1630171/ansgar-wiechers"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1554370228,
                "post_id": 55511484,
                "comment_id": 97729809,
                "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": 1554412348,
                "post_id": 55511484,
                "comment_id": 97754102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554452689,
                "post_id": 55511484,
                "comment_id": 97765725,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554495907,
                "post_id": 55511484,
                "comment_id": 97788940,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1554992961,
                "creation_date": 1554992961,
                "answer_id": 55634949,
                "question_id": 55511484,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Numbers in the json path need to be marked Oldschool like:\r\n.starbase_detailed_scan.resources[&quot;2614028847&quot;]\r\n\r\nBR\r\nTimo",
                "title": "JQ: Numeric field names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1554992961,
        "creation_date": 1554367332,
        "last_edit_date": 1554452544,
        "question_id": 55511484,
        "body_markdown": "I use JQ 1.5 in a Windows10 enviroment (PowerShell).\r\nI built a `jq` statement that works on the example data on jqplay but throws a error on my enviroment:\r\n\r\nSample: [Code share][1]\r\n\r\nCode:\r\n\r\n    . | { last_update:  .starbase_detailed_scan.last_update_time, user_name:  .starbase_detailed_scan.owner_name, alliance_id: .starbase_detailed_scan.owner_alliance_id, drydocks: .starbase_detailed_scan.num_drydocks, tier: .starbase_detailed_scan.owner_level, defence_plattform: .starbase_detailed_scan.num_defence_platforms, shield_triggered: .starbase_detailed_scan.player_shield.triggered_on, shield_end: .starbase_detailed_scan.player_shield.expiry_time, parsteel: .resources.&quot;325683920&quot;.current_amount, tritanium: .resources.&quot;743985951&quot;.current_amount, dilithium: .resources.&quot;2614028847&quot;.current_amount, user_id: .starbase_detailed_scan.owner_user_id, defence_rating: .starbase_detailed_scan.defense_rating }\r\n\r\nThe problem are the JSON objects with a numeric identifier. On jqplay I got the correct values. On PowerShell `jq` I get an error. I expected that this is a PowerShell problem so I tried to move the filter into a filter file. The error is then gone but I get only NULL as value for the three objects.\r\n\r\n  [1]: https://codebeautify.org/online-json-editor/cb8adb0a",
        "link": "https://stackoverflow.com/questions/55511484/jq-numeric-field-names",
        "title": "JQ: Numeric field names"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1554400679,
                "creation_date": 1554400679,
                "answer_id": 55522307,
                "question_id": 55522216,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have a key named `bucketName`; you have a string that can be *decoded* as a key/value pair.\r\n\r\n    $ jq &#39;.[] | split(&quot;=&quot;) | select(.[0]==&quot;bucketName&quot;)[1]&#39; &lt;&lt;&lt; &#39;[&quot;bucketName=myBucket&quot;, &quot;a=b&quot;]\r\n    &quot;myBucket&quot;",
                "title": "How to extract a value from JSON array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1554400679,
        "creation_date": 1554400366,
        "question_id": 55522216,
        "body_markdown": "I have the following json array.\r\n\r\n    [\r\n    &quot;bucketName=myBucket&quot;,\r\n    ]\r\n\r\nIt exists in a separate json file called parameters.json. It is the only thing in the file.\r\n\r\nI have a bash script that is trying to extract the value &quot;myBucket&quot; from this json file with the following command:\r\n\r\n```\r\njq &#39;.bucketName&#39; parameters.json\r\n```\r\n\r\nI am getting the following error:\r\n```\r\njq: error (at parameters.json:3): Cannot index array with string &quot;bucketName&quot;\r\n```\r\nHow can extract the value myBucket?",
        "link": "https://stackoverflow.com/questions/55522216/how-to-extract-a-value-from-json-array",
        "title": "How to extract a value from JSON array?"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1,
                "creation_date": 1554735256,
                "post_id": 55574326,
                "comment_id": 97851261,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554729811,
                "creation_date": 1554729811,
                "answer_id": 55574527,
                "question_id": 55574326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--arg key value` treats value as a string. Since a string containing literal `&quot;`s needs to have escapes added to be valid in JSON, that&#39;s what `jq` does.\r\n\r\n`--argjson key value`, by contrast, parses `value` as JSON text; which appears to be what you want to do here.\r\n\r\nChange `--arg attachments &quot;$status&quot;` to `--argjson attachments &quot;$status&quot;`.",
                "title": "How to use shell script pipe json to curl to sent slack message"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1554729811,
        "creation_date": 1554729213,
        "question_id": 55574326,
        "body_markdown": "I have a monitor API (for example: www.example.com/monitor ) well return system status in JSON format, for example:\r\n\r\n```JSON\r\n{\r\n   &quot;foo&quot; : 1000,\r\n   &quot;bar&quot; : 100\r\n}\r\n```\r\nI want to use curl to get system status from this API and pipe to Slack\r\n\r\nThe following is my current script.\r\n\r\n```bash\r\nstatus=$(curl &quot;http://www.xample.com/monitor/status&quot; )\r\nslackWebHook=&quot;https://hooks.slack.com/services/xxxxx/xxxxx/xxxxx&quot;\r\n\r\nfunction sentSlack () {\r\n json_template=&#39;{\r\n    channel:    $channel,\r\n    username:   $username,\r\n    text:       $text,\r\n    icon_emoji: $icon_emoji,\r\n    attachments: [$attachments]\r\n  }&#39;\r\n \r\n  jq -n --arg channel  &quot;#unicorn_log&quot; \\\r\n       --arg username &quot;Kuasa Search Report&quot; \\\r\n       --arg text     &quot;${msg}&quot;\\\r\n       --arg icon_emoji &quot;chart_with_upwards_trend&quot; \\\r\n       --arg attachments &quot;${status}&quot; &quot;$json_template&quot; |\r\n       curl -i -X POST --data-urlencode &quot;$(&lt;/dev/stdin)&quot;  ${slackWebHook}\r\n\r\n}\r\n\r\nsentSlack\r\n```\r\n\r\nI always get **invalid_payload** , because the status be escaped.\r\n\r\n```JSON\r\n{\r\n   \\&quot;foo\\&quot; : 1000,\r\n   \\&quot;bar\\&quot; : 100\r\n}\r\n \r\n```\r\n\r\nHow can I pass JSON to Slack payload correctly?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55574326/how-to-use-shell-script-pipe-json-to-curl-to-sent-slack-message",
        "title": "How to use shell script pipe json to curl to sent slack message"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554750371,
                "post_id": 55579845,
                "comment_id": 97858802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13402784,
                    "reputation": 937,
                    "user_id": 9671763,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-SJjxf3uJ4Vk/AAAAAAAAAAI/AAAAAAAAAAc/kn7QhYit8Jk/s256-rj/photo.jpg",
                    "display_name": "Ken J",
                    "link": "https://stackoverflow.com/users/9671763/ken-j"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1554750608,
                "post_id": 55579845,
                "comment_id": 97858905,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554751293,
                "post_id": 55579845,
                "comment_id": 97859230,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13402784,
                    "reputation": 937,
                    "user_id": 9671763,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-SJjxf3uJ4Vk/AAAAAAAAAAI/AAAAAAAAAAc/kn7QhYit8Jk/s256-rj/photo.jpg",
                    "display_name": "Ken J",
                    "link": "https://stackoverflow.com/users/9671763/ken-j"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554751938,
                "post_id": 55579845,
                "comment_id": 97859514,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557848876,
                "creation_date": 1557848876,
                "answer_id": 56134251,
                "question_id": 55579845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use object construction to do this. \r\n\r\n`cat generator.json | jq --arg variable $variable &#39;{Parameters: {DesiredCount: .Parameters.developmentDesiredCount, Zone: .Parameters.devZone, environmentName: &quot;Production&quot;, var: $variable}}&#39;\r\n`\r\n\r\nHere I have shown a few solutions to help you. \r\n\r\n1. you can reference the parameters in `generator.json` by using dot notation in the value for that field in the new object. \r\n2. You can simply define a string \r\n3. You can use the args flag to pass in a bash variable. \r\n\r\n\r\nOutput (incomplete, but shows solution)\r\n\r\n```\r\n{\r\n  &quot;Parameters&quot;: {\r\n    &quot;DesiredCount&quot;: &quot;1&quot;,\r\n    &quot;Zone&quot;: &quot;service-dev.example.com&quot;,\r\n    &quot;environmentName&quot;: &quot;Production&quot;,\r\n    &quot;var&quot;: &quot;VariableString&quot;\r\n  }\r\n}\r\n```",
                "title": "Jq Replace Existing JSON with Values Complex"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557858977,
                "creation_date": 1557858977,
                "answer_id": 56136582,
                "question_id": 55579845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one such way you can generate that json. Perhaps the tricky part here is generating the dynamic name for the environment `DesiredCount` and `Zone`. But jq handles that rather easily.\r\n\r\n    $ jq --arg ServiceName &quot;myservice&quot; --arg EnvironmentName &quot;production&quot; &#39;.Parameters |=\r\n    {\r\n        FargateStackSuffix,\r\n        VPCStackSuffix,\r\n        $ServiceName,\r\n        $EnvironmentName,\r\n        ContainerPort,\r\n        ContainerCpu,\r\n        ContainerMemory,\r\n        Path,\r\n        DesiredCount: .&quot;\\($EnvironmentName)DesiredCount&quot;,\r\n        ELBType,\r\n        ELBIpAddressType,\r\n        Zone: .&quot;\\($EnvironmentName)Zone&quot;\r\n    }\r\n    &#39; generator.json &gt; config.json\r\n\r\n    $ cat config.json\r\n    {\r\n      &quot;Parameters&quot;: {\r\n        &quot;FargateStackSuffix&quot;: &quot;environment-fargate&quot;,\r\n        &quot;VPCStackSuffix&quot;: &quot;environment-base-vpc&quot;,\r\n        &quot;ServiceName&quot;: &quot;myservice&quot;,\r\n        &quot;EnvironmentName&quot;: &quot;production&quot;,\r\n        &quot;ContainerPort&quot;: &quot;80&quot;,\r\n        &quot;ContainerCpu&quot;: &quot;256&quot;,\r\n        &quot;ContainerMemory&quot;: &quot;512&quot;,\r\n        &quot;Path&quot;: &quot;*&quot;,\r\n        &quot;DesiredCount&quot;: &quot;3&quot;,\r\n        &quot;ELBType&quot;: &quot;application&quot;,\r\n        &quot;ELBIpAddressType&quot;: &quot;ipv4&quot;,\r\n        &quot;Zone&quot;: &quot;service.example.com&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Jq Replace Existing JSON with Values Complex"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1557858977,
        "creation_date": 1554748928,
        "last_edit_date": 1554751606,
        "question_id": 55579845,
        "body_markdown": "I need to generate a CloudFormation parameter list (config.json) during a CodeBuild. I have a bash script in my repo that will take a couple of parameters. This will either be production, staging, or development.\r\n\r\nHere&#39;s the generator.json. The values here will be used to generate config.json.\r\n\r\n    {\r\n      &quot;Parameters&quot; : {\r\n        &quot;FargateStackSuffix&quot; : &quot;environment-fargate&quot;,\r\n        &quot;VPCStackSuffix&quot;: &quot;environment-base-vpc&quot;,\r\n        &quot;ContainerPort&quot; : &quot;80&quot;,\r\n        &quot;ContainerCpu&quot; : &quot;256&quot;,\r\n        &quot;ContainerMemory&quot; : &quot;512&quot;,\r\n        &quot;Path&quot; : &quot;*&quot;,\r\n        &quot;productionDesiredCount&quot; : &quot;3&quot;,\r\n        &quot;stagingDesiredCount&quot; : &quot;2&quot;,\r\n        &quot;developmentDesiredCount&quot; : &quot;1&quot;,\r\n        &quot;ELBType&quot; : &quot;application&quot;,\r\n        &quot;ELBIpAddressType&quot;: &quot;ipv4&quot;,\r\n        &quot;productionZone&quot;: &quot;service.example.com&quot;,\r\n        &quot;stagingZone&quot;: &quot;service-staging.example.com&quot;,\r\n        &quot;devZone&quot;: &quot;service-dev.example.com&quot;\r\n      }\r\n    }\r\n\r\nFor example:\r\n\r\n    ./generate.sh my-service production\r\n\r\nWould generate this:\r\n\r\n    {\r\n      &quot;Parameters&quot; : {\r\n        &quot;FargateStackSuffix&quot; : &quot;production-fargate&quot;,\r\n        &quot;VPCStackSuffix&quot;: &quot;production-base-vpc&quot;,\r\n        &quot;ServiceName&quot; : &quot;myservice&quot;,\r\n        &quot;EnvironmentName&quot; : &quot;production&quot;,\r\n        &quot;ContainerPort&quot; : &quot;80&quot;,\r\n        &quot;ContainerCpu&quot; : &quot;256&quot;,\r\n        &quot;ContainerMemory&quot; : &quot;512&quot;,\r\n        &quot;Path&quot; : &quot;*&quot;,\r\n        &quot;DesiredCount&quot; : &quot;3&quot;,\r\n        &quot;ELBType&quot; : &quot;application&quot;,\r\n        &quot;ELBIpAddressType&quot;: &quot;ipv4&quot;,\r\n        &quot;Zone&quot;: &quot;myservice.example.com&quot;\r\n      }\r\n    }\r\n\r\nAs you can see there&#39;s a bit of replacement based on additions. Just iterating over the keys won&#39;t do this. Is there a way to do all fot eh transformations I need with just jq?   \r\n\r\n**EDIT**: I ended up using some sed to filter replace a few values. Now I need to replace the appropriate DesiredCount:\r\n\r\n    cat .codedeploy/generator.json | jq &#39;[paths(type == &quot;string&quot; and contains(&quot;DesiredCount&quot;))]&#39;\r\n    []\r\nMy problem is that it&#39;s returning an empty array.",
        "link": "https://stackoverflow.com/questions/55579845/jq-replace-existing-json-with-values-complex",
        "title": "Jq Replace Existing JSON with Values Complex"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1554768500,
                "creation_date": 1554768500,
                "answer_id": 55583399,
                "question_id": 55583325,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "VolumeId is twice nested, you need to identify that with your query\r\n\r\n    valueid=`echo ${value} | jq &#39;.[]|.[]|.VolumeId&#39;`",
                "title": "How to filter a value using jq&#39;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1554798984,
                "creation_date": 1554798984,
                "answer_id": 55588428,
                "question_id": 55583325,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or simply:\r\n\r\n    jq &#39;.Volumes[].VolumeId&#39;",
                "title": "How to filter a value using jq&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1554798984,
        "creation_date": 1554767750,
        "last_edit_date": 1554768008,
        "question_id": 55583325,
        "body_markdown": "I am writing a script to create AWS volumes automatically. I am trying to filter out the value for volumeId using echo and jq\r\n\r\n    [root@ip-172-41-23-8 ~]# aws ec2 describe-volumes --filters Name=status,Values=available Name=availability-zone,Values=us-east-1d  Name=tag:Name,Values=*USEPROD*|jq &quot;.VolumeId&quot;\r\n    null\r\n    [root@ip-172-41-23-8 ~]# echo $value | jq\r\n    {\r\n      &quot;Volumes&quot;: [\r\n        {\r\n          &quot;AvailabilityZone&quot;: &quot;us-east-1d&quot;,\r\n          &quot;Attachments&quot;: [],\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;Dev&quot;,\r\n              &quot;Key&quot;: &quot;Env&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;Shell&quot;,\r\n              &quot;Key&quot;: &quot;Deployment&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;cnx30au - Kafka-Data-Node - /dev/sdg - /abc/data/sda&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            }\r\n          ],\r\n          &quot;Encrypted&quot;: true,\r\n          &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n          &quot;VolumeId&quot;: &quot;vol-095ac513f0f049ba5&quot;,\r\n          &quot;State&quot;: &quot;available&quot;,\r\n          &quot;KmsKeyId&quot;: &quot;arn:aws:kms:us-east-1:709721360603:key/xvfgfr-dsdsd-dsdsds-a00c-dsdsdsd34dsd&quot;,\r\n          &quot;SnapshotId&quot;: &quot;&quot;,\r\n          &quot;Iops&quot;: 100,\r\n          &quot;CreateTime&quot;: &quot;2019-04-08T21:52:31.473Z&quot;,\r\n          &quot;Size&quot;: 10\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n    json=&quot;aws ec2 describe-volumes --filters Name=status,Values=available Name=availability-zone,Values=us-east-1d  Name=tag:Name,Values=*USEPROD*&quot;\r\n    echo &quot;Executing: ${json}&quot;\r\n    value=`${json}`\r\n    valueid=`echo ${value}|jq &#39;.VolumeId&#39;`\r\n    [root@ip-172-31-87-1 ~]# echo $valueid\r\n    null\r\n\r\n\r\nWhen i filter for available volumes i only want the output to be as follows\r\n\r\n    vol-095ac513f0f049ba5\r\n",
        "link": "https://stackoverflow.com/questions/55583325/how-to-filter-a-value-using-jq",
        "title": "How to filter a value using jq&#39;"
    },
    {
        "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": 1554912817,
                "post_id": 55583568,
                "comment_id": 97927448,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554787708,
                "creation_date": 1554787708,
                "answer_id": 55585646,
                "question_id": 55583568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you looking only to get the object corresponding to `host001`? You can use `to_entries` and `from_entries` to map between key/value pairs and JSON objects and use a `select()` expression between to match the host needed\r\n\r\n    jq &#39;.[][] | to_entries | map(select(.key==&quot;host001&quot;)) | from_entries&#39;\r\n\r\nTo make it dynamic, pass the name as a separate arg,\r\n\r\n    jq --arg host &quot;host001&quot; &#39;.[][] | to_entries | map(select(.key==$host)) | from_entries&#39;\r\n",
                "title": "Filtering JSON by object name using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1554788009,
        "creation_date": 1554770202,
        "last_edit_date": 1554788009,
        "question_id": 55583568,
        "body_markdown": "I&#39;m unable to filter by keys using jq.\r\n\r\n    # /home/test/show_param_db.sh -p memory -h host00* -f json | jq &#39;.[]&#39;\r\n\r\n    &gt; [   {\r\n    &gt;     &quot;host001&quot;: {\r\n    &gt;       &quot;status&quot;: &quot;OK&quot;,\r\n    &gt;       &quot;msg&quot;: &quot;&quot;,\r\n    &gt;       &quot;data&quot;: [\r\n    &gt;         {\r\n    &gt;           &quot;hi_shared_memory_address&quot;: &quot;0&quot;\r\n    &gt;         },\r\n    &gt;         {\r\n    &gt;           &quot;memory_max_target&quot;: &quot;1G&quot;\r\n    &gt;         },\r\n    &gt;         {\r\n    &gt;           &quot;memory_target&quot;: &quot;1G&quot;\r\n    &gt;         },\r\n    &gt;         {\r\n    &gt;           &quot;shared_memory_address&quot;: &quot;0&quot;\r\n    &gt;         }\r\n    &gt;       ]\r\n    &gt;     },\r\n    &gt;     &quot;host002&quot;: {\r\n    &gt;       &quot;status&quot;: &quot;ERROR&quot;,\r\n    &gt;       &quot;msg&quot;: &quot;su: user oracle does not exist&quot;,\r\n    &gt;       &quot;data&quot;: []\r\n    &gt;     }   } ]\r\n\r\n\r\nWhen I tried to filter by keys:\r\n\r\n    # /home/test/show_param_db.sh -p memory -h host00* -f json | jq -r &#39;.[&quot;host001&quot;]&#39;\r\n\r\n==&gt; null\r\n\r\nOr even list out the keys:\r\n\r\n    # /home/test/show_param_db.sh -p memory -h host00* -f json | jq -r &#39;.[]&#39; |  jq -r &#39;keys&#39;\r\n\r\n[\r\n  0\r\n]\r\n\r\n\r\nI&#39;m hoping to get json by hostname. Thanks for all suggestions.\r\n",
        "link": "https://stackoverflow.com/questions/55583568/filtering-json-by-object-name-using-jq",
        "title": "Filtering JSON by object name using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1554797648,
                "post_id": 55587279,
                "comment_id": 97873104,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554798897,
                "creation_date": 1554798897,
                "answer_id": 55588403,
                "question_id": 55587279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You probably want the following or a variation thereof :\r\n\r\n    jq --slurp &#39;group_by(.TZ) | map({TZ:.[0].TZ, values:map({TN, TNN})})&#39;\r\n\r\nYou can [try it here](https://jqplay.org/s/JKxcjOk9Wc)",
                "title": "Output based on a specific key (group_by)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1554798897,
        "creation_date": 1554794906,
        "last_edit_date": 1554798025,
        "question_id": 55587279,
        "body_markdown": "I have the following JSON output. I would like the output to be grouped by the common TZ. \r\n\r\nInput: \r\n\r\n    {\r\n      &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8056-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2331&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8051-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2332&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8054-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2437&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8052-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2438&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8050-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2439&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8053-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2440&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8056-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2331&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8051-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2332&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8054-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2437&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8052-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2438&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8050-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2439&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8053-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2440&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1814&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8059-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1815&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8058-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1816&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8057-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1817&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1818&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;577d18d8-519e-11e9-a1e8-005056962661&quot;,\r\n      &quot;TNN&quot;: &quot;edg1&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;60971284-519e-11e9-9f28-00505696744e&quot;,\r\n      &quot;TNN&quot;: &quot;edg2&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;67f2aaa2-519e-11e9-a7ff-00505696f042&quot;,\r\n      &quot;TNN&quot;: &quot;edg3&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;711dc120-519e-11e9-ba09-005056965018&quot;,\r\n      &quot;TNN&quot;: &quot;edg4&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;7acbdc7a-519e-11e9-99c3-005056965c74&quot;,\r\n      &quot;TNN&quot;: &quot;edg5&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;82830f7e-519e-11e9-b1a5-00505696749d&quot;,\r\n      &quot;TNN&quot;: &quot;edg6&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;8ac12ffe-519e-11e9-8bf9-00505696d434&quot;,\r\n      &quot;TNN&quot;: &quot;edg7&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n      &quot;TN&quot;: &quot;943a9d40-519e-11e9-a918-00505696771c&quot;,\r\n      &quot;TNN&quot;: &quot;edg8&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1814&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8059-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1815&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8058-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1816&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8057-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1817&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1818&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;577d18d8-519e-11e9-a1e8-005056962661&quot;,\r\n      &quot;TNN&quot;: &quot;edg1&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;60971284-519e-11e9-9f28-00505696744e&quot;,\r\n      &quot;TNN&quot;: &quot;edg2&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;67f2aaa2-519e-11e9-a7ff-00505696f042&quot;,\r\n      &quot;TNN&quot;: &quot;edg3&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;711dc120-519e-11e9-ba09-005056965018&quot;,\r\n      &quot;TNN&quot;: &quot;edg4&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;7acbdc7a-519e-11e9-99c3-005056965c74&quot;,\r\n      &quot;TNN&quot;: &quot;edg5&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;82830f7e-519e-11e9-b1a5-00505696749d&quot;,\r\n      &quot;TNN&quot;: &quot;edg6&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;8ac12ffe-519e-11e9-8bf9-00505696d434&quot;,\r\n      &quot;TNN&quot;: &quot;edg7&quot;\r\n    }\r\n    {\r\n      &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n      &quot;TN&quot;: &quot;943a9d40-519e-11e9-a918-00505696771c&quot;,\r\n      &quot;TNN&quot;: &quot;edg8&quot;\r\n    }\r\n\r\n\r\nExpected Output: \r\n\r\n    [\r\n    &quot;TZ&quot;: &quot;5f105439-a0a7-4134-9e98-87553d434b35&quot;\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8056-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2331&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8051-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2332&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8054-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2437&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8052-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2438&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8050-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2439&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8053-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2440&quot;\r\n    }\r\n    ]\r\n    \r\n    [\r\n    &quot;TZ&quot;: &quot;8dc3bff5-09b2-4518-81e8-39a8136f885f&quot;,\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8056-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2331&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8051-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2332&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8054-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2437&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5110-8052-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2438&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0030-5210-8050-b3c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2439&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-0046-3310-8053-b2c04f433432&quot;,\r\n      &quot;TNN&quot;: &quot;a2440&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1814&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8059-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1815&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8058-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1816&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8057-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1817&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1818&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;577d18d8-519e-11e9-a1e8-005056962661&quot;,\r\n      &quot;TNN&quot;: &quot;edg1&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;60971284-519e-11e9-9f28-00505696744e&quot;,\r\n      &quot;TNN&quot;: &quot;edg2&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;67f2aaa2-519e-11e9-a7ff-00505696f042&quot;,\r\n      &quot;TNN&quot;: &quot;edg3&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;711dc120-519e-11e9-ba09-005056965018&quot;,\r\n      &quot;TNN&quot;: &quot;edg4&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;7acbdc7a-519e-11e9-99c3-005056965c74&quot;,\r\n      &quot;TNN&quot;: &quot;edg5&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;82830f7e-519e-11e9-b1a5-00505696749d&quot;,\r\n      &quot;TNN&quot;: &quot;edg6&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;8ac12ffe-519e-11e9-8bf9-00505696d434&quot;,\r\n      &quot;TNN&quot;: &quot;edg7&quot;\r\n    }\r\n    {\r\n      &quot;TN&quot;: &quot;943a9d40-519e-11e9-a918-00505696771c&quot;,\r\n      &quot;TNN&quot;: &quot;edg8&quot;\r\n    }\r\n    ]\r\n    \r\n    &quot;TZ&quot;: &quot;e1c4ad26-2b2b-41cf-b7be-155704018580&quot;,\r\n    {\r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1814&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8059-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1815&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8058-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1816&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3810-8057-b9c04f4c4e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1817&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;4c4c4544-004a-3710-8050-b9c04f394e32&quot;,\r\n      &quot;TNN&quot;: &quot;d1818&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;577d18d8-519e-11e9-a1e8-005056962661&quot;,\r\n      &quot;TNN&quot;: &quot;edg1&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;60971284-519e-11e9-9f28-00505696744e&quot;,\r\n      &quot;TNN&quot;: &quot;edg2&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;67f2aaa2-519e-11e9-a7ff-00505696f042&quot;,\r\n      &quot;TNN&quot;: &quot;edg3&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;711dc120-519e-11e9-ba09-005056965018&quot;,\r\n      &quot;TNN&quot;: &quot;edg4&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;7acbdc7a-519e-11e9-99c3-005056965c74&quot;,\r\n      &quot;TNN&quot;: &quot;edg5&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;82830f7e-519e-11e9-b1a5-00505696749d&quot;,\r\n      &quot;TNN&quot;: &quot;edg6&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;8ac12ffe-519e-11e9-8bf9-00505696d434&quot;,\r\n      &quot;TNN&quot;: &quot;edg7&quot;\r\n    }\r\n    {\r\n       \r\n      &quot;TN&quot;: &quot;943a9d40-519e-11e9-a918-00505696771c&quot;,\r\n      &quot;TNN&quot;: &quot;edg8&quot;\r\n    }\r\n\r\nI could not find a way to make this work with group_by and map functions. Any help will be much appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/55587279/output-based-on-a-specific-key-group-by",
        "title": "Output based on a specific key (group_by)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3415784,
                    "reputation": 62375,
                    "user_id": 2864740,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/98e74e03b5b1cd2dad5f5dc5c245bb0f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2864740",
                    "link": "https://stackoverflow.com/users/2864740/user2864740"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554831621,
                "post_id": 55598354,
                "comment_id": 97893173,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1821511,
                    "reputation": 7482,
                    "user_id": 1655478,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/5424ecc7236cd16441fafd0d584eb7c5?s=256&d=identicon&r=PG",
                    "display_name": "dessalines",
                    "link": "https://stackoverflow.com/users/1655478/dessalines"
                },
                "reply_to_user": {
                    "account_id": 3415784,
                    "reputation": 62375,
                    "user_id": 2864740,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/98e74e03b5b1cd2dad5f5dc5c245bb0f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2864740",
                    "link": "https://stackoverflow.com/users/2864740/user2864740"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1554831665,
                "post_id": 55598354,
                "comment_id": 97893181,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1821511,
                    "reputation": 7482,
                    "user_id": 1655478,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/5424ecc7236cd16441fafd0d584eb7c5?s=256&d=identicon&r=PG",
                    "display_name": "dessalines",
                    "link": "https://stackoverflow.com/users/1655478/dessalines"
                },
                "reply_to_user": {
                    "account_id": 3415784,
                    "reputation": 62375,
                    "user_id": 2864740,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/98e74e03b5b1cd2dad5f5dc5c245bb0f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2864740",
                    "link": "https://stackoverflow.com/users/2864740/user2864740"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1554832105,
                "post_id": 55598354,
                "comment_id": 97893400,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1554874388,
                "last_edit_date": 1554874388,
                "creation_date": 1554839354,
                "answer_id": 55600294,
                "question_id": 55598354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "something like following will work **for your sample input**.\r\n```jq\r\nforeach inputs as $pv ([[],[]]; # [A, B]\r\n  if ($pv|length) == 2          # if pv is a path-value pair\r\n  then .[0] |= if . == []       # if A is empty\r\n    then . + [$pv[0][0],$pv[1]] # add first key from path definition and the value located at path to A\r\n    else . + [$pv[1]] end       # add value to A\r\n  else [[],.[0]] end;           # move A to B&#39;s place, leave A empty\r\n  if .[0] == [] and .[1] != []  # if A is empty but B is not\r\n  then .[1] else empty end      # print B\r\n)\r\n```\r\ninvocation:\r\n```\r\njq --stream -n &#39;foreach inputs as $pv ([[],[]]; if ($pv|length) == 2 then (.[0] |= if . == [] then . + [$pv[0][0],$pv[1]] else . + [$pv[1]] end) else [[],.[0]] end; if .[0] == [] and .[1] != [] then .[1] else empty end)&#39; file\r\n```\r\njqplay: https://jqplay.org/s/Q81EZahkjG",
                "title": "Transformation working on small files fails when used with the &quot;--stream&quot; option (required due to file size)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1555045974,
                "last_edit_date": 1555045974,
                "creation_date": 1555041500,
                "answer_id": 55644293,
                "question_id": 55598354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need a way to get to_entries[] working with streaming \r\n\r\nHere&#39;s a def that does just that:\r\n\r\n    def atomize(s):\r\n        fromstream(foreach s as $in ( {previous:null, emit: null};\r\n          if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\r\n          then {emit: [[.previous]], previous: $in|.[0][0]}\r\n          else { previous: ($in|.[0][0]), emit: null}\r\n          end;\r\n          (.emit // empty), $in) ) ;\r\n\r\nWith this def, you can use your filter by prepending `atomize(inputs)` assuming you invoke jq with both the `-n` and `--stream` options.  That is, your main filter would be:\r\n\r\n    atomize(inputs)\r\n    | to_entries[]\r\n    | {hash: .key, val: .value[]}\r\n    | [.hash, .val.i, .val.p, .val.l]\r\n\r\n\r\n\r\n## Alternative\r\nIf the JSON is completely regular, as in the example, you could alternatively write:\r\n\r\n    atomize(inputs)\r\n    | to_entries[]\r\n    | .value[] as $value\r\n    | [.key, $value[]]\r\n\r\n",
                "title": "Transformation working on small files fails when used with the &quot;--stream&quot; option (required due to file size)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1555045974,
        "creation_date": 1554831508,
        "last_edit_date": 1554831743,
        "question_id": 55598354,
        "body_markdown": "JQ play snippet: https://jqplay.org/s/D5-FZl8wOs\r\n\r\nI&#39;m using jq to flatten a json array to be used for sql. \r\n\r\njson:\r\n```\r\n{\r\n&quot;0123&quot;:[\r\n    {&quot;i&quot;:0,&quot;p&quot;:&quot;file 1&quot;,&quot;l&quot;:100},\r\n    {&quot;i&quot;:1,&quot;p&quot;:&quot;file 2&quot;,&quot;l&quot;:200}\r\n    ],\r\n&quot;0234&quot;:[\r\n    {&quot;i&quot;:0,&quot;p&quot;:&quot;file 1&quot;,&quot;l&quot;:100},\r\n    {&quot;i&quot;:1,&quot;p&quot;:&quot;file 2&quot;,&quot;l&quot;:200}\r\n    ]\r\n}\r\n```\r\njq: \r\n```\r\njq -r to_entries[] | {hash: .key, val: .value[]} | [.hash, .val.i, .val.p, .val.l]\r\n```\r\n\r\nDesired output:\r\n```\r\n[\r\n  &quot;0123&quot;,\r\n  0,\r\n  &quot;file 1&quot;,\r\n  100\r\n]\r\n[\r\n  &quot;0123&quot;,\r\n  1,\r\n  &quot;file 2&quot;,\r\n  200\r\n]\r\n[\r\n  &quot;0234&quot;,\r\n  0,\r\n  &quot;file 1&quot;,\r\n  100\r\n]\r\n[\r\n  &quot;0234&quot;,\r\n  1,\r\n  &quot;file 2&quot;,\r\n  200\r\n]\r\n```\r\n\r\nThe above worked only while the file was small, but now I get memory errors / OS killing it as its grown larger.\r\n\r\nIf I pass the --stream parameter, I get the error:\r\n\r\n`jq: error (at &lt;stdin&gt;:9): Cannot index array with string &quot;i&quot;`\r\n\r\nHow can I solve this?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55598354/transformation-working-on-small-files-fails-when-used-with-the-stream-option",
        "title": "Transformation working on small files fails when used with the &quot;--stream&quot; option (required due to file size)"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq",
            "data-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554839595,
                "post_id": 55599748,
                "comment_id": 97896706,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554839627,
                "post_id": 55599748,
                "comment_id": 97896720,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554839655,
                "post_id": 55599748,
                "comment_id": 97896732,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554839720,
                "post_id": 55599748,
                "comment_id": 97896757,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554837597,
                "creation_date": 1554837597,
                "answer_id": 55599842,
                "question_id": 55599748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you *sure* you want that? What&#39;s your end goal? You can merge all of the inputs into a single array using `jq -n &#39;[inputs]&#39;` (the `-n` avoids the usual reading of stdin into `.`, allowing it all to appear on `inputs`), but that means that it can&#39;t produce any output, or do any further processing, until the entire input has been read, which may or may not be what you want.",
                "title": "How can I process oneline json files using `jq`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1554837597,
        "creation_date": 1554837212,
        "question_id": 55599748,
        "body_markdown": "I have a onelined json file that looks similar to this\r\n\r\n```\r\n{&quot;fieldA&quot;:1, &quot;fieldB&quot;:&quot;foo&quot;}\r\n{&quot;fieldA&quot;:2, &quot;fieldB&quot;:&quot;bar&quot;}\r\n{&quot;fieldA&quot;:4, &quot;fieldB&quot;:&quot;foobar&quot;}\r\n...\r\n```\r\n\r\nHow can I properly read this file using `jq`?\r\n\r\nI tried doing:\r\n\r\n```\r\ncat myFile.json | jq [.]\r\n```\r\n\r\nbut this returns something like:\r\n\r\n```\r\n[{\r\n  &quot;fieldA&quot;:1, \r\n  &quot;fieldB&quot;:&quot;foo&quot;\r\n}]\r\n[{\r\n  &quot;fieldA&quot;:2, \r\n  &quot;fieldB&quot;:&quot;bar&quot;\r\n}]\r\n[{\r\n  &quot;fieldA&quot;:4, \r\n  &quot;fieldB&quot;:&quot;foobar&quot;\r\n}]\r\n...\r\n```\r\n\r\nbut I would like to receive this instead:\r\n```\r\n[{\r\n  &quot;fieldA&quot;:1, \r\n  &quot;fieldB&quot;:&quot;foo&quot;\r\n},\r\n{\r\n  &quot;fieldA&quot;:2, \r\n  &quot;fieldB&quot;:&quot;bar&quot;\r\n},\r\n{\r\n  &quot;fieldA&quot;:4, \r\n  &quot;fieldB&quot;:&quot;foobar&quot;\r\n},\r\n...]\r\n```\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/55599748/how-can-i-process-oneline-json-files-using-jq",
        "title": "How can I process oneline json files using `jq`"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1555030425,
                "last_edit_date": 1555030425,
                "creation_date": 1554878258,
                "answer_id": 55606167,
                "question_id": 55606056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `jq`&#39;s `-c` or `--compact-output` option:\r\n\r\n    diff &lt;(jq -c .[] &lt;&lt;&lt;&quot;$bb_cfg&quot;) &lt;(jq -c .[] &lt;&lt;&lt;&quot;$cd_tool_cfg&quot;)\r\n    1c1\r\n    &lt; {&quot;key&quot;:&quot;IGNORE_VALIDATION_ERROR&quot;,&quot;value&quot;:&quot;true&quot;,&quot;tags&quot;:[]}\r\n    ---\r\n    &gt; {&quot;key&quot;:&quot;IGNORE_VALIDATION_ERROR&quot;,&quot;value&quot;:&quot;false&quot;,&quot;tags&quot;:[]}\r\n\r\nThe `-c` option will simply output a json with each array member on a separate line.\r\n\r\nThe following command will give you something like you requested:\r\n\r\n    diff --old-line-format=&quot;%L&quot; --unchanged-line-format=&quot;&quot; --new-line-format=&quot;%L&quot; &lt;(jq -c .[] &lt;&lt;&lt;&quot;$bb_cfg&quot;) &lt;(jq -c .[] &lt;&lt;&lt;&quot;$cd_tool_cfg&quot;) | jq\r\n\r\nwill output:\r\n\r\n    {\r\n        &quot;key&quot;: &quot;IGNORE_VALIDATION_ERROR&quot;,\r\n        &quot;value&quot;: &quot;true&quot;,\r\n        &quot;tags&quot;: []\r\n    }\r\n    {\r\n        &quot;key&quot;: &quot;IGNORE_VALIDATION_ERROR&quot;,\r\n        &quot;value&quot;: &quot;false&quot;,\r\n        &quot;tags&quot;: []\r\n    }",
                "title": "compare 2 json arrays and return the difference"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1555030425,
        "creation_date": 1554877814,
        "last_edit_date": 1554878337,
        "question_id": 55606056,
        "body_markdown": "We have a custom CD Pipeline Tool, which unfortunately does not version the deployment parameters. So I put these in a Bitbucket Repo as a json file and validate them against a REST API of this CD Tool.\r\n\r\nSo I have 2 json arrays, which are structurally the same, but may contain different objects or values in these objects. I want to compare them to see if they are different and what is different.\r\n\r\nSo far, I used the solution from here: \r\nhttps://stackoverflow.com/questions/31930041/using-jq-or-alternative-command-line-tools-to-diff-json-files\r\n\r\nSo I have put this in my code:\r\n\r\n    jq --argjson a &quot;${bb_cfg}&quot; --argjson b &quot;${cd_tool_cfg}&quot; -n &#39;def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); ($a | (post_recurse | arrays) |= sort) as $a | ($b | (post_recurse | arrays) |= sort) as $b | $a == $b&#39;\r\n\r\nnow I get a true if they are identical or false if 2 jsons have differences, but I do not know what is different.\r\n\r\n\r\n\r\nI tried to do this with this if I get false back:\r\n\r\n    diff --suppress-common-lines -y &lt;(jq . -S &lt;&lt;&lt; &quot;${bb_cfg}&quot;) &lt;(jq . -S &lt;&lt;&lt; &quot;${cd_tool_cfg}&quot;)\r\n\r\n\r\nInput $bb_cfg:\r\n\r\n    [{\r\n\t\t&quot;key&quot;: &quot;IGNORE_VALIDATION_ERROR&quot;,\r\n\t\t&quot;value&quot;: &quot;true&quot;,\r\n\t\t&quot;tags&quot;: []\r\n\t},\r\n\t{\r\n\t\t&quot;key&quot;: &quot;BB_CFG_REPO_NAME&quot;,\r\n\t\t&quot;value&quot;: &quot;cd-tool-cfg&quot;,\r\n\t\t&quot;tags&quot;: []\r\n\t}]\r\n\r\nInput $cd_tool_cfg\r\n\r\n    [{\r\n\t\t&quot;key&quot;: &quot;IGNORE_VALIDATION_ERROR&quot;,\r\n\t\t&quot;value&quot;: &quot;false&quot;,\r\n\t\t&quot;tags&quot;: []\r\n\t},\r\n\t{\r\n\t\t&quot;key&quot;: &quot;BB_CFG_REPO_NAME&quot;,\r\n\t\t&quot;value&quot;: &quot;cd-tool-cfg&quot;,\r\n\t\t&quot;tags&quot;: []\r\n\t}]\r\n\r\nwhich works partly, because if only the value is different, the output is like this:\r\n\r\n        &quot;value&quot;: &quot;true&quot;\t\t\t\t\t      |\t    &quot;value&quot;: &quot;false&quot;\r\n\r\nso I do not get the whole json object here to quickly find out what parameter is different.\r\n\r\nWhat I eventually want is to get something like this:\r\n\r\n    {\r\n\t\t&quot;key&quot;: &quot;IGNORE_VALIDATION_ERROR&quot;,\r\n\t\t&quot;value&quot;: &quot;true&quot;,\r\n\t\t&quot;tags&quot;: []\r\n\t}\r\n    {\r\n\t\t&quot;key&quot;: &quot;IGNORE_VALIDATION_ERROR&quot;,\r\n\t\t&quot;value&quot;: &quot;false&quot;,\r\n\t\t&quot;tags&quot;: []\r\n\t}\r\n\r\nwhere I can store this in a variable in my bash script and transform this in an output I can use.",
        "link": "https://stackoverflow.com/questions/55606056/compare-2-json-arrays-and-return-the-difference",
        "title": "compare 2 json arrays and return the difference"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1554912860,
                "post_id": 55616211,
                "comment_id": 97927476,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1554912265,
                "creation_date": 1554912265,
                "answer_id": 55616919,
                "question_id": 55616211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just use the `+= [..]` operator to add to the array with the elements needed.\r\n\r\n    jq &#39;.IntendedFor += [ &quot;scan1&quot;, &quot;scan2&quot; ]&#39; existing.json &gt; output.json\r\n",
                "title": "Add a new field containing a list of values to an existing JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554978191,
                "creation_date": 1554978191,
                "answer_id": 55630221,
                "question_id": 55616211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, thank you! Eventually this code worked:\r\n\r\n    cat existing.json | jq --argjson args &#39;[&quot;scan1&quot;,&quot;scan2&quot;]&#39; &#39;.{&quot;IntededFor&quot;] += $args&#39; &gt; output.json",
                "title": "Add a new field containing a list of values to an existing JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1554978191,
        "creation_date": 1554909828,
        "last_edit_date": 1554915005,
        "question_id": 55616211,
        "body_markdown": "I would like to add a variable `IntendedFor` with values `scan1` and `scan2` to an existing JSON file.\r\n\r\nI would like to do this with `jq` function, I tried:\r\n\r\n    cat existing.json | jq &#39;.IntendedFor |= &quot;[&quot;scan1&quot;, &quot;scan2&quot;]&quot;&#39; &gt; output.json\r\n\r\nbut I get the error and and empty JSON file.\r\n\r\n\r\n\r\n\r\nThis is what i want the output.json file to look like:\r\n\r\n    {  &quot;existingjsonstuff&quot;: &quot;andsoon&quot;,  \r\n       &quot;IntendedFor&quot;: [&quot;scan1&quot;, &quot;scan2&quot;] \r\n    }\r\n\r\n\r\nHow do i get this??\r\n",
        "link": "https://stackoverflow.com/questions/55616211/add-a-new-field-containing-a-list-of-values-to-an-existing-json-using-jq",
        "title": "Add a new field containing a list of values to an existing JSON using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line",
            "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": 1554939887,
                "post_id": 55622553,
                "comment_id": 97938430,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554939163,
                "creation_date": 1554939163,
                "answer_id": 55622675,
                "question_id": 55622553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This &quot;hack&quot; is what did it for me so far. I am curious if there is anything better.\r\n\r\n```\r\njq -s &#39;. as $input | $input[0] | to_entries | map(select(.key | in($input[1]) | not)) | from_entries&#39; temp1.json temp2.json\r\n```",
                "title": "Filter json object if keys exists in another object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1554962221,
                "last_edit_date": 1554962221,
                "creation_date": 1554961160,
                "answer_id": 55625421,
                "question_id": 55622553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward approach using `reduce`:\r\n\r\n    jq -n --argfile one file1.json --argfile two file2.json &#39;\r\n     reduce ($two|keys_unsorted)[] as $k ($one; delpaths([[$k]]))&#39;\r\n\r\nAnd here is a more efficient filter that still uses `delpaths`:\r\n\r\n    $one | delpaths($two|keys_unsorted|map([.]))",
                "title": "Filter json object if keys exists in another object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1555095409,
                "last_edit_date": 1555095409,
                "creation_date": 1555017610,
                "answer_id": 55641353,
                "question_id": 55622553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic function for performing object subtraction:\r\n\r\n    # remove from $x all the keys that occur in $y\r\n    def minus($x; $y):\r\n      ((($x + $y)|to_entries) - ($y|to_entries))\r\n      | from_entries;\r\n\r\nThis can be used to solve the problem in a variety of ways, e.g. with the invocation:\r\n\r\n    jq -n -f program.jq file1.json file2.json\r\n\r\nwhere program.jq contains the above def followed by:\r\n\r\n    minus(input; input)\r\n",
                "title": "Filter json object if keys exists in another object"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1555095409,
        "creation_date": 1554938123,
        "question_id": 55622553,
        "body_markdown": "I have two files\r\n\r\nfile1.json\r\n```\r\n{\r\n  &quot;a&quot;: &quot;x1&quot;,\r\n  &quot;b&quot;: &quot;y1&quot;,\r\n  &quot;c&quot;: &quot;z1&quot;\r\n}\r\n```\r\n\r\nfile2.json\r\n```\r\n{\r\n  &quot;a&quot;: &quot;x2&quot;,\r\n  &quot;b&quot;: &quot;y2&quot;\r\n}\r\n```\r\n\r\nSince a &amp; b already exists in file2, I want to output a new object that contains only c. The values don&#39;t really matter.\r\n```\r\n{\r\n  &quot;c&quot;: &quot;z1&quot;\r\n}\r\n```\r\n\r\n\r\nI tried\r\n```\r\njq -s &#39;.[0] | to_entries | map(select(.key | in(.[1]) | not)) | from_entries&#39; temp1.json temp2.json\r\n```\r\n\r\nBut I am getting the following error:\r\n```\r\njq: error (at temp2.json:4): Cannot index string with number\r\n```\r\n\r\nThe funny thing, when I try:\r\n```\r\njq -s &#39;.[0] | to_entries | map(select(.key | in({&quot;a&quot;: &quot;x2&quot;, &quot;b&quot;: &quot;y2&quot;}) | not)) | from_entries&#39; file1.json file2.json\r\n```\r\n\r\nI get the right output. So it just seems like jq is treating .[1] as an int? and not as a json object.",
        "link": "https://stackoverflow.com/questions/55622553/filter-json-object-if-keys-exists-in-another-object",
        "title": "Filter json object if keys exists in another object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554994615,
                "post_id": 55635532,
                "comment_id": 97962314,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2460388,
                    "reputation": 3,
                    "user_id": 2144692,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6231a55d02ddcb868e6224850e521c02?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2144692",
                    "link": "https://stackoverflow.com/users/2144692/user2144692"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1554994718,
                "post_id": 55635532,
                "comment_id": 97962382,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1554995607,
                "last_edit_date": 1554995607,
                "creation_date": 1554995177,
                "answer_id": 55635740,
                "question_id": 55635532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "use `select` with `contains`:\r\n```\r\njq &#39;.a.b|=[.[]|select(.x|contains(&quot;z&quot;)|not)]&#39; file\r\n```",
                "title": "How to filter some array in a sub-object with object in a json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1555706197,
        "creation_date": 1554994527,
        "last_edit_date": 1555000908,
        "question_id": 55635532,
        "body_markdown": "I need to filter a JSON with a nested strucutre like below.\r\nAll objects in array b where attribute x contains a &quot;z&quot; in the value of x should be filtered out. The rest should stay in the file. \r\n\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;b&quot;: [\r\n                {\r\n                    &quot;c&quot;: &quot;1&quot;,\r\n                    &quot;x&quot;: &quot;aaa&quot;,\r\n                },\r\n                {\r\n                    &quot;c&quot;: &quot;2&quot;,\r\n                    &quot;x&quot;: &quot;aza&quot;,\r\n                },\r\n                {\r\n                    &quot;c&quot;: &quot;7&quot;,\r\n                    &quot;x&quot;: &quot;azb&quot;,\r\n                }\r\n            ]\r\n        },\r\n        &quot;d&quot;: {\r\n            &quot;e&quot;: [\r\n                &quot;1&quot;\r\n            ],\r\n            &quot;f&quot;: [\r\n                &quot;2&quot;\r\n            ]\r\n        }\r\n    }\r\nExpected output:\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;1&quot;,\r\n        &quot;x&quot;: &quot;aaa&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;d&quot;: {\r\n    &quot;e&quot;: [\r\n      &quot;1&quot;\r\n    ],\r\n    &quot;f&quot;: [\r\n      &quot;2&quot;\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55635532/how-to-filter-some-array-in-a-sub-object-with-object-in-a-json-file-with-jq",
        "title": "How to filter some array in a sub-object with object in a json file with jq"
    },
    {
        "tags": [
            "select",
            "jq",
            "containment"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9352879,
                    "reputation": 81,
                    "user_id": 6941958,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/76496fbf9edbb6228522e230047f5e79?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mr Janitor",
                    "link": "https://stackoverflow.com/users/6941958/mr-janitor"
                },
                "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": 1555122717,
                "post_id": 55661161,
                "comment_id": 98010958,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1555123112,
                "last_edit_date": 1555123112,
                "creation_date": 1555119626,
                "answer_id": 55661284,
                "question_id": 55661161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter:\r\n\r\n    .[]\r\n    | select(.input[] | .[&quot;$link&quot;] | contains(&quot;randomtext1&quot;)) \r\n    | .id\r\n\r\nproduces:\r\n\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n\r\n\r\nNote, however, that `contains` has very complex semantics, so it would probably be better to use `index` instead. ",
                "title": "jq select and contains error: null (null) and string (&quot;randomtext1&quot;) cannot have their containment checked"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1627343738,
        "creation_date": 1555117999,
        "last_edit_date": 1627343738,
        "question_id": 55661161,
        "body_markdown": "command: \r\n\r\n    cat test.json | jq -r &#39;.[] | select(.[&quot;$link&quot;] | contains(&quot;randomtext1&quot;)).id&#39;\r\n\r\nI was expecting to have both ids (a and b) show up as result of the above command since they both contains `&quot;randomtext1&quot;` text under \r\n\r\n    &quot;input&quot;|&quot;obj1&quot;|&quot;$link&quot; and &quot;input&quot;|&quot;obj3&quot;|&quot;$link&quot;. \r\n\r\n```none\r\njq: error (at &lt;stdin&gt;:11): null (null) and string (&quot;randomtext1&quot;) cannot have their containment checked\r\nparse error: Expected value before &#39;,&#39; at line 11, column 2\r\n```\r\n\r\nI see that the `&quot;$link&quot;` object is within the `&quot;input&quot;` and `&quot;obj#&quot;` objects. How do I specify them or do I need to? The error message seems to be pointing to something else. Also only the `&quot;input&quot;` and `&quot;$link&quot;` are constant among the records, the name of the `&quot;obj#&quot;` can change which makes them random.\r\n\r\nThe test.json file:\r\n```\r\n[{\r\n      &quot;input&quot;: {\r\n            &quot;obj1&quot;: {\r\n                &quot;$link&quot;: &quot;randomtext1&quot;\r\n            }, \r\n            &quot;obj2&quot;: {\r\n                &quot;$link&quot;: &quot;randomtext2&quot;\r\n            }\r\n      },\r\n      &quot;id&quot;: &quot;a&quot;\r\n},\r\n{\r\n      &quot;input&quot;: {\r\n            &quot;obj3&quot;: {\r\n                &quot;$link&quot;: &quot;randomtext1&quot;\r\n            }, \r\n            &quot;obj4&quot;: {\r\n                &quot;$link&quot;: &quot;randomtext3&quot;\r\n            }\r\n      },\r\n      &quot;id&quot;: &quot;b&quot;\r\n}]\r\n```",
        "link": "https://stackoverflow.com/questions/55661161/jq-select-and-contains-error-null-null-and-string-randomtext1-cannot-have",
        "title": "jq select and contains error: null (null) and string (&quot;randomtext1&quot;) cannot have their containment checked"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1555185126,
                "last_edit_date": 1555185126,
                "creation_date": 1555145431,
                "answer_id": 55663673,
                "question_id": 55662024,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What I really want is to be able to search for any entries that have at least one &quot;$link&quot;: &quot;randomtext1&quot; pair under input.\r\n\r\nThe key word here, both in the question and the following answer, is `any`:\r\n\r\n    .[]\r\n    | select( any(.input[];\r\n                  type==&quot;object&quot; and has(&quot;$link&quot;) and (.[&quot;$link&quot;] | index(&quot;randomtext1&quot;))))\r\n    | .id\r\n\r\nOf course if you require the key&#39;s value to be &quot;randomtext1&quot;, you&#39;d write `.[&quot;$link&quot;] == &quot;randomtext1&quot;`.",
                "title": "jq select error: &quot;Cannot index string with string &lt;object&gt;&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1555185126,
        "creation_date": 1555129834,
        "last_edit_date": 1555142473,
        "question_id": 55662024,
        "body_markdown": "command:\r\n```\r\ncat test.json | jq -r &#39;.[] | select(.input[] | .[&quot;$link&quot;] | contains(&quot;randomtext1&quot;)) | .id&#39;\r\n```\r\n\r\nI was expecting to have both entries (`a` and `b`) to show up since they both contains `randomtext1`\r\n\r\nInstead, I got the following output message:\r\n```\r\na\r\n\r\njq: error (at &lt;stdin&gt;:22): Cannot index string with string &quot;$link&quot;\r\n```\r\nFrom some digging I understand that the issue is likely caused by the following object/value pair in the `a` entry:\r\n\r\n    &quot;someotherobj&quot;: &quot;123&quot;\r\n\r\nbecause it does not contain the object `$link` and the filter in the command expects to see `$link` in all objects under the `input` so it errors out before the command has a chance to search in the `b` entry.\r\n\r\nWhat I really want is to be able to search for any entries that have at least one `&quot;$link&quot;: &quot;randomtext1&quot;` pair under `input`. Is there a fuzzier search feature allowing me to achieve this?\r\n\r\nI tried to use two `contains` hoping it will just pipe things through:\r\n\r\n```\r\njq -r &#39;.[] | select(.input[] | contains([&quot;$link&quot;]) | contains(&quot;randomtext1&quot;)) | .id&#39;\r\n```\r\nbut it did not like that at all..\r\n\r\n\r\nthe test.json file:\r\n```\r\n[\r\n  {\r\n    &quot;input&quot;: {\r\n      &quot;obj1&quot;: {\r\n        &quot;$link&quot;: &quot;randomtext1&quot;\r\n      },\r\n      &quot;obj2&quot;: {\r\n        &quot;$link&quot;: &quot;randomtext2&quot;\r\n      },\r\n      &quot;someotherobj&quot;: &quot;123&quot;\r\n    },\r\n    &quot;id&quot;: &quot;a&quot;\r\n  },\r\n  {\r\n    &quot;input&quot;: {\r\n      &quot;obj3&quot;: {\r\n        &quot;$link&quot;: &quot;randomtext1&quot;\r\n      },\r\n      &quot;obj4&quot;: {\r\n        &quot;$link&quot;: &quot;randomtext2&quot;\r\n      }\r\n    },\r\n    &quot;id&quot;: &quot;b&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/55662024/jq-select-error-cannot-index-string-with-string-object",
        "title": "jq select error: &quot;Cannot index string with string &lt;object&gt;&quot;"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6644804,
                    "reputation": 7687,
                    "user_id": 5411198,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/c79f8d61facfb530de7f9f3822f4ff44?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "builder-7000",
                    "link": "https://stackoverflow.com/users/5411198/builder-7000"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1555210444,
                "post_id": 55671522,
                "comment_id": 98029305,
                "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": 1555212203,
                "post_id": 55671522,
                "comment_id": 98029466,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1555211027,
                "creation_date": 1555211027,
                "answer_id": 55671624,
                "question_id": 55671522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Evidently in the JSON file, the year is a string, so you should use `--arg y $YEAR` or `--arg y &quot;$YEAR&quot;`.  \r\n\r\nWith the shell variable YEAR set to a value such as 2000, the effect of `--argjson y &quot;$YEAR&quot;` is to set the jq variable $y to an integer:\r\n\r\n    $ jq -n --argjson y &quot;2000&quot; &#39;$y|type&#39;\r\n    &quot;number&quot;",
                "title": "Why is using $s in jq --argjson s &quot;2000&quot; different from using &quot;2000&quot; in the JQ code?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1555212066,
        "creation_date": 1555209459,
        "last_edit_date": 1555212066,
        "question_id": 55671522,
        "body_markdown": "I am trying to write a bash script which parses from the nobel prize JSON file. The first argument is the year, and the second is the category.\r\n\r\n```\r\nset -- 2000 physics  # set $1 to 2000 and $2 to physics\r\njq -cr --argjson y &quot;$1&quot; --arg c &quot;$2&quot; \\\r\n  &#39;.prizes[] | select(.category == $c)| select(.year == $y )&#39; &lt;&lt;&#39;EOF&#39;\r\n{&quot;prizes&quot;: [\r\n  {&quot;category&quot;: &quot;math&quot;, &quot;year&quot;: &quot;1999&quot;},\r\n  {&quot;category&quot;: &quot;physics&quot;, &quot;year&quot;: &quot;2000&quot;}]}\r\nEOF\r\n```\r\n\r\n...has no output, whereas it should output a single line with \r\n\r\n```\r\n{&quot;category&quot;:&quot;physics&quot;,&quot;year&quot;:&quot;2000&quot;}\r\n```\r\n\r\n---\r\n\r\n\r\nHowever, with only the category coming from a variable, it works:\r\n\r\n```\r\nset -- physics  # set $1 to physics\r\njq -cr --arg c &quot;$1&quot; \\\r\n  &#39;.prizes[] | select(.category == $c)| select(.year == &quot;2000&quot; )&#39; &lt;&lt;&#39;EOF&#39;\r\n{&quot;prizes&quot;: [\r\n  {&quot;category&quot;: &quot;math&quot;, &quot;year&quot;: &quot;1999&quot;},\r\n  {&quot;category&quot;: &quot;physics&quot;, &quot;year&quot;: &quot;2000&quot;}]}\r\nEOF\r\n```\r\n\r\n...correctly emits the line given above.\r\n\r\nThus, only the numeric year has trouble being passed -- whatever the problem is, it doesn&#39;t apply to the category.",
        "link": "https://stackoverflow.com/questions/55671522/why-is-using-s-in-jq-argjson-s-2000-different-from-using-2000-in-the-jq-c",
        "title": "Why is using $s in jq --argjson s &quot;2000&quot; different from using &quot;2000&quot; in the JQ code?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1659457252,
                "last_edit_date": 1659457252,
                "creation_date": 1555342569,
                "answer_id": 55692689,
                "question_id": 55689032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `tostring` is not going to help, because `tostring` only gets to see the number **after** the jq parser has read the input.\r\n\r\nThe jq maintainers are well-aware of this issue and indeed there is a &quot;pull request&quot; which addresses it:\r\nhttps://github.com/stedolan/jq/pull/1752\r\n\r\nIf you wish to use an officially released version of jq, then the only available &quot;workaround&quot; will be to change the number in the JSON source to a string.  You might wish to use the &quot;bigint&quot; library for handling &quot;bigint&quot; strings - https://github.com/joelpurra/jq-bigint\r\n\r\n# UPDATES\r\n\r\nAs of Oct 22, 2019, the version of jq at &quot;master&quot; preserves the precision of numbers that are read, and `tostring` can be used on such numbers without loss of precision, e.g.\r\n```\r\n$ jq tostring\r\n123456789123456789123456789123456789123456789123456789\r\n&quot;123456789123456789123456789123456789123456789123456789&quot;\r\n````\r\n\r\nYou might alternatively wish to use gojq, the Go implementation of jq.",
                "title": "JQ: Bigint Numbers precision"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659457252,
        "creation_date": 1555330603,
        "last_edit_date": 1555334985,
        "question_id": 55689032,
        "body_markdown": "I have actually a situation were i run into the BIGINT Problem and the haziness with that in jq 1.5/1.6 (in a Windows enviroment).\r\nI read the issue reports and thought that if i transform the number to a string, i can handle that. But i test it with a specific command and the result is the same\r\n\r\n```\r\n[. | { last_update: .starbase_detailed_scan.last_update_time, user_name: .starbase_detailed_scan.owner_name, alliance_id: .starbase_detailed_scan.owner_alliance_id | tostring, drydocks: .starbase_detailed_scan.num_drydocks, tier: .starbase_detailed_scan.owner_level, defence_plattform: .starbase_detailed_scan.num_defence_platforms, shield_triggered: .starbase_detailed_scan.player_shield.triggered_on, shield_end: .starbase_detailed_scan.player_shield.expiry_time, parsteel: .starbase_detailed_scan.resources[&quot;2325683920&quot;], tritanium: .starbase_detailed_scan.resources[&quot;743985951&quot;], dilithium: .starbase_detailed_scan.resources[&quot;2614028847&quot;], user_id: .starbase_detailed_scan.owner_user_id, defence_rating: .starbase_detailed_scan.defense_rating }]\r\n```\r\n\r\nresult:\r\n```\r\n[{&quot;last_update&quot;:&quot;2018-12-23T19:26:24&quot;,&quot;user_name&quot;:&quot;Hamita40&quot;,&quot;alliance_id&quot;:&quot;774615702811599900&quot;,&quot;drydocks&quot;:3,&quot;tier&quot;:19,&quot;defence_plattform&quot;:3,&quot;shield_triggered&quot;:&quot;0001-01-01T00:00:00&quot;,&quot;shield_end&quot;:&quot;0001-01-01T00:00:00&quot;,&quot;parsteel&quot;:183649,&quot;tritanium&quot;:22459,&quot;dilithium&quot;:7074,&quot;user_id&quot;:&quot;a2588903decc455283c88508f6a7fedf&quot;,&quot;defence_rating&quot;:25200}]\r\n```\r\nThe `Alliance_id` is not correct. The correct id is:\r\n```\r\n774615702811599864\r\n```\r\n\r\nIs there any Workaround?\r\n\r\nBR\r\nTimo",
        "link": "https://stackoverflow.com/questions/55689032/jq-bigint-numbers-precision",
        "title": "JQ: Bigint Numbers precision"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1555353620,
                "post_id": 55695364,
                "comment_id": 98073247,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15669359,
                    "reputation": 59,
                    "user_id": 11306324,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9ab6ae8d8587192ca463aef37df55e66?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mohamed afrid",
                    "link": "https://stackoverflow.com/users/11306324/mohamed-afrid"
                },
                "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": 1555353717,
                "post_id": 55695364,
                "comment_id": 98073285,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555353814,
                "post_id": 55695364,
                "comment_id": 98073342,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555358364,
                "post_id": 55695364,
                "comment_id": 98075204,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1653419163,
                "last_edit_date": 1653419163,
                "creation_date": 1555353661,
                "answer_id": 55695432,
                "question_id": 55695364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq].\r\n```\r\n$ jq -Rc &#39;. / &quot; &quot;&#39; &lt;&lt;&lt; ${hosts[*]}\r\n[&quot;afrid.google.com&quot;,&quot;farid.google.com&quot;]\r\n```",
                "title": "Bash array to JSON array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1555354761,
                "creation_date": 1555354761,
                "answer_id": 55695694,
                "question_id": 55695364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A non jq answer, basically feeding the array through printf command with our formatting included (e.g. quotes and comma, then removing the the last chars from the string in the next command) :\r\n\r\n\r\n    hosts_str=$( printf &#39;&quot;%s&quot;, &#39; &quot;${hosts[@]}&quot; )\r\n    hosts_str=&quot;[ ${hosts_str: : -2} ]&quot;\r\n    echo $hosts_str",
                "title": "Bash array to JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1666449772,
        "creation_date": 1555353414,
        "last_edit_date": 1666449772,
        "question_id": 55695364,
        "body_markdown": "I want to print all the string in the array delimited with comma\r\n\r\n    #! /bin/bash\r\n    clear\r\n    echo -e &quot;Enter the list of hosts to print statement:\\n&quot;\r\n    readarray hosts\r\n    \r\n    echo &quot;=======================================================&quot;\r\n    echo -e &quot;Enter the list to print&quot;\r\n    echo &quot;=======================================================&quot;\r\n    \r\n    for i in ${hosts[@]}\r\n    do\r\n     id=&quot;${i[@]}&quot;;echo [ ${i// /, } ]\r\n    echo $id\r\n    done\r\n\r\nIf these inputs\r\n\r\n    afrid.google.com\r\n    farid.google.com\r\n\r\nMy expected results is\r\n\r\n    [ &quot;afrid.google.com&quot;, &quot;farid.google.com&quot; ]\r\n\r\nBut My result is \r\n\r\n    [ farid.google.com ]\r\n    farid.google.com\r\n    [ farid.google.com ]\r\n    farid.google.com\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55695364/bash-array-to-json-array",
        "title": "Bash array to JSON array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1555375122,
                "creation_date": 1555375122,
                "answer_id": 55699006,
                "question_id": 55698554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply add an &quot;or&quot; to cover the new possibility:\r\n\r\n\r\n    .[]\r\n    | select( any(.input[];\r\n                  (type==&quot;object&quot; and (has(&quot;$link&quot;) and (.[&quot;$link&quot;]==&quot;randomtext1&quot;)))\r\n                  or (type==&quot;array&quot; and any(.[];\r\n                                            type == &quot;object&quot; and (has(&quot;$link&quot;) and (.[&quot;$link&quot;]==&quot;randomtext1&quot;)))) ))\r\n    |.id\r\n\r\n## ... or more readably:\r\n\r\n\r\n    def relevant($txt):\r\n      type == &quot;object&quot; and has(&quot;$link&quot;) and (.[&quot;$link&quot;]==$txt);\r\n      \r\n    .[]\r\n    | select( any(.input[];\r\n                  relevant(&quot;randomtext1&quot;)\r\n                  or (type==&quot;array&quot; and any(.[]; relevant(&quot;randomtext1&quot;))) ))\r\n    |.id\r\n\r\n",
                "title": "How to filter for key pairs in an object array (json and jq)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1555704035,
        "creation_date": 1555370991,
        "last_edit_date": 1555371900,
        "question_id": 55698554,
        "body_markdown": "This is a follow-up on \r\nhttps://stackoverflow.com/questions/55662024/jq-select-error-cannot-index-string-with-string-object\r\n\r\n\r\nPreviously, I can filter the entries in a json file that has the target objects with the following command and filter:\r\n```\r\n[{\r\n\t&quot;input&quot;: {\r\n\t\t&quot;obj1&quot;: {\r\n\t\t\t&quot;$link&quot;: &quot;randomtext1&quot;\r\n\t\t},\r\n\t\t&quot;id&quot;: &quot;a&quot;\r\n\t}\r\n}]\r\n```\r\n`jq -r &#39;.[] | select( any(.input[]; type==&quot;object&quot; and has(&quot;$link&quot;) and (.[&quot;$link&quot;]==&quot;randomtext1&quot;)))|.id&#39;`\r\nwill give &quot;a&quot;\r\n\r\nHow can I filter if now the key &quot;$link&quot; and its value &quot;randomtext1&quot; belong to an array?\r\n```\r\n[{\r\n\t&quot;input&quot;: {\r\n\t\t&quot;obj1&quot;: [{\r\n\t\t\t&quot;$link&quot;: &quot;randomtext1&quot;\r\n\t\t}],\r\n\t\t&quot;id&quot;: &quot;a&quot;\r\n\t}\r\n}]\r\n```\r\n(I still want to be able to find &quot;a&quot; as the result)\r\n\r\nExample .json:\r\n```\r\n[\r\n  {\r\n    &quot;input&quot;: {\r\n      &quot;obj1&quot;: [{\r\n        &quot;$link&quot;: &quot;randomtext1&quot;\r\n      }],\r\n      &quot;obj2&quot;: [{\r\n        &quot;$link&quot;: &quot;randomtext2&quot;\r\n      }],\r\n      &quot;someotherobj&quot;: &quot;123&quot;\r\n    },\r\n    &quot;id&quot;: &quot;a&quot;\r\n  },\r\n  {\r\n    &quot;input&quot;: {\r\n      &quot;obj3&quot;: {\r\n        &quot;$link&quot;: &quot;randomtext1&quot;\r\n      },\r\n      &quot;obj4&quot;: {\r\n        &quot;$link&quot;: &quot;randomtext2&quot;\r\n      }\r\n    },\r\n    &quot;id&quot;: &quot;b&quot;\r\n  }\r\n]\r\n```\r\n\r\nI am hoping to find both a and b with &quot;randomtext1&quot; keyword but only got b with the same filter from the previous case after obj1 and obj2 have been &quot;shielded/masked&quot; by the array brackets in the example json file.",
        "link": "https://stackoverflow.com/questions/55698554/how-to-filter-for-key-pairs-in-an-object-array-json-and-jq",
        "title": "How to filter for key pairs in an object array (json and jq)"
    },
    {
        "tags": [
            "python",
            "json",
            "bash",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3803360,
                    "reputation": 1133,
                    "user_id": 3156383,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/1aa4fe089ace5cb79043f124702463d8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dks551",
                    "link": "https://stackoverflow.com/users/3156383/dks551"
                },
                "reply_to_user": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555432153,
                "post_id": 55712633,
                "comment_id": 98106140,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3803360,
                    "reputation": 1133,
                    "user_id": 3156383,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/1aa4fe089ace5cb79043f124702463d8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dks551",
                    "link": "https://stackoverflow.com/users/3156383/dks551"
                },
                "reply_to_user": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555432203,
                "post_id": 55712633,
                "comment_id": 98106165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 2,
                "creation_date": 1555433363,
                "post_id": 55712633,
                "comment_id": 98106730,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1555435574,
                "post_id": 55712633,
                "comment_id": 98107816,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3803360,
                    "reputation": 1133,
                    "user_id": 3156383,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/1aa4fe089ace5cb79043f124702463d8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dks551",
                    "link": "https://stackoverflow.com/users/3156383/dks551"
                },
                "reply_to_user": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555436420,
                "post_id": 55712633,
                "comment_id": 98108196,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3803360,
                    "reputation": 1133,
                    "user_id": 3156383,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/1aa4fe089ace5cb79043f124702463d8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dks551",
                    "link": "https://stackoverflow.com/users/3156383/dks551"
                },
                "reply_to_user": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555475037,
                "post_id": 55712633,
                "comment_id": 98119522,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1555446110,
                "last_edit_date": 1555446110,
                "creation_date": 1555435906,
                "answer_id": 55713679,
                "question_id": 55712633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution based on the suggestion in one of the comments:\r\n\r\n&gt; If you can e.g. prefix the lines with the sort key so that they can be sorted as text rather than JSON, then GNU sort can easily sort 10GB+ files without loading them into memory. – that other guy\r\n\r\nYou can use jq to do this along the following lines:\r\n\r\n    jq -cr &#39;&quot;\\(.ps)\\t\\(.)&quot;&#39; \r\n\r\nThis will produce lines with tab-separated values like so:\r\n\r\n    abc\t{&quot;ps&quot;:&quot;abc&quot;,&quot;x&quot;:0}\r\n    abc\t{&quot;ps&quot;:&quot;abc&quot;,&quot;x&quot;:1}\r\n\r\nUsing the -c option ensures that each pair (i.e. the sorting key and object) is written to a single line. \r\n\r\nNow you can easily sort the lines, e.g. using `sort`; and then use e.g. `cut` to strip the .ps field. \r\n\r\nFinally, if you really want the output to be formatted, you can again use `jq` ( e.g. `jq .`), the point being that jq is by default stream-oriented.\r\n\r\n## Caveat\r\nThe above assumes that the .ps values are tab-free.  If that is not the case, then you could either use a different field-separator, or:\r\n\r\n    jq -cr &#39;([.ps] | @tsv) + &quot;\\t&quot; + tostring&#39;\r\n",
                "title": "Sort huge JSON file using bash or python"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613043328,
                "creation_date": 1613043328,
                "answer_id": 66153956,
                "question_id": 55712633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nInstead of being concerned about different kinds of edge cases you can instead use base64 encoding and decoding.\r\n\r\nThis approach creates two columns that are tab separated. The first column contains the values used for sorting. The second is the complete JSON in base64 format.\r\n\r\nAfter sorting we get the second column and base64 decode.\r\n\r\n```bash\r\ngzcat sth.json.gz | \\\r\n  | jq -cr &#39;[(. | .ps | @text), (. | @base64)] | @tsv&#39; \\ # Create a TSV where the first column contains the value that should be sorted on.\r\n  | sort -t$&#39;\\t&#39; -k1,1 \\ # Sort only on first column.\r\n  | cut -f 2 \\ # Get the base64 encoded JSON from seconds column.\r\n  | base64 -d \\ # Decode the base64 encoded JSON. (Ignores newlines)\r\n  | jq -c . # Required to place each JSON on separate line.\r\n```",
                "title": "Sort huge JSON file using bash or python"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1613043328,
        "creation_date": 1555431659,
        "last_edit_date": 1555475284,
        "question_id": 55712633,
        "body_markdown": "**Requirement**: I have a Json file which is in .gz format. So, when it is compressed it is around ~500 MB in size. When I extract it, the json file becomes nearly around ~10 GB. The extracted JSON file contains individual JSON objects line by line.What I want is to sort the file based on a field `ps` using either any bash script or python programs. \r\n\r\nBecause the file is too large, its not advisable to load it into memory. So, I used gzcat and cat bash command to stream the JSON data and then pipe them to jq for sorting purpose. But either the system doesn&#39;t respond during the process or I get empty file in the output.json\r\n\r\n    &gt;cat  sth2.json | parallel --pipe --group --block 1000M --recend &#39;\\n}\\n&#39; &quot;jq -s -c &#39;sort_by(.ps) | .[]&#39;&quot;  &gt; &quot;output.json&quot;\r\n    &gt;gzcat  sth2.json.gz | parallel --pipe --group --block 1000M --recend &#39;\\n}\\n&#39; &quot;jq -s -c &#39;sort_by(.ps) | .[]&#39;&quot;  &gt; &quot;output.json&quot;\r\n\r\n**Hardware**:\r\n16GB RAM, \r\ncore i5 processor\r\n\r\n**Sample JSON Data:-**\r\n\r\n    {\r\n    \t&quot;ps&quot;:&quot;abc&quot;\r\n        ....\r\n    }\r\n    {\t\r\n        &quot;ps&quot;:&quot;def&quot;\r\n        ......\r\n    }\r\n    {\r\n    \t&quot;ps&quot;:&quot;abc&quot;\r\n        ....\r\n    }\r\n\r\n\r\n**Expected output**:\r\n\r\n    {\r\n    \t&quot;ps&quot;:&quot;abc&quot;\r\n        ....\r\n    }\r\n    {\t\r\n        &quot;ps&quot;:&quot;abc&quot;\r\n        ....\r\n    }\r\n    {\r\n    \t&quot;ps&quot;:&quot;def&quot;\r\n        ....\r\n    }\r\n\r\nI don&#39;t understand what I am doing wrong. Can anyone suggest how to sort such huge JSON file ?\r\nLinks I followed:\r\nhttps://github.com/joelpurra/jq-hopkok/tree/master/src/parallelism\r\n\r\nAlso, is there any way I can do via any Map reduce without Hadoop ?\r\n\r\n**Approach-1: Streaming data to local Sqlite DB.**\r\n\r\n    import sqlite3\r\n    import fileinput\r\n    \r\n    PATH=&quot;.../sqlite-snapshot-201904101324/testDB.db&quot;\r\n    insert_query=&quot;INSERT INTO feeds (data) VALUES (?)&quot;\r\n    \r\n    def db_connect(db_path=PATH):\r\n        con = sqlite3.connect(db_path)\r\n        return con\r\n    \r\n    con = db_connect() # connect to the database\r\n    cur = con.cursor() # instantiate a cursor obj\r\n    \r\n    record_count = 0\r\n    for line in fileinput.input():\r\n        cur.execute(insert_query,(line,))\r\n\r\ncommand line:\r\n\r\n    &gt;gzcat sth.json.gz | python insert.py",
        "link": "https://stackoverflow.com/questions/55712633/sort-huge-json-file-using-bash-or-python",
        "title": "Sort huge JSON file using bash or python"
    },
    {
        "tags": [
            "npm",
            "node-modules",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1555657183,
                "last_edit_date": 1555657183,
                "creation_date": 1555603138,
                "answer_id": 55749814,
                "question_id": 55730360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this response, I&#39;ll focus on the main point - that it is possible to construct the\r\nshell commands with just one invocation of jq.  jq does not have a &quot;system&quot; command\r\nfor executing these commands, so the jq program given here may need to be modified, depending e.g. on security requirements.\r\n\r\nTo get the ball rolling, note that the script given in the question generates (and executes)\r\nthe following shell commands:\r\n\r\n    find . -path ./node_modules/bootstrap/* -name bootstrap.min.css | xargs -I{} cp -fa {} public/css/\r\n    find . -path ./node_modules/bootstrap/* -name bootstrap.min.js | xargs -I{} cp -fa {} public/js/\r\n    find . -path ./node_modules/jquery/* -name jquery.min.js | xargs -I{} cp -fa {} public/js/\r\n\r\nThese commands can be generated with just one invocation of jq using the following jq program:\r\n\r\n    def construct:\r\n      (.value | to_entries[] | &quot;-name \\(.value[0]) | xargs -I{} cp -fs {} public/\\(.key)/&quot;) as $s\r\n      | &quot;find . -path ./node_modules/\\(.key)/* &quot; + $s ;\r\n    \r\n    .[][]\r\n    | to_entries[]\r\n    | construct\r\n\r\nNote that in the output produced by this jq program, the ordering is different, because the script in the question uses `keys`, which sorts the keys alphabetically.\r\n",
                "title": "jq json tree traversal (npm node_modules)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1555657183,
        "creation_date": 1555512379,
        "question_id": 55730360,
        "body_markdown": "The question concerns the code optimization.\r\n\r\nI want to define a json-file which specify what files will be copied and where.  Namely, I want to apply it in npm-type project to transfer the files from node_modules to the destination directory from which I include files (on the templates of the pages for the web browser).  So I wrote a json file:\r\n\r\n```json\r\n{\r\n  &quot;public&quot;: [\r\n    {\r\n       &quot;bootstrap&quot;: {\r\n         &quot;js&quot;: [\r\n           &quot;bootstrap.min.js&quot;\r\n         ],\r\n         &quot;css&quot;: [\r\n           &quot;bootstrap.min.css&quot;\r\n         ]\r\n      }\r\n    },\r\n    {\r\n      &quot;jquery&quot;: {\r\n        &quot;js&quot;: [\r\n          &quot;jquery.min.js&quot;\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe first level defines the name of the destination directory (&#39;public&#39;) which would contain the packages specified on the second level.  The third level defines the names of the destination folders inside &#39;public&#39; (&#39;js&#39; or &#39;css&#39;) which contain the list of files to find and copy.\r\n\r\nThe code which traverses the json file follows:\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\ncfg=&#39;push2public.json&#39;\r\nP=$(cat &quot;$cfg&quot; | jq keys[0] -r)\r\nn=$(cat &quot;$cfg&quot; | jq &quot;.$P | length&quot;)\r\nfor (( i=0;i&lt;$n;i++ )); do\r\n  p=$(cat &quot;$cfg&quot; | jq &quot;.$P[$i]&quot; | jq keys[0] -r)\r\n  m=$(cat &quot;$cfg&quot; | jq &quot;.$P[$i].$p | length&quot;)\r\n  for (( j=0;j&lt;$m;j++ )); do\r\n    d=$(cat &quot;$cfg&quot; | jq &quot;.$P[$i].$p&quot; | jq keys[$j] -r)\r\n    mkdir -p &quot;$P/$d&quot;\r\n    l=$(cat &quot;$cfg&quot; | jq &quot;.$P[$i].$p&quot; | jq &quot;.$d | length&quot; )\r\n    for (( k=0;k&lt;$l;k++ )); do\r\n      f=$(cat &quot;$cfg&quot; | jq &quot;.$P[$i].$p.$d[$k]&quot; -r)\r\n      find . -path &quot;./node_modules/$p/*&quot; -name &quot;$f&quot; | xargs -I{} cp -fa &quot;{}&quot; &quot;$P/$d/&quot;\r\n    done\r\n  done\r\ndone\r\n```\r\n\r\nThe code seems to work, yet it looks kinda strange.  Can you think of a better way to apply jq for the task just described?",
        "link": "https://stackoverflow.com/questions/55730360/jq-json-tree-traversal-npm-node-modules",
        "title": "jq json tree traversal (npm node_modules)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1555612277,
                "post_id": 55751874,
                "comment_id": 98180330,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1555612664,
                "creation_date": 1555612664,
                "answer_id": 55751996,
                "question_id": 55751874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can concatenate strings using `+` operator:\r\n```\r\njq -r &#39;.[]|.location+&quot; &quot;+(.services[]|.name+&quot; &quot;+.version)&#39; file\r\nlocationa serviceA 5.2.0.2\r\nlocationa serviceB 4.19.0.5\r\nlocationb serviceA 5.2.0.2\r\nlocationb serviceB 4.19.0.5\r\nlocationb serviceC 1.0.0.1\r\n```",
                "title": "jq filtering sub-array values with main values of an object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1555626831,
                "creation_date": 1555626831,
                "answer_id": 55754485,
                "question_id": 55751874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generally when trying to output csv/tsv, you would want to generate arrays of the rows to output then pass to the `@csv` or `@tsv` or utilize `join/1` to output in the format of your choice.\r\n\r\n    jq -r &#39;.[] | [.location] + (.services[] | [.name, .version]) | @tsv&#39; input.json",
                "title": "jq filtering sub-array values with main values of an object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1555700969,
        "creation_date": 1555612101,
        "last_edit_date": 1555626591,
        "question_id": 55751874,
        "body_markdown": "I am having an issue figuring out what filters and methods I need to use in jq to transform my json data into what I am looking for. Every combination I have tried has ended up either not working at all, or iterating for each value, for each sub-arrary, for each object. \r\n\r\nI have spent too long on this and am not making any more progress. Need someone to put another set of eyes on it. I am sure it is something more simple than I am making it out to be, but I am just unable to figure it out!\r\n\r\nHere is the json data I am working with:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;location&quot;: &quot;locationa&quot;,\r\n        &quot;services&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;serviceA&quot;,\r\n                &quot;version&quot;: &quot;5.2.0.2&quot;,\r\n                &quot;updatedAt&quot;: &quot;2018-04-17&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;serviceB&quot;,\r\n                &quot;version&quot;: &quot;4.19.0.5&quot;,\r\n                &quot;updatedAt&quot;: &quot;2018-04-17&quot;\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;location&quot;: &quot;locationb&quot;,\r\n        &quot;services&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;serviceA&quot;,\r\n                &quot;version&quot;: &quot;5.2.0.2&quot;,\r\n                &quot;updatedAt&quot;: &quot;2018-04-17&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;serviceB&quot;,\r\n                &quot;version&quot;: &quot;4.19.0.5&quot;,\r\n                &quot;updatedAt&quot;: &quot;2018-04-17&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;serviceC&quot;,\r\n                &quot;version&quot;: &quot;1.0.0.1&quot;,\r\n                &quot;updatedAt&quot;: &quot;2018-04-17&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n\r\n```\r\n\r\nAnd this is the format I am attempting to get out:\r\n\r\n```\r\nlocationa serviceA 5.2.0.2\r\nlocationa serviceB 4.19.0.5\r\nlocationb serviceA 5.2.0.2\r\nlocationb serviceB 4.19.0.5\r\nlocationb serviceC 1.0.0.1\r\n```",
        "link": "https://stackoverflow.com/questions/55751874/jq-filtering-sub-array-values-with-main-values-of-an-object",
        "title": "jq filtering sub-array values with main values of an object"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1555948340,
                "creation_date": 1555948340,
                "answer_id": 55797147,
                "question_id": 55754060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "String Interpolation will work for this.\r\n\r\nI&#39;m called the AWS CLI `list-aliases` directly and piped it into `jq`, used the select/contains filter and piped it out using String Interpolation for output.\r\n\r\n    aws kms list-aliases |jq -r &#39;.Aliases[] |select (.AliasArn |contains(&quot;:alias/aws/&quot;) | not) | &quot;AliasArn: \\(.AliasArn)\\t\\tTargetKeyId: \\(.TargetKeyId)&quot;&#39;\r\n\r\nI added a couple of tabs in the output for readability.\r\n\r\n**References**\r\n\r\n[https://stedolan.github.io/jq/manual/][1]\r\n\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How can I query multiple fields of an object array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1556093687,
                "creation_date": 1556093687,
                "answer_id": 55825325,
                "question_id": 55754060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thank you Kenlukas, that hit the nail on the head.\r\n\r\nI made a small refinement to just capture the alias description along with the key as seen here - \r\n\r\n    aws kms list-aliases |jq -r &#39;.Aliases[] |select (.AliasArn |contains(&quot;:alias/aws/&quot;) | not) | &quot;AliasArn: \\(.AliasArn | split(&quot;/&quot;)[1])\\t\\tTargetKeyId: \\(.TargetKe yId)&quot;&#39;",
                "title": "How can I query multiple fields of an object array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1556094933,
                "creation_date": 1556094933,
                "answer_id": 55825721,
                "question_id": 55754060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re very close to the solution. You just need to add the field you want to get on your filter: \r\n\r\n    .Aliases[]|select(.AliasArn|contains(&quot;:alias/aws&quot;)|not) |.AliasArn,.TargetKeyId\r\n\r\n",
                "title": "How can I query multiple fields of an object array?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1556094933,
        "creation_date": 1555623670,
        "last_edit_date": 1556054166,
        "question_id": 55754060,
        "body_markdown": "I am querying AWS CLI output as per the json below. \r\n\r\n    {\r\n    &quot;Aliases&quot;: [\r\n        {\r\n          &quot;AliasName&quot;: &quot;alias/ab1&quot;,\r\n          &quot;AliasArn&quot;: &quot;arn:aws:kms:eu-west-1:123:alias/key1&quot;,\r\n          &quot;TargetKeyId&quot;: &quot;66&quot;\r\n        },\r\n        {\r\n          &quot;AliasName&quot;: &quot;alias/ab2&quot;,\r\n          &quot;AliasArn&quot;: &quot;arn:aws:kms:eu-west-1:123:alias/key2&quot;,\r\n          &quot;TargetKeyId&quot;: &quot;77&quot;\r\n        },\r\n        {\r\n          &quot;AliasName&quot;: &quot;alias/ab3&quot;,\r\n          &quot;AliasArn&quot;: &quot;arn:aws:kms:eu-west-1:123:alias/key3&quot;,\r\n          &quot;TargetKeyId&quot;: &quot;88&quot;\r\n        },\r\n        {\r\n          &quot;AliasName&quot;: &quot;alias/ab4&quot;,\r\n          &quot;AliasArn&quot;: &quot;arn:aws:kms:eu-west-1:123:alias/aws/key4&quot;,\r\n          &quot;TargetKeyId&quot;: &quot;99&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nWith query \r\n\r\n    .Aliases[] | (.AliasArn | select(contains(&quot;:alias/aws/&quot;) | not) ) \r\n\r\nBut this only pulls `AliasArn` field, `TargetKeyId` is also required. Any ideas on how to pull both fields?\r\n\r\n    &quot;arn:aws:kms:eu-west-1:123:alias/key1&quot;\r\n    &quot;arn:aws:kms:eu-west-1:123:alias/key2&quot;\r\n    &quot;arn:aws:kms:eu-west-1:123:alias/key3&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55754060/how-can-i-query-multiple-fields-of-an-object-array",
        "title": "How can I query multiple fields of an object array?"
    },
    {
        "tags": [
            "bash",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1555692908,
                "last_edit_date": 1555692908,
                "creation_date": 1555692119,
                "answer_id": 55765025,
                "question_id": 55764974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No, [tag:sed] is for searching and replacing regular expressions in a file/files.   \r\nI would normally use [tag:jq] for parsing JSON but your sample is an invalid JSON value and I assume so is your actual input, so, use [tag:grep] instead:\r\n```\r\n$ grep -o &#39;&quot;temp&quot;:[0-9.]*&#39; weather.txt &gt; newfile.txt\r\n$ cat newfile.txt\r\n&quot;temp&quot;:281.61\r\n&quot;temp&quot;:279.9\r\n```",
                "title": "Extract phrases in bash (using sed)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1555722753,
                "creation_date": 1555722753,
                "answer_id": 55769394,
                "question_id": 55764974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "try gnu sed\r\n\r\n     sed -En &#39;s/&quot;temp&quot;:\\s*[0-9.]+/\\n&amp;\\n/g; s/[^\\n]*(\\n(&quot;temp&quot;:\\s*[0-9.]+)|\\s*$)/\\2/gp&#39; weather.txt &gt;&gt; newFile.txt",
                "title": "Extract phrases in bash (using sed)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1666425291,
        "creation_date": 1555691835,
        "last_edit_date": 1666425291,
        "question_id": 55764974,
        "body_markdown": "I&#39;m trying to extract some fragments of JSON document using regular expressions in bash. My goal is to catch every instance of this phrase and save them in new file. I thought that sed is good tool for such tasks.\r\n\r\nI&#39;ve tried sth like this:\r\n\r\n    sed &#39;&quot;temp&quot;:[0-9]+\\.[0-9]*&#39; weather.txt &gt;&gt; newFile.txt\r\n\r\n Example of weather.txt:\r\n```\r\n{&quot;temp&quot;:281.61,&quot;temp_min&quot;:280.005,&quot;temp_max&quot;:281.61,&quot;pressure&quot;:1033.941,&quot;sea_level&quot;:1033.941,&quot;grnd_level&quot;:1024.038,&quot;humidity&quot;:57,&quot;temp_kf&quot;:1.6},&quot;weather&quot;:[{&quot;id&quot;:800,&quot;main&quot;:&quot;Clear&quot;,&quot;description&quot;:&quot;clear sky&quot;,&quot;icon&quot;:&quot;01n&quot;}],&quot;clouds&quot;:{&quot;all&quot;:0},&quot;wind&quot;:{&quot;speed&quot;:2.19,&quot;deg&quot;:6.817},&quot;sys&quot;:{&quot;pod&quot;:&quot;n&quot;},&quot;dt_txt&quot;:&quot;2019-04-19 18:00:00&quot;},{&quot;dt&quot;:1555707600,&quot;main&quot;:{&quot;temp&quot;:279.9,&quot;temp_min&quot;:278.7,&quot;temp_max&quot;:279.9,&quot;pressure&quot;:1034.219,&quot;sea_level&quot;:1034.219,&quot;grnd_level&quot;:1024.211,&quot;humidity&quot;:64,&quot;temp_kf&quot;:1.2}\r\n```\r\n\r\nExpected result for input like this above is: :\r\n```\r\n &quot;temp&quot;:281.61 \r\n &quot;temp&quot;:279.9\r\n```\r\nDespite trying defferent variations it isn&#39;t still correct.\r\nDo you have any idea how I can solve this problem?\r\n\r\nThank you in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55764974/extract-phrases-in-bash-using-sed",
        "title": "Extract phrases in bash (using sed)"
    },
    {
        "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": 1,
                "creation_date": 1555710294,
                "post_id": 55768086,
                "comment_id": 98210563,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1555711417,
                "last_edit_date": 1555711417,
                "creation_date": 1555710275,
                "answer_id": 55768181,
                "question_id": 55768086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Variables passed to jq using `--arg` are all converted to string, you need to use `--argjson` to pass integers.\r\n```\r\njq --arg host &quot;foo.bar&quot; --argjson port &quot;8082&quot; --arg id &quot;123&quot; &#39;.[] | select((.hostname==$host) and (.targetPort==$port)).serviceId = $id&#39; &lt;&lt;&lt;&quot;${JSON}&quot; | jq -s\r\n```\r\nAs a sidenote, you don&#39;t need to call jq twice, just use `map`.\r\n```\r\njq &#39;map(select(.hostname==$host and .targetPort==$port).serviceId=$id)&#39; --arg host &quot;foo.bar&quot; --argjson port 8082 --arg id &quot;123&quot; &lt;&lt;&lt;&quot;$JSON&quot;\r\n```",
                "title": "Why do adding jq arguments not change value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574354328,
        "creation_date": 1555709526,
        "last_edit_date": 1574354328,
        "question_id": 55768086,
        "body_markdown": "I&#39;m writing a bash script and came across this problem. When I pass `jq` `--arg` flags, it is not updating the value. But when I hard code in the values without the `--arg` flags, it does.\r\n\r\nI have tried this in a script, and have also tried this directly in a terminal in both ways (with and without the argument flags). With does not update the value. Without does update the value.\r\n\r\n```bash\r\necho &quot;${JSON}&quot;\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;portRule&quot;,\r\n    &quot;hostname&quot;: &quot;fizz.buzz&quot;,\r\n    &quot;protocol&quot;: &quot;https&quot;,\r\n    &quot;serviceId&quot;: &quot;1s1495&quot;,\r\n    &quot;sourcePort&quot;: 443,\r\n    &quot;targetPort&quot;: 80\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;portRule&quot;,\r\n    &quot;hostname&quot;: &quot;foo.bar&quot;,\r\n    &quot;serviceId&quot;: &quot;1s1499&quot;,\r\n    &quot;sourcePort&quot;: 443,\r\n    &quot;targetPort&quot;: 8082\r\n  }\r\n]\r\n```\r\n\r\nWorks\r\n```bash\r\njq &#39;.[] | select((.hostname==&quot;foo.bar&quot;) and (.targetPort==8082)).serviceId = &quot;123&quot;&#39; &lt;&lt;&lt;&quot;${JSON}&quot; | jq -s\r\n```\r\nOutput\r\n```bash\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;portRule&quot;,\r\n    &quot;hostname&quot;: &quot;fizz.buzz&quot;,\r\n    &quot;protocol&quot;: &quot;https&quot;,\r\n    &quot;serviceId&quot;: &quot;1s1495&quot;,\r\n    &quot;sourcePort&quot;: 443,\r\n    &quot;targetPort&quot;: 80\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;portRule&quot;,\r\n    &quot;hostname&quot;: &quot;foo.bar&quot;,\r\n    &quot;serviceId&quot;: &quot;123&quot;,\r\n    &quot;sourcePort&quot;: 443,\r\n    &quot;targetPort&quot;: 8082\r\n  }\r\n]\r\n```\r\n\r\nDoes not work\r\n```bash\r\njq --arg host &quot;foo.bar&quot; --arg port &quot;8082&quot; --arg id &quot;123&quot; &#39;.[] | select((.hostname==$host) and (.targetPort==$port)).serviceId = $id&#39; &lt;&lt;&lt;&quot;${JSON}&quot; | jq -s\r\n```\r\nOutput\r\n```bash\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;portRule&quot;,\r\n    &quot;hostname&quot;: &quot;fizz.buzz&quot;,\r\n    &quot;protocol&quot;: &quot;https&quot;,\r\n    &quot;serviceId&quot;: &quot;1s1495&quot;,\r\n    &quot;sourcePort&quot;: 443,\r\n    &quot;targetPort&quot;: 80\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;portRule&quot;,\r\n    &quot;hostname&quot;: &quot;foo.bar&quot;,\r\n    &quot;serviceId&quot;: &quot;1s1499&quot;,\r\n    &quot;sourcePort&quot;: 443,\r\n    &quot;targetPort&quot;: 8082\r\n  }\r\n]\r\n```\r\n\r\nI will note that I am hoping that I can replace even the arguments values with environment variables rather than the strings as my examples shows. But I&#39;ve tested both ways, same results.\r\n\r\nSo am I doing something wrong? Or is this a bug with `jq` (Probably not).\r\n\r\nExpected results. It updates the value in the json with `--arg` flags as it does without and hard coding the strings.",
        "link": "https://stackoverflow.com/questions/55768086/why-do-adding-jq-arguments-not-change-value",
        "title": "Why do adding jq arguments not change value"
    },
    {
        "tags": [
            "json",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15595756,
                    "reputation": 1672,
                    "user_id": 11251344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/30fba5cd70307304cd9a84e9815127b2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BlackPearl",
                    "link": "https://stackoverflow.com/users/11251344/blackpearl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555740942,
                "post_id": 55770671,
                "comment_id": 98214879,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4486560,
                    "reputation": 529,
                    "user_id": 3648969,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/25f0872056afc21e5a2eca6659bb6dc3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "h0bb5",
                    "link": "https://stackoverflow.com/users/3648969/h0bb5"
                },
                "reply_to_user": {
                    "account_id": 15595756,
                    "reputation": 1672,
                    "user_id": 11251344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/30fba5cd70307304cd9a84e9815127b2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BlackPearl",
                    "link": "https://stackoverflow.com/users/11251344/blackpearl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555741744,
                "post_id": 55770671,
                "comment_id": 98215012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4486560,
                    "reputation": 529,
                    "user_id": 3648969,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/25f0872056afc21e5a2eca6659bb6dc3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "h0bb5",
                    "link": "https://stackoverflow.com/users/3648969/h0bb5"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555743870,
                "post_id": 55770671,
                "comment_id": 98215385,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555762657,
                "post_id": 55770671,
                "comment_id": 98219419,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4486560,
                    "reputation": 529,
                    "user_id": 3648969,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/25f0872056afc21e5a2eca6659bb6dc3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "h0bb5",
                    "link": "https://stackoverflow.com/users/3648969/h0bb5"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555782119,
                "post_id": 55770671,
                "comment_id": 98224594,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4486560,
                    "reputation": 529,
                    "user_id": 3648969,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/25f0872056afc21e5a2eca6659bb6dc3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "h0bb5",
                    "link": "https://stackoverflow.com/users/3648969/h0bb5"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1555782217,
                "post_id": 55770671,
                "comment_id": 98224613,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557850106,
                "creation_date": 1557850106,
                "answer_id": 56134549,
                "question_id": 55770671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should use `sed` to do the substitution and then inject the value back into the JSON. \r\n\r\n`echo $TARGET_ID | sed &#39;s/stag4/stag5/g&#39;`\r\n\r\nOutputs\r\n`S3-Website-stag5.example.io.s3-website.us-east-2.amazonaws.com`\r\n\r\nNext we&#39;ll put the value back into the original JSON, this will technically output a new JSON and does not edit the file, however, you can easily solve for this on the output by temporarily saving to a tmp file.\r\n\r\nWe will use the --arg flag to reference our bash variable and set the new value for our field\r\n\r\n\r\n`cat distconfig.json | jq --arg &#160;TARGET_ID $TARGET_ID &#39;.DefaultCacheBehavior.TargetOriginId = $TARGET_ID&#39; &gt; tmp.json &amp;&amp; mv tmp.json distconfig.json`",
                "title": "How to find and replace json with shell variables using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1557850106,
        "creation_date": 1555739325,
        "last_edit_date": 1555782145,
        "question_id": 55770671,
        "body_markdown": "I have read properties with jq from a json object and have stored them to variables. \r\n\r\nI want to now read these variables and essentially find and replace a word inside the string with a global shell variable. \r\n\r\n\r\n\r\n\r\n\r\nI&#39;ve set my json ID&#39;s from my JSON file\r\n```\r\n# Set Json ID&#39;s\r\nTARGET_ID=$(jq &#39;.DefaultCacheBehavior.TargetOriginId&#39; distconfig.json)\r\nDOMAIN_NAME=$(jq &#39;.Origins.Items[0].DomainName&#39; distconfig.json)\r\nORIGIN_ID=$(jq &#39;.Origins.Items[0].Id&#39; distconfig.json)\r\n\r\necho &quot;$TARGET_ID&quot;\r\necho &quot;$DOMAIN_NAME&quot;\r\necho &quot;$ORIGIN_ID&quot;\r\n```\r\n\r\nThis returns \r\n\r\n```\r\n&quot;S3-Website-stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n&quot;stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n&quot;S3-Website-stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n```\r\n\r\nI have my location id variable and would like to write it to find and replace all `stag4` references in those 3 ID&#39;s. \r\n\r\nThen I would like to write those 3 ID&#39;s to the initial json object, or create a temp version of it. \r\n\r\nExample, if: \r\n`$DOMAIN_NAME` is`&quot;stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;`\r\n\r\nI would like to essentially have it set to: \r\n\r\n\r\n```\r\n$LOCATION_NAME=&quot;stag6&quot;\r\nDOMAIN_LOCATION=&quot;example.io&quot;\r\n```\r\n\r\n```\r\n&quot;$DOMAIN_NAME=S3-Website-\\$LOCATION_NAME\\.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n&quot;$TARGET_ID=\\$LOCATION_NAME\\.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n&quot;$ORIGIN_ID=S3-Website-\\$LOCATION_NAME\\.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n```\r\n\r\nThen write those 3 to the temp or new json file so I can run my cloudformation command:\r\n\r\n`aws cloudfront create-distribution --distribution-config file://disttemp.json`\r\n\r\n\r\nI have now built out the proper variables from the initial json file like so: \r\n\r\n```\r\n$LOCATION_NAME=&quot;stag6&quot;\r\nDOMAIN_LOCATION=&quot;example.io&quot;\r\n```\r\n\r\n```\r\necho &quot;Build New IDs&quot;\r\nTARGET_ID_BUILT=&quot;S3-Website-$LOCATION_NAME.$DOMAIN_LOCATION.s3-website.us-east-2.amazonaws.com&quot;\r\nDOMAIN_NAME_BUILT=&quot;$LOCATION_NAME.$DOMAIN_LOCATION.s3-website.us-east-2.amazonaws.com&quot;\r\nORIGIN_ID_BUILT=&quot;S3-Website-$LOCATION_NAME.$DOMAIN_LOCATION.s3-website.us-east-2.amazonaws.com&quot;\r\n\r\necho &quot;$TARGET_ID_BUILT&quot;\r\necho &quot;$DOMAIN_NAME_BUILT&quot;\r\necho &quot;$ORIGIN_ID_BUILT&quot;\r\n\r\n```\r\n\r\nHow do I write these variables to the json file with jq?\r\n\r\n\r\nEDIT: Sample of distconfig.json requested – domain/creds swapped to example\r\n```\r\n{\r\n  &quot;CallerReference&quot;: &quot;my-test-distribution-2&quot;,\r\n  &quot;Comment&quot;: &quot;&quot;, \r\n  &quot;CacheBehaviors&quot;: {\r\n      &quot;Quantity&quot;: 0\r\n  }, \r\n  &quot;IsIPV6Enabled&quot;: true, \r\n  &quot;Logging&quot;: {\r\n      &quot;Bucket&quot;: &quot;&quot;, \r\n      &quot;Prefix&quot;: &quot;&quot;, \r\n      &quot;Enabled&quot;: false, \r\n      &quot;IncludeCookies&quot;: false\r\n  }, \r\n  &quot;WebACLId&quot;: &quot;&quot;, \r\n  &quot;Origins&quot;: {\r\n      &quot;Items&quot;: [\r\n          {\r\n              &quot;OriginPath&quot;: &quot;&quot;, \r\n              &quot;CustomOriginConfig&quot;: {\r\n                  &quot;OriginSslProtocols&quot;: {\r\n                      &quot;Items&quot;: [\r\n                          &quot;TLSv1&quot;, \r\n                          &quot;TLSv1.1&quot;, \r\n                          &quot;TLSv1.2&quot;\r\n                      ], \r\n                      &quot;Quantity&quot;: 3\r\n                  }, \r\n                  &quot;OriginProtocolPolicy&quot;: &quot;http-only&quot;, \r\n                  &quot;OriginReadTimeout&quot;: 30, \r\n                  &quot;HTTPPort&quot;: 80, \r\n                  &quot;HTTPSPort&quot;: 443, \r\n                  &quot;OriginKeepaliveTimeout&quot;: 5\r\n              }, \r\n              &quot;CustomHeaders&quot;: {\r\n                  &quot;Quantity&quot;: 0\r\n              }, \r\n              &quot;Id&quot;: &quot;S3-Website-stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;, \r\n              &quot;DomainName&quot;: &quot;stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;\r\n          }\r\n      ], \r\n      &quot;Quantity&quot;: 1\r\n  },\r\n}\r\n&quot;DefaultRootObject&quot;: &quot;&quot;, \r\n  &quot;PriceClass&quot;: &quot;PriceClass_All&quot;, \r\n  &quot;Enabled&quot;: true, \r\n  &quot;DefaultCacheBehavior&quot;: {\r\n      &quot;TrustedSigners&quot;: {\r\n          &quot;Enabled&quot;: false, \r\n          &quot;Quantity&quot;: 0\r\n      }, \r\n      &quot;LambdaFunctionAssociations&quot;: {\r\n          &quot;Quantity&quot;: 0\r\n      }, \r\n      &quot;TargetOriginId&quot;: &quot;S3-Website-stag4.example.io.s3-website.us-east-2.amazonaws.com&quot;, \r\n      &quot;ViewerProtocolPolicy&quot;: &quot;redirect-to-https&quot;, \r\n      &quot;ForwardedValues&quot;: {\r\n          &quot;Headers&quot;: {\r\n              &quot;Quantity&quot;: 0\r\n          }, \r\n          &quot;Cookies&quot;: {\r\n              &quot;Forward&quot;: &quot;none&quot;\r\n          }, \r\n          &quot;QueryStringCacheKeys&quot;: {\r\n              &quot;Quantity&quot;: 0\r\n          }, \r\n          &quot;QueryString&quot;: false\r\n      }, \r\n      &quot;MaxTTL&quot;: 31536000, \r\n      &quot;SmoothStreaming&quot;: false, \r\n      &quot;DefaultTTL&quot;: 86400, \r\n      &quot;AllowedMethods&quot;: {\r\n          &quot;Items&quot;: [\r\n              &quot;HEAD&quot;, \r\n              &quot;GET&quot;\r\n          ], \r\n          &quot;CachedMethods&quot;: {\r\n              &quot;Items&quot;: [\r\n                  &quot;HEAD&quot;, \r\n                  &quot;GET&quot;\r\n              ], \r\n              &quot;Quantity&quot;: 2\r\n          }, \r\n          &quot;Quantity&quot;: 2\r\n      }, \r\n      &quot;MinTTL&quot;: 0, \r\n      &quot;Compress&quot;: true\r\n  }, \r\n  &quot;ViewerCertificate&quot;: {\r\n      &quot;SSLSupportMethod&quot;: &quot;sni-only&quot;, \r\n      &quot;ACMCertificateArn&quot;: &quot;xxxx&quot;, \r\n      &quot;MinimumProtocolVersion&quot;: &quot;TLSv1.1_2016&quot;, \r\n      &quot;Certificate&quot;: &quot;xxxx&quot;, \r\n      &quot;CertificateSource&quot;: &quot;acm&quot;\r\n  }, \r\n  &quot;CustomErrorResponses&quot;: {\r\n      &quot;Quantity&quot;: 0\r\n  }, \r\n  &quot;HttpVersion&quot;: &quot;http2&quot;, \r\n  &quot;Restrictions&quot;: {\r\n      &quot;GeoRestriction&quot;: {\r\n          &quot;RestrictionType&quot;: &quot;none&quot;, \r\n          &quot;Quantity&quot;: 0\r\n      }\r\n  }, \r\n  &quot;Aliases&quot;: {\r\n      &quot;Quantity&quot;: 0\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55770671/how-to-find-and-replace-json-with-shell-variables-using-jq",
        "title": "How to find and replace json with shell variables using jq?"
    },
    {
        "tags": [
            "json",
            "object",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1555762890,
                "creation_date": 1555762890,
                "answer_id": 55773482,
                "question_id": 55773054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A generic function, `atomize(s)`, for converting objects to key-value objects is provided in the [jq Cookbook][1].  Using it, the solution to the problem here is simply:\r\n\r\n    atomize(inputs) | to_entries[] | .value + {key}\r\n\r\n(`{key}` is shorthand for `{key: .key}`.)\r\n\r\nFor reference, here is the `def`:\r\n\r\n### atomize(s)\r\n\r\n    # Convert an object (presented in streaming form as the stream s) into\r\n    # a stream of single-key objects\r\n    # Example:\r\n    #   atomize(inputs) (used in conjunction with &quot;jq -n --stream&quot;)\r\n    def atomize(s):\r\n      fromstream(foreach s as $in ( {previous:null, emit: null};\r\n          if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\r\n          then {emit: [[.previous]], previous: ($in|.[0][0])}\r\n          else { previous: ($in|.[0][0]), emit: null}\r\n          end;\r\n          (.emit // empty), $in\r\n          ) ) ;\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "Streaming without truncating"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1555764606,
        "creation_date": 1555759508,
        "last_edit_date": 1555764606,
        "question_id": 55773054,
        "body_markdown": "I have json data of the form below. I want to transform it, making the key of each record into a field of that record in a streaming fashion. My problem: I don&#39;t know how to do that without truncating the key and losing it. I have inferred the required structure of the stream, see at the bottom.\r\n\r\nQuestion: how do I transform the input data into a stream without losing the key?\r\n\r\nData:\r\n\r\n```\r\n{\r\n  &quot;foo&quot; : {\r\n    &quot;a&quot; : 1,\r\n    &quot;b&quot; : 2\r\n  },\r\n  &quot;bar&quot; : {\r\n    &quot;a&quot; : 1,\r\n    &quot;b&quot; : 2\r\n  }\r\n}\r\n```\r\n\r\nA non-streaming transformation uses:\r\n\r\n```\r\njq &#39;with_entries(.value += {key}) | .[]&#39;\r\n```\r\nyielding:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;key&quot;: &quot;foo&quot;\r\n}\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;key&quot;: &quot;bar&quot;\r\n}\r\n\r\n```\r\n\r\nNow, if my data file is very very large, I&#39;d prefer to stream:\r\n\r\n```\r\njq -ncr --stream &#39;fromstream(1|truncate_stream(inputs))`\r\n```\r\n\r\nThe problem: this truncates the keys `&quot;foo&quot;` and `&quot;bar&quot;`. On the other hand, not truncating the stream and just calling `fromstream(inputs)` is pretty meaningless: this makes the whole `--stream` part a no-op and `jq` reads everything into memory.\r\n\r\nThe structure of the stream is the following, using `. | tostream`:\r\n\r\n```\r\n[\r\n  [\r\n    &quot;foo&quot;,\r\n    &quot;a&quot;\r\n  ],\r\n  1\r\n]\r\n[\r\n  [\r\n    &quot;foo&quot;,\r\n    &quot;b&quot;\r\n  ],\r\n  2\r\n]\r\n[\r\n  [\r\n    &quot;foo&quot;,\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;,\r\n    &quot;a&quot;\r\n  ],\r\n  1\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;,\r\n    &quot;b&quot;\r\n  ],\r\n  2\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;,\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;\r\n  ]\r\n]\r\n```\r\n\r\nwhile with truncation, `. as $dot | (1|truncate_stream($dot | tostream))`, the structure is:\r\n\r\n```\r\n[\r\n  [\r\n    &quot;a&quot;\r\n  ],\r\n  1\r\n]\r\n[\r\n  [\r\n    &quot;b&quot;\r\n  ],\r\n  2\r\n]\r\n[\r\n  [\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    &quot;a&quot;\r\n  ],\r\n  1\r\n]\r\n[\r\n  [\r\n    &quot;b&quot;\r\n  ],\r\n  2\r\n]\r\n[\r\n  [\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n```\r\n\r\nSo it looks like that in order for me to construct a stream the way I need it, I will have to generate the following structure (I have inserted a `[[&quot;foo&quot;]]` after the first record is finished):\r\n\r\n```\r\n[\r\n  [\r\n    &quot;foo&quot;,\r\n    &quot;a&quot;\r\n  ],\r\n  1\r\n]\r\n[\r\n  [\r\n    &quot;foo&quot;,\r\n    &quot;b&quot;\r\n  ],\r\n  2\r\n]\r\n[\r\n  [\r\n    &quot;foo&quot;,\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    &quot;foo&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;,\r\n    &quot;a&quot;\r\n  ],\r\n  1\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;,\r\n    &quot;b&quot;\r\n  ],\r\n  2\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;,\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    &quot;bar&quot;\r\n  ]\r\n]\r\n```\r\n\r\nMaking this into a string `jq` can consume, I indeed get what I need (see also the snippet here: https://jqplay.org/s/iEkMfm_u92):\r\n\r\n```\r\nfromstream([ [ &quot;foo&quot;, &quot;a&quot; ], 1 ],[ [ &quot;foo&quot;, &quot;b&quot; ], 2 ],[ [ &quot;foo&quot;, &quot;b&quot; ] ],[[&quot;foo&quot;]],[ [ &quot;bar&quot;, &quot;a&quot; ], 1 ],[ [ &quot;bar&quot;, &quot;b&quot; ], 2 ],[ [ &quot;bar&quot;, &quot;b&quot; ] ],[ [ &quot;bar&quot; ] ])\r\n```\r\n\r\nyielding:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  }\r\n}\r\n{\r\n  &quot;bar&quot;: {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  }\r\n}\r\n```\r\n\r\nThe final result (see https://jqplay.org/s/-UgbEC4BN8) would be:\r\n\r\n```\r\nfromstream([ [ &quot;foo&quot;, &quot;a&quot; ], 1 ],[ [ &quot;foo&quot;, &quot;b&quot; ], 2 ],[ [ &quot;foo&quot;, &quot;b&quot; ] ],[[&quot;foo&quot;]],[ [ &quot;bar&quot;, &quot;a&quot; ], 1 ],[ [ &quot;bar&quot;, &quot;b&quot; ], 2 ],[ [ &quot;bar&quot;, &quot;b&quot; ] ],[ [ &quot;bar&quot; ] ]) | with_entries(.value += {key}) | .[]\r\n```\r\n\r\nyielding\r\n\r\n```\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;key&quot;: &quot;foo&quot;\r\n}\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;key&quot;: &quot;bar&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55773054/streaming-without-truncating",
        "title": "Streaming without truncating"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1555801369,
                "last_edit_date": 1555801369,
                "creation_date": 1555781662,
                "answer_id": 55776053,
                "question_id": 55775930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ jq -r &#39;\r\nreduce .ResourceTagMappingList[] as $p\r\n( { names: null, rows: null };\r\n  ( $p | { ResourceARN } + ( .Tags // [] | from_entries ) ) as $p\r\n  | .names[$p | keys_unsorted[]] = 0\r\n  | .rows += [$p]\r\n) | ( .names | keys_unsorted ) as $names\r\n| $names, ( .rows[] | [.[$names[]]] )\r\n| @csv&#39; file\r\n&quot;ResourceARN&quot;,&quot;Name&quot;,&quot;AppCluster&quot;,&quot;AppEnv&quot;,&quot;AppGroup&quot;,&quot;App01&quot;,&quot;aws:autoscaling:groupName&quot;,&quot;aws:ec2launchtemplate:id&quot;,&quot;aws:ec2launchtemplate:version&quot;\r\n&quot;arn:aws:ec2:us-east-1:027906322765228:customer-gateway/cgw-e404f4440d&quot;,&quot;useast-prod-vpn01-cisco&quot;,,,,,,,\r\n&quot;arn:aws:ec2:us-east-1:017906322765228:customer-gateway/cgw-e7a447508555e&quot;,&quot;useast-prod-vpn02-cisco&quot;,,,,,,,\r\n&quot;arn:aws:ec2:us-east-1:5079063766562328:customer-gateway/cgw-e7a44754408e&quot;,,,,,,,,\r\n&quot;arn:aws:ec2:us-east-1:07945406375465228:image/ami-012446b78ea15546fbd&quot;,&quot;processor-USE-img-18022019&quot;,,,,,,,\r\n&quot;arn:aws:ec2:us-east-1:079063765434343228:image/ami-0624f58fdf53eacd3775&quot;,,&quot;DevOpsUSE1&quot;,&quot;Image&quot;,&quot;Image&quot;,,,,\r\n&quot;arn:aws:ec2:us-east-1:079063765228:instance/i-0087f44110c478d49&quot;,,,&quot;Production&quot;,,&quot;Inst01USE1&quot;,&quot;usev-app01-ond-asg01&quot;,&quot;lt-0ec354ad560e508cc&quot;,&quot;8&quot;\r\n```",
                "title": "not able to convert json to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1555896198,
        "creation_date": 1555780684,
        "last_edit_date": 1555896198,
        "question_id": 55775930,
        "body_markdown": "finding difficult to convert json to csv using jq command\r\n```\r\n{\r\n  &quot;ResourceTagMappingList&quot;: [\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:us-east-1:027906322765228:customer-gateway/cgw-e404f4440d&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;useast-prod-vpn01-cisco&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:us-east-1:017906322765228:customer-gateway/cgw-e7a447508555e&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;useast-prod-vpn02-cisco&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:us-east-1:5079063766562328:customer-gateway/cgw-e7a44754408e&quot;\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:us-east-1:07945406375465228:image/ami-012446b78ea15546fbd&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;processor-USE-img-18022019&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:us-east-1:079063765434343228:image/ami-0624f58fdf53eacd3775&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;DevOpsUSE1&quot;,\r\n          &quot;Key&quot;: &quot;AppCluster&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Image&quot;,\r\n          &quot;Key&quot;: &quot;AppEnv&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Image&quot;,\r\n          &quot;Key&quot;: &quot;AppGroup&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:us-east-1:079063765228:instance/i-0087f44110c478d49&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;Inst01USE1&quot;,\r\n          &quot;Key&quot;: &quot;App01&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Production&quot;,\r\n          &quot;Key&quot;: &quot;AppEnv&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;usev-app01-ond-asg01&quot;,\r\n          &quot;Key&quot;: &quot;aws:autoscaling:groupName&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;lt-0ec354ad560e508cc&quot;,\r\n          &quot;Key&quot;: &quot;aws:ec2launchtemplate:id&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;8&quot;,\r\n          &quot;Key&quot;: &quot;aws:ec2launchtemplate:version&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\noutput expecting to get :\r\n```\r\n&quot;ResourceARN&quot;,&quot;Name&quot;,&quot;AppCluster&quot;,&quot;AppEnv&quot;,&quot;AppGroup&quot;,&quot;App01&quot;,&quot;aws:autoscaling:groupName&quot;,&quot;aws:ec2launchtemplate:id&quot;,&quot;aws:ec2launchtemplate:version&quot;\r\n&quot;arn:aws:ec2:us-east-1:027906322765228:customer-gateway/cgw-e404f4440d&quot;,&quot;useast-prod-vpn01-cisco&quot;,null,null,null,null,null,null,null\r\n&quot;arn:aws:ec2:us-east-1:017906322765228:customer-gateway/cgw-e7a447508555e&quot;,&quot;useast-prod-vpn02-cisco&quot;,null,null,null,null,null,null,null\r\n&quot;arn:aws:ec2:us-east-1:5079063766562328:customer-gateway/cgw-e7a44754408e&quot;,null,null,null,null,null,null,null,null\r\n&quot;arn:aws:ec2:us-east-1:07945406375465228:image/ami-012446b78ea15546fbd&quot;,&quot;processor-USE-img-18022019&quot;,null,null,null,null,null,null,null\r\n&quot;arn:aws:ec2:us-east-1:079063765434343228:image/ami-0624f58fdf53eacd3775&quot;,null,&quot;DevOpsUSE1&quot;,&quot;Image&quot;,&quot;Image&quot;,null,null,null,null\r\n&quot;arn:aws:ec2:us-east-1:079550666376445228:instance/i-0087f44110c478d49&quot;,null,null,&quot;Production&quot;,null,&quot;Inst01USE1&quot;,&quot;usev-app01-ond-asg01&quot;,&quot;lt-0ec354ad560e508cc&quot;,&quot;8&quot;\r\n```\r\n\r\nSomething I tried, but didn&#39;t able achieve:\r\n```\r\ncat resourcesfile.json | jq -rc &#39;.ResourceTagMappingList[]|{ResourceARN,tags: [ .[&quot;Tags&quot;][][&quot;Value&quot;] ]}|.[]&#39;\r\ncat resourcesfile.json | jq -r &#39;[[.ResourceTagMappingList[]|[{ResourceARN},(.Tags|from_entries)]|add]|.[]|to_entries|.[]|.key]|unique&#39; \r\ncat resourcesfile.json | jq -r &#39;[.ResourceTagMappingList[]|[[{ResourceARN},(.Tags|from_entries)]|add]|.[]|to_entries|.[]|.key]|unique as $fields | ($fields | @csv)&#39;\r\n```\r\nThanks in advance for any help.",
        "link": "https://stackoverflow.com/questions/55775930/not-able-to-convert-json-to-csv",
        "title": "not able to convert json to csv"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 42701,
                    "reputation": 1,
                    "user_id": 124486,
                    "user_type": "registered",
                    "accept_rate": 46,
                    "profile_image": "https://www.gravatar.com/avatar/605442f85418d858e2ce1e1aea2092bb?s=256&d=identicon&r=PG",
                    "display_name": "Evan Carroll",
                    "link": "https://stackoverflow.com/users/124486/evan-carroll"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628219978,
                "post_id": 55777505,
                "comment_id": 121367806,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1555792969,
                "creation_date": 1555792969,
                "answer_id": 55777582,
                "question_id": 55777505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--argjson` option instead of parameter interpolation.\r\n\r\n    jq --argjson dnb &quot;$DOMAIN_NAME_BUILT&quot; \\\r\n        &#39;.Origins.Items[0].DomainName = $dnb&#39; distconfig.json &gt; &quot;$tmp&quot; &amp;&amp;\r\n      mv &quot;$tmp&quot; distconfig.json\r\n\r\n(Your immediate issue is that parameter expansion doesn&#39;t occur inside single quotes, but building a static filter that takes an argument is safer than building a filter dynamically.)",
                "title": "How to concatenate jq with variables?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1555792969,
        "creation_date": 1555792467,
        "question_id": 55777505,
        "body_markdown": "I have a json object I am reading with jq and trying to write some properties with local variables. \r\n\r\n\r\n\r\nI am setting local variable in my shell script like so: \r\n```\r\nLOCATION_NAME=&quot;stag5&quot;\r\nDOMAIN_LOCATION=&quot;example.io&quot;\r\n```\r\n\r\nI am then building out the following variable: \r\n\r\n```\r\n\r\necho &quot;Build New ID&quot;\r\n\r\nDOMAIN_NAME_BUILT=&quot;$LOCATION_NAME.$DOMAIN_LOCATION.s3-website.us-east-2.amazonaws.com&quot;\r\n\r\n\r\n```\r\n\r\n\r\nI am trying to read my `distconfig.json` file and set the properties with the above variables. \r\n\r\n```\r\ntmp=$(mktemp)\r\njq &#39;.Origins.Items[0].DomainName = &quot;$DOMAIN_NAME_BUILT&quot;&#39; distconfig.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; distconfig.json\r\n```\r\n\r\nThe command is working, but it is passing in the variable as a string to my new json file. \r\nSo when I view the property in the new created json file it is being saved as `&quot;$DOMAIN_NAME_BUILT&quot;` instead of `stag5.example.io.s3-website.us-east-2.amazonaws.com`\r\n\r\nHow can I instead of passing the string pass the variable for $DOMAIN_NAME_BUILT and write it to the new json file",
        "link": "https://stackoverflow.com/questions/55777505/how-to-concatenate-jq-with-variables",
        "title": "How to concatenate jq with variables?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1555802612,
                "last_edit_date": 1555802612,
                "creation_date": 1555800730,
                "answer_id": 55778435,
                "question_id": 55778231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "pipe should be **inside the filter**. and, consider using assignment operator to shorten your code:\r\n```\r\njq --arg dnb &quot;$DOMAIN_NAME_BUILT&quot; \\\r\n   --arg origin &quot;$DOMAIN_ID_BUILT&quot; \\\r\n   &#39;.Origins.Items[0] |= ( .DomainName = $dnb | .Id = $origin )&#39; \\\r\ndistconfig.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; distconfig.json\r\n```",
                "title": "how to pass multiple args into jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1555802612,
        "creation_date": 1555798668,
        "question_id": 55778231,
        "body_markdown": "I am trying to write a new json file. I want to define multiple variables then set them with piping to different properties in the new json file.\r\n\r\n\r\n```\r\njq --arg dnb &quot;$DOMAIN_NAME_BUILT&quot; --arg origin &quot;$DOMAIN_ID_BUILT&quot; \\ \r\n   &#39;.Origins.Items[0].DomainName = $dnb&#39; | &#39;.Origins.Items[0].Id = $origin&#39; distconfig.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; distconfig.json\r\n```\r\n\r\nThis works with just one variable: --arg NAME VALUE pattern, but when I add in a second arg and use piping `jq ... &#39;x1 = y1 | x2 = y2, e.g.` it breaks.",
        "link": "https://stackoverflow.com/questions/55778231/how-to-pass-multiple-args-into-jq",
        "title": "how to pass multiple args into jq?"
    },
    {
        "tags": [
            "curl",
            "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": 1555953715,
                "post_id": 55791097,
                "comment_id": 98265641,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1555920228,
                "last_edit_date": 1592644375,
                "creation_date": 1555920228,
                "answer_id": 55791140,
                "question_id": 55791097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# Solution #\n&gt; remove the -i flag\n\nSolution courtesy of https://github.com/stedolan/jq/issues/1119",
                "title": "Curl Response with JQ parising error : parse error: Invalid numeric literal at line 1, column 9"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1555920228,
        "creation_date": 1555920014,
        "last_edit_date": 1592644375,
        "question_id": 55791097,
        "body_markdown": "I ran into this issue and didn&#39;t find any reference on stackoverflow, someone may find this useful... Saving a json response of curl to a variable with -i flag may yield unexpected result.\n\n&lt;pre&gt;\njq --version\njq-1.5\n\ncurl --version\ncurl 7.58.0 (x86_64-w65-mingw32)\n&lt;/pre&gt;\n\n# Problem #\nSave curl response to a variable json with -i flag\n\n```` json=$(curl http://www.jsonresourcehere.com -i) ````\n\necho output will show json result \n\n```` echo $json ````\n\n\n\nhowever, performing a jq filter will yields... parse error: Invalid numeric literal at line 1, column 9\n\n&lt;pre&gt;echo $json | jq &#39;.property&#39;\nparse eror: Invalid numeric literal at line1, column 9\n&lt;/pre&gt;\n",
        "link": "https://stackoverflow.com/questions/55791097/curl-response-with-jq-parising-error-parse-error-invalid-numeric-literal-at-l",
        "title": "Curl Response with JQ parising error : parse error: Invalid numeric literal at line 1, column 9"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 115497,
                    "reputation": 20444,
                    "user_id": 303270,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/4ad1c6176652d437e0fadb39ff275323?s=256&d=identicon&r=PG",
                    "display_name": "fardjad",
                    "link": "https://stackoverflow.com/users/303270/fardjad"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556006684,
                "post_id": 55806642,
                "comment_id": 98281157,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15796489,
                    "reputation": 63,
                    "user_id": 11398153,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-kTj398PfFgY/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfKal9zc1fHf21Z9QW7mrmOaTJM1Q/mo/s256-rj/photo.jpg",
                    "display_name": "Woori Roh",
                    "link": "https://stackoverflow.com/users/11398153/woori-roh"
                },
                "reply_to_user": {
                    "account_id": 115497,
                    "reputation": 20444,
                    "user_id": 303270,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/4ad1c6176652d437e0fadb39ff275323?s=256&d=identicon&r=PG",
                    "display_name": "fardjad",
                    "link": "https://stackoverflow.com/users/303270/fardjad"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556060490,
                "post_id": 55806642,
                "comment_id": 98307258,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556062334,
                "last_edit_date": 1556062334,
                "creation_date": 1556020409,
                "answer_id": 55810644,
                "question_id": 55806642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the following, we use the generic function `combine` for combining two objects, as defined below.\r\n \r\nWith this function, and using an invocation such as:\r\n\r\n    jq -n -f combine.jq --slurpfile f1 file1.json --slurpfile f2 file2.json\r\n\r\nand assuming your jq has `INDEX/2`, then a solution can be obtained by simply writing:\r\n\r\n    INDEX( $f1[]; .id) as $d1\r\n    | INDEX( $f2[]; .id) as $d2\r\n    | reduce (($d1+$d2)|keys_unsorted)[] as $id\r\n        ({}; .[$id] = ($d1[$id] | combine($d2[$id])) )\r\n    | .[]\r\n\r\nThat is, we construct a dictionary for each of the two files, and then combine the objects at the corresponding keys, and then produce the desired stream.\r\n\r\nIf your installation of jq does not have `INDEX/2`, then now would be a good time to upgrade, but an alternative would be to copy its def from builtin.jq (see the &quot;comment&quot; below).  \r\n\r\n## combine/1\r\n\r\nIn the following, which is intended for jq 1.5 or later, the details of combining values are left to the inner function, `aggregate`.\r\n\r\n    # Combine . with obj using aggregate/2 for shared keys whose values differ\r\n    def combine($obj):\r\n    \r\n      # Combine two entities in an array-oriented fashion:\r\n      # if both are arrays:  a + b \r\n      # else if a is an array: a + [b]\r\n      # else if b is an array: [a] + b\r\n      # else [a, b]\r\n      def aggregate(a; b):\r\n        if (a|type) == &quot;array&quot; then\r\n          if (b|type) == &quot;array&quot; then a + b\r\n          else a + [b]\r\n          end\r\n        else\r\n          if (b|type) == &quot;array&quot; then [a] + b\r\n          else [a, b]\r\n          end\r\n        end;\r\n      \r\n      if . == null then $obj\r\n      elif $obj == null then .\r\n      else reduce ($obj|keys_unsorted[]) as $key (.;\r\n             if .[$key] == $obj[$key] then . \r\n             else .[$key] = if has($key) and ($obj|has($key))\r\n                            then aggregate( .[$key]; $obj[$key] )\r\n                            else .[$key] + $obj[$key]\r\n    \t\t        end\r\n             end )\r\n       end ;\r\n\r\n\r\n\r\n",
                "title": "How to combine and append two json files by using common key without losing other data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1556062334,
        "creation_date": 1556006176,
        "question_id": 55806642,
        "body_markdown": "I have two json files which have several json objects.\r\nI want to merge two json files on linux by using jq with group_by(.id)\r\nActually I don&#39;t need to use jq but I need to make linux shell script files.\r\n\r\nOf course I tried to many solutions but they didn&#39;t work exactly like what I want.\r\n\r\nInput 1: file1.json\r\n```\r\n{&quot;id&quot;:&quot;1234&quot;, &quot;branch&quot;: &quot;master&quot;, &quot;arr&quot;:[&quot;say&quot;, &quot;one&quot;, &quot;more&quot;]}\r\n{&quot;id&quot;:&quot;102&quot;, &quot;branch&quot;: &quot;master&quot;, &quot;arr&quot;:[&quot;yes&quot;]}\r\n{&quot;id&quot;:&quot;1228&quot;, &quot;branch&quot;: &quot;master&quot;}\r\n```\r\n\r\nInput 2: file2.json\r\n```\r\n{&quot;id&quot;:&quot;1234&quot;, &quot;branch&quot;: &quot;dev&quot;, &quot;other&quot;: &quot;value&quot;, &quot;arr&quot;:[&quot;what&quot;]}\r\n{&quot;id&quot;:&quot;102&quot;, &quot;branch&quot;: &quot;dev&quot;}\r\n{&quot;id&quot;:&quot;0806&quot;, &quot;branch&quot;: &quot;master&quot;}\r\n```\r\n\r\nWhat I expect is\r\n\r\n```\r\n{&quot;id&quot;:&quot;1234&quot;, &quot;branch&quot;: [&quot;master&quot;, &quot;dev&quot;], &quot;other&quot;: &quot;value&quot;, &quot;arr&quot;:[&quot;say&quot;, &quot;one&quot;, &quot;more&quot;, &quot;what&quot;]}\r\n{&quot;id&quot;:&quot;102&quot;, &quot;branch&quot;: [&quot;master&quot;, &quot;dev&quot;], &quot;arr&quot;:[&quot;yes&quot;]}\r\n{&quot;id&quot;:&quot;1228&quot;, &quot;branch&quot;: &quot;master&quot;}\r\n{&quot;id&quot;:&quot;0806&quot;, &quot;branch&quot;: &quot;master&quot;}\r\n```\r\n\r\nbut the actual output is like\r\n```\r\n{&quot;id&quot;:&quot;1234&quot;, &quot;branch&quot;: &quot;dev&quot;, &quot;other&quot;: &quot;value&quot;, &quot;arr&quot;:[&quot;what&quot;]}\r\n{&quot;id&quot;:&quot;102&quot;, &quot;branch&quot;: &quot;dev&quot;}\r\n{&quot;id&quot;:&quot;0806&quot;, &quot;branch&quot;: &quot;master&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/55806642/how-to-combine-and-append-two-json-files-by-using-common-key-without-losing-othe",
        "title": "How to combine and append two json files by using common key without losing other data"
    },
    {
        "tags": [
            "json",
            "jq",
            "filemerge"
        ],
        "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": 2,
                "creation_date": 1556015540,
                "post_id": 55807612,
                "comment_id": 98285756,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2567288,
                    "reputation": 20882,
                    "user_id": 2226988,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5c6fbec3a71b2e95e4a6e41478deb379?s=256&d=identicon&r=PG",
                    "display_name": "Tom Blodget",
                    "link": "https://stackoverflow.com/users/2226988/tom-blodget"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556039281,
                "post_id": 55807612,
                "comment_id": 98299154,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15125733,
                    "reputation": 7,
                    "user_id": 10915103,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-jCZVZmer2WQ/AAAAAAAAAAI/AAAAAAAAAOs/2IH_fUbQGvk/s256-rj/photo.jpg",
                    "display_name": "Nitin Rao",
                    "link": "https://stackoverflow.com/users/10915103/nitin-rao"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556090427,
                "post_id": 55807612,
                "comment_id": 98314038,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2567288,
                    "reputation": 20882,
                    "user_id": 2226988,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5c6fbec3a71b2e95e4a6e41478deb379?s=256&d=identicon&r=PG",
                    "display_name": "Tom Blodget",
                    "link": "https://stackoverflow.com/users/2226988/tom-blodget"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556246168,
                "post_id": 55807612,
                "comment_id": 98380912,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1557777900,
                "creation_date": 1557777900,
                "answer_id": 56119194,
                "question_id": 55807612,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since `jq` doesn&#39;t require a valid JSON to read in a file, any JSON stream will do, I would suggest you just append the two files \r\n\r\n`cat file1.json &gt;&gt; file2.json`\r\n\r\n\r\nThat said, I believe you can use `jq -s &#39;.[0] * .[1]&#39; file1 file2` to merge two JSON files\r\n\r\nSee: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq",
                "title": "To output the merged file into a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1557777900,
        "creation_date": 1556009791,
        "last_edit_date": 1556010036,
        "question_id": 55807612,
        "body_markdown": "Please let me know how to merge 2 json files into a new json file.\r\n\r\nI used jq , and used the below command: \r\n\r\n```\r\njq -s add file1.json file2.json &gt; Output.json\r\n```\r\n\r\nBut I am not getting the output in json ascii encode. While pasing I get an error : \r\n&gt; Failed to parse template: Error parsing JSON: invalid character &#39;&#255;&#39; looking for beginning of value\r\n\r\nPlease let me know how can I output to json file in a windows command prompt.",
        "link": "https://stackoverflow.com/questions/55807612/to-output-the-merged-file-into-a-json-file",
        "title": "To output the merged file into a json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1556028355,
                "creation_date": 1556028355,
                "answer_id": 55813116,
                "question_id": 55812342,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unless I didn&#39;t understand what you&#39;re asking, I think there is no need for extra shell script, you can use plain `jq` script:\r\n\r\n    echo &#39;{&quot;success&quot;:true, &quot;failure&quot;:false, &quot;results&quot;:{&quot;a&quot;: &quot;...&quot;, &quot;b&quot;: &quot;...&quot;, &quot;c&quot;: &quot;...&quot;}}&#39; | jq &#39;{ success, results }&#39;\r\n\r\nThe jq script only selects the 2 objects you want. Note the shorter form that uses 1 keyword per object (instead of `&quot;success&quot;:.success`).\r\n\r\n    echo &#39;{&quot;success&quot;:true, &quot;failure&quot;:false, &quot;results&quot;:{&quot;a&quot;: &quot;...&quot;, &quot;b&quot;: &quot;...&quot;, &quot;c&quot;: &quot;...&quot;}}&#39; | jq &#39;{ success, &quot;results.b&quot;:.results.b }&#39;    \r\n\r\nThis script is almost the same except that the object name is explicit.\r\n\r\n\r\n",
                "title": "jq select subset of nested keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1556032828,
        "creation_date": 1556026041,
        "question_id": 55812342,
        "body_markdown": "I&#39;m trying to build a SQL layer on top of jq for json files and I would like to implement the select. So far I got that:\r\n\r\n```\r\n function join() {\r\n     # If no arguments, do nothing.\r\n     # This avoids confusing errors in some shells.\r\n     if [ $# -eq 0 ]; then\r\n         return\r\n     fi\r\n\r\n     local joiner=&quot;$1&quot;\r\n     shift\r\n\r\n     while [ $# -gt 1 ]; do\r\n         printf &quot;%s%s&quot; &quot;$1&quot; &quot;$joiner&quot;\r\n         shift\r\n     done\r\n\r\n     printf &#39;%s\\n&#39; &quot;$1&quot;\r\n }\r\n\r\n function jselect {\r\n     keys=`join &quot;\\&quot;:1, \\&quot;&quot; $@`\r\n     jq &quot;with_entries(select(.key | in({\\&quot;$keys\\&quot;:1})))&quot;\r\n }\r\n```\r\n\r\nallows me to do\r\n\r\n```\r\n$ echo &#39;{&quot;success&quot;:true, &quot;failure&quot;:false, &quot;results&quot;:{&quot;a&quot;: &quot;...&quot;, &quot;b&quot;: &quot;...&quot;, &quot;c&quot;: &quot;...&quot;}}&#39; | jselect success results\r\n\r\n&gt;&gt;&gt; {\r\n  &quot;success&quot;: true,\r\n  &quot;results&quot;: {\r\n    &quot;a&quot;: &quot;...&quot;,\r\n    &quot;b&quot;: &quot;...&quot;,\r\n    &quot;c&quot;: &quot;...&quot;\r\n  }\r\n}\r\n```\r\n\r\nbut I would like to be able to index nested properties as well something like:\r\n\r\n```\r\n$ echo &#39;{&quot;success&quot;:true, &quot;failure&quot;:false, &quot;results&quot;:{&quot;a&quot;: &quot;...&quot;, &quot;b&quot;: &quot;...&quot;, &quot;c&quot;: &quot;...&quot;}}&#39; | jselect success results\r\n\r\n&gt;&gt;&gt; {\r\n  &quot;success&quot;: true,\r\n  &quot;results&quot;: {\r\n    &quot;b&quot;: &quot;...&quot;\r\n  }\r\n}\r\n\r\nor\r\n\r\n&gt;&gt;&gt; {\r\n  &quot;success&quot;: true,\r\n  &quot;results.b&quot;: &quot;...&quot;\r\n}\r\n```\r\n\r\nAny idea?",
        "link": "https://stackoverflow.com/questions/55812342/jq-select-subset-of-nested-keys",
        "title": "jq select subset of nested keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1556036875,
                "creation_date": 1556036875,
                "answer_id": 55815647,
                "question_id": 55815623,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\necho $json |jq &#39;.StackSummaries[]&#39; | jq --arg kill $killdate &#39;select (.CreationTime &lt; $kill ) | .CreationTime&#39;\r\n```\r\nThe argument needs to come from outside the selection :/ \r\n\r\nthanks",
                "title": "Im looking to find AWS instances over X days old to shut down"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1585642967,
        "creation_date": 1556036806,
        "last_edit_date": 1592644375,
        "question_id": 55815623,
        "body_markdown": "This is part of a bigger project but I am in this first instance trying to collate AWS instances over X days old.\nI am struggling to work with the formatted dates or jq :/ \n\n\n\nI have tried a number of formatting ideas (unix time, short date etc)\nUltimately it would be easier to work with the date field in the json that is brought back by the awscli\n\n\n\nExample JSON\n\n```\naws cloudformation list-stacks\n```\n```\n{\n    &quot;StackSummaries&quot;: [\n       {\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:eu-029e8e947a9c&quot;, \n            &quot;DriftInformation&quot;: {\n                &quot;StackDriftStatus&quot;: &quot;NOT_CHECKED&quot;\n            }, \n            &quot;TemplateDescription&quot;: &quot;Testing - SINGLE&quot;, \n            &quot;CreationTime&quot;: &quot;2019-04-23T15:25:22.757Z&quot;, \n            &quot;StackName&quot;: &quot;HAPPYHARRY123456789&quot;, \n            &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;\n        }, \n        {\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:eu-0a4e84363f34&quot;, \n            &quot;DriftInformation&quot;: {\n                &quot;StackDriftStatus&quot;: &quot;NOT_CHECKED&quot;\n            }, \n            &quot;TemplateDescription&quot;: &quot;Testing - SINGLE&quot;, \n            &quot;CreationTime&quot;: &quot;2019-04-15T14:31:42.515Z&quot;, \n            &quot;StackName&quot;: &quot;HAPPYHARRY123789456&quot;, \n            &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;\n        }, \n        {\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:eu-50faeb5394d2&quot;, \n            &quot;LastUpdatedTime&quot;: &quot;2018-01-23T15:44:53.640Z&quot;, \n            &quot;TemplateDescription&quot;: &quot;Lambda Gateway&quot;, \n            &quot;CreationTime&quot;: &quot;2018-01-23T15:44:48.134Z&quot;, \n            &quot;StackName&quot;: &quot;BARRYLAMBDA&quot;, \n            &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;, \n            &quot;DriftInformation&quot;: {\n                &quot;StackDriftStatus&quot;: &quot;NOT_CHECKED&quot;\n            }\n        }\n    ]\n}\n```\n\n\nI am looking for a date to kill the cloudformation\nI&#39;ve tried lots of date formatting including using jq to extract CreationTime and covert to Unix time and minus from today in Unix time.. blah, blah, blah\n\n\nNow I&#39;m here...\nI created an iso time to match the aws time\n\n```\n#how far back do I wish\ndaysback=7 \n\n#iso date of today\ntoday=$(date -u +&quot;%Y-%m-%dT%H:%M:%S.000Z&quot;) \n\n#take daysback from indicated time of aws instance\nkilldate=`date -d &quot;$today - $daysback days&quot; +&quot;%Y-%m-%dT%H:%M:%S.000Z&quot;` \n\n#the killdate &gt; kill all older than\necho $killdate\n\n#2019-04-16T16:10:20.000Z\n```\n\n\npseudo I want \nlooking in json, find any stack with a date further back than killdate and list stack name only if starts with HAPPY which I achieve with\n```\necho $json |jq &#39;.StackSummaries[]&#39; | jq -r &#39;select (.CreationTime&gt;&quot;$killdate&quot;) | .StackName&#39; | awk &#39;/^HAPPY/&#39;\n```\n\nI am using this to prove my syntax\n\nThis gives me no output\n```\necho $json |jq &#39;.StackSummaries[]&#39; | jq &#39;select (.CreationTime&lt;&quot;$killdate&quot;) | .CreationTime&#39;\n```\n\nThis gives me everything\n```\necho $json |jq &#39;.StackSummaries[]&#39; | jq &#39;select (.CreationTime&gt;&quot;$killdate&quot;) | .CreationTime&#39;\n```\n\nI would have expected the below\n```\n&quot;2019-04-15T14:31:42.515Z&quot;\n&quot;2018-01-23T15:44:48.134Z&quot;\n```\nand once returning the stackname instead\n```\n&quot;HAPPYHARRY123789456&quot;\n```\n\nCan anyone see where im going wrong and why it isnt returning what i wish??\n\n\n# FOUND MY ANSWER WHILST WRITING THIS SO PUT IT HERE FOR OTHERS\n```\necho $json |jq &#39;.StackSummaries[]&#39; | jq --arg kill $killdate &#39;select (.CreationTime &lt; $kill ) | .CreationTime&#39;\n```",
        "link": "https://stackoverflow.com/questions/55815623/im-looking-to-find-aws-instances-over-x-days-old-to-shut-down",
        "title": "Im looking to find AWS instances over X days old to shut down"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq",
            "chronological"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1556069556,
                "last_edit_date": 1556069556,
                "creation_date": 1556038347,
                "answer_id": 55816000,
                "question_id": 55815888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ jq -r &#39;.Images | map(select(.Name | index(&quot;stable&quot;))) | max_by(.CreationDate).Name&#39; file\r\nCoreOS-stable-600.3.0\r\n```\r\nsince `contains` is a bit overkill for checking a string for its containment in another string, `index` is used instead.  \r\n`max_by` is used because it avoids sorting and yields the element with max. `CreationDate`. ",
                "title": "Selecting and filtering latest element in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1556069556,
        "creation_date": 1556037848,
        "last_edit_date": 1556048733,
        "question_id": 55815888,
        "body_markdown": "I have the following sample data:\r\n\r\n```\r\n{\r\n    &quot;Images&quot;: [\r\n        {\r\n            &quot;Name&quot;: &quot;CoreOS-alpha-1939.0.0-hvm&quot;,\r\n            &quot;CreationDate&quot;: &quot;2014-12-24T23:00:48.000Z&quot;\r\n        },\r\n        {\r\n            &quot;Name&quot;: &quot;CoreOS-stable-522.3.0&quot;,\r\n            &quot;CreationDate&quot;: &quot;2014-12-24T23:00:48.000Z&quot;\r\n        },\r\n        {\r\n            &quot;Name&quot;: &quot;CoreOS-stable-600.3.0&quot;,\r\n            &quot;CreationDate&quot;: &quot;2019-12-24T23:00:48.000Z&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI&#39;m trying to get the `Name` of the most recent (by `CreationDate`) image that contains &quot;stable&quot; in its `Name`.\r\n\r\nMy naive attempt is:\r\n\r\n```\r\njq &#39;.Images[] | select(.Name | contains(&quot;stable&quot;)) |= sort_by(.CreationDate)&#39; data.json\r\n```\r\nHowever this is giving me an error, and would only sort them by `CreationDate` (not only return the latest one)",
        "link": "https://stackoverflow.com/questions/55815888/selecting-and-filtering-latest-element-in-array",
        "title": "Selecting and filtering latest element in array"
    },
    {
        "tags": [
            "variables",
            "pipeline",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556138916,
                "post_id": 55837980,
                "comment_id": 98340660,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1459537,
                    "reputation": 2337,
                    "user_id": 1597106,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/3c189c06ba07211c1e81c5e7b5dcbd56?s=256&d=identicon&r=PG",
                    "display_name": "antun",
                    "link": "https://stackoverflow.com/users/1597106/antun"
                },
                "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": 1556139421,
                "post_id": 55837980,
                "comment_id": 98340865,
                "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": 1556140481,
                "post_id": 55837980,
                "comment_id": 98341270,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556139360,
                "creation_date": 1556139360,
                "answer_id": 55838422,
                "question_id": 55837980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your jq filter could be fixed with a couple of parentheses:\r\n\r\n    (.vertices\r\n     | range(0;length) as $i\r\n     | select(.[$i].alias==&quot;polarized&quot; and .[$i].ns==&quot;ca&quot;)\r\n     | $i) as $i\r\n    | .edgeGroups.hasAttributeValue[]\r\n    | select(.[0] == $i)\r\n\r\n\r\n",
                "title": "Use a jq range variable to feed into a new jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1556228681,
        "creation_date": 1556137304,
        "last_edit_date": 1556155589,
        "question_id": 55837980,
        "body_markdown": "I have some JSON that looks like this:\r\n\r\n    {\r\n        &quot;vertices&quot;: [\r\n            {\r\n             &quot;id&quot;: 71597,\r\n              &quot;ns&quot;: &quot;ca&quot;,\r\n              &quot;alias&quot;: &quot;polarized&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 129748,\r\n              &quot;ns&quot;: &quot;av&quot;,\r\n              &quot;name&quot;: &quot;Polarized&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 129898,\r\n              &quot;ns&quot;: &quot;av&quot;,\r\n              &quot;name&quot;: &quot;False&quot;\r\n            }\r\n        ],\r\n        &quot;edgeGroups&quot;: {\r\n            &quot;hasAttributeValue&quot;: [\r\n                [\r\n                  0,\r\n                  1\r\n                ],\r\n                [\r\n                  0,\r\n                  2\r\n                ]\r\n            ]\r\n        }\r\n    }\r\n\r\nThe various entries in `.vertices` are related by their array index. So in this case, the first vertex (id: 71597 - with an array index of 0) has attribute values 129748 and 129898 (with array indices 1 and two respectively).\r\n\r\nI can get the array index for the attribute I&#39;m searching for with the following jq filter:\r\n\r\n`.vertices | range(0;length) as $i | select(.[$i].alias==&quot;polarized&quot; and .[$i].ns==&quot;ca&quot;) | $i`\r\n\r\nThat returns an $i value of 0, since the object with alias &quot;polarized&quot; is the first item in the array. You can try it out here on jq play:\r\n\r\nhttps://jqplay.org/s/DsHYi7ixyn\r\n\r\nNow I want to **use that $i value** in a different filter, so instead of outputting 0 it outputs something like the result of this:\r\n\r\n`.edgeGroups.hasAttributeValue[] | select(.[0] == 0)`\r\n\r\nI&#39;ve tried using the pipe operator like this but it just gives me an error:\r\n\r\n`.vertices | range(0;length) as $i | select(.[$i].alias==&quot;polarized&quot; and .[$i].ns==&quot;ca&quot;) | .edgeGroups.hasAttributeValue[] | select(.[0] == $i)` \r\n\r\nIf I could understand how to use the $i in a chained filter, I think I could solve my main goal, which is to chain several filters together so that I can get all the items associated with the 71597 object - i.e.\r\n\r\n```\r\n        {\r\n          &quot;id&quot;: 129748,\r\n          &quot;ns&quot;: &quot;av&quot;,\r\n          &quot;name&quot;: &quot;Polarized&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 129898,\r\n          &quot;ns&quot;: &quot;av&quot;,\r\n          &quot;name&quot;: &quot;False&quot;\r\n        }\r\n```\r\n\r\nThanks for any help in advance!",
        "link": "https://stackoverflow.com/questions/55837980/use-a-jq-range-variable-to-feed-into-a-new-jq-filter",
        "title": "Use a jq range variable to feed into a new jq filter"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1556156800,
                "post_id": 55840662,
                "comment_id": 98344706,
                "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": 1556157079,
                "post_id": 55840662,
                "comment_id": 98344768,
                "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": 1556157156,
                "post_id": 55840662,
                "comment_id": 98344784,
                "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": 1556157511,
                "post_id": 55840662,
                "comment_id": 98344847,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1556157813,
                "last_edit_date": 1556157813,
                "creation_date": 1556157296,
                "answer_id": 55840766,
                "question_id": 55840662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you run:\r\n\r\n```\r\necho new.json | jq &#39;.tags[] | .[&quot;image_id&quot;]&#39;\r\n```\r\n\r\n...the string `new.json` -- **not** the contents of the file named `new.json` -- is fed to `jq`&#39;s stdin, and is thus what it tries to parse as JSON text.\r\n\r\n[Instead, run:](https://jqplay.org/s/OpJxQ-1mQp)\r\n\r\n```\r\njq -r &#39;.tags[] | .[&quot;image_id&quot;]&#39; &lt;new.json\r\n```\r\n\r\n...to directly open `new.json` connected to the stdin of `jq` (and, with `-r`, to avoid adding unwanted quotes to the output stream).",
                "title": "Bash script to extract all specific key values from a unstructured JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1556218780,
                "creation_date": 1556218780,
                "answer_id": 55856001,
                "question_id": 55840662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Your filter `.tags[] | .[&quot;image_id&quot;]`\r\n\r\nis valid, but can be abbreviated to:\r\n\r\n    .tags[] | .image_id\r\n\r\nor even:\r\n\r\n    .tags[].image_id\r\n\r\n2. If you want the values associated with the &quot;image_id&quot; key, wherever that key occurs, you could go with:\r\n\r\n    `.. | objects | select(has(&quot;image_id&quot;)) | .image_id`\r\n\r\nOr, if you don&#39;t mind throwing away false and null values:\r\n\r\n    .. | .image_id? // empty",
                "title": "Bash script to extract all specific key values from a unstructured JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1556218780,
        "creation_date": 1556156261,
        "last_edit_date": 1556157705,
        "question_id": 55840662,
        "body_markdown": "I was trying to extract all the values from a specific key in the below JSON file.\r\n\r\n```\r\n{\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;xxx1&quot;,\r\n      &quot;image_id&quot;: &quot;yyy1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;xxx2&quot;,\r\n      &quot;image_id&quot;: &quot;yyy2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nI used the below code to get the image_id key values.\r\n\r\n```\r\necho new.json | jq &#39;.tags[] | .[&quot;image_id&quot;]&#39;\r\n```\r\n\r\nI&#39;m getting the below error message. \r\n\r\n```none\r\nparse error: Invalid literal at line 2, column 0\r\n```\r\n\r\nI think either the JSON file is not in the proper format OR the echo command to call the Json file is wrong.\r\n\r\nGiven the above input, my intended/desired output is:\r\n\r\n```none\r\nyyy1\r\nyyy2\r\n```\r\n\r\nWhat needs to be fixed to make this happen?",
        "link": "https://stackoverflow.com/questions/55840662/bash-script-to-extract-all-specific-key-values-from-a-unstructured-json-file",
        "title": "Bash script to extract all specific key values from a unstructured JSON file"
    },
    {
        "tags": [
            "json",
            "jq",
            "git-bash"
        ],
        "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": 1556292643,
                "post_id": 55841335,
                "comment_id": 98401429,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556162798,
                "creation_date": 1556162798,
                "answer_id": 55841388,
                "question_id": 55841335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Changes the output format slightly:\r\n\r\n    jq -r &#39;.data.Layer| .Features[] | .Name ,.Version, .Vulnerabilities[].Severity&#39; input\r\n\r\nBut this also works:\r\n\r\n    jq -r &#39;.data.Layer| .Features[] | &quot;\\(.Name)  \\(.Version)  \\(.Vulnerabilities[].Severity)&quot;&#39; input",
                "title": "jq: error : Cannot iterate over null (null)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556228377,
                "last_edit_date": 1556228377,
                "creation_date": 1556187956,
                "answer_id": 55847128,
                "question_id": 55841335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if an alternative solution is acceptable, let me offer you a solution based on a walk-path unix tool for JSON: **[`jtc`][1]** (accommodating your comment to William):\r\n\r\nThis way, you&#39;ll collect `Name`, `Version` and `Severity` only predicated `Severity` record is present in `Vulnerabilities` (and, obviously, if `Vulnerabilities` record exists):\r\n\r\n    bash $ &lt;status.json jtc -x&#39;&lt;Features&gt;l[:][Vulnerabilities]&lt;Severity&gt;l[^4]&#39; -y&#39;[Name]&#39; -y&#39;[Version]&#39; -y&#39;&lt;Severity&gt;l&#39; \r\n    &quot;openssl1.0&quot;\r\n    &quot;1.0.2q-1~deb9u1&quot;\r\n    &quot;Medium&quot;\r\n    &quot;nettle&quot;\r\n    &quot;3.3-1&quot;\r\n    &quot;Low&quot;\r\n    bash $ \r\n\r\nAnd, if you like to group those on each line, pipe it to `xargs`, or `paste`:\r\n\r\n    bash $ &lt;status.json jtc -x&#39;&lt;Features&gt;l[:][Vulnerabilities]&lt;Severity&gt;l[^4]&#39; -y&#39;[Name]&#39; -y&#39;[Version]&#39; -y&#39;&lt;Severity&gt;l&#39; | xargs -L3\r\n    openssl1.0 1.0.2q-1~deb9u1 Medium\r\n    nettle 3.3-1 Low\r\n    bash $ \r\n\r\nDisclosure: I&#39;m the creator of `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n",
                "title": "jq: error : Cannot iterate over null (null)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709540035,
                "creation_date": 1709540035,
                "answer_id": 78099770,
                "question_id": 55841335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use `Vulnerabilities[]?` instead of `[]` jq will just skip the Features which don&#39;t have a Vulnerability.",
                "title": "jq: error : Cannot iterate over null (null)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1709540035,
        "creation_date": 1556162366,
        "last_edit_date": 1556165675,
        "question_id": 55841335,
        "body_markdown": "In the below Json file, I am trying to extract &quot;Name&quot;: &quot;abcd&quot;,&quot;Version&quot;: &quot;1.0.2&quot; and &quot;Severity&quot;: &quot;Medium&quot;. \r\n\r\n   \r\n\r\n    &quot;status&quot;: &quot;scanned&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;Layer&quot;: {\r\n                &quot;IndexedByVersion&quot;: 3,\r\n                &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                &quot;ParentName&quot;: &quot;e762&quot;,\r\n                &quot;Name&quot;: &quot;.4530bfac-5e99-4138-b071-4286c06669a3&quot;,\r\n                &quot;Features&quot;: [\r\n                    {\r\n                        &quot;Name&quot;: &quot;openssl1.0&quot;,\r\n                        &quot;VersionFormat&quot;: &quot;dpkg&quot;,\r\n                        &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                        &quot;AddedBy&quot;: &quot;85aa73fb8281cc252ed7e151f10386f36588ec6c967d45136103a4e1e705a81c.01bc7eff-9a5d-43f5-ab14-2e3e470cba77&quot;,\r\n                        &quot;Version&quot;: &quot;1.0.2q-1~deb9u1&quot;,\r\n                        &quot;Vulnerabilities&quot;: [\r\n                            {\r\n                                &quot;Severity&quot;: &quot;Medium&quot;,\r\n                                &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                                &quot;Link&quot;: &quot;xxxx&quot;,\r\n                                &quot;FixedBy&quot;: &quot;1.0.2r-1~deb9u1&quot;,\r\n                                &quot;Description&quot;: &quot; n must call SSL_shutdown() twice even if a protocol error has occurred (applications should not do this but some do anyway). Fixed in OpenSSL 1.0.2r (Affected 1.0.2-1.0.2q).&quot;,\r\n                                &quot;Name&quot;: &quot;CVE-2019-1559&quot;,\r\n                                &quot;Metadata&quot;: {\r\n                                    &quot;NVD&quot;: {\r\n                                        &quot;CVSSv2&quot;: {\r\n                                            &quot;Score&quot;: 4.3,\r\n                                            &quot;Vectors&quot;: &quot;AV:N/AC:M/Au:N/C:P/I:N&quot;\r\n                                        }\r\n                                    }\r\n                                }\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;VersionFormat&quot;: &quot;dpkg&quot;,\r\n                        &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                        &quot;Version&quot;: &quot;0.16-1+deb9u1&quot;,\r\n                        &quot;Name&quot;: &quot;libidn2-0&quot;,\r\n                        &quot;AddedBy&quot;: &quot;85aa73fb8281cc252ed7e151f10386f36588ec6c967d45136103a4e1e705a81c.01bc7eff-9a5d-43f5-ab14-2e3e470cba77&quot;\r\n                    },\r\n                    {\r\n                        &quot;VersionFormat&quot;: &quot;dpkg&quot;,\r\n                        &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                        &quot;Version&quot;: &quot;0.29-4&quot;,\r\n                        &quot;Name&quot;: &quot;pkg-config&quot;,\r\n                        &quot;AddedBy&quot;: &quot;4d2169f1dc7652ffd2a4f32d2c0ae2\r\n                    },\r\n                    \r\n                    \r\n                    {\r\n                        &quot;Name&quot;: &quot;nettle&quot;,\r\n                        &quot;VersionFormat&quot;: &quot;dpkg&quot;,\r\n                        &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                        &quot;AddedBy&quot;: &quot;7494d6c991278b43e8388f7cec2f138075\r\n                        &quot;Version&quot;: &quot;3.3-1&quot;,\r\n                        &quot;Vulnerabilities&quot;: [\r\n                            {\r\n                                &quot;Severity&quot;: &quot;Low&quot;,\r\n                                &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n                                &quot;Link&quot;: &quot;xxxx&quot;,\r\n                                &quot;Description&quot;: &quot;er.&quot;,\r\n                                &quot;Name&quot;: &quot;CVE-2018-16869&quot;,\r\n                                &quot;Metadata&quot;: {\r\n                                    &quot;NVD&quot;: {\r\n                                        &quot;CVSSv2&quot;: {\r\n                                            &quot;Score&quot;: 3.3,\r\n                                            &quot;Vectors&quot;: &quot;:P&quot;\r\n                                        }\r\n\r\nSo far I am able to extract the values of Name &amp; version using the jq command below.\r\n\r\n    jq -r &#39;.data.Layer| .Features[] | &quot;\\(.Name) \\(.Version)&quot;&#39; status.json\r\nbut when I try to extract values of &quot;Severity&quot; field using the below command \r\n\r\n    `jq -r &#39;.data.Layer| .Features[] | &quot;\\(.Name) \\(.Version)&quot;| .Vulnerabilities[].Severity&#39; status.json`\r\n I get the error message in the title.\r\n\r\n    Required output: abcd 12.0 medium\r\nAny help is much appreciated.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55841335/jq-error-cannot-iterate-over-null-null",
        "title": "jq: error : Cannot iterate over null (null)"
    },
    {
        "tags": [
            "json",
            "bash",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1556193741,
                "creation_date": 1556193741,
                "answer_id": 55848872,
                "question_id": 55848752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For session id, it is looking for quotes. For response status, it is not quoted.\r\n\r\n    grep -m1  -oP &#39;\\s*&quot;response_status&quot;\\s*:\\s*\\K[^,]+&#39; RGLogin.json",
                "title": "Bash grep JSON Response"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1556227727,
                "last_edit_date": 1556227727,
                "creation_date": 1556194514,
                "answer_id": 55849090,
                "question_id": 55848752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "ideologically, a correct way to resolve such asks would be to use tools which are aware of the data format. I.e. if it&#39;s JSON then json-aware tool must be used (and line-aware tools like `grep` should be use for linear/non-nested data structures).\r\n\r\nE.g., for your JSON structure, to extract the required info using a walk-path unix tool for JSON: **[`jtc`][1]**:\r\n\r\n    bash $ &lt;RGLogin.json jtc -w&#39;[response_status]&#39;\r\n    200\r\n    bash $ \r\n\r\nDisclosure: I&#39;m the creator of `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n",
                "title": "Bash grep JSON Response"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556196520,
                "creation_date": 1556196520,
                "answer_id": 55849681,
                "question_id": 55848752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In addition to the answer of @Dmitry\r\n\r\nI use always the php interpreter for analyzing json data. But other script languages are possible too. Here is my bash/php solution to get both values:\r\n\r\n    #!/bin/bash\r\n\r\n    # define json string (get it from source)\r\n    json=&#39;{&quot;response&quot;:{&quot;session_id&quot;:&quot;2d48cc11ceabf28c9e92f4b677337dcd&quot;},&quot;response_status&quot;:200,&quot;response_details&quot;:null}&#39;\r\n\r\n    # execute php script and eval the results\r\n    eval $( php &lt;&lt;- __EOT__\r\n            &lt;?PHP\r\n            # php dollar sign must be escaped\r\n            \\$data = json_decode(&#39;$json&#39;);\r\n\r\n            # print results in bash set-var format\r\n            printf(&quot;session_id=\\&quot;%s\\&quot;\\nresponse_status=\\&quot;%s\\&quot;\\n&quot;,\r\n                    \\$data-&gt;response-&gt;session_id,\r\n                    \\$data-&gt;response_status );\r\n            ?&gt;\r\n            # end-of-text marker must be placed at first column, \r\n            # or can be indented by real TABS (not SPACES).\r\n    __EOT__\r\n            )\r\n\r\n    # show params in bash\r\n    echo &quot;session_id      : $session_id&quot;\r\n    echo &quot;response_status : $response_status&quot;\r\n\r\nAnd the output is:\r\n\r\n    session_id      : 2d48cc11ceabf28c9e92f4b677337dcd\r\n    response_status : 200\r\n",
                "title": "Bash grep JSON Response"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1556208896,
                "last_edit_date": 1556208896,
                "creation_date": 1556205293,
                "answer_id": 55852599,
                "question_id": 55848752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "grep is not the right tool for parsing JSON. Use [tag:jq] instead:\r\n```\r\n$ jq -r &#39;.response_status&#39; RGLogin.json\r\n200\r\n$\r\n$ jq -r &#39;.response.session_id&#39; RGLogin.json\r\n2d48cc11ceabf28c9e92f4b677337dcd\r\n$\r\n$jq -r &#39;.response.session_id, .response_status&#39; RGLogin.json\r\n2d48cc11ceabf28c9e92f4b677337dcd\r\n200\r\n```",
                "title": "Bash grep JSON Response"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1666424992,
        "creation_date": 1556193305,
        "last_edit_date": 1666424992,
        "question_id": 55848752,
        "body_markdown": "Here is the JSON Response in a File, namely, *RGLogin.json*\r\n\r\n    {&quot;response&quot;:{&quot;session_id&quot;:&quot;2d48cc11ceabf28c9e92f4b677337dcd&quot;},&quot;response_status&quot;:200,&quot;response_details&quot;:null}\r\n\r\n\r\nThe grep command below can retrieve *session_id*\r\n\r\n    grep -m1 -oP &#39;\\s*&quot;session_id&quot;\\s*:\\s*&quot;\\K[^&quot;]+&#39; RGLogin.json\r\n\r\nBut the following grep command can not retrieve response_status\r\n  \r\n    grep -m1  -oP &#39;\\s*&quot;response_status&quot;\\s*:\\s*&quot;\\K[^&quot;]+&#39; RGLogin.json",
        "link": "https://stackoverflow.com/questions/55848752/bash-grep-json-response",
        "title": "Bash grep JSON Response"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1556233420,
                "last_edit_date": 1556233420,
                "creation_date": 1556225058,
                "answer_id": 55857362,
                "question_id": 55857004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`del(.foo)` expects there to be a top-level dictionary with a key named `foo`. That&#39;s not the case here; instead, you have a top-level list with `ParameterKey` having a series of values, with only one of which you want to remove the entire pair.\r\n\r\n```\r\njq &#39;[ .[] | select(.ParameterKey != &quot;RTSMSnapshotID&quot;) ]&#39;\r\n```\r\n\r\n...or...\r\n\r\n```\r\njq &#39;map(select(.ParameterKey != &quot;RTSMSnapshotID&quot;))&#39;\r\n```\r\n",
                "title": "Delete key/value pair with jq when key is a known string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1556233492,
        "creation_date": 1556223404,
        "last_edit_date": 1556233492,
        "question_id": 55857004,
        "body_markdown": "I&#39;m trying to delete one specific key/value pair from a json file. \r\n\r\nMy json file is, for this example, `params.json`\r\n\r\n    [ \r\n     {\r\n        &quot;ParameterKey&quot;: &quot;RTSMMinSize&quot;,\r\n        &quot;ParameterValue&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;RTSMReplicateDB&quot;,\r\n        &quot;ParameterValue&quot;: &quot;false&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;RTSMSnapshotID&quot;,\r\n        &quot;ParameterValue&quot;: &quot;snapID&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;RTSMEMAIL&quot;,\r\n        &quot;ParameterValue&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n\r\nI want to remove the `RTSMSnapshotID` key value pair entirely as part of my bash script. The file should look like this after:\r\n\r\n    [ \r\n     {\r\n        &quot;ParameterKey&quot;: &quot;RTSMMinSize&quot;,\r\n        &quot;ParameterValue&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;RTSMReplicateDB&quot;,\r\n        &quot;ParameterValue&quot;: &quot;false&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;RTSMEMAIL&quot;,\r\n        &quot;ParameterValue&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n\r\nI thought this would be something as simple as \r\n\r\n    jq &#39;del(.RTSMSnapshotID)&#39; params.json  \r\n\r\nbut I&#39;m getting\r\n\r\n    jq: error (at &lt;filename&gt;): Cannot index array with string &quot;RTSMSnapshotID&quot;\r\n\r\nClearly I don&#39;t understand how delete works. Any help?",
        "link": "https://stackoverflow.com/questions/55857004/delete-key-value-pair-with-jq-when-key-is-a-known-string",
        "title": "Delete key/value pair with jq when key is a known string"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15320796,
                    "reputation": 2030,
                    "user_id": 11053344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/daf773b3cde1bca287f60c6e3c046751?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vintnes",
                    "link": "https://stackoverflow.com/users/11053344/vintnes"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556328237,
                "post_id": 55876313,
                "comment_id": 98412703,
                "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": 1556328990,
                "post_id": 55876313,
                "comment_id": 98412770,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7404423,
                    "reputation": 896,
                    "user_id": 5633744,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/1a2ad582bc4b4f487256043a6919a38b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gowtham Ramamoorthy",
                    "link": "https://stackoverflow.com/users/5633744/gowtham-ramamoorthy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556331184,
                "post_id": 55876313,
                "comment_id": 98413013,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7404423,
                    "reputation": 896,
                    "user_id": 5633744,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/1a2ad582bc4b4f487256043a6919a38b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gowtham Ramamoorthy",
                    "link": "https://stackoverflow.com/users/5633744/gowtham-ramamoorthy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556331309,
                "post_id": 55876313,
                "comment_id": 98413032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15320796,
                    "reputation": 2030,
                    "user_id": 11053344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/daf773b3cde1bca287f60c6e3c046751?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vintnes",
                    "link": "https://stackoverflow.com/users/11053344/vintnes"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556333230,
                "post_id": 55876313,
                "comment_id": 98413224,
                "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": 1556333641,
                "post_id": 55876313,
                "comment_id": 98413271,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556338178,
                "last_edit_date": 1556338178,
                "creation_date": 1556332734,
                "answer_id": 55876786,
                "question_id": 55876313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\n#!/usr/bin/env bash\r\n\r\nwhile read line\r\ndo\r\n  jq -r --arg repovar &quot;$line&quot; &#39;.data.Layer.Features[] | .Name + &quot;, &quot; + .Version + &quot;, &quot; + $repovar&#39; severity.json\r\ndone &lt; quayrepo.txt &gt; volume.csv\r\n\r\n```\r\nwith `quayrepo.txt` as \r\n```text\r\nReponame1\r\n\r\n```\r\nand `severity.json` as \r\n```json\r\n{\r\n  &quot;status&quot;: &quot;scanned&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;Layer&quot;: {\r\n      &quot;IndexedByVersion&quot;: 3,\r\n      &quot;Features&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;elfutils&quot;,\r\n          &quot;Version&quot;: &quot;0.168-1&quot;,\r\n          &quot;Vulnerabilities&quot;: [\r\n            {\r\n              &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n              &quot;Severity&quot;: &quot;Medium&quot;,\r\n              &quot;Name&quot;: &quot;CVE-2016-2779&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nproduces `volume.csv` containing \r\n```text\r\nelfutils, 0.168-1, Reponame1\r\n```\r\n\r\nTo @peak&#39;s point, changing `&gt;` to `&gt;&gt;` in `...severity.json &gt;&gt; volume.csv` will create a multi-line csv instead of just overwriting until the last line",
                "title": "cannot call bash environment variable inside jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1556333041,
                "creation_date": 1556333041,
                "answer_id": 55876811,
                "question_id": 55876313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to surround $repovar with parenthesis, as the other values\r\n\r\n    repovar=&#39;qweqe&#39;; jq -r --arg repovar &quot;$repovar&quot; &#39;.data.Layer| .Features[] | &quot;\\(.Name), \\(.Version), \\($repovar)&quot;&#39; tmp.json\r\n\r\nResult:\r\n\r\n    elfutils, 0.168-1, qweqe\r\n\r\nThere&#39;s no need for the `export`.",
                "title": "cannot call bash environment variable inside jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556377227,
                "last_edit_date": 1556377227,
                "creation_date": 1556376765,
                "answer_id": 55881769,
                "question_id": 55876313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a `while read` loop in bash at all; `jq` itself can loop over your input lines, even when they aren&#39;t JSON, letting you run `jq` only once, not once per line in `quayrepo.txt`.\r\n\r\n```\r\njq -rR --slurpfile inJson severity.json &lt;quayrepo.txt &gt;volume.csv &#39;\r\n($inJson[0].data.Layer | .Features[]) as $features |\r\n[$features.Name, $features.Version, .] |\r\n@csv\r\n&#39;\r\n```\r\n\r\n- `jq -R` specifies raw input, letting jq directly read lines from `quayrepo.txt` into `.`\r\n- `jq --slurpfile varname filename.json` reads `filename.json` into an array of JSON objects parsed from that file. If the file contains only one object, one needs to refer to `$varname[0]` to refer to it.\r\n- `@csv` converts an array to a CSV output line, correctly handling data with embedded quotes or other oddities that require special processing.",
                "title": "cannot call bash environment variable inside jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1556377227,
        "creation_date": 1556325528,
        "last_edit_date": 1556377070,
        "question_id": 55876313,
        "body_markdown": "In the below script, I am not able to successfully call the &quot;repovar&quot; variable in the jq command.\r\n\r\n    cat quayrepo.txt | while read line\r\n    do\r\n      export repovar=&quot;$line&quot;\r\n      jq -r --arg repovar &quot;$repovar&quot; &#39;.data.Layer| .Features[] | &quot;\\(.Name), \\(.Version), $repovar&quot;&#39; severity.json &gt; volume.csv\r\n    done\r\n\r\nThe script uses a text file to loop through the repo names\r\n\r\nquayrepo.txt---&gt; file has the list of names in this case the file has a value of `&quot;Reponame1&quot;`\r\n\r\nsample input severity.json file:\r\n\r\n```\r\n{\r\n  &quot;status&quot;: &quot;scanned&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;Layer&quot;: {\r\n      &quot;IndexedByVersion&quot;: 3,\r\n      &quot;Features&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;elfutils&quot;,\r\n          &quot;Version&quot;: &quot;0.168-1&quot;,\r\n          &quot;Vulnerabilities&quot;: [\r\n            {\r\n              &quot;NamespaceName&quot;: &quot;debian:9&quot;,\r\n              &quot;Severity&quot;: &quot;Medium&quot;,\r\n              &quot;Name&quot;: &quot;CVE-2016-2779&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\ndesired output:  \r\n\r\n    elfutils, 0.168-1, Medium, Reponame1\r\n\r\n\r\nRequired output: I need to retrieve the value of my environment variable as the last column in my output csv file",
        "link": "https://stackoverflow.com/questions/55876313/cannot-call-bash-environment-variable-inside-jq",
        "title": "cannot call bash environment variable inside jq"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "precision",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1556437872,
                "post_id": 55888111,
                "comment_id": 98433681,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2075037,
                    "reputation": 86088,
                    "user_id": 1848654,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84180c0f3c9c04f8b8f0613fc0129dac?s=256&d=identicon&r=PG",
                    "display_name": "melpomene",
                    "link": "https://stackoverflow.com/users/1848654/melpomene"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556440355,
                "post_id": 55888111,
                "comment_id": 98434196,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2075037,
                    "reputation": 86088,
                    "user_id": 1848654,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84180c0f3c9c04f8b8f0613fc0129dac?s=256&d=identicon&r=PG",
                    "display_name": "melpomene",
                    "link": "https://stackoverflow.com/users/1848654/melpomene"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556440418,
                "post_id": 55888111,
                "comment_id": 98434208,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1556444830,
        "creation_date": 1556437490,
        "last_edit_date": 1556444830,
        "question_id": 55888111,
        "body_markdown": "I have `a.json` file with the following content\r\n```\r\n{&quot;created_at&quot;: &quot;Fri Feb 01 03:19:49 +0000 2019&quot;, &quot;id&quot;: 1091174254324928512, &quot;id_str&quot;: &quot;1091174254324928512&quot;, &quot;text&quot;: &quot;\\u091c\\u094b \\u091c\\u0940\\u0902\\u0926 \\u0915\\u093e \\u092e\\u0942\\u0921 \\u0939\\u0948, \\u0935\\u0939\\u0940 \\u0939\\u093f\\u0928\\u094d\\u0926 \\u0915\\u093e \\u092e\\u0942\\u0921 \\u0939\\u0948 \\u270c\\ufe0f\\n\\n#JindByPollResults #JindByelection\\n#jindbypoll #JindResults\\n#fridayfeelings&quot;, &quot;truncated&quot;: false, &quot;entities&quot;: {&quot;hashtags&quot;: [{&quot;text&quot;: &quot;JindByPollResults&quot;, &quot;indices&quot;: [43, 61]}, {&quot;text&quot;: &quot;JindByelection&quot;, &quot;indices&quot;: [62, 77]}, {&quot;text&quot;: &quot;jindbypoll&quot;, &quot;indices&quot;: [78, 89]}, {&quot;text&quot;: &quot;JindResults&quot;, &quot;indices&quot;: [90, 102]}, {&quot;text&quot;: &quot;fridayfeelings&quot;, &quot;indices&quot;: [103, 118]}], &quot;symbols&quot;: [], &quot;user_mentions&quot;: [], &quot;urls&quot;: []}, &quot;source&quot;: &quot;&lt;a href=\\&quot;http://twitter.com/download/android\\&quot; rel=\\&quot;nofollow\\&quot;&gt;Twitter for Android&lt;/a&gt;&quot;, &quot;in_reply_to_status_id&quot;: null, &quot;in_reply_to_status_id_str&quot;: null, &quot;in_reply_to_user_id&quot;: null, &quot;in_reply_to_user_id_str&quot;: null, &quot;in_reply_to_screen_name&quot;: null, &quot;user&quot;: {&quot;id&quot;: 439154852, &quot;id_str&quot;: &quot;439154852&quot;, &quot;name&quot;: &quot;Chowkidar Kailash Vijayvargiya&quot;, &quot;screen_name&quot;: &quot;KailashOnline&quot;, &quot;location&quot;: &quot;Delhi&quot;, &quot;description&quot;: &quot;National General Secretary of #BJP, Active Worker &amp; a Proud Indian who continuously strives for development.&quot;, &quot;url&quot;: &quot;https://twitter.com/KbWcYpNlEZ&quot;, &quot;entities&quot;: {&quot;url&quot;: {&quot;urls&quot;: [{&quot;url&quot;: &quot;https://twitter.com/KbWcYpNlEZ&quot;, &quot;expanded_url&quot;: &quot;http://www.KailashOnline.in&quot;, &quot;display_url&quot;: &quot;KailashOnline.in&quot;, &quot;indices&quot;: [0, 23]}]}, &quot;description&quot;: {&quot;urls&quot;: []}}, &quot;protected&quot;: false, &quot;followers_count&quot;: 756260, &quot;friends_count&quot;: 1777, &quot;listed_count&quot;: 243, &quot;created_at&quot;: &quot;Sat Dec 17 12:36:56 +0000 2011&quot;, &quot;favourites_count&quot;: 7206, &quot;utc_offset&quot;: null, &quot;time_zone&quot;: null, &quot;geo_enabled&quot;: true, &quot;verified&quot;: true, &quot;statuses_count&quot;: 17644, &quot;lang&quot;: &quot;en&quot;, &quot;contributors_enabled&quot;: false, &quot;is_translator&quot;: false, &quot;is_translation_enabled&quot;: false, &quot;profile_background_color&quot;: &quot;000000&quot;, &quot;profile_background_image_url&quot;: &quot;http://abs.twimg.com/images/themes/theme1/bg.png&quot;, &quot;profile_background_image_url_https&quot;: &quot;https://abs.twimg.com/images/themes/theme1/bg.png&quot;, &quot;profile_background_tile&quot;: true, &quot;profile_image_url&quot;: &quot;http://pbs.twimg.com/profile_images/1073134305466114048/Kx-Y7xkk_normal.jpg&quot;, &quot;profile_image_url_https&quot;: &quot;https://pbs.twimg.com/profile_images/1073134305466114048/Kx-Y7xkk_normal.jpg&quot;, &quot;profile_banner_url&quot;: &quot;https://pbs.twimg.com/profile_banners/439154852/1544690191&quot;, &quot;profile_link_color&quot;: &quot;E06412&quot;, &quot;profile_sidebar_border_color&quot;: &quot;000000&quot;, &quot;profile_sidebar_fill_color&quot;: &quot;DDEEF6&quot;, &quot;profile_text_color&quot;: &quot;333333&quot;, &quot;profile_use_background_image&quot;: true, &quot;has_extended_profile&quot;: true, &quot;default_profile&quot;: false, &quot;default_profile_image&quot;: false, &quot;following&quot;: false, &quot;follow_request_sent&quot;: false, &quot;notifications&quot;: false, &quot;translator_type&quot;: &quot;none&quot;}, &quot;geo&quot;: null, &quot;coordinates&quot;: null, &quot;place&quot;: null, &quot;contributors&quot;: null, &quot;is_quote_status&quot;: false, &quot;retweet_count&quot;: 663, &quot;favorite_count&quot;: 2705, &quot;favorited&quot;: false, &quot;retweeted&quot;: false, &quot;lang&quot;: &quot;hi&quot;}\r\n```\r\nAs you can see, the `id` field value is = 1091174254324928512\r\n\r\nIn python3, with original `a.json`\r\n```\r\n&gt;&gt;&gt; import json\r\n&gt;&gt;&gt; f=open(&quot;a.json&quot;,&quot;r&quot;)\r\n&gt;&gt;&gt; d=json.load(f)\r\n&gt;&gt;&gt; d[&quot;id&quot;]\r\n1091174254324928512\r\n```\r\n\r\nWhen I print the same file with the command \r\n`cat a.json | jq .`&lt;br&gt;\r\nI get the following output\r\n\r\n```\r\n{\r\n  &quot;created_at&quot;: &quot;Fri Feb 01 03:19:49 +0000 2019&quot;,\r\n  &quot;id&quot;: 1091174254324928500,\r\n  &quot;id_str&quot;: &quot;1091174254324928512&quot;,\r\n  &quot;text&quot;: &quot;जो जींद का मूड है, वही हिन्द का मूड है ✌️\\n\\n#JindByPollResults #JindByelection\\n#jindbypoll #JindResults\\n#fridayfeelings&quot;,\r\n  &quot;truncated&quot;: false,\r\n  &quot;entities&quot;: {\r\n    &quot;hashtags&quot;: [\r\n      {\r\n        &quot;text&quot;: &quot;JindByPollResults&quot;,\r\n        &quot;indices&quot;: [\r\n          43,\r\n          61\r\n        ]\r\n      },\r\n      {\r\n        &quot;text&quot;: &quot;JindByelection&quot;,\r\n        &quot;indices&quot;: [\r\n          62,\r\n          77\r\n        ]\r\n      },\r\n      {\r\n        &quot;text&quot;: &quot;jindbypoll&quot;,\r\n        &quot;indices&quot;: [\r\n          78,\r\n          89\r\n        ]\r\n      },\r\n      {\r\n        &quot;text&quot;: &quot;JindResults&quot;,\r\n        &quot;indices&quot;: [\r\n          90,\r\n          102\r\n        ]\r\n      },\r\n      {\r\n        &quot;text&quot;: &quot;fridayfeelings&quot;,\r\n        &quot;indices&quot;: [\r\n          103,\r\n          118\r\n        ]\r\n      }\r\n    ],\r\n    &quot;symbols&quot;: [],\r\n    &quot;user_mentions&quot;: [],\r\n    &quot;urls&quot;: []\r\n  },\r\n  &quot;source&quot;: &quot;&lt;a href=\\&quot;http://twitter.com/download/android\\&quot; rel=\\&quot;nofollow\\&quot;&gt;Twitter for Android&lt;/a&gt;&quot;,\r\n  &quot;in_reply_to_status_id&quot;: null,\r\n  &quot;in_reply_to_status_id_str&quot;: null,\r\n  &quot;in_reply_to_user_id&quot;: null,\r\n  &quot;in_reply_to_user_id_str&quot;: null,\r\n  &quot;in_reply_to_screen_name&quot;: null,\r\n  &quot;user&quot;: {\r\n    &quot;id&quot;: 439154852,\r\n    &quot;id_str&quot;: &quot;439154852&quot;,\r\n    &quot;name&quot;: &quot;Chowkidar Kailash Vijayvargiya&quot;,\r\n    &quot;screen_name&quot;: &quot;KailashOnline&quot;,\r\n    &quot;location&quot;: &quot;Delhi&quot;,\r\n    &quot;description&quot;: &quot;National General Secretary of #BJP, Active Worker &amp; a Proud Indian who continuously strives for development.&quot;,\r\n    &quot;url&quot;: &quot;https://twitter.com/KbWcYpNlEZ&quot;,\r\n    &quot;entities&quot;: {\r\n      &quot;url&quot;: {\r\n        &quot;urls&quot;: [\r\n          {\r\n            &quot;url&quot;: &quot;https://twitter.com/KbWcYpNlEZ&quot;,\r\n            &quot;expanded_url&quot;: &quot;http://www.KailashOnline.in&quot;,\r\n            &quot;display_url&quot;: &quot;KailashOnline.in&quot;,\r\n            &quot;indices&quot;: [\r\n              0,\r\n              23\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      &quot;description&quot;: {\r\n        &quot;urls&quot;: []\r\n      }\r\n    },\r\n    &quot;protected&quot;: false,\r\n    &quot;followers_count&quot;: 756260,\r\n    &quot;friends_count&quot;: 1777,\r\n    &quot;listed_count&quot;: 243,\r\n    &quot;created_at&quot;: &quot;Sat Dec 17 12:36:56 +0000 2011&quot;,\r\n    &quot;favourites_count&quot;: 7206,\r\n    &quot;utc_offset&quot;: null,\r\n    &quot;time_zone&quot;: null,\r\n    &quot;geo_enabled&quot;: true,\r\n    &quot;verified&quot;: true,\r\n    &quot;statuses_count&quot;: 17644,\r\n    &quot;lang&quot;: &quot;en&quot;,\r\n    &quot;contributors_enabled&quot;: false,\r\n    &quot;is_translator&quot;: false,\r\n    &quot;is_translation_enabled&quot;: false,\r\n    &quot;profile_background_color&quot;: &quot;000000&quot;,\r\n    &quot;profile_background_image_url&quot;: &quot;http://abs.twimg.com/images/themes/theme1/bg.png&quot;,\r\n    &quot;profile_background_image_url_https&quot;: &quot;https://abs.twimg.com/images/themes/theme1/bg.png&quot;,\r\n    &quot;profile_background_tile&quot;: true,\r\n    &quot;profile_image_url&quot;: &quot;http://pbs.twimg.com/profile_images/1073134305466114048/Kx-Y7xkk_normal.jpg&quot;,\r\n    &quot;profile_image_url_https&quot;: &quot;https://pbs.twimg.com/profile_images/1073134305466114048/Kx-Y7xkk_normal.jpg&quot;,\r\n    &quot;profile_banner_url&quot;: &quot;https://pbs.twimg.com/profile_banners/439154852/1544690191&quot;,\r\n    &quot;profile_link_color&quot;: &quot;E06412&quot;,\r\n    &quot;profile_sidebar_border_color&quot;: &quot;000000&quot;,\r\n    &quot;profile_sidebar_fill_color&quot;: &quot;DDEEF6&quot;,\r\n    &quot;profile_text_color&quot;: &quot;333333&quot;,\r\n    &quot;profile_use_background_image&quot;: true,\r\n    &quot;has_extended_profile&quot;: true,\r\n    &quot;default_profile&quot;: false,\r\n    &quot;default_profile_image&quot;: false,\r\n    &quot;following&quot;: false,\r\n    &quot;follow_request_sent&quot;: false,\r\n    &quot;notifications&quot;: false,\r\n    &quot;translator_type&quot;: &quot;none&quot;\r\n  },\r\n  &quot;geo&quot;: null,\r\n  &quot;coordinates&quot;: null,\r\n  &quot;place&quot;: null,\r\n  &quot;contributors&quot;: null,\r\n  &quot;is_quote_status&quot;: false,\r\n  &quot;retweet_count&quot;: 663,\r\n  &quot;favorite_count&quot;: 2705,\r\n  &quot;favorited&quot;: false,\r\n  &quot;retweeted&quot;: false,\r\n  &quot;lang&quot;: &quot;hi&quot;\r\n}\r\n```\r\nhere `id` field value that is printed is = 1091174254324928500 which is different from `id` field value that is present in the file.\r\n\r\nIn python3, with prettified `pretty_a.json`\r\n```\r\n&gt;&gt;&gt; import json\r\n&gt;&gt;&gt; f=open(&quot;pretty_a.json&quot;,&quot;r&quot;)\r\n&gt;&gt;&gt; d=json.load(f)\r\n&gt;&gt;&gt; d[&quot;id&quot;]\r\n1091174254324928500\r\n```\r\n\r\nAlso, When I opened `a.json` with VSCode and used [prettify_JSON][1] extension, then I get the same prettified output as that of what is printed with `cat a.json | jq .`\r\n\r\nSo I think the problem is because of how json decoders handles number data type.&lt;br&gt;It seems like json decoders of `jq` and `python3` handle datatypes differently.\r\n\r\nMy question is why exactly this happens and how to handle these type of peculiarities while coding with `json` module of `python3` irrespective of whether the given json file is `jq` prettified or not.\r\n\r\n\r\n\r\n  [1]: https://marketplace.visualstudio.com/items?itemName=mohsen1.prettify-json",
        "link": "https://stackoverflow.com/questions/55888111/value-that-is-printed-by-jq-is-different-from-value-that-is-present-in-jso",
        "title": "Value that is printed by &quot; jq . &quot; is different from value that is present in json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556445675,
                "last_edit_date": 1556445675,
                "creation_date": 1556440094,
                "answer_id": 55888403,
                "question_id": 55888155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Parse dates using `strptime` and assign the result to *value*s, thus you can get the latest *attendance* using `max_by`. Convert the *value* to seconds since Epoch using `mktime`, substract it from *now*, divide by 24 * 60 * 60 to get number of days since.\r\n```\r\n$ jq -r &#39;\r\ndef days_since:\r\n  (now - .) / 86400 | floor;\r\n.students[]\r\n| [ .name, .class ] +\r\n  ( .attendance\r\n    | map(.value |= strptime(&quot;%d-%b-%Y&quot;))\r\n    | max_by(.value)\r\n    | [ .key, &quot;\\(.value | mktime | days_since) days ago&quot; ]\r\n  ) +\r\n  [ .teacher + &quot;.&quot; + .class ]\r\n| @tsv&#39; file\r\nName1   parentClass1    class1  148 days ago    teacher1.parentClass1\r\nName2   parentClass2    class2  144 days ago    teacher2.parentClass2\r\n```\r\nNote that this solution doesn&#39;t deal with daylight saving time changes.",
                "title": "How to get latest date key-value pair from json array including parent keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556445355,
                "last_edit_date": 1556445355,
                "creation_date": 1556445009,
                "answer_id": 55889037,
                "question_id": 55888155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For production purposes `jq` can&#39;t be used here because it doesn&#39;t allow to perform daylight saving time safe date calculations.\r\n\r\nI would use Python because it allows to perform daylight saving time safe date calculations, comes with json support by default and is installed on most to all UNIX derivates.\r\n\r\n    #!/usr/bin/env python\r\n    import argparse\r\n    from datetime import datetime\r\n    import json\r\n    \r\n    \r\n    def parse_args():\r\n        parser = argparse.ArgumentParser()\r\n        parser.add_argument(&#39;filename&#39;)\r\n        return parser.parse_args()\r\n    \r\n    \r\n    def main():\r\n        args = parse_args()\r\n        with open(args.filename) as file_desc:\r\n            data = json.load(file_desc)\r\n    \r\n        print(&#39;Name\\tParentClass\\tkey\\tdateValue&#39;)\r\n    \r\n        today = datetime.today()\r\n        for record in data[&#39;students&#39;]:\r\n            for a in record[&#39;attendance&#39;]:\r\n                date = datetime.strptime(a[&#39;value&#39;], &#39;%d-%b-%Y&#39;)\r\n                a[&#39;since&#39;] = (today - date).days\r\n            last = sorted(record[&#39;attendance&#39;], key=lambda x: x[&#39;since&#39;])[0]\r\n            print(&#39;\\t&#39;.join([\r\n                record[&#39;name&#39;],\r\n                record[&#39;class&#39;],\r\n                last[&#39;key&#39;],\r\n                &#39;{} days ago&#39;.format(last[&#39;since&#39;]),\r\n                &#39;{}.{}&#39;.format(record[&#39;teacher&#39;], record[&#39;class&#39;]),\r\n            ]))\r\n    \r\n    \r\n    if __name__ == &#39;__main__&#39;:\r\n        main()\r\n\r\n\r\nOutput (on the day when this answer was written):\r\n\r\n    Name\tParentClass\tKey\tDateValue\tSummary\r\n    Name1\tparentClass1\tclass1\t148 days ago\tteacher1.parentClass1\r\n    Name2\tparentClass2\tclass2\t144 days ago\tteacher2.parentClass2\r\n\r\n",
                "title": "How to get latest date key-value pair from json array including parent keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1556470051,
        "creation_date": 1556437774,
        "last_edit_date": 1556441497,
        "question_id": 55888155,
        "body_markdown": "1) I am trying to generate a CSV file using jq from a json.\r\n2) I need parent keys along with one key-value pair from the child array\r\n3) Which ever value has latest date in it , will be the resulting key-value pair\r\n4) Need to generate a csv out of that result\r\n\r\n\r\nThis is my json\r\n\r\n```\r\n{\r\n    &quot;students&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;Name1&quot;,\r\n            &quot;class&quot;: &quot;parentClass1&quot;,\r\n            &quot;teacher&quot;: &quot;teacher1&quot;,\r\n            &quot;attendance&quot;: [\r\n                {\r\n                    &quot;key&quot;: &quot;class1&quot;,\r\n                    &quot;value&quot;: &quot;01-DEC-2018&quot;\r\n                },\r\n                {\r\n                    &quot;key&quot;: &quot;class1&quot;,\r\n                    &quot;value&quot;: &quot;28-Nov-2018&quot;\r\n                },\r\n                {\r\n                    &quot;key&quot;: &quot;class1&quot;,\r\n                    &quot;value&quot;: &quot;26-Oct-2018&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;Name2&quot;,\r\n            &quot;class&quot;: &quot;parentClass2&quot;,\r\n            &quot;teacher&quot;: &quot;teacher2&quot;,\r\n            &quot;attendance&quot;: [\r\n                {\r\n                    &quot;key&quot;: &quot;class2&quot;,\r\n                    &quot;value&quot;: &quot;05-DEC-2018&quot;\r\n                },\r\n                {\r\n                    &quot;key&quot;: &quot;class2&quot;,\r\n                    &quot;value&quot;: &quot;25-Nov-2018&quot;\r\n                },\r\n                {\r\n                    &quot;key&quot;: &quot;class2&quot;,\r\n                    &quot;value&quot;: &quot;20-Oct-2018&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI did not made much progress I am trying to create csv like this\r\n\r\n\r\n\r\n```\r\njq  &#39;.students[] | [.name, .class, attendance[].key,.properties[].value] | @csv &#39; main.json\r\n```\r\n\r\n\r\nBelow is expected CSV from that json\r\n\r\n```\r\nName         ParentClass        key         dateValue                                                                           Summary\r\nName1        parentClass1      class1       150 days ago(difference with today date with latest date i.e 01-DEC-2018 )         Teacher1.parentClass1\r\nName2        parentClass2      class2       150 days ago(difference with today date with latest date i.e 05-DEC-2018 )         Teacher2.parentClass2\r\n```",
        "link": "https://stackoverflow.com/questions/55888155/how-to-get-latest-date-key-value-pair-from-json-array-including-parent-keys",
        "title": "How to get latest date key-value pair from json array including parent keys"
    },
    {
        "tags": [
            "json",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556481228,
                "creation_date": 1556481228,
                "answer_id": 55894068,
                "question_id": 55894052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to specify the full path:\r\n```\r\n$ jq &#39;.listingRequest.queueSize.byteCount&#39; file.json\r\n480\r\n```\r\n",
                "title": "jq command returning null"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1556487834,
                "creation_date": 1556487834,
                "answer_id": 55894826,
                "question_id": 55894052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative to specifying the full path is to use `..`, e.g.\r\n\r\n    $ jq &#39;.. | .byteCount? // empty&#39; queue.json \r\n    480",
                "title": "jq command returning null"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1556544387,
        "creation_date": 1556481105,
        "last_edit_date": 1556544387,
        "question_id": 55894052,
        "body_markdown": "I have the below json content in my sample file but while using the ```jq``` command the result is always null: \r\n\r\n\r\n    {\r\n        &quot;listingRequest&quot;: {\r\n            &quot;id&quot;: &quot;016a1050-82dc-1262-cc9b-4baf3e0b7123&quot;,\r\n            &quot;uri&quot;: &quot;http://localhost:9090/nifi-api/flowfile-queues/016a104a-82dc-1262-7d78-d84a704abfbf/listing-requests/016a1050-82dc-1262-cc9b-4baf3e0b7123&quot;,\r\n            &quot;submissionTime&quot;: &quot;04/28/2019 19:40:58.593 UTC&quot;,\r\n            &quot;lastUpdated&quot;: &quot;19:40:58 UTC&quot;,\r\n            &quot;percentCompleted&quot;: 0,\r\n            &quot;finished&quot;: false,\r\n            &quot;maxResults&quot;: 100,\r\n            &quot;state&quot;: &quot;Waiting for other queue requests to complete&quot;,\r\n            &quot;queueSize&quot;: {\r\n                &quot;byteCount&quot;: 480,\r\n                &quot;objectCount&quot;: 20\r\n            },\r\n            &quot;sourceRunning&quot;: false,\r\n            &quot;destinationRunning&quot;: false\r\n        }\r\n    }\r\n\r\nI want to retrieve the value of the byte count i.e. byteCount. The result should be 480.\r\n\r\nBut below is the output that I get:\r\n\r\n```\r\ncat queue.json | jq -r &#39;.byteCount&#39;\r\nnull\r\n```\r\n\r\n\r\nI just found out that jq tool cannot be installed in our servers due to restrictions. \r\n\r\nHow do I do it via sed/grep? I tried  ```grep -Po &#39;&quot;byteCount&quot;:.*?[^\\\\]&quot;,&#39;``` but did not get any output",
        "link": "https://stackoverflow.com/questions/55894052/jq-command-returning-null",
        "title": "jq command returning null"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1556533314,
                "last_edit_date": 1556533314,
                "creation_date": 1556513882,
                "answer_id": 55897174,
                "question_id": 55896344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the sake of specificity, let&#39;s suppose you want to extract the the `(before, focus, after)` triple as an array, where `before` and `after` wrap around as described. For simplicity, let&#39;s also suppose the source array is of length at least 2.  \r\n\r\nNext, for ease of exposition and understanding, we will define a helper function for extracting the three items:\r\n\r\n    # $i is assumed to be a valid index into the input array,\r\n    # which is assumed to be of length at least 2\r\n    def triple($i):\r\n      if $i == 0 then [last] + .[0:2]\r\n      elif $i == (length-1) then .[$i-1: $i+2] + [first]\r\n      else .[$i-1: $i+2]\r\n      end;\r\n\r\nNow we have only to find the index, and use it:\r\n\r\n    (map(.type) | index(&quot;bird&quot;)) as $i\r\n    | if $i then triple($i) else empty end\r\n\r\nUsing this approach, other variants can easily be obtained.\r\n\r\n",
                "title": "Get the element after/before the matched one in json with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1556530839,
                "creation_date": 1556530839,
                "answer_id": 55900667,
                "question_id": 55896344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "let me also offer you an alternative solution, based on a walk-path unix tool for JSON: **[`jtc`][1]** - there you &quot;encode&quot; your query logic right into the path:\r\n\r\ne.g. to find a `&quot;type&quot;:&quot;bird&quot;` record and then it&#39;s preceding sibling (in the parent&#39;s array) would be like this:\r\n\r\n    bash $ &lt;file.json jtc -w&#39;[type]:&lt;bird&gt; [-1]&lt;idx&gt;k [-1]&gt;idx&lt;t-1&#39; -r\r\n    { &quot;set&quot;: &quot;foo&quot;, &quot;type&quot;: &quot;dog&quot; }\r\n\r\nlet me break it down for you:\r\n\r\n- `[type]:&lt;bird&gt;` - will find recursively a record `&quot;type&quot;:&quot;bird&quot;`\r\n- `[-1]&lt;idx&gt;k` - will step up 1 tier in JSON tree (select parent, effectively select the entire record `{&quot;type&quot;:&quot;bird&quot;, &quot;set&quot;:&quot;bar&quot;}`) and will memorize its array index into the namespace `idx`\r\n- `[-1]&gt;idx&lt;t-1` - will again step up 1 level in JSON (selecting the top array) and will search (non-recursively) for the entry with index (stored in `idx`) offset by `-1`\r\n\r\nEqually once can select a next sibling:\r\n\r\n    bash $ &lt;file.json jtc -w&#39;[type]:&lt;bird&gt;[-1]&lt;idx&gt;k[-1]&gt;idx&lt;t1&#39;\r\n    { &quot;set&quot;: &quot;blaz&quot;, &quot;type&quot;: &quot;cat&quot; }\r\n\r\nOr, select the first entry (based on the last match):\r\n\r\n    bash $ &lt;file.json jtc -w&#39;[type]:&lt;fish&gt;[-1]&lt;idx&gt;k[-1]&gt;idx&lt;t-1000&#39; -r\r\n    { &quot;set&quot;: &quot;foo&quot;, &quot;type&quot;: &quot;dog&quot; }\r\n\r\n(just put some surely low value as the relative quantifier - it&#39;ll get normalized to the first entry)\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "Get the element after/before the matched one in json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1556533314,
        "creation_date": 1556505839,
        "last_edit_date": 1556508177,
        "question_id": 55896344,
        "body_markdown": "Suppose I have the following json input to the jq command:\r\n\r\n    [\r\n      {&quot;type&quot;:&quot;dog&quot;,  &quot;set&quot;:&quot;foo&quot;},\r\n      {&quot;type&quot;:&quot;bird&quot;, &quot;set&quot;:&quot;bar&quot;},\r\n      {&quot;type&quot;:&quot;cat&quot;,  &quot;set&quot;:&quot;blaz&quot;},\r\n      {&quot;type&quot;:&quot;fish&quot;, &quot;set&quot;:&quot;mor&quot;}\r\n    ]\r\n\r\nI know that there is an element in this array whose `type` is &quot;bird&quot;, in this case, the second element.  But I want its next (or previous) sibling, that is, the element after (before) it, in this case, the third (first) element.  How can I get it in jq?\r\n\r\nAlso, I have another question: If the matched element (that is, the element whose value of `type` I know) is the last one in the array, I want it to get the first one as next (that is, cycle through the array) instead of returning nothing. The same whether the matched element is the first one (then I want to get the last element).",
        "link": "https://stackoverflow.com/questions/55896344/get-the-element-after-before-the-matched-one-in-json-with-jq",
        "title": "Get the element after/before the matched one in json with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1556511110,
                "post_id": 55896711,
                "comment_id": 98449938,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556512317,
                "creation_date": 1556512317,
                "answer_id": 55897001,
                "question_id": 55896711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I solved it like this:\r\n\r\n    jq -r &#39;[ .results[].properties[] | select(.key | contains(&quot;prod&quot;)) ]&#39;\r\n\r\nThis grabs all key-value pairs from _each_ result&#39;s properties array.  It then selects those that contain &quot;prod&quot; in the key, and returns an array of those keys and values.  Given your example input from above, this is the return value:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;deploy.prod.TLE&quot;,\r\n        &quot;value&quot;: &quot;2018-10-20&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;deploy.prodXYZ&quot;,\r\n        &quot;value&quot;: &quot;2018-10-20&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;deploy.prodPDQ&quot;,\r\n        &quot;value&quot;: &quot;2018-10-20&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;deploy.prod.ABC&quot;,\r\n        &quot;value&quot;: &quot;2018-10-21&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;deploy.prodPDQ&quot;,\r\n        &quot;value&quot;: &quot;2018-10-22&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;deploy.prodABC&quot;,\r\n        &quot;value&quot;: &quot;2018-10-20&quot;\r\n      }\r\n    ]\r\n\r\nIs that close to what you&#39;re looking for?\r\n\r\n",
                "title": "Parsing a JSON array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1556531431,
        "creation_date": 1556509708,
        "last_edit_date": 1556510429,
        "question_id": 55896711,
        "body_markdown": "I need to parse out specific information from the following JSON example bellow using jq.  depending on the &#39;repo&#39; I need to be able to parse from the properties array all &#39;key&#39; &amp; &#39;values&#39; and associated with the repository.  For example the repo &quot;libs-production-local&quot; would need to parse out any properties key with &#39;prod&#39; in the string and its associated date value.  has to be jq and run in .sh.\r\n\r\n    {\r\n       &quot;results&quot;:[\r\n          {\r\n             &quot;repo&quot;:&quot;libs-production-local&quot;,\r\n             &quot;path&quot;:&quot;com/company/version&quot;,\r\n             &quot;name&quot;:&quot;sql.21.tar&quot;,\r\n             &quot;type&quot;:&quot;file&quot;,\r\n             &quot;size&quot;:&quot;40123&quot;,\r\n             &quot;created&quot;:&quot;date&quot;,\r\n             &quot;created_by&quot;:&quot;someone&quot;,\r\n             &quot;modified&quot;:&quot;date&quot;,\r\n             &quot;modified_by&quot;:&quot;someone&quot;,\r\n             &quot;updated&quot;:&quot;date&quot;,\r\n             &quot;depth&quot;:4,\r\n             &quot;actual_md5&quot;:&quot;asdflsdf23a4324234&quot;,\r\n             &quot;orginal_sha1&quot;:&quot;sadlkfjsdklfjsadf&quot;,\r\n             &quot;properties&quot;:[\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.uat&quot;,\r\n                   &quot;value&quot;:&quot;2018-09-23&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.prod.TLE&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-20&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.prodXYZ&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-20&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.prodPDQ&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-20&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.prod.ABC&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-21&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;businessUnit.name&quot;,\r\n                   &quot;value&quot;:&quot;IndivdualName&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.qa.ser2&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-20&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.qa.ser1&quot;,\r\n                   &quot;value&quot;:&quot;2018-11-23&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;build.timestamp&quot;,\r\n                   &quot;value&quot;:&quot;1510850899004&quot;\r\n                }\r\n             ],\r\n             &quot;virtual_repos&quot;:[\r\n                &quot;libs-production &quot;\r\n             ]\r\n          },\r\n          {\r\n             &quot;repo&quot;:&quot;libs-production-local&quot;,\r\n             &quot;path&quot;:&quot;com/company/version&quot;,\r\n             &quot;name&quot;:&quot;sql.22.tar&quot;,\r\n             &quot;type&quot;:&quot;file&quot;,\r\n             &quot;size&quot;:&quot;40123&quot;,\r\n             &quot;created&quot;:&quot;date&quot;,\r\n             &quot;created_by&quot;:&quot;someone&quot;,\r\n             &quot;modified&quot;:&quot;date&quot;,\r\n             &quot;modified_by&quot;:&quot;someone&quot;,\r\n             &quot;updated&quot;:&quot;date&quot;,\r\n             &quot;depth&quot;:4,\r\n             &quot;actual_md5&quot;:&quot;asdflsdf23a4324234&quot;,\r\n             &quot;orginal_sha1&quot;:&quot;sadlkfjsdklfjsadf&quot;,\r\n             &quot;properties&quot;:[\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.prodPDQ&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-22&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.prodABC&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-20&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;businessUnit.name&quot;,\r\n                   &quot;value&quot;:&quot;IndivdualName&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.qa&quot;,\r\n                   &quot;value&quot;:&quot;2018-10-20&quot;\r\n                },\r\n                {\r\n                   &quot;key&quot;:&quot;deploy.dev&quot;,\r\n                   &quot;value&quot;:&quot;2018-11-19&quot;\r\n                }\r\n             ],\r\n             &quot;virtual_repos&quot;:[\r\n                &quot;libs-production &quot;\r\n             ]\r\n          }\r\n       ],\r\n       &quot;range&quot;:{\r\n          &quot;start_pos&quot;:0,\r\n          &quot;end_pos&quot;:479,\r\n          &quot;total&quot;:479\r\n       }\r\n    }\r\n\r\n\r\nI&#39;ve tried a number of ways to do this (including this one) and nothing works.\r\n\r\n    jq -r &#39;.results[] |  ( .properties |map(select(.key[] contains (&quot;prod&quot;)) &#39;\r\n",
        "link": "https://stackoverflow.com/questions/55896711/parsing-a-json-array-with-jq",
        "title": "Parsing a JSON array with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556534895,
                "post_id": 55901703,
                "comment_id": 98459327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8436221,
                    "reputation": 245,
                    "user_id": 6330341,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8bb990f3fe9fa1211a9e74a6d8f0e6d5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rajiv Rai",
                    "link": "https://stackoverflow.com/users/6330341/rajiv-rai"
                },
                "reply_to_user": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556535069,
                "post_id": 55901703,
                "comment_id": 98459416,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1556535285,
                "post_id": 55901703,
                "comment_id": 98459520,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8436221,
                    "reputation": 245,
                    "user_id": 6330341,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8bb990f3fe9fa1211a9e74a6d8f0e6d5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rajiv Rai",
                    "link": "https://stackoverflow.com/users/6330341/rajiv-rai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556535986,
                "post_id": 55901703,
                "comment_id": 98459829,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1556536872,
                "post_id": 55901703,
                "comment_id": 98460235,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8436221,
                    "reputation": 245,
                    "user_id": 6330341,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8bb990f3fe9fa1211a9e74a6d8f0e6d5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rajiv Rai",
                    "link": "https://stackoverflow.com/users/6330341/rajiv-rai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556537651,
                "post_id": 55901703,
                "comment_id": 98460630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 301110,
                    "reputation": 103185,
                    "user_id": 608639,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/aPIhh.jpg?s=256",
                    "display_name": "jww",
                    "link": "https://stackoverflow.com/users/608639/jww"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556555198,
                "post_id": 55901703,
                "comment_id": 98470133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556536054,
                "creation_date": 1556536054,
                "answer_id": 55902064,
                "question_id": 55901703,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure I understand what you need. If you need to just merge the two arrays into one, you can use\r\n\r\n    jq &#39;[.[0][], .[1][]]&#39; &lt;&lt;&lt; &quot;[$local, $org]&quot;",
                "title": "Merging two json arrays (loaded into memory) into one json array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1556537296,
                "last_edit_date": 1556537296,
                "creation_date": 1556536129,
                "answer_id": 55902092,
                "question_id": 55901703,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `+`, not `*`:\r\n\r\n    #!/bin/sh\r\n    \r\n    j1=&#39;[{&quot;account_id&quot;:&quot;01C&quot;,&quot;id&quot;:&quot;0XVWKCFV6P9CA5&quot;},{&quot;account_id&quot;:&quot;CSDTHQ&quot;,&quot;id&quot;:&quot;631QGYBNSF&quot;}]&#39;\r\n    j2=&#39;[{&quot;account_id&quot;:&quot;BJPKWSH&quot;,&quot;id&quot;:&quot;15BS0XP4F91V6YH4G0PV&quot;},{&quot;account_id&quot;:&quot;01BKK44V5F6A1FKH60Q0ANX9JX&quot;,&quot;id&quot;:&quot;01BKK44V7&quot;}]&#39;\r\n    echo $(jq -s &#39;.[0] + .[1]&#39; &lt;&lt;EOF\r\n    $j1\r\n    $j2\r\n    EOF\r\n    )\r\n\r\nproduces:\r\n\r\n&lt;!-- language: javascript --&gt;\r\n\r\n    [ { &quot;account_id&quot;: &quot;01C&quot;, &quot;id&quot;: &quot;0XVWKCFV6P9CA5&quot; }, { &quot;account_id&quot;: &quot;CSDTHQ&quot;, &quot;id&quot;: &quot;631QGYBNSF&quot; }, { &quot;account_id&quot;: &quot;BJPKWSH&quot;, &quot;id&quot;: &quot;15BS0XP4F91V6YH4G0PV&quot; }, { &quot;account_id&quot;: &quot;01BKK44V5F6A1FKH60Q0ANX9JX&quot;, &quot;id&quot;: &quot;01BKK44V7&quot; } ]",
                "title": "Merging two json arrays (loaded into memory) into one json array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1556537296,
        "creation_date": 1556534533,
        "question_id": 55901703,
        "body_markdown": "I have two json array, which i have initialised as given below.\r\n```\r\nlocal=[{&quot;account_id&quot;:&quot;01C&quot;,&quot;id&quot;:&quot;0XVWKCFV6P9CA5&quot;},{&quot;account_id&quot;:&quot;CSDTHQ&quot;,&quot;id&quot;:&quot;631QGYBNSF&quot;},...............]\r\n\r\norg=[{&quot;account_id&quot;:&quot;BJPKWSH&quot;,&quot;id&quot;:&quot;15BS0XP4F91V6YH4G0PV&quot;},{&quot;account_id&quot;:&quot;01BKK44V5F6A1FKH60Q0ANX9JX&quot;,&quot;id&quot;:&quot;01BKK44V7&quot;},.....................]\r\n\r\n```\r\nwhat i want is something like below.\r\n```\r\noutputJson=[{&quot;account_id&quot;:&quot;BJPKWSH&quot;,&quot;id&quot;:&quot;15BS0XP4F91V6YH4G0PV&quot;},\r\n{&quot;account_id&quot;:&quot;BJPKWSH&quot;,&quot;id&quot;:&quot;15BS0XP4F91V6YH4G0PV&quot;},\r\n{&quot;account_id&quot;:&quot;01BKK44V5F6A1FKH60Q0ANX9JX&quot;,&quot;id&quot;:&quot;01BKK44V7&quot;},.....................]        \r\n```\r\ni.e. i want to merge these two json arrays into one.\r\nI tried this,\r\n```\r\njq -s &#39;.[0] * .[1]&#39; &lt;&lt;&lt; &quot;$local $org&quot;\r\n```\r\nbut it is giving ```parse error: Invalid literal at line 1, column 17```",
        "link": "https://stackoverflow.com/questions/55901703/merging-two-json-arrays-loaded-into-memory-into-one-json-array",
        "title": "Merging two json arrays (loaded into memory) into one json array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1556630286,
                "post_id": 55921743,
                "comment_id": 98497326,
                "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": 1556630311,
                "post_id": 55921743,
                "comment_id": 98497351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4589587,
                    "reputation": 1480,
                    "user_id": 3723306,
                    "user_type": "registered",
                    "accept_rate": 46,
                    "profile_image": "https://graph.facebook.com/1515773058/picture?type=large",
                    "display_name": "JaviOverflow",
                    "link": "https://stackoverflow.com/users/3723306/javioverflow"
                },
                "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": 1556631004,
                "post_id": 55921743,
                "comment_id": 98497782,
                "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": 1556632698,
                "post_id": 55921743,
                "comment_id": 98498789,
                "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": 3,
                "creation_date": 1556632760,
                "post_id": 55921743,
                "comment_id": 98498840,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4677143,
                    "reputation": 15627,
                    "user_id": 3787051,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/k2G2V.png?s=256",
                    "display_name": "Alex Harvey",
                    "link": "https://stackoverflow.com/users/3787051/alex-harvey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1557585864,
                "post_id": 55921743,
                "comment_id": 98819079,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556630514,
                "creation_date": 1556630514,
                "answer_id": 55921886,
                "question_id": 55921743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map`, it applies a filter to all elements of an array.\r\n```\r\n$ jq &#39;map({k1})&#39; file\r\n[\r\n  {\r\n    &quot;k1&quot;: &quot;v1&quot;\r\n  },\r\n  {\r\n    &quot;k1&quot;: &quot;v1&quot;\r\n  },\r\n  {\r\n    &quot;k1&quot;: &quot;v1&quot;\r\n  }\r\n]\r\n```",
                "title": "get subset of keys and wrap output to list using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1559741211,
        "creation_date": 1556630082,
        "last_edit_date": 1559741211,
        "question_id": 55921743,
        "body_markdown": "Let&#39;s assume we have the following records:\r\n\r\n```\r\n[\r\n{&quot;k1&quot;: &quot;v1&quot;, &quot;k2&quot;: &quot;v2&quot;},\r\n{&quot;k1&quot;: &quot;v1&quot;, &quot;k2&quot;: &quot;v2&quot;},\r\n{&quot;k1&quot;: &quot;v1&quot;, &quot;k2&quot;: &quot;v2&quot;}\r\n]\r\n```\r\n\r\nand we want to keep only a subset of the keys such as `k1`\r\n\r\nWhat operation do we have to do to get the following output?\r\n```\r\n[\r\n{&quot;k1&quot;: &quot;v1&quot;},\r\n{&quot;k1&quot;: &quot;v1&quot;},\r\n{&quot;k1&quot;: &quot;v1&quot;}\r\n]\r\n```\r\n\r\nI&#39;ve tried doing `jq &#39;.[] | { &quot;k1&quot;: .k1 }&#39;` but it returns\r\n```\r\n{&quot;k1&quot;: &quot;v1&quot;}\r\n{&quot;k1&quot;: &quot;v1&quot;}\r\n{&quot;k1&quot;: &quot;v1&quot;}\r\n```\r\n\r\nAlso tried doing `jq &#39;.[] | { &quot;k1&quot;: .k1 }&#39; | jq &#39;[inputs]&#39;` but for some reason it removes the first row\r\n```\r\n[\r\n{&quot;k1&quot;: &quot;v1&quot;},\r\n{&quot;k1&quot;: &quot;v1&quot;}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/55921743/get-subset-of-keys-and-wrap-output-to-list-using-jq",
        "title": "get subset of keys and wrap output to list using jq"
    },
    {
        "tags": [
            "json",
            "streaming",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556635859,
                "post_id": 55922362,
                "comment_id": 98500736,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1556655603,
                "last_edit_date": 1556655603,
                "creation_date": 1556639121,
                "answer_id": 55924518,
                "question_id": 55922362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you&#39;ve indicated you want to handle the &quot;daily&quot; values separately from the &quot;monthly&quot; values, let&#39;s focus on the former.\r\n\r\nFor this, let&#39;s start by using just `fromstream` and `truncate_stream`:\r\n\r\nWith input like the example given, but adjusted so that it&#39;s valid JSON:\r\n\r\n    fromstream( 1|truncate_stream(1|truncate_stream(\r\n      inputs | select( .[0][0] == &quot;stats&quot; and .[0][1] == &quot;daily&quot; ) )) )\r\n\r\n\r\nwould produce:\r\n\r\n    {&quot;k1&quot;:{&quot;a&quot;:[1]},&quot;k2&quot;:{&quot;a&quot;:[1]},&quot;kN&quot;:{&quot;a&quot;:[1]}}\r\n\r\nIf you have jq 1.6 then the above jq filter can be streamlined to:\r\n\r\n    fromstream(2|truncate_stream(\r\n      inputs | select( .[0][0:2] == [&quot;stats&quot;,&quot;daily&quot;] ) ))\r\n\r\n\r\nNow we have only to use `atomize` instead of `fromstream` to obtain the desired result.  For example, using jq 1.6, we see that:\r\n\r\n    atomize(2|truncate_stream(\r\n      inputs | select( .[0][0:2] == [&quot;stats&quot;,&quot;daily&quot;] ) ))\r\n\r\nwould produce:\r\n\r\n    {&quot;k1&quot;:{&quot;a&quot;:[1]}}\r\n    {&quot;k2&quot;:{&quot;a&quot;:[1]}}\r\n    {&quot;kN&quot;:{&quot;a&quot;:[1]}}\r\n\r\n\r\n## Invocation\r\n\r\n    jq -n -c --stream -f program.jq input.json\r\n\r\n## An efficiency enhancement\r\n\r\nOn the assumption that objects in the input do not have repeated keys, the above solution can be streamlined so that once the key of interest has been processed, no further processing is done.  This can be achieved using `run/3` as defined below.  The streaming solution then becomes:\r\n\r\n    atomize( 1 | truncate_stream( 1 | truncate_stream(\r\n      run( inputs; .[0][0:2]; [&quot;stats&quot;, &quot;daily&quot;] ))))\r\n\r\nOr with jq 1.6:\r\n\r\n    atomize( 2 | truncate_stream(\r\n      run( inputs; .[0][0:2]; [&quot;stats&quot;, &quot;daily&quot;] )))\r\n\r\n### `run/3`\r\n\r\n    # emit the first run of items in the stream for which f == $value\r\n    def run(stream; f; $value):\r\n      label $done\r\n      | foreach stream as $x ( {};\r\n          ($x | f) as $k\r\n          | if .start then (if $k == $value then . else .stop = true end)\r\n            elif $k == $value then .start = true\r\n    \t    else .\r\n    \t    end;\r\n          if .stop then break $done \r\n          elif .start then $x\r\n          else empty\r\n          end );\r\n\r\n",
                "title": "jq: how to customize the atomize function for a large streaming use-case?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678132298,
                "creation_date": 1678132298,
                "answer_id": 75655239,
                "question_id": 55922362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq streaming parser (activated by the --stream command-line option) handles very large JSON inputs economically but can be quite tricky to use even for relatively simple tasks, so the command-line utilities [jm and jm.py][1] (the former based on &quot;JSON Machine&quot; and the latter using a streaming Python parser) may be of interest.\r\n\r\nHere at any rate are some very simple solutions for the present task using these utilities:\r\n```\r\n&lt; $IN jm.py -s -i stats\r\n{&quot;daily&quot;: {&quot;k1&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;k2&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;etc&quot;: &quot;...&quot;, &quot;kN&quot;: {&quot;etc&quot;: &quot;...&quot;}}}\r\n{&quot;monthly&quot;: {&quot;p1&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;p2&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;etc&quot;: &quot;...&quot;, &quot;pN&quot;: {&quot;etc&quot;: &quot;...&quot;}}}\r\n```\r\n```\r\n&lt; $IN jm.py -i stats --values\r\n{&quot;k1&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;k2&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;etc&quot;: &quot;...&quot;, &quot;kN&quot;: {&quot;etc&quot;: &quot;...&quot;}}\r\n{&quot;p1&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;p2&quot;: {&quot;etc&quot;: &quot;...&quot;}, &quot;etc&quot;: &quot;...&quot;, &quot;pN&quot;: {&quot;etc&quot;: &quot;...&quot;}}\r\n```\r\n```\r\n&lt; $IN jm -s --pointer /stats\r\n{&quot;daily&quot;: {&quot;k1&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;k2&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;etc&quot;:&quot;...&quot;,&quot;kN&quot;:{&quot;etc&quot;:&quot;...&quot;}}}\r\n{&quot;monthly&quot;: {&quot;p1&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;p2&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;etc&quot;:&quot;...&quot;,&quot;pN&quot;:{&quot;etc&quot;:&quot;...&quot;}}}\r\n```\r\n```\r\n&lt; $IN jm --pointer /stats\r\n{&quot;k1&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;k2&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;etc&quot;:&quot;...&quot;,&quot;kN&quot;:{&quot;etc&quot;:&quot;...&quot;}}\r\n{&quot;p1&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;p2&quot;:{&quot;etc&quot;:&quot;...&quot;},&quot;etc&quot;:&quot;...&quot;,&quot;pN&quot;:{&quot;etc&quot;:&quot;...&quot;}}\r\n```\r\n\r\nNote that both jm and jm.py are designed to handle very large JSON inputs.\r\n\r\nDisclaimer: I wrote both the jm and jm.py scripts but they are just wrappers around JSON Machine and ijson respectively.\r\n\r\n\r\n  [1]: https://www.github.com/pkoppstein/jm",
                "title": "jq: how to customize the atomize function for a large streaming use-case?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1678132298,
        "creation_date": 1556632061,
        "last_edit_date": 1556646477,
        "question_id": 55922362,
        "body_markdown": "I have a very large file with the following structure:\r\n```\r\n{ \r\n  &quot;users&quot;: { ... },\r\n  ...\r\n  &quot;stats&quot;: {\r\n    &quot;daily&quot;: {\r\n      &quot;k1&quot;: { ... },\r\n      &quot;k2&quot;: { ... },\r\n      ...\r\n      &quot;kN&quot;: { ... }\r\n    },\r\n    &quot;monthly&quot;: {\r\n      &quot;p1&quot;: { ... },\r\n      &quot;p2&quot;: { ... },\r\n      ...\r\n      &quot;pN&quot;: { ... }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThere are only two keys in `stats`: `daily` and `monthly`, which both contain a very large amount of key-value pairs.\r\n\r\nI would like to stream all the key-value pairs inside of `.stats.daily` and `.stats.monthly` separately.\r\nIf the file was small, I&#39;d simply do `jq &#39;.stats.daily&#39; myfile.json` and `jq &#39;.stats.monthly&#39; myfile.json`\r\n\r\nI cannot figure out how to edit the `atomize` function from the cookbook in order to do what I want. Here&#39;s what I&#39;m trying which doesn&#39;t work:\r\n```\r\njq -nc --stream &#39;\r\n  def atomize(s):\r\n    fromstream(foreach s as $in ( {previous:null, emit: null};\r\n      if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\r\n      then {emit: [[.previous]], previous: $in|.[0][0]}\r\n      else { previous: ($in|.[0][0]), emit: null}\r\n      end;\r\n      (.emit // empty), $in) ) ;\r\n  atomize(2|truncate_stream(inputs | select(.[0][0] == &quot;daily&quot;))\r\n```\r\n\r\nCan someone please explain how it works and how to fix it for my use-case? Thank you",
        "link": "https://stackoverflow.com/questions/55922362/jq-how-to-customize-the-atomize-function-for-a-large-streaming-use-case",
        "title": "jq: how to customize the atomize function for a large streaming use-case?"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1556699259,
                "last_edit_date": 1556699259,
                "creation_date": 1556697001,
                "answer_id": 55933121,
                "question_id": 55932654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re misunderstanding what `in/1` is doing. It&#39;s not testing whether a value is a member of the array, but rather if the value is a member of the object&#39;s keys. So for arrays, numbers are expected (the indices) or for objects, strings (the keys). It&#39;s exactly the same as `has/1` but the inputs are swapped.\r\n\r\n    $ jq -n &#39;[0,-1,20,9,16,10] | map(in([range(20;30)]))&#39; # 10 item array\r\n    [\r\n      true,\r\n      false,\r\n      false,\r\n      true,\r\n      false,\r\n      false\r\n    ]\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ jq -n &#39;[&quot;foo&quot;,&quot;bar&quot;] | map(in({foo:1,boo:2,bat:3}))&#39;\r\n    [\r\n      true,\r\n      false\r\n    ]\r\n\r\nIf you wanted to test membership in the array, there isn&#39;t a builtin but you could craft it yourself. Though `contains/1` is close but not quite since it tests if strings are substrings and not equal. `any/2` could be used to do this.\r\n\r\n    def has_value($value):\r\n        any(.[]; . == $value);\r\n\r\n    def in_array($arr): # swapped input version\r\n        . as $value | any($arr[]; . == $value);",
                "title": "Inconsistent behaviour for jq in/1"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1556701590,
                "creation_date": 1556701590,
                "answer_id": 55933914,
                "question_id": 55932654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`index/1` is the builtin that can most conveniently be used for checking array membership.  Although it is not strictly boolean, the semantics of `if` and `//` make it convenient to use as though it were.  If you want a strictly boolean test, then simply use the idiom `index(_) != null`.\r\n\r\n`index/1` is worth understanding in detail, so consider reviewing the jq manual and FAQ accordingly. Note also that `INDEX/1` is no relation.",
                "title": "Inconsistent behaviour for jq in/1"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1584041597,
                "creation_date": 1584041597,
                "answer_id": 60660790,
                "question_id": 55932654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "actually [inside][1] does seem to do the trick (apparently added in v1.5)\r\n\r\n    jq -n &#39;[123,444,565,344,&quot;333&quot;,111,1111,87] | map([.]|inside([111,333,344]))&#39;\r\n\r\nproduces \r\n\r\n    [\r\n      false,\r\n      false,\r\n      false,\r\n      true,\r\n      false,\r\n      true,\r\n      false,\r\n      false\r\n    ]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.5/#inside",
                "title": "Inconsistent behaviour for jq in/1"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1584041597,
        "creation_date": 1556693969,
        "last_edit_date": 1556701736,
        "question_id": 55932654,
        "body_markdown": "The following example from the [jq docs](https://stedolan.github.io/jq/manual/v1.5/#in) worked as expected -- \r\n```sh\r\n$ echo &#39;[1,2]&#39; | jq &#39;map(in([0,1]))&#39;\r\n[\r\n  true,\r\n  false\r\n]\r\n```\r\n\r\nbut making the values into strings failed -\r\n```sh\r\n$ echo &#39;[&quot;1&quot;, &quot;2&quot;]&#39; | jq &#39;map(in([&quot;0&quot;,&quot;1&quot;]))&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot check whether array has a string key\r\n```\r\n\r\nTo make sure that this wasn&#39;t a shell-quoting issue, I also tried --\r\n```sh\r\n$ echo &quot;[\\&quot;1\\&quot;, \\&quot;2\\&quot;]&quot; | jq &#39;map(in([&quot;0&quot;,&quot;1&quot;]))&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot check whether array has a string key\r\n```\r\n\r\nTo add to this, the following snippet also fails, which is probably due to a casting of 0 into the boolean false -\r\n```sh\r\n$ echo &#39;[0,1]&#39; | jq &#39;map(in([1,2]))&#39;       \r\n[\r\n  true,\r\n  true\r\n]\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/55932654/inconsistent-behaviour-for-jq-in-1",
        "title": "Inconsistent behaviour for jq in/1"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1556774971,
                "post_id": 55946071,
                "comment_id": 98544896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11381172,
                    "reputation": 26772,
                    "user_id": 8344060,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/1UbPk.png?s=256",
                    "display_name": "kvantour",
                    "link": "https://stackoverflow.com/users/8344060/kvantour"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556778360,
                "post_id": 55946071,
                "comment_id": 98546083,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556787555,
                "post_id": 55946071,
                "comment_id": 98550384,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1556888020,
                "last_edit_date": 1556888020,
                "creation_date": 1556787775,
                "answer_id": 55948972,
                "question_id": 55946071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to store the `PURCHASEORDERNO` in a variable in order to add it to each row.\r\n\r\n    jq -r &#39;.RECEIPT.HEADER[] | .PURCHASEORDERNO as $pono | .LINE[] | [ $pono, .ITEMCODE, .QUANTITY ] | @csv&#39; input\r\n\r\nUpdate with header:\r\n\r\n    {\r\n      echo &#39;#Reference,ProductCode,Quantity&#39;\r\n      jq -r &#39;.RECEIPT.HEADER[] | .PURCHASEORDERNO as $pono | .LINE[] | [ $pono, .ITEMCODE, .QUANTITY ] | @csv&#39; input\r\n    } &gt; output\r\n",
                "title": "JSON to CSV conversion via JQ command in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1556888020,
        "creation_date": 1556774372,
        "last_edit_date": 1556781449,
        "question_id": 55946071,
        "body_markdown": "Want to convert a json into CSV file. CSV file require all the Line Item Object 1 per line + that line should also contain PURCHASEORDERNO.\r\n\r\nTrying to access the object PURCHASEORDERNO of the HEADER array from the LINE ARRAY by using .HEADER[].PURCHASEORDERNO. But getting error jq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n\r\n**JQ command :-**\r\n```\r\necho &#39;{&quot;RECEIPT&quot;:{&quot;HEADER&quot;:[{&quot;LINE&quot;:[{&quot;ITEMCODE&quot;:&quot;CF7219&quot;,&quot;QUANTITY&quot;:&quot;6&quot;},{&quot;ITEMCODE&quot;:&quot;CF7223&quot;,&quot;QUANTITY&quot;:&quot;8&quot;},{&quot;ITEMCODE&quot;:&quot;CF7223L&quot;,&quot;QUANTITY&quot;:&quot;8&quot;},{&quot;ITEMCODE&quot;:&quot;CF7419&quot;,&quot;QUANTITY&quot;:&quot;6&quot;},{&quot;ITEMCODE&quot;:&quot;CF7119&quot;,&quot;QUANTITY&quot;:&quot;3&quot;},{&quot;ITEMCODE&quot;:&quot;AP7119/7219L&quot;,&quot;QUANTITY&quot;:&quot;4&quot;},{&quot;ITEMCODE&quot;:&quot;CF7620&quot;,&quot;QUANTITY&quot;:&quot;6&quot;},{&quot;ITEMCODE&quot;:&quot;HP7313&quot;,&quot;QUANTITY&quot;:&quot;40&quot;}],&quot;SUPPCUSTNAME&quot;:&quot;CONFOIL CONTAINERS&quot;,&quot;SUPPCUSTCODE&quot;:&quot;CON001&quot;,&quot;PROCESSDATE&quot;:&quot;20190321&quot;,&quot;PURCHASEORDERNO&quot;:&quot;P6254&quot;},{&quot;LINE&quot;:[{&quot;ITEMCODE&quot;:&quot;CF7219&quot;,&quot;QUANTITY&quot;:&quot;6&quot;},{&quot;ITEMCODE&quot;:&quot;CF7223&quot;,&quot;QUANTITY&quot;:&quot;8&quot;},{&quot;ITEMCODE&quot;:&quot;CF7223L&quot;,&quot;QUANTITY&quot;:&quot;8&quot;},{&quot;ITEMCODE&quot;:&quot;CF7419&quot;,&quot;QUANTITY&quot;:&quot;6&quot;},{&quot;ITEMCODE&quot;:&quot;CF7119&quot;,&quot;QUANTITY&quot;:&quot;3&quot;},{&quot;ITEMCODE&quot;:&quot;AP7119/7219L&quot;,&quot;QUANTITY&quot;:&quot;4&quot;},{&quot;ITEMCODE&quot;:&quot;CF7620&quot;,&quot;QUANTITY&quot;:&quot;6&quot;},{&quot;ITEMCODE&quot;:&quot;HP7313&quot;,&quot;QUANTITY&quot;:&quot;40&quot;}],&quot;SUPPCUSTNAME&quot;:&quot;CONFOIL CONTAINERS&quot;,&quot;SUPPCUSTCODE&quot;:&quot;CON001&quot;,&quot;PROCESSDATE&quot;:&quot;20190321&quot;,&quot;PURCHASEORDERNO&quot;:&quot;P6254&quot;}]}}&#39;\r\n | jq -r &#39;.RECEIPT.HEADER[].LINE[] | [&quot;&quot;,&quot;ANCPACMEL&quot;,&quot;ADS&quot;,.HEADER[].PURCHASEORDERNO,&quot;&quot;,.ITEMCODE,.QUANTITY,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;]|@csv&#39;\r\n\r\n\r\n```\r\n\r\n\r\n**Error:-**\r\n\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n\r\n\r\n**Desired Output:-**\r\n```\r\n#CustomsEntryNo,ClientCode,Warehouse,Reference,ArrivalDate,ProductCode,Quantity,QuantityUQ,Pallets,Location,Attribute1,Attribute2,Attribute3,ExpiryDate,PackingDate,CustomsEntryLineNo,CustomsEntryDate,CustomsAddInfo,CustomsQty,CustomsUQ,CtryOfOrigin,ValueForDuty,BondedWhsQty,BondedWhsUQ,TILV,CustomsSecondQuantity,CustomsSecondUnitQty,Tariff,PrimaryPreference,CustomsThirdQuantity,CustomsThirdUnitQty,ManufacturerCode,ZoneStatus,IsFromOtherFTZWarehouse,OutwardType,OutwardType\r\n,ANCPACMEL,ADS,P62541,,CF721911,6,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,CF722311,8,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,CF7223L11,8,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,CF741911,6,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,CF711911,3,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,AP7119/7219L11,4,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,CF762011,6,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62541,,HP731311,40,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,CF7219,6,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,CF7223,8,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,CF7223L,8,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,CF7419,6,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,CF7119,3,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,AP7119/7219L,4,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,CF7620,6,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n,ANCPACMEL,ADS,P62542,,HP7313,40,,,,,,,,,,,,,,,,,,,,,,,,,,,,,\r\n```",
        "link": "https://stackoverflow.com/questions/55946071/json-to-csv-conversion-via-jq-command-in-bash",
        "title": "JSON to CSV conversion via JQ command in bash"
    },
    {
        "tags": [
            "jq",
            "cartesian-product"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1556838399,
                "last_edit_date": 1556838399,
                "creation_date": 1556808675,
                "answer_id": 55955043,
                "question_id": 55954949,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Cartesian product\r\n\r\nOne way to generate the array of pairs in the specified order would be as follow:\r\n\r\n    def data: [0,1,2];\r\n\r\n    data | [.[] as $i | .[] as $j | [$i, $j] ] \r\n\r\nAlternatively, avoiding $-variables:\r\n\r\n    [range(0;3) | [.] + (range(0;3)|[.])]\r\n\r\n\r\n## Square matrix with m[i][j] = [i,j]\r\n \r\n    def Mij(n):\r\n      [ range(0;n) as $i\r\n        | [ range(0;n) as $j\r\n            | [$i, $j] ] ];\r\n \r\n    \r\n    Mij(3)\r\n\r\nproduces:\r\n\r\n    [[[0,0],[0,1],[0,2]],[[1,0],[1,1],[1,2]],[[2,0],[2,1],[2,2]]]\r\n",
                "title": "How to produce cartesian square in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1556838399,
        "creation_date": 1556808400,
        "question_id": 55954949,
        "body_markdown": "How to produce the Cartesian square of an array in `jq`?\r\n\r\nInput:\r\n```\r\n[0,1,2]\r\n```\r\n\r\nOutput:\r\n```\r\n[[0,0],[0,1],[0,2],\r\n [1,0],[1,1],[1,2],\r\n [2,0],[2,1],[2,2]]\r\n```\r\n\r\nI found simple way to make it work with arithmetic operations, but no luck with comma operator.",
        "link": "https://stackoverflow.com/questions/55954949/how-to-produce-cartesian-square-in-jq",
        "title": "How to produce cartesian square in jq?"
    },
    {
        "tags": [
            "json",
            "newline",
            "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": 1556829861,
                "post_id": 55959877,
                "comment_id": 98571563,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1556832022,
                "last_edit_date": 1556832022,
                "creation_date": 1556829604,
                "answer_id": 55959932,
                "question_id": 55959877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `keys_unsorted` to get object keys (`keys` does the same as well but the former is faster), generate desired output by means of string interpolation.\r\n```\r\n$ jq -r &#39;keys_unsorted[] as $k | &quot;\\($k) \\(.[$k])&quot;&#39; file\r\nfoo 42\r\nbaz -12\r\nbar{label1=&quot;value1&quot;} 12.34\r\n```\r\nAnd, by adding `-j` option and printing line feed manually as @peak suggested you can make this portable.",
                "title": "convert JSON object to Prometheus metrics format using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1556830256,
                "creation_date": 1556830256,
                "answer_id": 55960066,
                "question_id": 55959877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On a Windows platform, jq will normally use CR-LF for newlines; to prevent this, use the -j command-line option and manually insert the desired &#39;newline&#39; characters like so:\r\n\r\n    jq -rj &#39;to_entries[] | &quot;\\(.key) \\(.value)\\n&quot;&#39; file",
                "title": "convert JSON object to Prometheus metrics format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1556832022,
        "creation_date": 1556829284,
        "last_edit_date": 1556830289,
        "question_id": 55959877,
        "body_markdown": "Consider a JSON object like\r\n\r\n    {\r\n      &quot;foo&quot;: 42,\r\n      &quot;baz&quot;: -12,\r\n      &quot;bar{label1=\\&quot;value1\\&quot;}&quot;: 12.34\r\n    }\r\n\r\nconstructed by [jq](https://github.com/stedolan/jq) using some data source. The actual key names and their amount may vary, but the result will always be an object with numbers (int or float) as values. The keys may contain quotation marks, but no whitespaces.\r\n\r\nCan I use jq to format the object into a [Prometheus](https://prometheus.io/)-compatible format so I can just use the output to push the data to a Prometheus Pushgateway?\r\n\r\nThe required result would look like\r\n\r\n    foo 42\r\n    bar{label1=&quot;value1&quot;} 12.34\r\n    baz -12\r\n\r\ni.e. space-separated with newlines (no `\\r`) and without quotes except for the label value.\r\n\r\nI can&#39;t use bash for post-processing and would therefore prefer a pure jq solution if possible.",
        "link": "https://stackoverflow.com/questions/55959877/convert-json-object-to-prometheus-metrics-format-using-jq",
        "title": "convert JSON object to Prometheus metrics format using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3758852,
                    "reputation": 35,
                    "user_id": 3124494,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/77a05007a2632b47f070dc1b19b6f557?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bchill",
                    "link": "https://stackoverflow.com/users/3124494/bchill"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556866967,
                "post_id": 55964317,
                "comment_id": 98580329,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1556866365,
                "creation_date": 1556866365,
                "answer_id": 55964656,
                "question_id": 55964317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t descend into children if you need parent.\r\n```\r\n.SecurityGroups[]\r\n| select(any(.IpPermissions[]; .FromPort == 22))\r\n| .GroupName, .GroupId\r\n```\r\nshould work.",
                "title": "Get values from only the related parents when matching a child"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1596277229,
        "creation_date": 1556864743,
        "last_edit_date": 1596277229,
        "question_id": 55964317,
        "body_markdown": "I am trying to get a value from an array by matching a value in a child array, but everything I try either returns nothing or all of members of the parent array. I only want the info from the parent where the child matches.\r\n\r\nSpecifically, I want to list all of the AWS security groups that have port 22 rules in them.\r\n\r\nThis is a reduced sample output from the aws command line that I am trying to parse:\r\n\r\n```\r\n{\r\n    &quot;SecurityGroups&quot;: [\r\n        {\r\n            &quot;Description&quot;: &quot;ssh and web group&quot;,\r\n            &quot;IpPermissions&quot;: [\r\n                {\r\n                    &quot;FromPort&quot;: 22,\r\n                    &quot;ToPort&quot;: 22\r\n                },\r\n                {\r\n                    &quot;FromPort&quot;: 80,\r\n                    &quot;ToPort&quot;: 80\r\n                }\r\n            ],\r\n            &quot;GroupName&quot;: &quot;ssh-web&quot;,\r\n            &quot;GroupId&quot;: &quot;sg-11111111&quot;\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;https group&quot;,\r\n            &quot;IpPermissions&quot;: [\r\n                {\r\n                    &quot;FromPort&quot;: 443,\r\n                    &quot;ToPort&quot;: 443\r\n                },\r\n                {\r\n                    &quot;FromPort&quot;: 8443,\r\n                    &quot;ToPort&quot;: 8443\r\n                }\r\n            ],\r\n            &quot;GroupName&quot;: &quot;https&quot;,\r\n            &quot;GroupId&quot;: &quot;sg-22222222&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI have tried this:\r\n\r\n    aws ec2 describe-security-groups |\r\n        jq &#39;.SecurityGroups[] as $top |\r\n            .SecurityGroups[].IpPermissions[] |\r\n            select(.FromPort == 22) |\r\n            $top&#39;\r\n\r\nand this:\r\n\r\n    aws ec2 describe-security-groups |\r\n        jq &#39;. as $top |\r\n            .SecurityGroups[].IpPermissions[] |\r\n            select(.FromPort == 22) |\r\n            $top&#39;\r\n\r\n\r\nBoth commands show both of the top-level array entries instead of just one containing the port 22 entry; they just show the entire output from the aws command.\r\n\r\nThe person who answered this question below specifically refers to the potential scoping problem that I am actually having, but his brief description of how to deal with it isn&#39;t enough for me to understand:\r\n\r\nhttps://stackoverflow.com/questions/38689645/jq-how-do-i-print-a-parent-value-of-an-object-when-i-am-already-deep-into-the\r\n\r\nI want to see this:\r\n\r\n```\r\nGroupName: &quot;https&quot;\r\nGroupID: &quot;sg-22222222&quot;\r\n```\r\n\r\nI don&#39;t think I fully understand how using &#39;as&#39; works, which may be my stumbling block.",
        "link": "https://stackoverflow.com/questions/55964317/get-values-from-only-the-related-parents-when-matching-a-child",
        "title": "Get values from only the related parents when matching a child"
    },
    {
        "tags": [
            "json",
            "syntax-error",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556884748,
                "post_id": 55969065,
                "comment_id": 98589346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3250044,
                    "reputation": 356,
                    "user_id": 3783949,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d93603cf04d8f41130318b4072cafdd2?s=256&d=identicon&r=PG",
                    "display_name": "Roberto Paz",
                    "link": "https://stackoverflow.com/users/3783949/roberto-paz"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1556884914,
                "post_id": 55969065,
                "comment_id": 98589431,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1556885041,
                "last_edit_date": 1556885041,
                "creation_date": 1556883649,
                "answer_id": 55969110,
                "question_id": 55969065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you just need to do below. If your `data[]` array contains multiple entries, specify the index inside the `[..]` part. In your case, the below filter is same as specifying the index as `0` inside the `[..]`  \r\n\r\n    jq &#39;.data[].wifi_score.client_score_avg&#39; file.json\r\n",
                "title": "Can&#39;t filter value inside a string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1556886952,
        "creation_date": 1556883494,
        "last_edit_date": 1556886952,
        "question_id": 55969065,
        "body_markdown": "I need to parse a json with the following format\r\n\r\n```\r\n{\r\n  &quot;meta&quot;: {\r\n    &quot;rc&quot;: &quot;ok&quot;\r\n  },\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;average_wifi_utilization&quot;: {\r\n        &quot;total&quot;: 21.928571428571427,\r\n        &quot;na&quot;: 9.035714285714286,\r\n        &quot;ng&quot;: 34.82142857142857\r\n      },\r\n      &quot;devices_status&quot;: {\r\n        &quot;uap&quot;: {\r\n          &quot;adopted&quot;: 28,\r\n          &quot;connected&quot;: 28,\r\n          &quot;disconnected&quot;: 0,\r\n          &quot;pending&quot;: 0,\r\n          &quot;disabled&quot;: 0\r\n        },\r\n        &quot;usw&quot;: {\r\n          &quot;adopted&quot;: 2,\r\n          &quot;connected&quot;: 2,\r\n          &quot;disconnected&quot;: 0,\r\n          &quot;pending&quot;: 0\r\n        },\r\n        &quot;ugw&quot;: {\r\n          &quot;adopted&quot;: 0,\r\n          &quot;connected&quot;: 0,\r\n          &quot;disconnected&quot;: 0,\r\n          &quot;pending&quot;: 0\r\n        }\r\n      },\r\n      &quot;wifi_score&quot;: {\r\n        &quot;client_score_avg&quot;: 81,\r\n        &quot;clients_with_poor_score&quot;: 8,\r\n        &quot;clients_with_fair_score&quot;: 3,\r\n        &quot;clients&quot;: 99,\r\n        &quot;retry_rate&quot;: 0,\r\n        &quot;signal&quot;: -61,\r\n        &quot;latency&quot;: 0\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI need to extract value from &quot;client_score_avg&quot; key.\r\n\r\nI&#39;m able to extract first level of info with:\r\n```\r\ncat file.json | jq &#39;.data&#39;\r\n```\r\nHowever, when I try next step\r\n```\r\ncat file.json | jq &#39;.data.[0]&#39;\r\n```\r\nI get an error message: \r\n\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nI&#39;m not sure what I&#39;m doing wrong.",
        "link": "https://stackoverflow.com/questions/55969065/cant-filter-value-inside-a-string",
        "title": "Can&#39;t filter value inside a string"
    },
    {
        "tags": [
            "json",
            "recursion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1556893545,
                "last_edit_date": 1556893545,
                "creation_date": 1556892640,
                "answer_id": 55971537,
                "question_id": 55970566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem description does not seem to match the sample input and output, but the following jq program produces the required output:\r\n\r\n    def descend:\r\n      select( type == &quot;object&quot; and has(&quot;name&quot;) )\r\n      | if has(&quot;fields&quot;) then ([.name] + (.fields[] | descend)) else empty end, \r\n        [.name] ;\r\n\r\n    .[]\r\n    | descend\r\n    | join(&quot;.&quot;)\r\n    \r\nWith your input, and using the -r command-line option, this produces:\r\n\r\n    alpha\r\n    beta.beta_sub_1\r\n    beta.beta_sub_2\r\n    beta\r\n    gamma.gamma_sub_1.gamma_sub_sub_1\r\n    gamma.gamma_sub_1\r\n    gamma\r\n\r\n## Resources\r\n\r\nApart from the [jq manual][1], [FAQ][2], and [Cookbook][3], you might find the following helpful:\r\n\r\n* [&quot;jq Language Description&quot;][4] \r\n* [&quot;A Stream-Oriented Introduction to jq&quot;][5]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n  [2]: https://github.com/stedolan/jq/wiki/FAQ\r\n  [3]: https://github.com/stedolan/jq/wiki/Cookbook\r\n  [4]: https://github.com/stedolan/jq/wiki/jq-Language-Description\r\n  [5]: https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq",
                "title": "How to retrieve recursive path to a specific key (not displaying the parents&#39; key name, but the value from a different key of each parent)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1556894667,
        "creation_date": 1556889164,
        "last_edit_date": 1556894667,
        "question_id": 55970566,
        "body_markdown": "I have the following JSON\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;alpha&quot;\r\n  },\r\n  {\r\n    &quot;fields&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;beta_sub_1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;beta_sub_2&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;beta&quot;\r\n  },\r\n  {\r\n    &quot;fields&quot;: [\r\n      {\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;gamma_sub_sub_1&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;gamma_sub_1&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;gamma&quot;\r\n  }\r\n]\r\n```\r\n\r\nand I would like to get the paths of &quot;name&quot; needed to get to each &quot;name&quot; values. Considering the above code, I would like the following result:\r\n\r\n```\r\n&quot;alpha&quot;\r\n&quot;beta.beta_sub_1&quot;\r\n&quot;beta.beta_sub_2&quot;\r\n&quot;beta&quot;\r\n&quot;gamma.gamma_sub_1.gamma_sub_sub_1&quot;\r\n&quot;gamma.gamma_sub_1&quot;\r\n&quot;gamma&quot;\r\n```\r\n\r\nI&#39;ve been searching around but I couldn&#39;t get to this result. So far, I have this:\r\n```\r\ntostream as [$p,$v]   | select($p[-1] == &quot;name&quot; and $v != null)   | &quot;\\([$p[0,1]] | join(&quot;.&quot;)).\\($v)&quot;\r\n```\r\n\r\nbut this gives me the path with the key name of the parents (and doesn&#39;t keep all the intermediary parents.\r\n```\r\n&quot;0.name.alpha&quot;\r\n&quot;1.fields.beta_sub_1&quot;\r\n&quot;1.fields.beta_sub_2&quot;\r\n&quot;1.name.beta&quot;\r\n&quot;2.fields.gamma_sub_sub_1&quot;\r\n&quot;2.fields.gamma_sub_1&quot;\r\n&quot;2.name.gamma&quot;\r\n```\r\n\r\nAny ideas?\r\n\r\nP.S.: I&#39;ve been searching for very detailed doc on jq but couldn&#39;t find anything good enough. If anyone has any recommendations, I&#39;d appreciate.",
        "link": "https://stackoverflow.com/questions/55970566/how-to-retrieve-recursive-path-to-a-specific-key-not-displaying-the-parents-ke",
        "title": "How to retrieve recursive path to a specific key (not displaying the parents&#39; key name, but the value from a different key of each parent)"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "keyvaluepair"
        ],
        "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": 1556899754,
                "post_id": 55973419,
                "comment_id": 98597842,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13672016,
                    "reputation": 37,
                    "user_id": 9864469,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6b737f469f7571e8f8da7c7f88681c04?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "greywolf",
                    "link": "https://stackoverflow.com/users/9864469/greywolf"
                },
                "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": 1556900932,
                "post_id": 55973419,
                "comment_id": 98598443,
                "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": 1557157582,
                "post_id": 55973419,
                "comment_id": 98662314,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557156185,
                "last_edit_date": 1557156185,
                "creation_date": 1556911905,
                "answer_id": 55976069,
                "question_id": 55973419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your JSON file is not too big for `jq` to read, a simple and efficient solution (modulo the use of jq to read the file into memory) would be to use `keys_unsorted/0` and `test/1`:\r\n\r\n    keys_unsorted[] as $k\r\n    | select(.[$k] | test(&quot;another&quot;))\r\n    | [$k, .[$k]]\r\n\r\n(Using `map_values` would be unnecessarily inefficient, and using `contains` is probably not a good idea unless you fully understand its complications.)\r\n\r\nIf you require the output to be a single object, you could either adapt the above, or (at the cost of the memory required for the output object):\r\n\r\n    . as $in\r\n    | reduce keys_unsorted[] as $k ({};\r\n        if ($in[$k] | test(&quot;another&quot;))\r\n        then  .[$k] = $in[$k]\r\n        else . end)\r\n\r\n\r\n### Very Large Files\r\n\r\nFor files that are too big to read into jq normally, you could use jq&#39;s streaming parser, i.e. using the `--stream` command-line option.  Unfortunately, this is easier said than done, but an easy approach would be to use `atomize` as defined e.g. at https://stackoverflow.com/questions/52326989/jq-stream-filter-on-multiple-values-of-same-key\r\n\r\n",
                "title": "jq map_values on very large file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1556918512,
                "creation_date": 1556918512,
                "answer_id": 55977257,
                "question_id": 55973419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use `with_entries/1` it allows you to effectively filter out properties of an object based on the key and/or value.\r\n\r\n    with_entries(select(.value | contains(&quot;PATTERN&quot;)))",
                "title": "jq map_values on very large file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1557156185,
        "creation_date": 1556899132,
        "last_edit_date": 1557018922,
        "question_id": 55973419,
        "body_markdown": "I&#39;m using jq to find patterns in a very large JSON file (500MB+) with the following flat object structure:\r\n``` \r\n{\r\n   &quot;prop1&quot;: &quot;large string&quot;,\r\n   &quot;prop2&quot;: &quot;another large string&quot;,\r\n   &quot;prop3&quot;: &quot;yet another large string&quot;,\r\n   ...\r\n}\r\n```\r\n\r\nThe below query works fine and it takes less than 15sec to return results:\r\n```\r\njq &#39;map(select(contains(&quot;PATTERN&quot;)==true))&#39; largefile.json &gt; res.json\r\n```\r\n\r\nbut that returns me an array of the strings in which the pattern is found, so I lose the property names.\r\nWhen I try to use map_values, so I can also get the property names, as in:\r\n```\r\njq &#39;map_values(select(contains(&quot;PATTERN&quot;)==true))&#39; largefile.json &gt; res.json\r\n```\r\n\r\nthe query takes forever.\r\n\r\nIs there an equivalent query that is fast like map, and which can also provide me with the key:value pairs?",
        "link": "https://stackoverflow.com/questions/55973419/jq-map-values-on-very-large-file",
        "title": "jq map_values on very large file"
    },
    {
        "tags": [
            "json",
            "jq",
            "repeat"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1556917208,
                "last_edit_date": 1556917208,
                "creation_date": 1556910465,
                "answer_id": 55975813,
                "question_id": 55974870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To achieve an efficient solution, let us define `repeated/2` to check whether a given value occurs more than once in a stream:\r\n\r\n    def repeated(stream; $value):\r\n      label $done\r\n      | foreach stream as $x (0;\r\n           if $x == $value then  . + 1 else . end;\r\n           if . == 2 then true, break $done else empty end)\r\n      // false;\r\n\r\nThe key here is of course to break out of the loop once the value has been encountered a second time.\r\n\r\n## Solution\r\nWith the above, the solution would be:\r\n\r\n    repeated(.[] | .downloadId; &quot;ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47&quot;)\r\n\r\n    \r\n",
                "title": "use jq to return a boolean if more than one key has a specified value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1556939425,
        "creation_date": 1556905763,
        "last_edit_date": 1556939425,
        "question_id": 55974870,
        "body_markdown": "I have a JSON blob. It contains a queue of items to process. I am using jq to filter it. Each object in this queue has the key `downloadId`. I can return a list of objects where `downloadId` has a certain value with this filter:\r\n\r\n    .[] | select((.downloadId) == &quot;ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47&quot;)\r\n\r\nBut what I really need is a boolean that will return `true` if there is more than one object in the queue with that value for `downloadId`. I&#39;ve been looking over the jq manual but I&#39;m not quite sure how to do that. I can try using `any`\r\n\r\n    any(.[]; .downloadId == &quot;ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47&quot;)\r\n\r\nbut that returns true if there is one instance of that value, not more than one.\r\n\r\nHere is a blob:\r\n\r\n    [\r\n      {\r\n        &quot;sizeleft&quot;: 805679928.0,\r\n        &quot;timeleft&quot;: &quot;00:00:00&quot;,\r\n        &quot;estimatedCompletionTime&quot;: &quot;2019-05-03T17:30:31.370856Z&quot;,\r\n        &quot;status&quot;: &quot;Paused&quot;,\r\n        &quot;trackedDownloadStatus&quot;: &quot;Ok&quot;,\r\n        &quot;statusMessages&quot;: [],\r\n        &quot;downloadId&quot;: &quot;1C2DE46A5B4258BE7AC47FEFAE71432897417126&quot;,\r\n        &quot;id&quot;: 1065601863\r\n      },\r\n      {\r\n        &quot;sizeleft&quot;: 836459293.0,\r\n        &quot;timeleft&quot;: &quot;00:00:00&quot;,\r\n        &quot;estimatedCompletionTime&quot;: &quot;2019-05-03T17:30:31.370864Z&quot;,\r\n        &quot;status&quot;: &quot;Paused&quot;,\r\n        &quot;trackedDownloadStatus&quot;: &quot;Ok&quot;,\r\n        &quot;statusMessages&quot;: [],\r\n        &quot;downloadId&quot;: &quot;728084A13FD172FED437C6AE503A8CF4A8D317AE&quot;,\r\n        &quot;id&quot;: 1177597916\r\n      },\r\n      {\r\n        &quot;sizeleft&quot;: 836459293.0,\r\n        &quot;timeleft&quot;: &quot;00:00:00&quot;,\r\n        &quot;estimatedCompletionTime&quot;: &quot;2019-05-03T17:30:31.370864Z&quot;,\r\n        &quot;status&quot;: &quot;Paused&quot;,\r\n        &quot;trackedDownloadStatus&quot;: &quot;Ok&quot;,\r\n        &quot;statusMessages&quot;: [],\r\n        &quot;downloadId&quot;: &quot;ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47&quot;,\r\n        &quot;id&quot;: 1177597916\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/55974870/use-jq-to-return-a-boolean-if-more-than-one-key-has-a-specified-value",
        "title": "use jq to return a boolean if more than one key has a specified value"
    },
    {
        "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": 2,
                "creation_date": 1557043165,
                "post_id": 55989933,
                "comment_id": 98628067,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1557059401,
                "last_edit_date": 1557059401,
                "creation_date": 1557043201,
                "answer_id": 55989954,
                "question_id": 55989933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of line oriented ones use a tool which is capable of parsing JSON values syntax wise. An example using [tag:jq]:\r\n```\r\n$ json_value=&#39;{&quot;A&quot;:{&quot;id&quot;:4},&quot;B&quot;:{&quot;foo&quot;:0},&quot;C&quot;:{&quot;A&quot;:{&quot;id&quot;:2}},&quot;E&quot;:{&quot;A&quot;:null},&quot;F&quot;:{&quot;foo&quot;:0}}&#39;\r\n$\r\n$ jq -c &#39;..|objects|.A//empty&#39; &lt;&lt;&lt; &quot;$json_value&quot;\r\n{&quot;id&quot;:4}\r\n{&quot;id&quot;:2}\r\n```\r\n``` lang-none\r\n..            # list nodes recursively\r\n| objects     # select objects\r\n| .A // empty # print A&#39;s value if present.\r\n```",
                "title": "Linux command to print all jsons of same key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1557158259,
        "creation_date": 1557042991,
        "last_edit_date": 1557068409,
        "question_id": 55989933,
        "body_markdown": "I have json as a string &quot;Str&quot;\r\n\r\n    &quot;{\r\n      &quot;A&quot;: {\r\n        &quot;id&quot;: 4\r\n      },\r\n      &quot;B&quot;: {//Something},\r\n      &quot;C&quot;: {\r\n        &quot;A&quot;: {\r\n          &quot;id&quot;: 2\r\n        }\r\n      },\r\n      &quot;E&quot;: {\r\n        &quot;A&quot;: null\r\n      },\r\n      &quot;F&quot;: {//Something}\r\n    }&quot;\r\n\r\nI wanted all non null values of &quot;A&quot; which can be repeated anywhere in json. I wanted output like all contents of &quot;A&quot;\r\n\r\n    {&quot;id&quot;: 4}\r\n    {&quot;id&quot;: 2}\r\n\r\nCan you please help me with Linux command to get this ?\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/55989933/linux-command-to-print-all-jsons-of-same-key",
        "title": "Linux command to print all jsons of same key"
    }
]