[
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582611102,
                "last_edit_date": 1582611102,
                "creation_date": 1582603865,
                "answer_id": 60387392,
                "question_id": 60387047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the following solution, the dictionary file is read using the `--slurpfile` command-line option, and the lines of &quot;text&quot; are read using `inputs` in conjunction with the -n command-line option.  The -r command-line option is used in conjunction with the `@csv` filter to produce the desired output.\r\n\r\n### Invocation\r\n\r\n    jq -n -R -r --slurpfile dict stream.json -f program.jq stream.txt\r\n\r\n### program.jq\r\n```\r\n(INDEX($dict[]; .uid) | map_values(.name)) as $d\r\n| inputs\r\n| split(&quot;,&quot;)\r\n| map(fromjson)\r\n| map($d[.])\r\n| @csv\r\n```\r\n\r\n### Caveat\r\nThe above assumes that the quoted values in stream.txt do not themselves contain commas.\r\n\r\nIf the quoted values in stream.txt do contain commas, then it would be much easier if the values given on each line in stream.txt were given as JSON entities, e.g. as an array of strings, or as a sequence of JSON strings with no separator character.\r\n\r\n\r\n## Solution to problem described in a comment\r\n\r\n### Invocation\r\n\r\n    &lt; original.json jq -r --slurpfile dict stream.json -f program.jq\r\n\r\n### program.jq\r\n```\r\n (INDEX($dict[]; .uid) | map_values(.name)) as $d\r\n | .source\r\n | map($d[.])\r\n | @csv\r\n```",
                "title": "Use jq to replace txt file array string values from dictionary"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582611102,
        "creation_date": 1582600800,
        "question_id": 60387047,
        "body_markdown": "I have a dictionary that looks like this:\r\n\r\n    {\r\n      &quot;uid&quot;: &quot;d6fc3e2b-0001a&quot;,\r\n      &quot;name&quot;: &quot;ABC Mgmt&quot;,\r\n      &quot;type&quot;: &quot;host&quot;\r\n    }\r\n    {\r\n      &quot;uid&quot;: &quot;d6fc3e2b-0002a&quot;,\r\n      &quot;name&quot;: &quot;Server XYZ&quot;,\r\n      &quot;type&quot;: &quot;group&quot;\r\n    }\r\n    {\r\n      &quot;uid&quot;: &quot;d6fc3e2b-0003a&quot;,\r\n      &quot;name&quot;: &quot;NTP Primary&quot;,\r\n      &quot;type&quot;: &quot;host&quot;\r\n    }\r\n    {\r\n      &quot;uid&quot;: &quot;d6fc3e2b-0004a&quot;,\r\n      &quot;name&quot;: &quot;H-10.10.10.10&quot;,\r\n      &quot;type&quot;: &quot;host&quot;\r\n    }\r\n\r\nThen I have a txt file:\r\n\r\n    &quot;d6fc3e2b-0001a&quot;\r\n    &quot;d6fc3e2b-0001a&quot;,&quot;d6fc3e2b-0002a&quot;,&quot;d6fc3e2b-0003a&quot;\r\n    &quot;d6fc3e2b-0004a&quot;\r\n\r\nExpected Output:\r\n\r\n    &quot;ABC Mgmt&quot;\r\n    &quot;ABC Mgmt&quot;,&quot;Server XYZ&quot;,&quot;NTP Primary&quot;\r\n    &quot;H-10.10.10.10&quot;\r\n\r\nI have some trouble to make jq using an array which is not json format. I tried various solutions that I found, but none of them worked. I am rather new to scripting, need some help.\r\n\r\n    input=file.txt\r\n    while IFS= read -r line\r\n    do\r\n    {\r\n    value=$(jq -r --arg line &quot;$line&quot; \\\r\n      &#39;from_entries | .[($line | split(&quot;,&quot;))[]]&#39; \\\r\n      dictionary.json)\r\n    echo $name\r\n    }\r\n    done &lt; &quot;$input&quot;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60387047/use-jq-to-replace-txt-file-array-string-values-from-dictionary",
        "title": "Use jq to replace txt file array string values from dictionary"
    },
    {
        "tags": [
            "shell",
            "firefox",
            "scripting",
            "jq",
            "bookmarks"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2320267,
                    "reputation": 170,
                    "user_id": 5821692,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-Lc5x-p28hFQ/AAAAAAAAAAI/AAAAAAAAAAA/TcUtMGdO4Qo/s256-rj/photo.jpg",
                    "display_name": "MostHated",
                    "link": "https://stackoverflow.com/users/5821692/mosthated"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608348836,
                "post_id": 60389427,
                "comment_id": 115563637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5008840,
                    "reputation": 2981,
                    "user_id": 4025659,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/4WeB0.jpg?s=256",
                    "display_name": "wbadart",
                    "link": "https://stackoverflow.com/users/4025659/wbadart"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1640892670,
                "post_id": 60389427,
                "comment_id": 124686272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1653408180,
                "post_id": 60389427,
                "comment_id": 127843257,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 3,
        "last_activity_date": 1632657179,
        "creation_date": 1582615530,
        "last_edit_date": 1632657179,
        "question_id": 60389427,
        "body_markdown": "I used to use *Google Chrome* bookmarks for a very long time, heavily utilizing its tagging.\r\nNow I would like to switch to plain *Firefox* bookmarking. I exported my bookmarks from\r\n`chrome://bookmarks` (*HTML* export) and imported them in *Firefox*. So far so good. But sadly what\r\nwas a tag in *Chrome* is a bookmark folder in *Firefox* now! I ended with many hundreds of\r\nbookmark folders and thousands of duplicates across them and, of course, no tags at all.\r\n\r\n*Firefox* can export bookmarks as *JSON* so I managed to find a way to restructure\r\nthe *JSON* export so that after importing what is the *Firefox* bookmark folder will be\r\nbookmark tag again. I tried some ways to do so using `jq(1)` but failed completely while\r\nI have to cope with levels of nesting in the bookmarks *JSON* export I do not know\r\nhow to cope with yet (yes, I am completely new to `jq(1)`).\r\n\r\nDeduplication of bookmarks can (hopefuly) be done using some of the *Firefox* addons for\r\nthe task. Therefore all what I need now is to convert bookmark folder paths in bookmark *JSON* export\r\nto bookmark tags.\r\n\r\nOf course, if &quot;deduplication&quot; (by concatening the bookmark folders as tags for every single\r\n*URL*) was possible, it would be fine too. If `jq(1)` is not the right tool for such a task\r\nany other solution is welcome of course. It is just &quot;single shot&quot; task for me but may be\r\nvery useful to anybody who would like to migrate their bookmarks from *Chrome* bookmarks\r\nto *Firefox*.",
        "link": "https://stackoverflow.com/questions/60389427/convert-bookmark-folder-names-to-tags-in-firefox-bookmarks-json-export",
        "title": "Convert bookmark folder names to tags in Firefox bookmarks JSON export"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582628038,
                "post_id": 60389855,
                "comment_id": 106834686,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582634438,
                "last_edit_date": 1582634438,
                "creation_date": 1582627075,
                "answer_id": 60392628,
                "question_id": 60389855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All those 1-element long arrays are a pain, and I&#39;m sure there&#39;s a better way to do this, but the following works:\r\n\r\n```\r\njq &#39;[.[]\r\n     | .jobs |=\r\n       [flatten\r\n        | group_by(.targetLanguage)\r\n        | .[]\r\n        | [reduce .[] as $job ({jobId:[], earlyAccessStatus:[]};\r\n             {targetLanguage: $job.targetLanguage,\r\n              jobId: (.jobId + [$job.jobId]),\r\n              earlyAccessStatus: (.earlyAccessStatus + [$job.earlyAccessStatus])})]\r\n        | walk(if type == &quot;object&quot; and has(&quot;earlyAccessStatus&quot;)\r\n               then .earlyAccessStatus |= unique\r\n               else . end) ] ]&#39; input.json\r\n```\r\n\r\n    [\r\n      {\r\n        &quot;projectId&quot;: 35525710,\r\n        &quot;jobs&quot;: [\r\n          [\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n              &quot;jobId&quot;: [\r\n                35826846,\r\n                35826837\r\n              ],\r\n              &quot;earlyAccessStatus&quot;: [\r\n                &quot;IN_PROGRESS&quot;\r\n              ]\r\n            }\r\n          ],\r\n          [\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n              &quot;jobId&quot;: [\r\n                35826845,\r\n                35826836\r\n              ],\r\n              &quot;earlyAccessStatus&quot;: [\r\n                &quot;IN_PROGRESS&quot;,\r\n                &quot;NOT_STARTED&quot;\r\n              ]\r\n            }\r\n          ]\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "Collapse json arrays into single array with combined key values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582633088,
                "creation_date": 1582633088,
                "answer_id": 60394486,
                "question_id": 60389855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might want to rethink all those arrays-within-arrays, but the following achieves what you want except perhaps for the ordering of the groups, and of the keys:\r\n```\r\n# meld all the objects in the given stream of objects\r\ndef meld(objects): \r\n  reduce objects as $o ({}; \r\n    reduce ($o|keys[]) as $k (.; .[$k] += [$o[$k]]));\r\n\r\n\r\n.[0].jobs |=\r\n  (group_by(.[0].targetLanguage)\r\n   | map( [meld(.[] | .[0] ) | .targetLanguage |= .[0] ] ))\r\n\r\n```\r\nThis produces the output shown below. The simplest way to remove duplicates would be to add `unique`, e.g. as a final step in the `meld` function.\r\n\r\nSimilarly, if you want the groups ordered differently, you could specify the order as a post-processing step, or write your own `group_by`.\r\n\r\n## Output \r\n```\r\n[\r\n  {\r\n    &quot;projectId&quot;: 35525710,\r\n    &quot;jobs&quot;: [\r\n      [\r\n        {\r\n          &quot;earlyAccessStatus&quot;: [\r\n            &quot;IN_PROGRESS&quot;,\r\n            &quot;IN_PROGRESS&quot;\r\n          ],\r\n          &quot;jobId&quot;: [\r\n            35826846,\r\n            35826837\r\n          ],\r\n          &quot;targetLanguage&quot;: &quot;pt_BR&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;earlyAccessStatus&quot;: [\r\n            &quot;NOT_STARTED&quot;,\r\n            &quot;IN_PROGRESS&quot;\r\n          ],\r\n          &quot;jobId&quot;: [\r\n            35826845,\r\n            35826836\r\n          ],\r\n          &quot;targetLanguage&quot;: &quot;zh_CN&quot;\r\n        }\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\n",
                "title": "Collapse json arrays into single array with combined key values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582821416,
                "creation_date": 1582821416,
                "answer_id": 60437861,
                "question_id": 60389855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Figured something out that worked! Went more the route of group_by and unique.\r\n\r\n    . | [{projectId: .projectId, \r\n          jobs: [( .jobs[] | { \r\n                targetLanguage: .targetLanguage, \r\n                jobId: .jobId, \r\n                earlyAccessStatus: (.steps[] | select(.workflowStepName == &quot;Target file export1&quot;) | .status), \r\n                finalStatus: (.steps[] | select(.workflowStepName == &quot;Target file export2&quot;) | .status) } )] }] | \r\n          .[].jobs | group_by(.targetLanguage) | map({\r\n                targetLanguage: .[0].targetLanguage, \r\n                jobId: map(.jobId),\r\n                earlyAccessStatus: map(.earlyAccessStatus) | unique, \r\n                finalStatus: map(.finalStatus) | unique})\r\n\r\nThis method works in two steps, first extracting the relevant data and organizing it like this:\r\n\r\n    [\r\n      {\r\n        &quot;projectId&quot;: 35525710,\r\n        &quot;jobs&quot;: [\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n              &quot;jobId&quot;: 35826845,\r\n              &quot;earlyAccessStatus&quot;: &quot;NOT_STARTED&quot;\r\n            },\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n              &quot;jobId&quot;: 35826846,\r\n              &quot;earlyAccessStatus&quot;: &quot;IN_PROGRESS&quot;\r\n            },\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n              &quot;jobId&quot;: 35826836,\r\n              &quot;earlyAccessStatus&quot;: &quot;IN_PROGRESS&quot;\r\n            },\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n              &quot;jobId&quot;: 35826837,\r\n              &quot;earlyAccessStatus&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n       }\r\n    ]\r\n\r\nOnce the content has been simplified in this manner, it is grouped by `.targetLanguage` and then the `.jobId`, `.earlyAccessStatus`, and `.finalStatus` keys are mapped for their unique values under each `.targetLanguage` key-value pair. I&#39;m sure there is a simpler way to format this, but it accomplishes exactly what I set out to accomplish, leaving the data in this format:\r\n\r\n    [\r\n      {\r\n        &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n        &quot;jobId&quot;: [\r\n          35902526,\r\n          36433561,\r\n          36433552\r\n        ],\r\n        &quot;earlyAccessStatus&quot;: [\r\n          &quot;IN_PROGRESS&quot;\r\n        ],\r\n        &quot;finalStatus&quot;: [\r\n          &quot;IN_PROGRESS&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n        &quot;jobId&quot;: [\r\n          35902516,\r\n          36433560,\r\n          36433551\r\n        ],\r\n        &quot;earlyAccessStatus&quot;: [\r\n          &quot;IN_PROGRESS&quot;,\r\n          &quot;NOT_STARTED&quot;\r\n        ],\r\n        &quot;finalStatus&quot;: [\r\n          &quot;IN_PROGRESS&quot;\r\n        ]\r\n      }\r\n    ]\r\n",
                "title": "Collapse json arrays into single array with combined key values"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1582821416,
        "creation_date": 1582617321,
        "last_edit_date": 1582755063,
        "question_id": 60389855,
        "body_markdown": "I&#39;m trying to combine multiple JSON arrays into a single array of collapsed like key values. Here&#39;s what I&#39;ve gotten the code down to.\r\n\r\n    [\r\n      {\r\n        &quot;projectId&quot;: 35525710,\r\n        &quot;jobs&quot;: [\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n              &quot;jobId&quot;: 35826845,\r\n              &quot;earlyAccessStatus&quot;: &quot;NOT_STARTED&quot;\r\n            },\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n              &quot;jobId&quot;: 35826846,\r\n              &quot;earlyAccessStatus&quot;: &quot;IN_PROGRESS&quot;\r\n            },\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n              &quot;jobId&quot;: 35826836,\r\n              &quot;earlyAccessStatus&quot;: &quot;IN_PROGRESS&quot;\r\n            },\r\n            {\r\n              &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n              &quot;jobId&quot;: 35826837,\r\n              &quot;earlyAccessStatus&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n       }\r\n    ]\r\n\r\n\r\nThe desired output would be: (***Edited below to take a different route***)\r\n\r\n  \r\n\r\n\r\n\r\n    [\r\n      {\r\n        &quot;projectId&quot;: 35525710,\r\n        &quot;jobs&quot;: [\r\n            {\r\n               &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n               &quot;jobIds&quot;: [35826845,35826836],\r\n               &quot;earlyAccessStatus&quot;: [&quot;NOT_STARTED&quot;,&quot;IN_PROGRESS&quot;]\r\n            },\r\n            {\r\n               &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n               &quot;jobIds&quot;: [35826846,35826837],\r\n               &quot;earlyAccessStatus&quot;: [&quot;IN_PROGRESS&quot;]\r\n            }\r\n         ] \r\n       }\r\n    ]\r\n\r\nI&#39;m not honestly sure what&#39;s going to happen with the duplicated ```.earlyAccessStatus``` key values, whether it will be ```[&quot;IN_PROGRESS&quot;,&quot;IN_PROGRESS&quot;]``` or ```[&quot;IN_PROGRESS&quot;]```. The latter suits my eventual needs, which are to grab the ```.targetLanguage``` value for any language whose only ```.earlyAccessStatus``` is ```[&quot;IN_PROGRESS&quot;]```.\r\n\r\nUsing this filter with the `jq -r` option, I can pull out the `.targetLanguage` value for any languages whose only `.earlyAccessStatus` is `[&quot;IN_PROGRESS&quot;]`. Any help would be greatly appreciated!\r\n\r\n    .[].jobs[] | select(.[] | .earlyAccessStatus == [&quot;IN_PROGRESS&quot;] ) | .[] | .targetLanguage\r\n\r\nUpdate:\r\nHere is what the raw JSON looks like before I&#39;ve manipulated anything. I&#39;m not attached to any specific method. What I&#39;m trying to do is take the data about a project with various jobs and isolate languages for whom all associated jobs have reached certain step (Target file export1) as indicated by &quot;IN_PROGRESS&quot;. If the language has one job in a different step, like for instance zh_CN below, then that language isn&#39;t ready and shouldn&#39;t make it through the filter.\r\n\r\nTo get the output above, I had made it as far as (with one update made to eliminate the redundant arrays inside of &quot;jobs&quot; suggested already and I apologize in advance for whatever Frankenstein attempt at line separation you see in the jq command):\r\n\r\n    . | [{&quot;projectId&quot;: .projectId, \r\n        &quot;jobs&quot;: [( .jobs[] | \r\n            { &quot;targetLanguage&quot;: .targetLanguage, \r\n              &quot;jobId&quot;: .jobId,\r\n              &quot;earlyAccessStatus&quot;: (.steps[] | select(.workflowStepName == &quot;Target file export1&quot;) | .status) } )] }]\r\n\r\nRaw JSON:\r\n\r\n    {\r\n      &quot;projectId&quot;: 35902499,\r\n      &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n      &quot;activity&quot;: &quot;ACTIVE&quot;,\r\n      &quot;sourceLanguage&quot;: &quot;en_US&quot;,\r\n      &quot;jobs&quot;: [\r\n        {\r\n          &quot;jobId&quot;: 35902526,\r\n          &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n          &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Project Intake and Quote Generation1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Translate1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Correct1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Segment greenification1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;,\r\n              &quot;autoStatus&quot;: &quot;SUCCESS&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Target file export1&quot;,\r\n              &quot;status&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;jobId&quot;: 35902516,\r\n          &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n          &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Project Intake and Quote Generation1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Translate1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Correct1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Segment greenification1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;,\r\n              &quot;autoStatus&quot;: &quot;SUCCESS&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Target file export1&quot;,\r\n              &quot;status&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;jobId&quot;: 36433561,\r\n          &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n          &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Project Intake and Quote Generation1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Translate1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Correct1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Segment greenification1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;,\r\n              &quot;autoStatus&quot;: &quot;SUCCESS&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Target file export1&quot;,\r\n              &quot;status&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;jobId&quot;: 36433560,\r\n          &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n          &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Project Intake and Quote Generation1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Translate1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Correct1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Segment greenification1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;,\r\n              &quot;autoStatus&quot;: &quot;SUCCESS&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Target file export1&quot;,\r\n              &quot;status&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;jobId&quot;: 36433552,\r\n          &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n          &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Project Intake and Quote Generation1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Translate1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Correct1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Segment greenification1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;,\r\n              &quot;autoStatus&quot;: &quot;SUCCESS&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Target file export1&quot;,\r\n              &quot;status&quot;: &quot;IN_PROGRESS&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;jobId&quot;: 36433551,\r\n          &quot;completionStatus&quot;: &quot;IN_PROGRESS&quot;,\r\n          &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n          &quot;steps&quot;: [\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Project Intake and Quote Generation1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Translate1&quot;,\r\n              &quot;status&quot;: &quot;FINISHED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Correct1&quot;,\r\n              &quot;status&quot;: &quot;IN_PROGRESS&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Segment greenification1&quot;,\r\n              &quot;status&quot;: &quot;NOT_STARTED&quot;\r\n            },\r\n            {\r\n              &quot;workflowStepName&quot;: &quot;Target file export1&quot;,\r\n              &quot;status&quot;: &quot;NOT_STARTED&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n***New approach***\r\n\r\nThe saga continues. I have gotten so close by taking another route. \r\n\r\n    .[].jobs | \r\n        map({targetLanguage: .targetLanguage, \r\n            earlyAccess: {\r\n                jobId: .jobId, \r\n                earlyAccessStatus: .earlyAccessStatus}}) \r\n            | group_by(.targetLanguage) \r\n            | map({targetLanguage: .[0].targetLanguage, \r\n                jobId: map(.jobId) | unique, \r\n                earlyAccessStatus: map(.earlyAccessStatus) | unique})\r\n\r\nThis gives me basically exactly the output I want, with the exception of the missing data that I need, which is, I suppose, a setback:\r\n\r\n    [\r\n      {\r\n        &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n        &quot;jobId&quot;: [\r\n          null\r\n        ],\r\n        &quot;earlyAccessStatus&quot;: [\r\n          null\r\n        ]\r\n      },\r\n      {\r\n        &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n        &quot;jobId&quot;: [\r\n          null\r\n        ],\r\n        &quot;earlyAccessStatus&quot;: [\r\n          null\r\n        ]\r\n      }\r\n    ]\r\n\r\nIdeally, this would instead output the unique values contained in the jobId and earlyAccessStatus keys like this:\r\n\r\n    [\r\n      {\r\n        &quot;targetLanguage&quot;: &quot;pt_BR&quot;,\r\n        &quot;jobId&quot;: [\r\n          35826846, 35826837\r\n        ],\r\n        &quot;earlyAccessStatus&quot;: [\r\n          &quot;IN_PROGRESS&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;targetLanguage&quot;: &quot;zh_CN&quot;,\r\n        &quot;jobId&quot;: [\r\n          35826845, 35826836\r\n        ],\r\n        &quot;earlyAccessStatus&quot;: [\r\n          &quot;IN_PROGRESS&quot;, &quot;NOT_STARTED&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nThat would let me easily filter for `targetLanguage` according to `earlyAccessStatus == [&quot;IN_PROGRESS&quot;]`.\r\n",
        "link": "https://stackoverflow.com/questions/60389855/collapse-json-arrays-into-single-array-with-combined-key-values",
        "title": "Collapse json arrays into single array with combined key values"
    },
    {
        "tags": [
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5758674,
                    "reputation": 1508,
                    "user_id": 4545741,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/4653cd2599b11a01989c1288f5e20c06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bob dylan",
                    "link": "https://stackoverflow.com/users/4545741/bob-dylan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582620942,
                "post_id": 60390634,
                "comment_id": 106830828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5758674,
                    "reputation": 1508,
                    "user_id": 4545741,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/4653cd2599b11a01989c1288f5e20c06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bob dylan",
                    "link": "https://stackoverflow.com/users/4545741/bob-dylan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582621099,
                "post_id": 60390634,
                "comment_id": 106830901,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9866122,
                    "reputation": 27,
                    "user_id": 7307539,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/869293f511a7daee67a7ed43ae498404?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NicK",
                    "link": "https://stackoverflow.com/users/7307539/nick"
                },
                "reply_to_user": {
                    "account_id": 5758674,
                    "reputation": 1508,
                    "user_id": 4545741,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/4653cd2599b11a01989c1288f5e20c06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bob dylan",
                    "link": "https://stackoverflow.com/users/4545741/bob-dylan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582621104,
                "post_id": 60390634,
                "comment_id": 106830905,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9866122,
                    "reputation": 27,
                    "user_id": 7307539,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/869293f511a7daee67a7ed43ae498404?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "NicK",
                    "link": "https://stackoverflow.com/users/7307539/nick"
                },
                "reply_to_user": {
                    "account_id": 5758674,
                    "reputation": 1508,
                    "user_id": 4545741,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/4653cd2599b11a01989c1288f5e20c06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bob dylan",
                    "link": "https://stackoverflow.com/users/4545741/bob-dylan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582621269,
                "post_id": 60390634,
                "comment_id": 106830983,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5758674,
                    "reputation": 1508,
                    "user_id": 4545741,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/4653cd2599b11a01989c1288f5e20c06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bob dylan",
                    "link": "https://stackoverflow.com/users/4545741/bob-dylan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582622894,
                "post_id": 60390634,
                "comment_id": 106831826,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582630846,
                "creation_date": 1582630846,
                "answer_id": 60393808,
                "question_id": 60390634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -n --argfile one test1.json --argfile two test2.json &#39;\r\n   $test2 | with_entries( select($test1[.key] != .value) )&#39;\r\n```\r\n\r\nor if you want to add the key functionality to your jq library, the key abstraction is:\r\n```\r\n   def minusObject(o1;o2):\r\n     o1 | with_entries( select(o2[.key] != .value) );\r\n```\r\n",
                "title": "Comparison of 2 JSON file using jq in bash storing difference in another json or text file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1582630846,
        "creation_date": 1582620508,
        "last_edit_date": 1582621162,
        "question_id": 60390634,
        "body_markdown": "I have 2 json files.\r\n\r\ntest1.json\r\n\r\n    {\r\n    &quot;GeoIP.x86_64&quot;:&quot;1.5.0-14.el7&quot;,\r\n    &quot;NetworkManager.x86_64&quot;:&quot;1:1.18.0-5.el7_7.1&quot;,\r\n    &quot;NetworkManager-libnm.x86_64&quot;:&quot;1:1.18.0-5.el7_7.1&quot;,\r\n    &quot;NetworkManager-ppp.x86_64&quot;:&quot;1:1.18.0-5.el7_7.1&quot;\r\n    }\r\n\r\ntest2.json\r\n\r\n    {\r\n    &quot;GeoIP.x86_64&quot;:&quot;1.5.0-14.el7&quot;,\r\n    &quot;NetworkManager.x86_64&quot;:&quot;1:2.18.0-5.el7_7.1&quot;,\r\n    &quot;NetworkManager-libnm.x86_64&quot;:&quot;1:1.19.0-5.el7_7.1&quot;,\r\n    &quot;NetworkManager-ppp.x86_64&quot;:&quot;1:1.19.0-5.el7_7.1&quot;,\r\n    &quot;gcc&quot; : &quot;1:1.9.0-el7_7.1&quot;\r\n    }\r\n\r\n\r\nThe above JSON may or not have same package, I want to create a new 2 json like this with above json:\r\n\r\n    {\r\n    &quot;NetworkManager.x86_64&quot;:&quot;1:2.18.0-5.el7_7.1&quot;,\r\n    &quot;NetworkManager-libnm.x86_64&quot;:&quot;1:1.19.0-5.el7_7.1&quot;,\r\n    &quot;NetworkManager-ppp.x86_64&quot;:&quot;1:1.19.0-5.el7_7.1&quot;,\r\n    &quot;gcc&quot; : &quot;1:1.9.0-el7_7.1&quot;\r\n    }\r\n\r\nThe key = **NetworkManager-libnm.x86_64** , **NetworkManager.x86_64** and **NetworkManager-ppp.x86_64** has different value in test2.json and **gcc** is new package. So these 3 packages comes to final json.\r\n\r\nI want to achieve this in shell script with help jq.\r\n\r\nThanks in Advance.",
        "link": "https://stackoverflow.com/questions/60390634/comparison-of-2-json-file-using-jq-in-bash-storing-difference-in-another-json-or",
        "title": "Comparison of 2 JSON file using jq in bash storing difference in another json or text file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1582640802,
                "creation_date": 1582640802,
                "answer_id": 60396848,
                "question_id": 60396693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to slurp them. Without any flags you can access the second input by `input` keyword.\r\n```\r\n$ jq &#39;.a += input.a&#39; master.json extra.json \r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;x&quot;: 1\r\n    },\r\n    {\r\n      &quot;x&quot;: 2\r\n    }\r\n  ],\r\n  &quot;b&quot;: 1\r\n}\r\n```",
                "title": "jq - merge only single key from second JSON file into main JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582641868,
                "creation_date": 1582641868,
                "answer_id": 60397200,
                "question_id": 60396693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As long as the files are not huge in size, slurping them and appending the contents of the array `a` would suffice\r\n\r\n    jq -s &#39;.[].a = ([.[].a]|add|unique)|.[0]&#39; master.json extra.json\r\n\r\nYou can remove the `unique` part, if you are allowed to keep duplicate objects for the array.",
                "title": "jq - merge only single key from second JSON file into main JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1582641868,
        "creation_date": 1582640323,
        "question_id": 60396693,
        "body_markdown": "Given:\r\n\r\nmaster.json:\r\n\r\n    {&quot;a&quot;:[{&quot;x&quot;:1}], &quot;b&quot;:1}\r\n\r\nextra.json:\r\n\r\n    {&quot;a&quot;:[{&quot;x&quot;:2}], &quot;somekey2&quot;:2, &quot;somekey3&quot;:3}\r\n\r\nExpected output:\r\n\r\n    {\r\n      &quot;a&quot;: [\r\n        {\r\n          &quot;x&quot;: 1\r\n        },\r\n        {\r\n          &quot;x&quot;: 2\r\n        }\r\n      ],\r\n      &quot;b&quot;: 1\r\n    }\r\n\r\nI need to merge into `master.json` contents of `&quot;a&quot;` key from `extra.json`, ignoring all other keys the second JSON may have.\r\n\r\nTried this, but it didn&#39;t work\r\n\r\n    jq -s &quot;add&quot; &#39;.[a] + .[a]&#39; x1 x2\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60396693/jq-merge-only-single-key-from-second-json-file-into-main-json-file",
        "title": "jq - merge only single key from second JSON file into main JSON file"
    },
    {
        "tags": [
            "bash",
            "awk",
            "scripting",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582657376,
                "post_id": 60401315,
                "comment_id": 106850750,
                "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": 1582659275,
                "post_id": 60401315,
                "comment_id": 106851578,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11496547,
                    "reputation": 107,
                    "user_id": 8479936,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3e675d289337635141a0402918c804ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "novice sysadmin",
                    "link": "https://stackoverflow.com/users/8479936/novice-sysadmin"
                },
                "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": 1582664388,
                "post_id": 60401315,
                "comment_id": 106853794,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582666263,
                "post_id": 60401315,
                "comment_id": 106854555,
                "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": 1582678606,
                "post_id": 60401315,
                "comment_id": 106858130,
                "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": 1582678770,
                "post_id": 60401315,
                "comment_id": 106858168,
                "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": 1582678869,
                "post_id": 60401315,
                "comment_id": 106858191,
                "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": 1582679003,
                "post_id": 60401315,
                "comment_id": 106858219,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1582678738,
        "creation_date": 1582656447,
        "last_edit_date": 1582678738,
        "question_id": 60401315,
        "body_markdown": "I am running `aws cli aws cloudwatch get-metric-statistics --metric-name CPUUtilization --start-time 2010-02-20T12:00:00 --end-time 2010-02-20T15:00:00 --period 60 --namespace AWS/EC2  --extended-statistics p80 --dimensions Name=InstanceId,Value=i-0b123423423` in a\r\nloop and extracting the metrics from json(using jq) in the below format for around 10-20 instances.\r\n\r\n    Illustrative JSON\r\n    \r\n        {\r\n          &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n          &quot;Datapoints&quot;: [\r\n            {\r\n              &quot;Timestamp&quot;: &quot;2020-02-20T12:15:00Z&quot;,\r\n              &quot;Unit&quot;: &quot;Percent&quot;,\r\n              &quot;ExtendedStatistics&quot;: {\r\n                &quot;p80&quot;: 0.16587132264856133\r\n              }\r\n            },\r\n\r\n    Instance-ABC\r\n    19.514049550078127  \r\n    12.721997782508938  \r\n    13.318820949213313  \r\n    15.994192991030545  \r\n    18.13096421299414 \r\n    \r\n    Instance-BCD\r\n    19.5140495 \r\n    12.7219977 \r\n    13.3188209\r\n    15.9941929  \r\n    18.1309642\r\n    13.3188209\r\n    15.9941929  \r\n    18.1309642 \r\n\r\nHow can i calculate and run operations from the values in above output to get results like below in using Bash scripting\r\n\r\n    Instance above 70% \r\n    Instance-ABC\r\n    Instance-BCD\r\n\r\n    Instances below 20% \r\n    Instance-EFG\r\n    Instance-HIJ\r\n\r\n  \r\n---\r\n\r\nI&#39;m currently retrieving statistics with:\r\n\r\n```\r\nfor i in $(aws ec2 describe-instances | jq -r &#39;.[&quot;Reservations&quot;]|.[]|.Instances|.[]| .InstanceId&#39; | sort -n); do\r\n  echo &quot;Instance $i&quot;\r\n  aws cloudwatch get-metric-statistics --metric-name CPUUtilization --start-time 2019-02-20T15:00:00T --end-time 2019-02-20T18:00:00 --period 60 --namespace AWS/EC2 --extended-statistics p80 --dimensions Name=InstanceId,Value=$i \\\r\n    | jq &#39;.Datapoints[].ExtendedStatistics[]&#39;\r\ndone\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/60401315/shell-scripting-running-operations-on-statistics-extracted-from-json-of-aws-clo",
        "title": "Shell scripting- Running operations on statistics extracted from json of aws cloudwatch statistics using bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1582730134,
                "last_edit_date": 1582730134,
                "creation_date": 1582719489,
                "answer_id": 60413774,
                "question_id": 60413215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Transform the second file into an object where ids and names are paired and use it as a reference while updating the first file.\r\n```\r\n$ jq &#39;(map({(.id): .}) | add) as $idx\r\n      | input\r\n      | map_values(.reference = $idx[.reference.id])&#39; file2 file1\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;5b9f50ccdcdf200283f29052&quot;,\r\n    &quot;reference&quot;: {\r\n      &quot;id&quot;: &quot;5de82d5072f4a72ad5d5dcc1&quot;,\r\n      &quot;name&quot;: &quot;FooBar&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "jq denormalize a nested field"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1582746235,
                "last_edit_date": 1582746235,
                "creation_date": 1582727885,
                "answer_id": 60416343,
                "question_id": 60413215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution uses the same strategy as used in the solution by @OguzIsmail but uses the built-in function `INDEX/2` to construct the dictionary from the second file.  \r\n\r\nThe important point is that this strategy allows the arrays in both files to be of arbitrary size.\r\n\r\n## Invocation\r\n\r\n    jq --argfile file2 file2.json -f program.jq file1.json\r\n\r\n\r\n## program.jq\r\n```\r\nINDEX($file2[]; .id) as $dict\r\n| map(.reference.id as $id | .reference = $dict[$id])\r\n```",
                "title": "jq denormalize a nested field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1582746235,
        "creation_date": 1582717541,
        "last_edit_date": 1582745887,
        "question_id": 60413215,
        "body_markdown": "*disclaimer: indeed, there are already different answers (like https://stackoverflow.com/questions/51269833 or https://stackoverflow.com/questions/33148557) for but none of them helped me yet or did have different circumstances I was unable to derive a solution from ;/*\r\n\r\n---\r\n\r\nI have 2 files, both are lists of objects where one of them ha field references to object ids of the other one \r\n\r\n**given**\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;5b9f50ccdcdf200283f29052&quot;,\r\n    &quot;reference&quot;: {\r\n      &quot;id&quot;: &quot;5de82d5072f4a72ad5d5dcc1&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nand \r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;5de82d5072f4a72ad5d5dcc1&quot;,\r\n    &quot;name&quot;: &quot;FooBar&quot;\r\n  }\r\n]\r\n```\r\n\r\nmy goal would be to get a denormalized object list:\r\n\r\n**expected**\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;5b9f50ccdcdf200283f29052&quot;,\r\n    &quot;reference&quot;: {\r\n      &quot;id&quot;: &quot;5de82d5072f4a72ad5d5dcc1&quot;,\r\n      &quot;name&quot;: &quot;FooBar&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n----\r\n\r\nwhile I&#39;m able to do the main parts, I didn&#39;t challenged to bring both together yet:\r\n\r\nwith\r\n**example 1**\r\n\r\n    jq -s &#39;(.[1][] | select(.id == &quot;5de82d5072f4a72ad5d5dcc1&quot;))&#39; objects.json referredObjects.json\r\nI get\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;5de82d5072f4a72ad5d5dcc1&quot;,\r\n  &quot;name&quot;: &quot;FooBar&quot;\r\n}\r\n```\r\n\r\nand with\r\n**example 2**\r\n\r\n    jq -s &#39;.[0][] | .reference = {}&#39; objects.json referredObjects.json\r\nI can manipulate any `.reference` getting\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;5b9f50ccdcdf200283f29052&quot;,\r\n  &quot;reference&quot;: {}\r\n}\r\n```\r\n(even I loose the list structure)\r\n\r\nBut: I can&#39;t do s.th. like\r\n\r\n**execpted &quot;join&quot;**\r\n\r\n    jq -s &#39;.[0][] as $obj | $obj.reference = (.[1][] | select(.id == $obj.reference.id))&#39; objects.json referredObjects.json\r\n\r\neven approaches with `foreach` or `reduce` looks promising\r\n\r\n    jq -s &#39;[foreach .[0][] as $obj ({}; .reference.id = &quot;&quot;; . + $obj )]&#39; objects.json referredObjects.json\r\n=&gt;\r\n```json\r\n[\r\n  {\r\n    &quot;reference&quot;: {\r\n      &quot;id&quot;: &quot;5de82d5072f4a72ad5d5dcc1&quot;\r\n    },\r\n    &quot;id&quot;: &quot;5b9f50ccdcdf200283f29052&quot;\r\n  }\r\n]\r\n```\r\n\r\nwhere I expected to get the same as in second example\r\n\r\nI end up in headaches and looking forward to write a ineffective while routine in any language ... hopefully I would appreciate any help on this\r\n\r\n~Marcel",
        "link": "https://stackoverflow.com/questions/60413215/jq-denormalize-a-nested-field",
        "title": "jq denormalize a nested field"
    },
    {
        "tags": [
            "json",
            "text",
            "import",
            "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": 1582828996,
                "post_id": 60418971,
                "comment_id": 106920979,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1662038488,
                "last_edit_date": 1662038488,
                "creation_date": 1582750999,
                "answer_id": 60422509,
                "question_id": 60418971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your jq supports the `--rawfile` command-line option (as does jq 1.6), the simplest would be to use it, e.g.:\r\n```\r\njq -Rs --rawfile pub id_rsa.pub &#39;{pem: ., pub: $pub}&#39; id_rsa\r\n```\r\n\r\nThe `-R` flag (aka `--raw-input`) tells jq not to parse the input as JSON. Each line of text is passed directly to the filter as a string. \r\n\r\nThe `-s` flag (aka `--slurp`) tells jq to read the entire incoming stream at one time. Combined with `-R` this pulls the entire file into a single variable.\r\n\r\n\r\n## Without --rawfile\r\n\r\n```\r\njq -Rs --argfile pub &lt;(jq -R &#39;{pub: .}&#39; id_rsa.pub) &#39;{pem: .} + $pub&#39; id_rsa\r\n```\r\n## Trailing newlines\r\n\r\nIf you want to ensure there is no trailing `\\n` at the end of the strings, then you could add calls to `sub(&quot;\\n$&quot;;&quot;&quot;)` as warranted.",
                "title": "Import plain text file in to JSON via JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1662038488,
        "creation_date": 1582736569,
        "question_id": 60418971,
        "body_markdown": "I have two files:\r\n\r\nid_rsa\r\n\r\n    -----BEGIN RSA PRIVATE KEY-----\r\n    ...\r\n    -----END RSA PRIVATE KEY-----\r\n\r\nand id_rsa.pub\r\n\r\n    ssh-rsa AAAAB3NzaC1yc2EAAA...\r\n\r\nUsing JQ, how can import them into a json file like:\r\n\r\n    {\r\n      &quot;pem&quot;: &quot;-----BEGIN RSA PRIVATE KEY-----\\n...\\n-----END RSA PRIVATE KEY-----&quot;,\r\n      &quot;pub&quot;: &quot;ssh-rsa AAAAB3NzaC1yc2EAAA...&quot;\r\n    }\r\n\r\nI have tried a couple, but it&#39;s not working:\r\n\r\n    jq --null-input --argfile pem id_rsa --argfile pub id_rsa.pub &#39;.pem=$pem | .pub=$pub&#39;\r\n    jq: Bad JSON in --argfile pem id_rsa: Invalid numeric literal at line 1, column 11\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60418971/import-plain-text-file-in-to-json-via-jq",
        "title": "Import plain text file in to JSON via JQ"
    },
    {
        "tags": [
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1582753997,
                "last_edit_date": 1582753997,
                "creation_date": 1582750269,
                "answer_id": 60422339,
                "question_id": 60420975,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following adaptation produces the desired output:\r\n\r\n```\r\necho &#39;{&quot;a&quot;:{&quot;value&quot;:&quot;b&quot;}, &quot;c&quot;:{&quot;value&quot;:&quot;d&quot;}}&#39; |\r\n  jq -r &#39;\r\n    def addindex(start;lessthan): \r\n      range(start;lessthan) as $i | &quot;\\(.) \\($i)&quot;;\r\n    . as $in\r\n    | keys[]\r\n    | $in[.].value\r\n    | addindex(1;3)&#39;\r\n```\r\n\r\nNote that `keys` emits the key names after they have been sorted, whereas `keys_unsorted` retains the ordering.",
                "title": "How to duplicate input into outputs with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582753997,
        "creation_date": 1582744475,
        "question_id": 60420975,
        "body_markdown": "I&#39;m trying to adapt the following snippet:\r\n\r\n```\r\necho &#39;{&quot;a&quot;:{&quot;value&quot;:&quot;b&quot;}, &quot;c&quot;:{&quot;value&quot;:&quot;d&quot;}}&#39; \\\r\n    | jq -r &#39;. as $in | keys[] | [$in[.].value | tostring + &quot; 1&quot;] | @tsv&#39;\r\nb 1\r\nd 1\r\n```\r\n\r\nto output:\r\n\r\n```\r\nb 1\r\nb 2\r\nd 1\r\nd 2\r\n```",
        "link": "https://stackoverflow.com/questions/60420975/how-to-duplicate-input-into-outputs-with-jq",
        "title": "How to duplicate input into outputs with jq?"
    },
    {
        "tags": [
            "bash",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user21926"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1582751862,
                "post_id": 60422639,
                "comment_id": 106889716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1720922,
                    "reputation": 4234,
                    "user_id": 1576804,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/1d8c02f1526bc8baeb2fd08b8b82f772?s=256&d=identicon&r=PG",
                    "display_name": "vkaul11",
                    "link": "https://stackoverflow.com/users/1576804/vkaul11"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582753623,
                "post_id": 60422639,
                "comment_id": 106890375,
                "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": 1582753760,
                "post_id": 60422639,
                "comment_id": 106890433,
                "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": 1582753886,
                "post_id": 60422639,
                "comment_id": 106890489,
                "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": 1582754009,
                "post_id": 60422639,
                "comment_id": 106890541,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582756604,
                "last_edit_date": 1582756604,
                "creation_date": 1582754936,
                "answer_id": 60423352,
                "question_id": 60422639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Reading between the lines, it would appear that the following filter should achieve the stated goals:\r\n\r\n```\r\n.[]\r\n| select( .results | any(.judgments[]; .data.rewrite_quality == &quot;1&quot;))\r\n\r\n```\r\n### &quot;Tags&quot;\r\n\r\nIf the intent in using &quot;.Tags&quot; was to indicate that it does not matter what path leads to `.rewrite_quality`, then the filter to use would be:\r\n\r\n```\r\n.[]\r\n| select( any(.. | objects | .rewrite_quality == &quot;1&quot;))\r\n```\r\n \r\n### Alternative to using `less`\r\nIf you want a brief indication of whether there are any matches, you could use this filter, which has the added value of revealing how many objects satisfy the criterion:\r\n\r\n    map(select(any(.. | objects | .rewrite_quality == &quot;1&quot;))) | length\r\n",
                "title": "Nested Filtering json file with jq statement"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582756604,
        "creation_date": 1582751543,
        "last_edit_date": 1582753590,
        "question_id": 60422639,
        "body_markdown": "I have a json file with the following structure of each object inside\r\n\r\n    {\r\n      &quot;id&quot;: 2400321267,\r\n      &quot;data&quot;: {\r\n        &quot;q&quot;: &quot;quinoa black bean and shrimp r&quot;,\r\n        &quot;r&quot;: &quot;quinoa black bean and shrimps r&quot;,\r\n        &quot;s&quot;: &quot;3&quot;\r\n      },\r\n      &quot;job_id&quot;: 1413792,\r\n      &quot;results&quot;: {\r\n        &quot;judgments&quot;: [\r\n          {\r\n            &quot;id&quot;: 5022700047,\r\n            &quot;unit_state&quot;: &quot;good&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;rewrite_quality&quot;: &quot;1&quot;\r\n            },\r\n            \r\n          }\r\n        ],\r\n        \r\n      }\r\n    },\r\n\r\n    {\r\n      &quot;id&quot;: 2400321267,\r\n      &quot;data&quot;: {\r\n        &quot;q&quot;: &quot;quinoa black bean and shrimp r&quot;,\r\n        &quot;r&quot;: &quot;quinoa black bean and shrimps r&quot;,\r\n        &quot;s&quot;: &quot;3&quot;\r\n      },\r\n      &quot;job_id&quot;: 1413792,\r\n      &quot;results&quot;: {\r\n        &quot;judgments&quot;: [\r\n          {\r\n            &quot;id&quot;: 5022700047,\r\n            &quot;unit_state&quot;: &quot;good&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;rewrite_quality&quot;: &quot;2&quot;\r\n            },\r\n            \r\n          }\r\n        ],\r\n        \r\n      }\r\n    }\r\n\r\nand I was trying to use the command `jq &#39;.[] | select(any(.Tags[]; .rewrite_quality == &quot;1&quot;))&#39; | less` to try to see if the output is correct but I don&#39;t see any output. \r\n\r\nI want the output to have only entries with rewrite_quality == &#39;1&#39;, in this case only the first entry.",
        "link": "https://stackoverflow.com/questions/60422639/nested-filtering-json-file-with-jq-statement",
        "title": "Nested Filtering json file with jq statement"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582764639,
                "post_id": 60424763,
                "comment_id": 106893588,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 189706,
                    "reputation": 7562,
                    "user_id": 429199,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/0032472303819b86829b681b7b20639c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "day0ops",
                    "link": "https://stackoverflow.com/users/429199/day0ops"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582764825,
                "post_id": 60424763,
                "comment_id": 106893637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 189706,
                    "reputation": 7562,
                    "user_id": 429199,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/0032472303819b86829b681b7b20639c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "day0ops",
                    "link": "https://stackoverflow.com/users/429199/day0ops"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582764940,
                "post_id": 60424763,
                "comment_id": 106893662,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1582824631,
                "creation_date": 1582824631,
                "answer_id": 60438799,
                "question_id": 60424763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need a multi level conditional evaluation, because having to check different fields on different conditions\r\n\r\n\r\n    jq &#39;\r\n    map (\r\n      objects |\r\n      if   has(&quot;merchantDetails&quot;) and has(&quot;description&quot;) then\r\n        select( .merchantDetails.name  | contains(&quot;DUMMY&quot;))\r\n      elif has(&quot;merchantDetails&quot;) then\r\n        select( .merchantDetails.name  | contains(&quot;DUMMY&quot;))\r\n      elif has(&quot;description&quot;) then\r\n        select( .description.sanitized | contains(&quot;DUMMY&quot;))\r\n      else empty\r\n      end\r\n    )\r\n    &#39;",
                "title": "jq select with multiple conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1582824631,
        "creation_date": 1582764454,
        "last_edit_date": 1582765267,
        "question_id": 60424763,
        "body_markdown": "I have the following few json objects that Id like to filter using a single `jq` command.\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: &quot;v2&quot;,\r\n        &quot;transactionId&quot;: &quot;10590541.2280012772&quot;,\r\n        &quot;description&quot;: {\r\n          &quot;original&quot;: &quot;DUMMY&quot;,\r\n          &quot;sanitized&quot;: &quot;DUMMY A.B. C&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nor\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: &quot;v2&quot;,\r\n        &quot;transactionId&quot;: &quot;10590541.2280012772&quot;,\r\n        &quot;description&quot;: {\r\n          &quot;original&quot;: &quot;DUMMY&quot;,\r\n          &quot;sanitized&quot;: &quot;DUMMY A.B. C&quot;\r\n        },\r\n        &quot;merchantDetails&quot;: {\r\n          &quot;name&quot;: &quot;DUMMY&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nor\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: &quot;v2&quot;,\r\n        &quot;transactionId&quot;: &quot;10590541.2280012772&quot;,\r\n        &quot;merchantDetails&quot;: {\r\n          &quot;name&quot;: &quot;DUMMY&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nIm trying to filter with `jq` so either of the above json objects satisfy the filter condition.\r\nIn other words, if both `.merchantDetails.name` and `.description.sanitized` exist then `.merchantDetails.name` has to take precedence when checking for the string &quot;DUMMY&quot;. If not then check either `.merchantDetails.name` or `.description.sanitized` for the string &quot;DUMMY&quot;.\r\n\r\nWhat i currently have is the following which doesn&#39;t really work.\r\n\r\n    jq . test.json  | jq &#39;.[] | select( (.merchantDetails.name | try contains (&quot;DUMMY&quot;)) or (.description.sanitized | try contains (&quot;DUMMY&quot;)) )&#39;\r\n\r\nAnyway to achieve this using a single in-line `jq` command ?",
        "link": "https://stackoverflow.com/questions/60424763/jq-select-with-multiple-conditions",
        "title": "jq select with multiple conditions"
    },
    {
        "tags": [
            "json",
            "transform",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582765659,
                "creation_date": 1582765659,
                "answer_id": 60424905,
                "question_id": 60424904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the process of writing the above question, I somewhat randomly stumbled upon the correct solution. Rather than keeping the knowledge for myself, I thought I’d share the answer here as well. Please feel free to delete this entire question &amp; answer if that’s not aligned to the site rules (I’m sorry if that’s the case).\r\n\r\n`select` really is the key, but I was not using it in the correct way at the time of writing the question. Here is the full `jq` command to accomplish my needs, showcasing all of the above requirements:\r\n\r\n- how to select the nested values based on searching through the `children` array;\r\n- how to lowercase the `type` value;\r\n- how to deal with sometimes missing `link` values;\r\n- (and I did not realize at that time, but sometimes I want to alter the form of the `link`, so I added that as well).\r\n\r\n```\r\ndef format(link): if link | tostring | startswith(&quot;/&quot;) then &quot;https://www.nihongomaster.com&quot; + link else link end;\r\n\r\n[.[] | { title: .children[] | select(.tag == &quot;h2&quot;).text, type: .children[] | select(.tag == &quot;span&quot;).text | ascii_downcase, perex: .children[] | select(.tag == &quot;p&quot;).text, link: format(((.children[] | select(.tag == &quot;a&quot;).href) // null)) }]\r\n```\r\n\r\nThere really is nothing better than rubber-duck debugging.",
                "title": "jq transform JSON structure by finding output values in input nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582856365,
                "last_edit_date": 1582856365,
                "creation_date": 1582832471,
                "answer_id": 60440652,
                "question_id": 60424904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution to the original problem:\r\n\r\n```\r\n[\r\n  .[]\r\n  | .children\r\n  | { title: [.[] | select(.tag == &quot;h2&quot;) | .text][0],\r\n      perex: [.[] | select(.tag == &quot;p&quot;) | .text][0],\r\n      type:  [.[] | select(.tag == &quot;span&quot;) | .text | ascii_downcase][0],\r\n      link:  [.[] | select(.tag == &quot;a&quot;) | .href][0] }\r\n]\r\n```\r\n\r\nThe key point here is the use of the idiom `[...][0]` to handle all possibilities with respect to the number of items in `...` (including 0).",
                "title": "jq transform JSON structure by finding output values in input nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1582882617,
        "creation_date": 1582765659,
        "last_edit_date": 1582882617,
        "question_id": 60424904,
        "body_markdown": "First of all, I’m sorry about the title. Even though English isn’t my first language, I wouldn’t even know how to call what I’m trying to accomplish in my mother tongue.\r\n\r\nWhat I’m trying to do is take an input (automatically generated by downloading a page with `curl`, then converted from HTML to JSON in a very crude way using `pup`) and convert it into something that would be easier to work with later on. The input looks like this:\r\n\r\n```json\r\n[\r\n {\r\n  &quot;children&quot;: [\r\n   {\r\n    &quot;class&quot;: &quot;label label-info&quot;,\r\n    &quot;tag&quot;: &quot;span&quot;,\r\n    &quot;text&quot;: &quot;Lesson&quot;\r\n   },\r\n   {\r\n    &quot;tag&quot;: &quot;h2&quot;,\r\n    &quot;text&quot;: &quot;Is That So?&quot;\r\n   },\r\n   {\r\n    &quot;tag&quot;: &quot;p&quot;,\r\n    &quot;text&quot;: &quot;Learn how to provide shortened answers with そうです and stay in the conversation with そうですか.&quot;\r\n   },\r\n   {\r\n    &quot;class&quot;: &quot;btn btn-primary&quot;,\r\n    &quot;href&quot;: &quot;https://www.nihongomaster.com/japanese/lessons/view/62/is-that-so&quot;,\r\n    &quot;tag&quot;: &quot;a&quot;,\r\n    &quot;text&quot;: &quot;Read Lesson&quot;\r\n   }\r\n  ],\r\n  &quot;class&quot;: &quot;row col-sm-12&quot;,\r\n  &quot;tag&quot;: &quot;div&quot;\r\n },\r\n {\r\n  &quot;children&quot;: [\r\n   {\r\n    &quot;class&quot;: &quot;label label-warning&quot;,\r\n    &quot;tag&quot;: &quot;span&quot;,\r\n    &quot;text&quot;: &quot;Drills&quot;\r\n   },\r\n   {\r\n    &quot;tag&quot;: &quot;h2&quot;,\r\n    &quot;text&quot;: &quot;Yes, That Is So.&quot;\r\n   },\r\n   {\r\n    &quot;tag&quot;: &quot;p&quot;,\r\n    &quot;text&quot;: &quot;Practice the phrases and vocab from the lesson, Is That So?&quot;\r\n   }\r\n  ],\r\n  &quot;class&quot;: &quot;row col-sm-12&quot;,\r\n  &quot;tag&quot;: &quot;div&quot;\r\n }\r\n]\r\n```\r\n\r\nAnd my desired output would pull various values from each object’s `children` array into something like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;Is That So?&quot;, // &lt;-- in other words, find &quot;tag&quot; == &quot;h2&quot; and output &quot;text&quot; value\r\n    &quot;perex&quot;: &quot;Learn how to provide shortened answers with そうです and stay in the conversation with そうですか.&quot;, // &quot;tag&quot; == &quot;p&quot;, &quot;text&quot; value\r\n    &quot;type&quot;: &quot;lesson&quot;, // &quot;tag&quot; == &quot;span&quot;, &quot;text&quot; value (lowercased if possible? Not needed though)\r\n    &quot;link&quot;: &quot;https://www.nihongomaster.com/japanese/lessons/view/62/is-that-so&quot; // &quot;tag&quot; == &quot;a&quot;, &quot;href&quot; value\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;Yes, That Is So.&quot;\r\n    &quot;perex&quot;: &quot;Practice the phrases and vocab from the lesson, Is That So?&quot;,\r\n    &quot;type&quot;: &quot;drills&quot;,\r\n    &quot;link&quot;: null // Can be missing!\r\n  }\r\n]\r\n```\r\n\r\nI tried various experiments with the `select` function but got nowhere near any usable result, so I’m not sure if my attempts are even worth sharing.",
        "link": "https://stackoverflow.com/questions/60424904/jq-transform-json-structure-by-finding-output-values-in-input-nested-array",
        "title": "jq transform JSON structure by finding output values in input nested array"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582901347,
                "last_edit_date": 1582901347,
                "creation_date": 1582768122,
                "answer_id": 60425184,
                "question_id": 60425030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a pretty good use case for a reducer.\r\n\r\nRun with your document on its stdin, the script:\r\n\r\n```jq\r\n#!/usr/bin/env jq -Rncf\r\n# ...caveat: not all platforms support more than two words on the shebang\r\n#            you may need to stop using env and pass a full path to your jq binary!\r\n\r\ndef input_line_to_object:\r\n  &quot;^(?&lt;key&gt;[^:]+): ?(?&lt;value&gt;.*)$&quot; as $re |\r\n  (capture($re) // (&quot;line \\(.) does not parse&quot; | halt_error(1))) | {(.key):.value};\r\n\r\nreduce (inputs, &quot;&quot;) as $item (\r\n  # Initializer. .[0] == current object; .[1] == list of objects already constructed\r\n  [{}, []];\r\n  # Handler. Run for each line, and the final &quot;&quot; at the end.\r\n  if $item == &quot;&quot; then\r\n    if .[0] == {} then\r\n      . # no new object is actually ready; maybe we had two newlines in a row?\r\n    else\r\n      # between objects: append .[0] to .[1], and clear .[0]\r\n      [{}, .[1]+[.[0]]]\r\n    end\r\n  else\r\n    # new data in an existing object; add new datum to .[0], leave .[1] alone\r\n    [.[0] + ($item | input_line_to_object), .[1]]\r\n  end\r\n) | .[1] # take the completed list in the .[1] position\r\n```\r\n\r\n...emits as output:\r\n\r\n```json\r\n[{&quot;key1&quot;:&quot;string1&quot;,&quot;key2&quot;:&quot;string1&quot;},{&quot;key1&quot;:&quot;string3&quot;,&quot;key2&quot;:&quot;string3&quot;}]\r\n```",
                "title": "Convert text file with line breaks to json with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582774817,
                "last_edit_date": 1582774817,
                "creation_date": 1582772194,
                "answer_id": 60425634,
                "question_id": 60425030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a succinct but fairly robust solution that assumes jq is called with the -n and -R options (e.g., `jq -nR ...`)\r\n\r\n```\r\n[foreach (inputs, null) as $in (null;\r\n  if ($in|length) == 0\r\n  then .out = .object | .object = null\r\n  else .object += ($in | capture(&quot;(?&lt;k&gt;^[^:]*): *(?&lt;v&gt;.*)&quot;) | {(.k):.v})\r\n  | .out = null\r\n  end;\r\n  .out // empty) ]\r\n```\r\n\r\nHere, one key point (no pun intended) is the use of `capture` rather than `split` or `splits` in case the value contains a colon.  Note also the use of the idiom `foreach (inputs,null) as ...`.  This ensures that the last key:value input is properly handled.\r\n",
                "title": "Convert text file with line breaks to json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1582776703,
                "creation_date": 1582776703,
                "answer_id": 60426146,
                "question_id": 60425030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since reduction is widely understood, here&#39;s a simple `reduce`-based solution that does not require newlines between groups of key:value lines.  That is, in constructing the array, a new object is started once a key is encountered that occurs in the previous object.\r\n\r\n```\r\n&lt; input.txt jq -nR &#39;\r\n  reduce (inputs\r\n          | select(length &gt; 0) \r\n          | capture(&quot;(?&lt;k&gt;^[^:]*): *(?&lt;v&gt;.*)&quot;) \r\n          | {(.k):.v}) as $in (null;\r\n    if . == null then [$in] \r\n    elif (.[-1] | has($in|keys_unsorted[0])) then . + [$in] \r\n    else .[-1] += $in end)&#39;\r\n```",
                "title": "Convert text file with line breaks to json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1582901347,
        "creation_date": 1582766780,
        "last_edit_date": 1582825565,
        "question_id": 60425030,
        "body_markdown": "I&#39;ve seen a lot of examples to convert a text file to json with jq, but I get stuck on something probably obvious. My input file has this format:\r\n\r\n```\r\nkey1: string1\r\nkey2: string1\r\n\r\nkey1: string3\r\nkey2: string3\r\n```\r\n\r\nHow can I translate that to:\r\n\r\n```json\r\n[\r\n  {&quot;key1&quot;:&quot;string1&quot;, &quot;key2&quot;: &quot;string2&quot;},\r\n  {&quot;key1&quot;:&quot;string3&quot;, &quot;key2&quot;: &quot;string4&quot;}\r\n]\r\n```\r\n\r\nI&#39;ve tried to use `inputs` with jq, something like `jq -R -n -c &#39;[inputs|split(&quot;:&quot;)|{(.[0]):.[1]}] | add&#39;`, but it fails as soon as there&#39;s a line break in the file:\r\n\r\n`jq: error (at result.txt:8): Cannot use null (null) as object key`.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/60425030/convert-text-file-with-line-breaks-to-json-with-jq",
        "title": "Convert text file with line breaks to json with jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "scripting",
            "max",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 68445,
                    "reputation": 5735,
                    "user_id": 199684,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/71b5e7b1d5db458be0ed74e34fa49d32?s=256&d=identicon&r=PG",
                    "display_name": "wmitchell",
                    "link": "https://stackoverflow.com/users/199684/wmitchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582859049,
                "post_id": 60444500,
                "comment_id": 106930127,
                "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": 1582859196,
                "post_id": 60444500,
                "comment_id": 106930158,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582859029,
                "creation_date": 1582859029,
                "answer_id": 60444660,
                "question_id": 60444500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq:\r\n\r\n    .tags | max_by(sub(&quot;X-&quot;;&quot;&quot;) | tonumber)\r\n",
                "title": "shell scripting - get the highest value from an alpha numeric list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582866954,
        "creation_date": 1582857434,
        "last_edit_date": 1582866954,
        "question_id": 60444500,
        "body_markdown": "I have the output of a bash script running like such\r\n\r\n```{&quot;name&quot;:&quot;abc/123&quot;,&quot;tags&quot;:[&quot;X-1&quot;,&quot;X-2&quot;,&quot;X-3&quot;,&quot;X-4&quot;....... &quot;X-1099&quot;]}```\r\n\r\nI&#39;d like to find the highest value for X in this case `X-1099`. Can someone suggest an approach? Seems like jq might be a start.\r\n\r\nSo I&#39;ve made a bit of progress jq &#39;.tags&#39; gives the list of X values \r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/60444500/shell-scripting-get-the-highest-value-from-an-alpha-numeric-list",
        "title": "shell scripting - get the highest value from an alpha numeric list"
    },
    {
        "tags": [
            "json",
            "header",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582907155,
                "post_id": 60455162,
                "comment_id": 106950281,
                "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": 1582908322,
                "post_id": 60455162,
                "comment_id": 106950843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582923561,
                "post_id": 60455162,
                "comment_id": 106956904,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "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": 1582934986,
                "post_id": 60455162,
                "comment_id": 106959933,
                "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": 1582935697,
                "post_id": 60455162,
                "comment_id": 106960039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1582920039,
                "last_edit_date": 1582920039,
                "creation_date": 1582918424,
                "answer_id": 60458190,
                "question_id": 60455162,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a relatively robust jq script for printing the TSV with headers using the key names in the first object:\r\n\r\n```\r\n(.[0] | keys_unsorted) as $keys\r\n| $keys,  (.[] | [.[$keys[]]])\r\n| @tsv  \r\n```\r\n\r\nThis of course assumes the -r command-line option.\r\n",
                "title": "Convert JSON to headed TSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582929165,
        "creation_date": 1582905155,
        "last_edit_date": 1582929165,
        "question_id": 60455162,
        "body_markdown": "Given a JSON file like this,\r\n\r\n```\r\n[\r\n  {\r\n    &quot;h1&quot;: &quot;x1&quot;,\r\n    &quot;h2&quot;: &quot;x2&quot;\r\n  },\r\n  {\r\n    &quot;h1&quot;: &quot;y1&quot;,\r\n    &quot;h2&quot;: &quot;y2&quot;\r\n  }\r\n]\r\n```\r\n\r\nI extract it as a headed TSV using the following jq code. But I need to specify the header names twice. Is there a way to just specify the header names once? Thanks.\r\n\r\n```\r\n[\r\n    &quot;h1&quot;\r\n    , &quot;h2&quot;\r\n], (.[] | [ \r\n    .h1\r\n    , .h2\r\n]) | @tsv\r\n```",
        "link": "https://stackoverflow.com/questions/60455162/convert-json-to-headed-tsv",
        "title": "Convert JSON to headed TSV"
    },
    {
        "tags": [
            "json",
            "average",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1582932938,
                "creation_date": 1582932938,
                "answer_id": 60460606,
                "question_id": 60460376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can create a single array instead of an array per entry, then pipe it to the filter add and the filter length, which will add the numbers in the array and compute the length of the array. FInally, you divide the results of both filters and... voila!\r\n\r\n    jq &#39;[.Datapoints[] | select(.ExtendedStatistics.p80&gt;=0) | .ExtendedStatistics.p80] | add/length&#39; file.json",
                "title": "How to calculate average using jq from JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1582948342,
        "creation_date": 1582931230,
        "last_edit_date": 1582948342,
        "question_id": 60460376,
        "body_markdown": "This is the exact JSON for which i am trying to parse with jq to get an average\r\n\r\n    {\r\n        &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n        &quot;Datapoints&quot;: [\r\n            {\r\n                &quot;Timestamp&quot;: &quot;2020-02-20T18:35:00Z&quot;,\r\n                &quot;Unit&quot;: &quot;Percent&quot;,\r\n                &quot;ExtendedStatistics&quot;: {\r\n                    &quot;p80&quot;: 7.39284928374\r\n                }\r\n            },\r\n            {\r\n                &quot;Timestamp&quot;: &quot;2020-02-20T18:00:00Z&quot;,\r\n                &quot;Unit&quot;: &quot;Percent&quot;,\r\n                &quot;ExtendedStatistics&quot;: {\r\n                    &quot;p80&quot;: 2.234234\r\n                }\r\n            },\r\n            {\r\n                &quot;Timestamp&quot;: &quot;2020-02-20T18:45:00Z&quot;,\r\n                &quot;Unit&quot;: &quot;Percent&quot;,\r\n                &quot;ExtendedStatistics&quot;: {\r\n                    &quot;p80&quot;: 2.4567\r\n                }\r\n            },\r\n            {\r\n                &quot;Timestamp&quot;: &quot;2020-02-20T18:50:00Z&quot;,\r\n                &quot;Unit&quot;: &quot;Percent&quot;,\r\n                &quot;ExtendedStatistics&quot;: {\r\n                    &quot;p80&quot;: 2.0\r\n                }\r\n            },\r\n           \r\n            {\r\n                &quot;Timestamp&quot;: &quot;2020-02-20T18:20:00Z&quot;,\r\n                &quot;Unit&quot;: &quot;Percent&quot;,\r\n                &quot;ExtendedStatistics&quot;: {\r\n                    &quot;p80&quot;: 2.0\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\nUsing `.Datapoints[]|select(.ExtendedStatistics.p80 &gt;=0  )| [.ExtendedStatistics.p80] | @tsv` \r\ngives me\r\n\r\n    &quot;7.39284928374&quot;\r\n    &quot;2.234234&quot;\r\n    &quot;2.4567&quot;\r\n    &quot;2&quot;\r\n    &quot;2&quot; \r\n\r\nI am trying to get an average of all the numbers\r\nHow do i get a single number as output \r\n**Expected Output**\r\n\r\n    3.216756656748\r\n\r\nCalculated as \r\n\r\n    Average:\t16.08378328374 / 5 = 3.216756656748",
        "link": "https://stackoverflow.com/questions/60460376/how-to-calculate-average-using-jq-from-json-output",
        "title": "How to calculate average using jq from JSON output"
    },
    {
        "tags": [
            "json",
            "out-of-memory",
            "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": 3,
                "creation_date": 1582962704,
                "post_id": 60463005,
                "comment_id": 106963762,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1955234,
                    "reputation": 4581,
                    "user_id": 1758363,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hBUXs.jpg?s=256",
                    "display_name": "Evgeny",
                    "link": "https://stackoverflow.com/users/1758363/evgeny"
                },
                "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": 1582964545,
                "post_id": 60463005,
                "comment_id": 106964076,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598338058,
                "last_edit_date": 1598338058,
                "creation_date": 1582971011,
                "answer_id": 60463974,
                "question_id": 60463005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[@peak has already pointed out the problem with your query](https://stackoverflow.com/questions/60463005/jq-produces-memory-overflow/60463974#comment106963762_60463005), and here is the solution based on the insight he provided:\r\n```\r\n[ (.data[] | {time: .[0], x: .[1], y: .[2]}) + {id: .info.id} ]\r\n```\r\n[See it online on jqplay.org](https://jqplay.org/s/23F00IzD38)",
                "title": "jq produces memory overflow"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1598338058,
        "creation_date": 1582961945,
        "last_edit_date": 1582997671,
        "question_id": 60463005,
        "body_markdown": "I have a json file where a time series in stored under `data` key and and an object id is in `info` key:\r\n\r\n```\r\n{info:\r\n  {id: abc},\r\ndata:[\r\n   [10, 5, 3],\r\n   [12, 6, 4],\r\n   # 5000 list items\r\n   ]\r\n}\r\n```\r\n \r\nI would like to flatten the json and produce something similar to:\r\n\r\n```\r\n[\r\n{id: abc, time: 10, x: 5, y: 3},\r\n{id: abc, time: 12, x: 6, y: 4},\r\n# the rest of 5000 points\r\n]\r\n```\r\n\r\nI&#39;m running a jq query and seems to work well to produce a series of items:\r\n\r\n`&quot;{time: .data[][0], x: .data[][2], y: .data[][1], item: .info.id}&quot;`\r\n\r\nWhen I try to put the same expression into a list to create a list of dicts, I&#39;m hitting a memory overflow limit:\r\n\r\n`&quot;[{time: .data[][0], x: .data[][2], y: .data[][1], item: .info.id}]&quot;`\r\n\r\nIs there anyhting else I can do differently? Many thanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/60463005/jq-produces-memory-overflow",
        "title": "jq produces memory overflow"
    },
    {
        "tags": [
            "json",
            "jq",
            "functor"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583080264,
                "post_id": 60471460,
                "comment_id": 106987958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583080377,
                "post_id": 60471460,
                "comment_id": 106987983,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583080450,
                "post_id": 60471460,
                "comment_id": 106988009,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1583030002,
        "creation_date": 1583029499,
        "last_edit_date": 1592644375,
        "question_id": 60471460,
        "body_markdown": "# Question\n\nIf there is a data type which stores a JSON string and offers all the JQ filters as the function for its fmap method to apply on the JSON, then the data type will be a functor. Is it correct?\n\nJQ filter takes an a sequence of whitespace-separated JSON values, apply a transformation function, and generates a sequence of whitespace-separated JSON data. \n\n\n&gt; It’s important to remember that every filter has an input and an output. Even literals like “hello” or 42 are filters - they take an input but always produce the same literal as output. \n&gt;\n&gt; The input to jq is parsed as a sequence of whitespace-separated JSON values which are passed through the provided filter one at a time. The output(s) of the filter are written to standard out, again as a sequence of whitespace-separated JSON data.\n\n* [Functors, Applicatives, And Monads In Pictures][1]\n* [Understanding functor laws: is this a functor?][2]\n\n\n  [1]: http://adit.io/posts/2013-04-17-functors,_applicatives,_and_monads_in_pictures.html\n  [2]: https://stackoverflow.com/questions/48958881/understanding-functor-laws-is-this-a-functor",
        "link": "https://stackoverflow.com/questions/60471460/a-data-type-of-json-jq-is-a-functor",
        "title": "A data type of (JSON + JQ) is a functor?"
    },
    {
        "tags": [
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583039416,
                "creation_date": 1583039416,
                "answer_id": 60472185,
                "question_id": 60472049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What is the data type of the JQ comma filter?\n\nThere&#39;s not really such a thing as a *data type* returned by the comma filter...\n\nBecause it doesn&#39;t really group the values in a single container data type. Rather, it sends the values separately through the following filters and reports each output separately at the end.\n\nPerhaps a good way to understand it is seeing this result:\n\n    $ printf &#39;{&quot;ika&quot;:[4,9],&quot;uni&quot;:[1,3,5]}&#39; | jq &#39;.ika, .uni | add&#39;\n    13\n    9\n\nThe two arrays went through the &quot;add&quot; filter, but each on its own, and the two results reported at the end.\n\nRe-read the docs for comma, you&#39;ll see that&#39;s what it&#39;s saying:\n\n&gt; If two filters are separated by a comma, then the same input **will be fed into both** and the **two filters’ output** value streams will be **concatenated** in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right.\n\nYou *can* turn them into an array, but you need to do that explicitly. For example:\n\n    $ printf &#39;{&quot;ika&quot;:[4,9],&quot;uni&quot;:[1,3,5]}&#39; | jq &#39;[ .ika, .uni | add ]&#39;\n    [\n      13,\n      9\n    ]\n",
                "title": "JQ - What is the data type of comma filter"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1583090191,
                "last_edit_date": 1583090191,
                "creation_date": 1583040280,
                "answer_id": 60472260,
                "question_id": 60472049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A comma expression in jq takes the form `P, Q` and like all jq expressions, produces a stream of JSON values, in this case the stream produced by P followed by the stream produced by Q. \r\n\r\nHere &quot;stream&quot; means a sequence of 0 or more JSON values, and is not to be confused with an array of JSON values.  A &quot;stream of JSON values&quot; is not itself a JSON value.\r\n\r\nIf this is unclear, you might be interested in my [&quot;Stream-Oriented Introduction to jq&quot;][1] \r\n\r\n\r\n## Elaboration\r\n\r\njq expressions are not themselves &quot;data types&quot;, but every jq expression is a filter that accepts as input a stream of JSON values, and produces a stream of JSON values.  Using the notation JSON* to mean &quot;a stream of JSON values&quot;, it being understood that a stream can conceptually be unbounded in length, we can think of jq expressions as being mappings from JSON* to JSON*.\r\n\r\nThis is important to understand since all jq expressions must always be understood in terms of their inputs. In the case of `P,Q`, the important point is that if R is a jq expression, then:\r\n\r\n    R | (P,Q)\r\n\r\nis equivalent to:\r\n\r\n    (R|P), (R|Q)\r\n\r\n(This is a very important point, firstly because it makes jq very powerful - R is in effect duplicated; and secondly because it makes the behavior of jq&#39;s pipe quite different from the superficially similar behavior of shell pipes - consider e.g. `P | (Q;R)` in [tag:bash].)\r\n\r\nThe -n command-line option signals that `null` should be used as the initial JSON value, so for example:\r\n\r\n    jq -n 1,2\r\n\r\nproduces:\r\n\r\n    1\r\n    2\r\n\r\n## The -s command-line option\r\n\r\nAn invocation of jq of the form `jq P` causes each JSON item in STDIN to be presented to the jq filter, P, on a one-at-a-time basis.\r\n  \r\nBy contrast, an invocation of the form `jq -s P` causes the items in STDIN to be wrapped in a JSON array, which is then presented to P.\r\n\r\n## `reduce`, `foreach`, `foo(P)`, etc\r\n\r\njq also supports reduction over a stream. This is particularly useful with the built-in filter, `inputs`, to circumvent the need to use the -s command-line option in order to process a stream of external inputs.\r\n\r\nParameterized filters, such as those of the form `foo(P)` where P is an arbitrary jq expression, are also supported. \r\n\r\nFor further details, see the jq manual, the [previously mentioned document][1], and/or other documentation.\r\n\r\n  [1]: https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq",
                "title": "JQ - What is the data type of comma filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1583090191,
        "creation_date": 1583037754,
        "last_edit_date": 1583083211,
        "question_id": 60472049,
        "body_markdown": "# Question \r\n\r\nWhat is the data type of the JQ comma filter?  \r\n\r\n# Background\r\nI get **Cannot iterate over number** error when trying to feed the output of the **comma** filter.\r\n\r\n\r\n```\r\n$ printf &#39;{&quot;ika&quot;:5,&quot;uni&quot;:3}&#39; | jq &#39;.ika, .uni | .&#39;\r\n5\r\n3\r\n\r\n$ printf &#39;{&quot;ika&quot;:5,&quot;uni&quot;:3}&#39; | jq &#39;.ika, .uni | . | add&#39;\r\njq: error (at &lt;stdin&gt;:0): Cannot iterate over number (5)\r\n```\r\n\r\nTo get around, need to convert to an array explicitly.\r\n\r\n```\r\n$ printf &#39;{&quot;ika&quot;:5,&quot;uni&quot;:3}&#39; | jq &#39;[ .ika, .uni ] | . | add&#39;\r\n8\r\n```\r\n\r\n## Clarifications\r\n\r\nAccording to the JQ manual, the output of a JQ filter is **a sequence of whitespace-separated JSON data**\r\n\r\nHowever, the output the **comma** filter (which is stated as one of the Basic filters) seems not to be **a sequence of whitespace-separated JSON data**. \r\n\r\n\r\n[Basic filters][1]\r\n&gt; **Comma**: ,&lt;br/&gt;\r\nIf two filters are separated by a comma, then the same input will be fed into both and the two filters’ output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right. For instance, filter .foo, .bar, produces both the “foo” fields and “bar” fields as separate outputs.\r\n\r\n\r\n[JQ Manual][2]\r\n&gt; jq filters run on a stream of JSON data. The input to jq is parsed as a sequence of whitespace-separated JSON values which are passed through the provided filter one at a time. The **output(s) of the filter are written to standard out, again as a sequence of whitespace-separated JSON data**.&lt;br/&gt;&lt;br/&gt;\r\nIt’s important to remember that every filter has an input and an output. Even literals like “hello” or 42 are filters - **they take an input but always produce the same literal as output**. Operations that combine two filters, like addition, generally feed the same input to both and combine the results.\r\n\r\n&lt;br/&gt;\r\nSo what is the output of **comma** filter? If is it **JSON data** as the JQ manual says? I assume, if it is to be a JSON, then should it be an array?\r\n\r\n```\r\n[5, 3]\r\n```\r\n---\r\n\r\n# Update\r\nBased on the answers:\r\n\r\n\r\nIn jq expressions such as P|Q, the filter Q processes each item in the stream produced by P one at a time. In the invocation `jq P`, each item in the STDIN stream is processed by P one at a time.\r\n```\r\n$ printf &#39;{&quot;ika&quot;:5,&quot;uni&quot;:3}&#39; | \\\r\njq &#39;.ika, .uni&#39; | \\\r\njq &#39;&quot;JQ is processing the \\(input_line_number) th line whose input value is \\(.)&quot;&#39;\r\n\r\n&quot;JQ is processing the 1 th line whose input value is 5&quot;\r\n&quot;JQ is processing the 2 th line whose input value is 3&quot;\r\n```\r\n\r\n[![enter image description here][3]][3]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Basicfilters\r\n  [2]: https://stedolan.github.io/jq/manual\r\n  [3]: https://i.sstatic.net/QKdhl.png",
        "link": "https://stackoverflow.com/questions/60472049/jq-what-is-the-data-type-of-comma-filter",
        "title": "JQ - What is the data type of comma filter"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5165555,
                    "reputation": 7786,
                    "user_id": 4135670,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/mArsS.jpg?s=256",
                    "display_name": "Rafael",
                    "link": "https://stackoverflow.com/users/4135670/rafael"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1583115002,
                "post_id": 60481640,
                "comment_id": 106995766,
                "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": 1583126371,
                "post_id": 60481640,
                "comment_id": 106997874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583127076,
                "post_id": 60481640,
                "comment_id": 106998044,
                "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": 1583129195,
                "post_id": 60481640,
                "comment_id": 106998577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583129306,
                "post_id": 60481640,
                "comment_id": 106998615,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1583122770,
                "last_edit_date": 1583122770,
                "creation_date": 1583116837,
                "answer_id": 60481857,
                "question_id": 60481640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;d like to process many json objects with one json object per line. Is it possible to let jq process each line as a separate json object ...\r\n\r\njq does that out-of-the-box.  (The JSON entities provided as input do not **have** to be on separate lines, but it&#39;s fine if they are.)\r\n\r\nThe more interesting question is what can be done if the input consists of an array that is too large to fit in memory.  If that is the problem, see https://stackoverflow.com/questions/48711199/use-jq-to-convert-json-array-to-jsonl-format\r\n",
                "title": "Can jq process multiple json object with each in a line?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -4,
        "last_activity_date": 1583122770,
        "creation_date": 1583114615,
        "question_id": 60481640,
        "body_markdown": "I&#39;d like to process many json objects with one json object per line. Is it possible to let jq process each line as a separate json object instead of the whole file as a single json object? Thanks.",
        "link": "https://stackoverflow.com/questions/60481640/can-jq-process-multiple-json-object-with-each-in-a-line",
        "title": "Can jq process multiple json object with each in a line?"
    },
    {
        "tags": [
            "json",
            "string",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1583191412,
                "last_edit_date": 1583191412,
                "creation_date": 1583189680,
                "answer_id": 60497784,
                "question_id": 60497517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following has worked for me:\r\n\r\n\r\n```\r\njq &#39;.[]|.Version as $v|select(.DownloadURL | contains($v)| not)&#39;\r\n```\r\n\r\n```\r\n{\r\n  &quot;Package&quot;: &quot;cachetools&quot;,\r\n  &quot;Version&quot;: &quot;3.1.1&quot;,\r\n  &quot;DownloadURL&quot;: &quot;https://files.pythonhosted.org/packages/08/6a/abf83cb951617793fd49c98cb9456860f5df66ff89883c8660aa0672d425/cachetools-4.0.0-py3-none-any.whl&quot;\r\n}\r\n```\r\n\r\nIs the result",
                "title": "Filtering one key with the value from another key in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583190765,
                "creation_date": 1583190765,
                "answer_id": 60497941,
                "question_id": 60497517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;d like to generate a list of items where .DownloadURL doesn&#39;t contain the string in .Version.\r\n\r\nIf as you say you want the result as a list, you could use `map`:\r\n\r\n    map(select( .Version as $v | .DownloadURL | contains($v) | not))\r\n\r\nHowever, the semantics of `contains` is very complex so you might wish to consider using `index` instead:\r\n \r\n    map(select( .Version as $v | .DownloadURL | index($v) | not))\r\n",
                "title": "Filtering one key with the value from another key in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1583193182,
        "creation_date": 1583187679,
        "last_edit_date": 1583193182,
        "question_id": 60497517,
        "body_markdown": "I&#39;ve got a list of package data in JSON format that looks like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Package&quot;: &quot;pyasn1&quot;,\r\n    &quot;Version&quot;: &quot;0.4.6&quot;,\r\n    &quot;DownloadURL&quot;: &quot;https://files.pythonhosted.org/packages/3d/50/5ce5dbe42eaf016cb9b062caf6d0f38018454756d4feb467de3e29431dae/pyasn1-0.4.6-py2.4.egg&quot;\r\n  },\r\n  {\r\n    &quot;Package&quot;: &quot;cachetools&quot;,\r\n    &quot;Version&quot;: &quot;3.1.1&quot;,\r\n    &quot;DownloadURL&quot;: &quot;https://files.pythonhosted.org/packages/08/6a/abf83cb951617793fd49c98cb9456860f5df66ff89883c8660aa0672d425/cachetools-4.0.0-py3-none-any.whl&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd I&#39;d like to generate a list of items where `.DownloadURL` doesn&#39;t contain the string in `.Version`.\r\n\r\nI&#39;ve tried this but it doesn&#39;t seem to work:\r\n```\r\njq &#39;.[]|select(.DownloadURL | contains(.Version)| not)&#39;\r\n```\r\nI get the following error:\r\n```\r\njq: error (at &lt;stdin&gt;:11): Cannot index string with string &quot;Version&quot;\r\nexit status 5\r\n```\r\n\r\nI was able to do the following...\r\n```\r\njq &#39;.[]|select(.DownloadURL | contains(&quot;0.4.6&quot;)| not)&#39;\r\n```\r\n...and it gave the results I would expect:\r\n```\r\n{\r\n  &quot;Package&quot;: &quot;cachetools&quot;,\r\n  &quot;Version&quot;: &quot;3.1.1&quot;,\r\n  &quot;DownloadURL&quot;: &quot;https://files.pythonhosted.org/packages/08/6a/abf83cb951617793fd49c98cb9456860f5df66ff89883c8660aa0672d425/cachetools-4.0.0-py3-none-any.whl&quot;\r\n}\r\n```\r\n\r\nIs there a way to use the contents of `.Version` with the `contains()` function or is there a better way to do this?  I&#39;ve set up [a playground with the data here][1]. \r\n\r\nThanks!\r\n\r\n\r\n  [1]: https://jqplay.org/s/6oDV3_sMmi",
        "link": "https://stackoverflow.com/questions/60497517/filtering-one-key-with-the-value-from-another-key-in-jq",
        "title": "Filtering one key with the value from another key in jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1583209818,
                "last_edit_date": 1583209818,
                "creation_date": 1583208764,
                "answer_id": 60499959,
                "question_id": 60499649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Edit #2\r\n\r\nIf you&#39;re going to be doing more than just a few simple things with the `JobId`s and the `ArchiveId`s, you might consider doing this in Python:\r\n```python\r\nimport json\r\n  \r\nwith open(&#39;my-json-archiving.json&#39;, &#39;r&#39;) as fp:\r\n    jobs = json.load(fp)[&#39;Jobs&#39;]\r\n\r\nseen = set()\r\nunique_by_archive_id = [job for job in jobs if job[&#39;ArchiveId&#39;] not in seen and not seen.add(job[&#39;ArchiveId&#39;])]\r\n\r\nfor job in unique_by_archive_id:\r\n    job_id = job[&#39;JobId&#39;]\r\n    archive_id  = job[&#39;ArchiveId&#39;]\r\n    # do stuff here\r\n```\r\n### Edit #1\r\n\r\nTo get `JobId` and `ArchiveId` as variables, you could do something like this:\r\n```\r\njq -r &#39;.Jobs |= unique_by(.ArchiveId) | .Jobs[] | &quot;\\(.JobId) \\(.ArchiveId)&quot;&#39; \\\r\n my-json-archiving.json | while IFS= read -r line; do\r\n        jobId=&quot;$(awk &#39;{print $1}&#39; &lt;&lt;&lt; $line)&quot;\r\n        archiveId=&quot;$(awk &#39;{print $2}&#39; &lt;&lt;&lt; $line)&quot;\r\n        echo &quot;Job id: $jobId&quot;\r\n        echo &quot;Archive id: $archiveId&quot;\r\ndone\r\n```\r\n\r\n### Original answer\r\n\r\nI&#39;m not 100% certain what you&#39;re asking here. If you want to just get the `JobId` and the `ArchiveId` from each job, you could do something like this:\r\n\r\n```\r\n$ jq -r &#39;.Jobs |= unique_by(.ArchiveId) | .Jobs[] | &quot;\\(.JobId) \\(.ArchiveId)&quot;&#39; \\\r\n my-json-archiving.json\r\n111 333\r\n114 444\r\n113 2323\r\n```\r\n\r\nText like this works very well with awk. For example:\r\n```\r\n$ jq -r &#39;.Jobs |= unique_by(.ArchiveId) | .Jobs[] | &quot;\\(.JobId) \\(.ArchiveId)&quot;&#39; \\\r\n my-json-archiving.json | awk &#39;{print &quot;JobId:&quot;, $1, &quot;ArchiveId:&quot;, $2}&#39;\r\nJobId: 111 ArchiveId: 333\r\nJobId: 114 ArchiveId: 444\r\nJobId: 113 ArchiveId: 2323\r\n```\r\n\r\nSimilar question: https://stackoverflow.com/questions/29982897/using-jq-to-extract-specific-property-values-and-output-on-a-single-line.\r\n\r\nAlso could take a look at jq&#39;s manpage (`man jq`). Lots of examples there.",
                "title": "cli and jq, how do I get the property value after filtering with unique_by"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1583209818,
        "creation_date": 1583206006,
        "last_edit_date": 1583207859,
        "question_id": 60499649,
        "body_markdown": "I have the following JSON data:\r\n\r\n```json\r\n{\r\n  &quot;Jobs&quot;:[\r\n     {&quot;JobId&quot;: 111, &quot;ArchiveId&quot;: 333},\r\n     {&quot;JobId&quot;: 112, &quot;ArchiveId&quot;: 333},\r\n     {&quot;JobId&quot;: 113, &quot;ArchiveId&quot;: 2323},\r\n     {&quot;JobId&quot;: 114, &quot;ArchiveId&quot;: 444}\r\n  ]\r\n}\r\n```\r\n\r\nAnd here&#39;s the shell script that looks at the JSON object:\r\n\r\n\r\n    count_again=0\r\n    jq -r &#39;.Jobs |= unique_by(.ArchiveId)&#39; my-json-archiving.json  \\\r\n       | while IFS= read -r job; do\r\n       count_again=$(($count_again + 1))\r\n       echo $job\r\n       echo $count_again\r\n    done\r\n\r\nMy first step worked by filtering any duplicates by a certain key (.ArchiveId). Once that&#39;s done I want to loop through the result. Below is what I have, the main issue with that is it actually reads through line by line. I think it&#39;s got to do with the `$job` that I return. \r\n\r\nI&#39;m very new to shell scripting so I&#39;m not certain on how to return the object that it&#39;s looping through when reading the object\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60499649/cli-and-jq-how-do-i-get-the-property-value-after-filtering-with-unique-by",
        "title": "cli and jq, how do I get the property value after filtering with unique_by"
    },
    {
        "tags": [
            "json",
            "linux",
            "terminal",
            "jq",
            "conditional-operator"
        ],
        "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": 1583208347,
                "post_id": 60499798,
                "comment_id": 107029152,
                "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": 1583220537,
                "post_id": 60499798,
                "comment_id": 107032570,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583219508,
                "last_edit_date": 1583219508,
                "creation_date": 1583208278,
                "answer_id": 60499918,
                "question_id": 60499798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[The following is a response to the original question, which was premised on JSON input.]\r\n\r\nSince you need to count the items in a group, it would appear that you will find `group_by( sub(&quot;/[^/]*$&quot;;&quot;&quot;) )` useful.  \r\n\r\nFor example, if you wanted to omit large groups entirely, as one interpretation of the stated requirements would seem to imply, you could use the following filter:\r\n\r\n```\r\n[.results[] | select(.status==301) | .url]\r\n| group_by( sub(&quot;/[^/]*$&quot;;&quot;&quot;) )\r\n| map(select(length &lt; 10) )\r\n| .[][]\r\n```",
                "title": "Filter results using bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1583220405,
                "last_edit_date": 1583220405,
                "creation_date": 1583219967,
                "answer_id": 60501957,
                "question_id": 60499798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the text input is in input.txt, then one solution using jq at the bash command line would be:\r\n\r\n```\r\n&lt; input.txt jq -Rr &#39;[inputs] \r\n  | group_by( sub(&quot;/[^/]*$&quot;;&quot;&quot;) )\r\n  | map(select(length &lt; 10) )\r\n  | .[][]&#39;\r\n```\r\n\r\n(If you want the output as JSON strings, omit the -r option.)\r\n\r\n## A more efficient solution\r\n\r\nThe above solution uses the built-in filter `group_by/1` and is thus somewhat inefficient.  For a very large number of input lines, a more efficient solution would be:\r\n```\r\n&lt; input.txt jq -Rr &#39;\r\n  def GROUPS_BY(stream; f):\r\n    reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n\r\n  GROUPS_BY(inputs;  sub(&quot;/[^/]*$&quot;;&quot;&quot;))\r\n  | select(length &lt; 10) \r\n  | .[]&#39;\r\n\r\n```",
                "title": "Filter results using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1583220405,
        "creation_date": 1583207263,
        "last_edit_date": 1583210487,
        "question_id": 60499798,
        "body_markdown": "\r\nTo be more clear, look at the below text file.\r\n\r\n```\r\nhttps://brianbrandt.dk/web/var/www/public_html/.htpasswd\r\nhttps://brianbrandt.dk/web/var/www/public_html/wp-config.php\r\nhttps://briannajackson1.wordpress.org/high-entropy-misc.txt\r\nhttps://briannajackson1.wordpress.org/Homestead.yaml\r\nhttps://brickellmiami.centric.hyatt.com/dev\r\nhttps://brickellmiami.centric.hyatt.com/django.log\r\nhttps://brickellmiami.centric.hyatt.com/.dockercfg\r\nhttps://brickellmiami.centric.hyatt.com/docker-compose.yml\r\nhttps://brickellmiami.centric.hyatt.com/.docker/config.json\r\nhttps://brickellmiami.centric.hyatt.com/Dockerfile\r\nhttps://brideonashoestring.wordpress.org/web/var/www/public_html/config.php\r\nhttps://brideonashoestring.wordpress.org/web/var/www/public_html/wp-config.php\r\nhttps://brideonashoestring.wordpress.org/wp-config.php\r\nhttps://brideonashoestring.wordpress.org/.wp-config.php.swp\r\nhttps://brideonashoestring.wordpress.org/_wpeprivate/config.json\r\nhttps://brideonashoestring.wordpress.org/yarn-debug.log\r\nhttps://brideonashoestring.wordpress.org/yarn-error.log\r\nhttps://brideonashoestring.wordpress.org/yarn.lock\r\nhttps://brideonashoestring.wordpress.org/.yarnrc\r\nhttps://bridgehome.adobe.com/etc/shadow\r\nhttps://bridgehome.adobe.com/phpinfo.php\r\nhttps://bridgetonema.wordpress.org/manifest.json\r\nhttps://bridgetonema.wordpress.org/manifest.yml\r\nhttps://bridge.twilio.com/.wp-config.php.swp\r\nhttps://bridge.twilio.com/wp-content/themes/.git/config\r\nhttps://bridge.twilio.com/_wpeprivate/config.json\r\nhttps://bridge.twilio.com/yarn-debug.log\r\nhttps://bridge.twilio.com/yarn-error.log\r\nhttps://bridge.twilio.com/yarn.lock\r\nhttps://bridge.twilio.com/.yarnrc\r\nhttps://brightside.mtn.co.za/config.lua\r\nhttps://brightside.mtn.co.za/config.php\r\nhttps://brightside.mtn.co.za/config.php.txt\r\nhttps://brightside.mtn.co.za/config.rb\r\nhttps://brightside.mtn.co.za/config.ru\r\nhttps://brightside.mtn.co.za/_config.yml\r\nhttps://brightside.mtn.co.za/console\r\nhttps://brightside.mtn.co.za/.credentials\r\nhttps://brightside.mtn.co.za/CVS/Entries\r\nhttps://brightside.mtn.co.za/CVS/Root\r\nhttps://brightside.mtn.co.za/dasbhoard/\r\nhttps://brightside.mtn.co.za/data\r\nhttps://brightside.mtn.co.za/data.txt\r\nhttps://brightside.mtn.co.za/db/dbeaver-data-sources.xml\r\nhttps://brightside.mtn.co.za/db/dump.sql\r\nhttps://brightside.mtn.co.za/db/.pgpass\r\nhttps://brightside.mtn.co.za/db/robomongo.json\r\nhttps://brightside.mtn.co.za/README.txt\r\nhttps://brightside.mtn.co.za/RELEASE_NOTES.txt\r\nhttps://brightside.mtn.co.za/.remote-sync.json\r\nhttps://brightside.mtn.co.za/Resources.zip.manifest\r\nhttps://brightside.mtn.co.za/.rspec\r\nhttps://br.infinite.sx/db/dump.sql\r\nhttps://br.infinite.sx/graphiql\r\n\r\n```\r\n\r\nThe domain name brightside.mtn.co.za and other domains repeated more than 10 times now i want to drop brightside.mtn.co.za and other domains that are repeated more than 10 times and then the output the results the output  should look like.\r\n\r\n```\r\nhttps://br.infinite.sx/db/dump.sql\r\nhttps://br.infinite.sx/graphiql\r\nhttps://bridgetonema.wordpress.org/manifest.json\r\nhttps://bridgetonema.wordpress.org/manifest.yml\r\n\r\n```\r\n         ",
        "link": "https://stackoverflow.com/questions/60499798/filter-results-using-bash",
        "title": "Filter results using bash"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1583255600,
                "creation_date": 1583255600,
                "answer_id": 60512373,
                "question_id": 60512115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your expression starts with `.[] |` and then the thing after the `|` produces an object, then you must be producing 0 or 1 objects *per element of the array*. But you know that that&#39;s not what you want. You want one object, so you should be starting by producing an object.\r\n\r\n    { \r\n        username: (.[] | select(.name == &quot;username&quot;).value), \r\n        password: (.[] | select(.name == &quot;password&quot;).value) \r\n    }\r\n\r\nis similar to what you&#39;re currently doing, but it works.\r\n\r\nYou could also do `map({ key: .name, value }) | from_entries` as a nicer way to do the same thing: it uses jq&#39;s builtin `from_entries` to turn an array of key/value pairs into an object. You just have to change your `name` key into `key`, which is what `from_entries` expects.",
                "title": "jq: How do I reshape into an object, using multiple selects as values?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1583280713,
                "last_edit_date": 1583280713,
                "creation_date": 1583276360,
                "answer_id": 60516761,
                "question_id": 60512115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As it happens, jq (version 1.5 or later) already understands the `{&quot;name&quot;:_, &quot;value&quot;:_}` method of representing a JSON object, so you can achieve the result simply using the jq filter:\r\n\r\n    from_entries\r\n",
                "title": "jq: How do I reshape into an object, using multiple selects as values?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1583280713,
        "creation_date": 1583254662,
        "last_edit_date": 1583276484,
        "question_id": 60512115,
        "body_markdown": "**JSON**\r\n```\r\n[\r\n      {\r\n        &quot;name&quot;: &quot;username&quot;,\r\n        &quot;value&quot;: &quot;my-username&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;password&quot;,\r\n        &quot;value&quot;: &quot;my-password&quot;\r\n      }\r\n]\r\n```\r\n\r\n**Desired Result**\r\n```\r\n{ &quot;username&quot;: &quot;my-username&quot;, &quot;password&quot;: &quot;my-password&quot; }\r\n```\r\n\r\n**A few failed attempts**\r\n\r\n```.[] | { username: select(.name == &quot;username&quot;).value, password: select(.name == &quot;password&quot;).value }```\r\n\r\nNo output\r\n\r\n```.[] | { username: select(.name == &quot;username&quot;).value} + { password: select(.name == &quot;password&quot;).value }```\r\n\r\nNo output\r\n\r\n\r\n```.[] | { username: select(.name == &quot;username&quot;).value } + .[] | { password: select(.name == &quot;password&quot;).value }```\r\n\r\nFails\r\n\r\nIf I only want a single field, the syntax works fine. E.g.\r\n\r\n`.[] | { username: select(.name == &quot;username&quot;).value  }`\r\n\r\nproduces\r\n\r\n`{ &quot;username&quot;: &quot;my-username&quot; }`\r\n\r\nThe only issue is trying to do the same with multiple elements.\r\n\r\nThoughts?\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/60512115/jq-how-do-i-reshape-into-an-object-using-multiple-selects-as-values",
        "title": "jq: How do I reshape into an object, using multiple selects as values?"
    },
    {
        "tags": [
            "json",
            "stream",
            "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": 1583256707,
                "post_id": 60512221,
                "comment_id": 107052249,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user13000929"
                },
                "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": 1583256866,
                "post_id": 60512221,
                "comment_id": 107052308,
                "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": 1583257074,
                "post_id": 60512221,
                "comment_id": 107052391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user13000929"
                },
                "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": 1583257518,
                "post_id": 60512221,
                "comment_id": 107052588,
                "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": 1583257586,
                "post_id": 60512221,
                "comment_id": 107052626,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user13000929"
                },
                "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": 1583257963,
                "post_id": 60512221,
                "comment_id": 107052784,
                "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": 1583258026,
                "post_id": 60512221,
                "comment_id": 107052810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user13000929"
                },
                "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": 1583258377,
                "post_id": 60512221,
                "comment_id": 107052980,
                "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": 1583259917,
                "post_id": 60512221,
                "comment_id": 107053660,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1583265182,
                "creation_date": 1583265182,
                "answer_id": 60514542,
                "question_id": 60512221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your input is already a stream, there is no need to use the --stream option.  The following produces the desired output: \r\n\r\n```\r\n&lt; input.json jq -r &#39;.content\r\n| fromjson\r\n| select( any(keys_unsorted[]; test(&quot;^4&quot;)) )\r\n| .[&quot;001&quot;]&#39;\r\n```",
                "title": "jq using stream to parse a json file &gt; 20 gb"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1583301541,
        "creation_date": 1583255036,
        "last_edit_date": 1583301541,
        "question_id": 60512221,
        "body_markdown": "i have a json file which is &gt;20 gb of data like below:\r\n\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;$serialnumber&quot;: &quot;572&quot;\r\n      },\r\n      &quot;content&quot;: &quot;{\\&quot;001\\&quot;:\\&quot;77\\&quot;,\\&quot;401\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;$serialnumber&quot;: &quot;573&quot;\r\n      },\r\n      &quot;content&quot;: &quot;{\\&quot;001\\&quot;:\\&quot;234\\&quot;,\\&quot;424\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;$serialnumber&quot;: &quot;574&quot;\r\n      },\r\n      &quot;content&quot;: &quot;{\\&quot;001\\&quot;:\\&quot;549\\&quot;,\\&quot;432\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;$serialnumber&quot;: &quot;575&quot;\r\n      },\r\n      &quot;content&quot;: &quot;{\\&quot;001\\&quot;:\\&quot;888\\&quot;,\\&quot;532\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n\r\ni need a way with jq stream (i have installed version 1.6) to get all 001 values, that have in the content, a 4.. element.(400, or 401, or 402, or 403, ...)\r\n\r\nfor example the above would return:\r\n\r\n    77\r\n    234\r\n    549\r\n\r\nand not 888, which does not contain any 4.. element.\r\n\r\n    001 77 has the \\&quot;401\\&quot; element\r\n    001 234 has the \\&quot;424\\&quot; element\r\n    001 549 has the \\&quot;432\\&quot; element\r\n\r\nbelow please find one of my attempts to solve this:\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][] == &quot;_id&quot;) | del(.[0][0]))) | select(.content == &quot;400&quot;)&#39;",
        "link": "https://stackoverflow.com/questions/60512221/jq-using-stream-to-parse-a-json-file-20-gb",
        "title": "jq using stream to parse a json file &gt; 20 gb"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583258452,
                "post_id": 60513099,
                "comment_id": 107053011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11261329,
                    "reputation": 11,
                    "user_id": 8259539,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/46c3679ea4e885ffd386ed26e74dc2b1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "project_linux",
                    "link": "https://stackoverflow.com/users/8259539/project-linux"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583258738,
                "post_id": 60513099,
                "comment_id": 107053137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583260057,
                "post_id": 60513099,
                "comment_id": 107053722,
                "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": 1583260283,
                "post_id": 60513099,
                "comment_id": 107053804,
                "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": 1583260357,
                "post_id": 60513099,
                "comment_id": 107053835,
                "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": 1583260409,
                "post_id": 60513099,
                "comment_id": 107053860,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1583273427,
                "creation_date": 1583273427,
                "answer_id": 60516273,
                "question_id": 60513099,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Suppose your initial file is object.json and that it contains an empty object, {};\r\nand that at the beginning of each iteration, the key:value pairs  are defined in another file, kv.txt.\r\n\r\nThen at each iteration, you can update array.json using the invocation:\r\n\r\n    &lt; kv.txt jq -Rn --argfile object object.json -f program.jq | sponge object.json\r\n\r\nwhere program.jq contains the jq program:\r\n```\r\n$object | .Array += \r\n  reduce inputs as $in ([]; . + [$in | capture(&quot;(?&lt;k&gt;^[^:]*): *(?&lt;v&gt;.*)&quot;) | {(.k):.v} ])\r\n```\r\n\r\n(`sponge` is part of the moreutils package.  If it cannot be used, then you will have to use another method of updating object.json.)\r\n",
                "title": "Create//append JSON array from text file in linux with loop"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1583273427,
        "creation_date": 1583258327,
        "last_edit_date": 1583260380,
        "question_id": 60513099,
        "body_markdown": "I have a below file in txt format. I want to arrange the data in json array format in linux and append more such data with for/while loop in the same json array based on condition. Please help me with the best way to achieve this.\r\n```none\r\nFile\r\nName:Rock\r\nName:Clock\r\n```\r\n\r\n```json\r\n{“Array&quot; :[\r\n{\r\n&quot;Name&quot;: &quot;Rock&quot;,\r\n},\r\n{\r\n&quot;Name”: &quot;Clock”,\r\n}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/60513099/create-append-json-array-from-text-file-in-linux-with-loop",
        "title": "Create//append JSON array from text file in linux with loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1707478869,
                "last_edit_date": 1707478869,
                "creation_date": 1583286923,
                "answer_id": 60518023,
                "question_id": 60517702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you&#39;re looking at the [manual for the development version of jq](https://jqlang.github.io/jq/manual/#if-then-else-end), rather than [the manual for jq version 1.6](https://jqlang.github.io/jq/manual/v1.6/#if-then-else-end).\r\n",
                "title": "Why is this &quot;if A then B end&quot; statement not accepted with jq 1.6?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1707478869,
        "creation_date": 1583283946,
        "question_id": 60517702,
        "body_markdown": "According to the `jq` manual (Conditionals and Comparisons &gt; if-then-else):\r\n\r\n&gt; `if A then B end` is the same as `if A then B else . end`. That is, the\r\n&gt; else branch is optional, and if absent is the same as ..\r\n\r\nThe same is  substantiated by the accepted answer to this Stack Overflow question: https://stackoverflow.com/questions/29949184/json-jq-if-without-else\r\n\r\nSo **why does this `if A then B end` statement invoke a parse error?**\r\n\r\n    $ jq --version\r\n    jq-1.6\r\n    $ echo 2 | jq &#39;if . == 0 then &quot;zero&quot; end&#39;\r\n    jq: error: syntax error, unexpected end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    if . == 0 then &quot;zero&quot; end                      \r\n    jq: error: Possibly unterminated &#39;if&#39; statement at &lt;top-level&gt;, line 1:\r\n    if . == 0 then &quot;zero&quot; end\r\n    jq: 2 compile errors\r\n    $ echo 0 | jq &#39;if . == 0 then &quot;zero&quot; end&#39;\r\n    jq: error: syntax error, unexpected end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    if . == 0 then &quot;zero&quot; end                      \r\n    jq: error: Possibly unterminated &#39;if&#39; statement at &lt;top-level&gt;, line 1:\r\n    if . == 0 then &quot;zero&quot; end\r\n    jq: 2 compile errors\r\n\r\nWhat I understand to be the _equivalent_ `if A then B else . end` form of the statement seems to work:\r\n\r\n    $ echo 2 | jq &#39;if . == 0 then &quot;zero&quot; else . end&#39;\r\n    2\r\n    $ echo 0 | jq &#39;if . == 0 then &quot;zero&quot; else . end&#39;\r\n    &quot;zero&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60517702/why-is-this-if-a-then-b-end-statement-not-accepted-with-jq-1-6",
        "title": "Why is this &quot;if A then B end&quot; statement not accepted with jq 1.6?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1583334746,
                "creation_date": 1583334746,
                "answer_id": 60529126,
                "question_id": 60524084,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, the relevant key is `.message`, not `.content`.\r\n\r\nSecond, since you are imposing an additional condition, you have only to use `and`.\r\n\r\nThird, the requirements are a bit ambiguous, but the following produces the expected results, and is a solution to one disambiguation of the stated problem:\r\n\r\n```\r\n.message\r\n    | fromjson\r\n    | select( any(keys_unsorted[]; test(&quot;^4&quot;)) \r\n              and (.[] | arrays | flatten | (index([&quot;v&quot;]) or index([&quot;9&quot;])) )  )\r\n    | .[&quot;id&quot;]\r\n```\r\n\r\nAs you suggest, you could also use `IN`.\r\n",
                "title": "filter json when it must fulfill two conditions. One for the key, and one in a nested array for the selected element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633365936,
        "creation_date": 1583318081,
        "last_edit_date": 1633365936,
        "question_id": 60524084,
        "body_markdown": "given the following json, how the below code should be altered, so as to add a new condition.\r\n\r\nreturn all ids, that have an element that starts with 4, but also have an array that has in it either the   \r\n \r\n\\&quot;v\\&quot; value, or the \\&quot;9\\&quot; value.\r\n\r\nInput json:\r\n\r\n    {\r\n      &quot;memo&quot;: {\r\n        &quot;notice&quot;: &quot;delivered on 17&quot;\r\n      },\r\n      &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;1\\&quot;,\\&quot;401\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n    {\r\n      &quot;memo&quot;: {\r\n        &quot;notice&quot;: &quot;delivered on 190&quot;\r\n      },\r\n      &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;2\\&quot;,\\&quot;424\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;v\\&quot;,\\&quot;UK\\&quot;],[\\&quot;9\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n    {\r\n      &quot;memo&quot;: {\r\n        &quot;notice&quot;: &quot;delivered on 734&quot;\r\n      },\r\n      &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;3\\&quot;,\\&quot;432\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;9\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;v\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n    {\r\n      &quot;memo&quot;: {\r\n        &quot;notice&quot;: &quot;delivered on 1092&quot;\r\n      },\r\n      &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;888\\&quot;,\\&quot;532\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;v\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n    }\r\n\r\n    snippet that needs to be adjusted:\r\n    &lt; input.json jq -r &#39;.content\r\n        | fromjson\r\n        | select( any(keys_unsorted[]; test(&quot;^4&quot;)) )\r\n        | .[&quot;id&quot;]&#39;\r\n\r\n\r\nDesired output:\r\n\r\n    2\r\n    3\r\n\r\njq version: 1.6, already tried without success to use:\r\n 1. index \r\n 2. the built-in IN statement \r\n\r\nWe need only the 001 values, of each json object, that has an element which starts with a 4, and that this element (say 401) also has a value of v, or 9 in its nested array, or both v and 9.",
        "link": "https://stackoverflow.com/questions/60524084/filter-json-when-it-must-fulfill-two-conditions-one-for-the-key-and-one-in-a-n",
        "title": "filter json when it must fulfill two conditions. One for the key, and one in a nested array for the selected element with jq"
    },
    {
        "tags": [
            "json",
            "regex",
            "command-line-interface",
            "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": 1583330679,
                "post_id": 60527224,
                "comment_id": 107079564,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17901887,
                    "reputation": 25,
                    "user_id": 13005972,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/12614e3b6bdd4cf39d605c46e3f751dc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "citizen4",
                    "link": "https://stackoverflow.com/users/13005972/citizen4"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583332586,
                "post_id": 60527224,
                "comment_id": 107080645,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583333335,
                "post_id": 60527224,
                "comment_id": 107081137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583334491,
                "post_id": 60527224,
                "comment_id": 107081897,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1583333878,
                "last_edit_date": 1583333878,
                "creation_date": 1583333493,
                "answer_id": 60528737,
                "question_id": 60527224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea is right, but the value iterator `.[]` operation does not accept the regex symbols directly. Which means your `$` anchor at the end of the `taxonomy/definition` is incorrect and needs to be removed. You can just simply do\r\n\r\n    jq -r &#39;.[].&quot;taxonomy/definition&quot;?&#39;\r\n\r\nor if you want to use a regex based approach to match the `&quot;taxonomy/definition&quot;` exactly, you could do\r\n\r\n    jq -r &#39;map(to_entries[] | select(.key| test(&quot;^taxonomy/definition$&quot;)?).value)[]&#39;\r\n\r\n\r\n    \r\n",
                "title": "retrieving null values from jq request"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583333878,
        "creation_date": 1583328519,
        "question_id": 60527224,
        "body_markdown": "I am new to jq and tried to extract only the values from the keys &quot;taxonomy/definitions&quot; as a list from this json file (it has many more objects than pasted here).\r\n\r\n    [\r\n        {\r\n            &quot;taxonomy/relations&quot;: {\r\n                &quot;taxonomy/broader&quot;: 1,\r\n                &quot;taxonomy/narrower&quot;: 0,\r\n                &quot;taxonomy/related&quot;: 0,\r\n                &quot;taxonomy/substitutability-to&quot;: 0,\r\n                &quot;taxonomy/substitutability-from&quot;: 0\r\n            },\r\n            &quot;taxonomy/id&quot;: &quot;ZxHj_Wvj_39H&quot;,\r\n            &quot;taxonomy/type&quot;: &quot;skill&quot;,\r\n            &quot;taxonomy/definition&quot;: &quot;VM/CMS, operativsystem&quot;,\r\n            &quot;taxonomy/preferred-label&quot;: &quot;VM/CMS, operativsystem&quot;\r\n        },\r\n        {\r\n            &quot;taxonomy/relations&quot;: {\r\n                &quot;taxonomy/broader&quot;: 1,\r\n                &quot;taxonomy/narrower&quot;: 0,\r\n                &quot;taxonomy/related&quot;: 0,\r\n                &quot;taxonomy/substitutability-to&quot;: 0,\r\n                &quot;taxonomy/substitutability-from&quot;: 0\r\n            },\r\n            &quot;taxonomy/id&quot;: &quot;oRCp_wLd_dWd&quot;,\r\n            &quot;taxonomy/type&quot;: &quot;skill&quot;,\r\n            &quot;taxonomy/definition&quot;: &quot;OS/400, operativsystem&quot;,\r\n            &quot;taxonomy/preferred-label&quot;: &quot;OS/400, operativsystem&quot;\r\n        }\r\n    ]\r\n\r\nI came to the following command:\r\n\r\n    jq -r &#39;.[].&quot;taxonomy/definitions$&quot;&#39; skills.json\r\n\r\nHowever, it retrieves me null values. I assume that I did something wrong concerning the path or whatsoever but couldn&#39;t figure it out in a while ... \r\n\r\n",
        "link": "https://stackoverflow.com/questions/60527224/retrieving-null-values-from-jq-request",
        "title": "retrieving null values from jq request"
    },
    {
        "tags": [
            "docker",
            "unix",
            "jq",
            "jsonpath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1583368973,
                "post_id": 60535547,
                "comment_id": 107096513,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4365279,
                    "reputation": 15263,
                    "user_id": 3561275,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Jk8uY.png?s=256",
                    "display_name": "omajid",
                    "link": "https://stackoverflow.com/users/3561275/omajid"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583369034,
                "post_id": 60535547,
                "comment_id": 107096522,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583394594,
                "post_id": 60535547,
                "comment_id": 107102803,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17809103,
                    "reputation": 1945,
                    "user_id": 12934138,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mC8wFyFlY6j2qMp809an4XpkYMv2fMXoZ_1rtca=k-s256",
                    "display_name": "Carolyn Cordeiro",
                    "link": "https://stackoverflow.com/users/12934138/carolyn-cordeiro"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583433267,
                "post_id": 60535547,
                "comment_id": 107124598,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583434209,
                "post_id": 60535547,
                "comment_id": 107125020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17809103,
                    "reputation": 1945,
                    "user_id": 12934138,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mC8wFyFlY6j2qMp809an4XpkYMv2fMXoZ_1rtca=k-s256",
                    "display_name": "Carolyn Cordeiro",
                    "link": "https://stackoverflow.com/users/12934138/carolyn-cordeiro"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583440989,
                "post_id": 60535547,
                "comment_id": 107127894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17809103,
                    "reputation": 1945,
                    "user_id": 12934138,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mC8wFyFlY6j2qMp809an4XpkYMv2fMXoZ_1rtca=k-s256",
                    "display_name": "Carolyn Cordeiro",
                    "link": "https://stackoverflow.com/users/12934138/carolyn-cordeiro"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583441802,
                "post_id": 60535547,
                "comment_id": 107128226,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 293130,
                    "reputation": 268849,
                    "user_id": 596285,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b6975c494d3d9c404dd3d7af2edf3133?s=256&d=identicon&r=PG",
                    "display_name": "BMitch",
                    "link": "https://stackoverflow.com/users/596285/bmitch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583444260,
                "post_id": 60535547,
                "comment_id": 107129222,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1583366993,
                "creation_date": 1583366993,
                "answer_id": 60536474,
                "question_id": 60535547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While creating docker you need to install jq `sudo apt-get install jq`",
                "title": "Why docker run saying Unknown operand whilst same shell script runs perfectly in ubuntu machine"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1583441665,
        "creation_date": 1583360391,
        "last_edit_date": 1583441665,
        "question_id": 60535547,
        "body_markdown": "I am trying to execute a ```./login.sh``` as a part of ```docker run``` now when i run the ```./login.sh``` in ubuntu machine i see success response but when i create a docker image i see output as ```sh: abc: unknown operand “invalid url”```\r\n\r\nHere is contents of ```./login.sh```\r\n\r\n     #!/bin/sh\r\n     # Black Box Tester!\r\n\r\n\r\n    content=$(curl  --location --request POST &quot;https://api.platform.abc.com. \r\n    /auth/oauth/token&quot; --header &#39;Content-Type: application/x-www-form- \r\n    urlencoded&#39; \\\r\n     --header &#39;Authorization: Basic V0zSA==&#39; --data-raw &#39;grant_type=password&amp;\r\n    username=test@example.com&amp;password=123456&#39;| jq -r &#39;.domain_id&#39; )\r\n    if [ $content = abc ]\r\n         then\r\n              echo “Valid Login Token”\r\n    else\r\n              echo “invalid url”\r\n    fi\r\n\r\nand here is contents of docker file\r\n\r\n    FROM ubuntu:16.04\r\n\r\n    RUN apt-get update &amp;&amp; apt-get install -y curl   \\\r\n        &amp;&amp; apt-get -y install jq\r\n\r\n\r\n    FROM openjdk:8-jre-alpine\r\n\r\n    RUN apk --no-cache add curl jq\r\n\r\n\r\n    WORKDIR /opt\r\n\r\n\r\n    ADD login.sh /opt\r\n\r\n    RUN pwd  \\\r\n       &amp;&amp; find /opt\r\n\r\n\r\n\r\n    CMD [&quot;./login.sh&quot;]\r\n\r\nWhen same ```./login.sh``` i execute normally in Ubuntu machine i get successful output as \r\n\r\n        ubuntu@ip-172-31-29-248:~$ ./login.sh \r\n       % Total    % Received % Xferd  Average Speed   Time    Time     Time    \r\n      Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n    100  2034  100  1958  100    76   9458    367 --:--:-- --:--:-- --:--:--  \r\n    9873\r\n    “Valid Login Token”\r\n\r\n\r\nHere is output of ```sudo docker run lots/loginimage```\r\n     \r\n     ubuntu@ip-172-31-29-248:~$ sudo docker run lots/loginimage\r\n     ./login.sh: line 6: jq: not found\r\n       % Total    % Received % Xferd  Average Speed   Time    Time     Time       \r\n     Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n     92  2034   92  1807  100    76   7199    302 --:--:-- --:--:-- --:--:--      \r\n    7501\r\n    curl: (23) Failed writing body (0 != 1024)\r\n    sh: abc: unknown operand\r\n    “invalid url”\r\n\r\nCan some one let me know why the login script which is simply a curl command runs sucessfully in ubuntu machine but same login script shows else condition in docker run?\r\n\r\nAlso i have included a code in docker file to download and install Json path ```jq``` but why image still says ```./login.sh: line 6: jq: not found```??\r\n\r\nyour help is highly appreciated\r\n",
        "link": "https://stackoverflow.com/questions/60535547/why-docker-run-saying-unknown-operand-whilst-same-shell-script-runs-perfectly-in",
        "title": "Why docker run saying Unknown operand whilst same shell script runs perfectly in ubuntu machine"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3771455,
                    "reputation": 3279,
                    "user_id": 3133518,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/522db88ba37cbedd99abc9a7ec2e0f0f?s=256&d=identicon&r=PG",
                    "display_name": "Jacky",
                    "link": "https://stackoverflow.com/users/3133518/jacky"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583366662,
                "post_id": 60536358,
                "comment_id": 107096010,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4412853,
                    "reputation": 765,
                    "user_id": 3595231,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/696098c5643657e2de534c56bf80b2a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3595231",
                    "link": "https://stackoverflow.com/users/3595231/user3595231"
                },
                "reply_to_user": {
                    "account_id": 3771455,
                    "reputation": 3279,
                    "user_id": 3133518,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/522db88ba37cbedd99abc9a7ec2e0f0f?s=256&d=identicon&r=PG",
                    "display_name": "Jacky",
                    "link": "https://stackoverflow.com/users/3133518/jacky"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583366839,
                "post_id": 60536358,
                "comment_id": 107096049,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1583370359,
                "creation_date": 1583370359,
                "answer_id": 60536854,
                "question_id": 60536358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach for you, but it&#39;s not pure jq. \r\n\r\n    cat results.json | jq -s -c &#39;.[]&#39; | sort -k1.12 -n\r\n\r\nSince I saw that you are using unix the sort is performed with the sort command:\r\n\r\n    sort -k1.12 -n\r\n\r\nHere is the explanation:\r\n\r\n    -k1.12 Define a restricted sort key that has the starting position field1, in this case position 12\r\n    -n Sort fields numerically by arithmetic value\r\n\r\nOutput:\r\n\r\n    {&quot;name&quot;:&quot;I-1&quot;,&quot;node_id&quot;:&quot;458d3d44-9d70-473d-87ae-9cd419277c92&quot;,&quot;console&quot;:5005}\r\n    {&quot;name&quot;:&quot;I-2&quot;,&quot;node_id&quot;:&quot;49253898-e628-4ed8-9268-69e6a0b01105&quot;,&quot;console&quot;:5007}\r\n    {&quot;name&quot;:&quot;I-10&quot;,&quot;node_id&quot;:&quot;c655c49b-083e-46e7-8866-08020761ffac&quot;,&quot;console&quot;:5023}\r\n    {&quot;name&quot;:&quot;I-11&quot;,&quot;node_id&quot;:&quot;5f62ce93-48ff-420e-9876-e92c01e3d1df&quot;,&quot;console&quot;:5025}\r\n    {&quot;name&quot;:&quot;I-12&quot;,&quot;node_id&quot;:&quot;af9000dd-0653-4c5d-91ae-def37a95d0fb&quot;,&quot;console&quot;:5027}\r\n    {&quot;name&quot;:&quot;I-13&quot;,&quot;node_id&quot;:&quot;5ad2301d-688d-4d70-9d35-07b421f4f893&quot;,&quot;console&quot;:5029}\r\n    {&quot;name&quot;:&quot;I-14&quot;,&quot;node_id&quot;:&quot;2f1fcc75-e642-496a-a822-0d6d0cb46376&quot;,&quot;console&quot;:5031}\r\n    {&quot;name&quot;:&quot;I-15&quot;,&quot;node_id&quot;:&quot;720c786c-8a38-4c0c-93b7-33850160837c&quot;,&quot;console&quot;:5033}\r\n    {&quot;name&quot;:&quot;I-16&quot;,&quot;node_id&quot;:&quot;20516282-7cad-43d8-999b-3c20b1e6c3bd&quot;,&quot;console&quot;:5035}\r\n    {&quot;name&quot;:&quot;I-17&quot;,&quot;node_id&quot;:&quot;e33fa2c1-d36e-4933-ab92-0dad99e2a276&quot;,&quot;console&quot;:5037}\r\n    {&quot;name&quot;:&quot;I-18&quot;,&quot;node_id&quot;:&quot;4215fe76-1b6b-457d-8a38-85e51b4c53ec&quot;,&quot;console&quot;:5039}\r\n    {&quot;name&quot;:&quot;I-19&quot;,&quot;node_id&quot;:&quot;351f85c2-7c9c-4847-b15c-43d35d5bdbcd&quot;,&quot;console&quot;:5041}\r\n    {&quot;name&quot;:&quot;I-20&quot;,&quot;node_id&quot;:&quot;0575b79c-4060-4ded-ad69-e5da6bcd4d8b&quot;,&quot;console&quot;:5043}\r\n    {&quot;name&quot;:&quot;I-21&quot;,&quot;node_id&quot;:&quot;4ba799eb-e48b-49f3-8bb1-65605be85061&quot;,&quot;console&quot;:5045}\r\n\r\n   ",
                "title": "How to have the json output sorted in my case"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1583375434,
                "creation_date": 1583375434,
                "answer_id": 60537408,
                "question_id": 60536358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An only-jq solution:\r\n\r\n    &lt; results.json jq -s -c &#39;\r\n        sort_by(.name|sub(&quot;I-&quot;;&quot;&quot;) | tonumber) | .[]&#39;",
                "title": "How to have the json output sorted in my case"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1583393054,
        "creation_date": 1583366020,
        "last_edit_date": 1583393054,
        "question_id": 60536358,
        "body_markdown": "This is the command I am using on Ubuntu to extract data from the original json file: \r\n\r\n        cat results.json | jq -s -c &#39;sort_by(.name) | .[]&#39;\r\n\r\nAnd these are the output I got: \r\n\r\n    {&quot;name&quot;:&quot;I-1&quot;,&quot;node_id&quot;:&quot;458d3d44-9d70-473d-87ae-9cd419277c92&quot;,&quot;console&quot;:5005}\r\n    {&quot;name&quot;:&quot;I-10&quot;,&quot;node_id&quot;:&quot;c655c49b-083e-46e7-8866-08020761ffac&quot;,&quot;console&quot;:5023}\r\n    {&quot;name&quot;:&quot;I-11&quot;,&quot;node_id&quot;:&quot;5f62ce93-48ff-420e-9876-e92c01e3d1df&quot;,&quot;console&quot;:5025}\r\n    {&quot;name&quot;:&quot;I-12&quot;,&quot;node_id&quot;:&quot;af9000dd-0653-4c5d-91ae-def37a95d0fb&quot;,&quot;console&quot;:5027}\r\n    {&quot;name&quot;:&quot;I-13&quot;,&quot;node_id&quot;:&quot;5ad2301d-688d-4d70-9d35-07b421f4f893&quot;,&quot;console&quot;:5029}\r\n    {&quot;name&quot;:&quot;I-14&quot;,&quot;node_id&quot;:&quot;2f1fcc75-e642-496a-a822-0d6d0cb46376&quot;,&quot;console&quot;:5031}\r\n    {&quot;name&quot;:&quot;I-15&quot;,&quot;node_id&quot;:&quot;720c786c-8a38-4c0c-93b7-33850160837c&quot;,&quot;console&quot;:5033}\r\n    {&quot;name&quot;:&quot;I-16&quot;,&quot;node_id&quot;:&quot;20516282-7cad-43d8-999b-3c20b1e6c3bd&quot;,&quot;console&quot;:5035}\r\n    {&quot;name&quot;:&quot;I-17&quot;,&quot;node_id&quot;:&quot;e33fa2c1-d36e-4933-ab92-0dad99e2a276&quot;,&quot;console&quot;:5037}\r\n    {&quot;name&quot;:&quot;I-18&quot;,&quot;node_id&quot;:&quot;4215fe76-1b6b-457d-8a38-85e51b4c53ec&quot;,&quot;console&quot;:5039}\r\n    {&quot;name&quot;:&quot;I-19&quot;,&quot;node_id&quot;:&quot;351f85c2-7c9c-4847-b15c-43d35d5bdbcd&quot;,&quot;console&quot;:5041}\r\n    {&quot;name&quot;:&quot;I-2&quot;,&quot;node_id&quot;:&quot;49253898-e628-4ed8-9268-69e6a0b01105&quot;,&quot;console&quot;:5007}\r\n    {&quot;name&quot;:&quot;I-20&quot;,&quot;node_id&quot;:&quot;0575b79c-4060-4ded-ad69-e5da6bcd4d8b&quot;,&quot;console&quot;:5043}\r\n    {&quot;name&quot;:&quot;I-21&quot;,&quot;node_id&quot;:&quot;4ba799eb-e48b-49f3-8bb1-65605be85061&quot;,&quot;console&quot;:5045}\r\n    ...\r\n\r\nHow may I have the output sorted in numerically way by this  **&quot;name&quot;** value ? Thanx. -Jack \r\n\r\n ",
        "link": "https://stackoverflow.com/questions/60536358/how-to-have-the-json-output-sorted-in-my-case",
        "title": "How to have the json output sorted in my case"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1583419141,
                "post_id": 60539044,
                "comment_id": 107116766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583425011,
                "post_id": 60539044,
                "comment_id": 107120455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3023868,
                    "reputation": 22536,
                    "user_id": 2564301,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06c050c0677999b783246c5ff7471bcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jongware",
                    "link": "https://stackoverflow.com/users/2564301/jongware"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583487448,
                "post_id": 60539044,
                "comment_id": 107141623,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1583457791,
                "creation_date": 1583457791,
                "answer_id": 60556311,
                "question_id": 60539044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the square brackets were not in the input, `jq` could process it like normal as a stream of objects. You could then throw them into an array or whatever.\r\n\r\nYou&#39;ll just need to invoke jq twice in this case. First read it in raw (`-Rs`) and trim out the leading and trailing brackets, output it raw (`-r`), then process in jq like normal.\r\n\r\n    $ jq -Rsr &#39;gsub(&quot;^\\\\s*\\\\[|\\\\]\\\\s*$&quot;; &quot;&quot;)&#39; input.json | jq -n &#39;[inputs]&#39;",
                "title": "How do I add a comma in between JSON objects?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1583487081,
                "creation_date": 1583487081,
                "answer_id": 60561150,
                "question_id": 60539044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [human JSON utility][1] to recover your malformed JSON file:\r\n\r\n    hjson -j file\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;message&quot;,\r\n        &quot;user&quot;: &quot;U024HFHU5&quot;,\r\n        &quot;text&quot;: &quot;hey there&quot;,\r\n        &quot;ts&quot;: &quot;1385407681.000003&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;message&quot;,\r\n        &quot;user&quot;: &quot;U024HGJ4E&quot;,\r\n        &quot;text&quot;: &quot;right back at you&quot;,\r\n        &quot;ts&quot;: &quot;1385407706.000006&quot;\r\n      }\r\n    ]\r\n\r\nThe option `-j` outputs the file with correct JSON syntax, by adding the missing comma between objects.\r\n\r\n\r\n  [1]: https://hjson.github.io/\r\n",
                "title": "How do I add a comma in between JSON objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1583487081,
        "creation_date": 1583388130,
        "last_edit_date": 1583419471,
        "question_id": 60539044,
        "body_markdown": "Say I have a sample.json file that looks like this. Notice the objects are not separated by a comma. I am aware that this is not a JSON file without the commas.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;message&quot;,\r\n    &quot;user&quot;: &quot;U024HFHU5&quot;,\r\n    &quot;text&quot;: &quot;hey there&quot;,\r\n    &quot;ts&quot;: &quot;1385407681.000003&quot;\r\n  }\r\n  {\r\n    &quot;type&quot;: &quot;message&quot;,\r\n    &quot;user&quot;: &quot;U024HGJ4E&quot;,\r\n    &quot;text&quot;: &quot;right back at you&quot;,\r\n    &quot;ts&quot;: &quot;1385407706.000006&quot;\r\n  }\r\n]\r\n```\r\n\r\nHow do I make it look like this (example from I got the example from https://thoughtbot.com/blog/jq-is-sed-for-json.)\r\n\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;message&quot;,\r\n    &quot;user&quot;: &quot;U024HFHU5&quot;,\r\n    &quot;text&quot;: &quot;hey there&quot;,\r\n    &quot;ts&quot;: &quot;1385407681.000003&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;message&quot;,\r\n    &quot;user&quot;: &quot;U024HGJ4E&quot;,\r\n    &quot;text&quot;: &quot;right back at you&quot;,\r\n    &quot;ts&quot;: &quot;1385407706.000006&quot;\r\n  }\r\n]\r\n```\r\n\r\nI tried doing },{ as some have suggested but it does not work.\r\n\r\nI think it&#39;s probably something like this in jq on the command line but am not sure. Here, my hope is that sample2.json outputs the desired format.\r\n\r\n```\r\njq -r &#39;. | join(&quot;, &quot;)&#39; sample.json &gt; sample2.json\r\n```",
        "link": "https://stackoverflow.com/questions/60539044/how-do-i-add-a-comma-in-between-json-objects",
        "title": "How do I add a comma in between JSON objects?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1657815286,
                "last_edit_date": 1657815286,
                "creation_date": 1583417576,
                "answer_id": 60547309,
                "question_id": 60546107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A generic approach to search for a key-value pair (`sk`-`sv`) in input recursively and extract another key&#39;s value (`pv`) from objects found:\r\n``` shell\r\njq -r --arg sk Name         \\\r\n      --arg sv InstanceType \\\r\n      --arg pv Value        \\\r\n&#39;.. | objects | select(contains({($sk): $sv})) | .[$pv]&#39; file\r\n```",
                "title": "Using jq find key/value pair based on another key/value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657815286,
        "creation_date": 1583413639,
        "last_edit_date": 1583417110,
        "question_id": 60546107,
        "body_markdown": "I&#39;m pasting here a JSON example data which would require some manipulation to get a desired output which is mentioned in the next section to be read after this piece of JSON code.\r\n\r\nI want to use jq for parsing my desired data.\r\n\r\n    {\r\n    &quot;MetricAlarms&quot;: [\r\n        {\r\n            &quot;EvaluationPeriods&quot;: 3,\r\n            &quot;ComparisonOperator&quot;: &quot;GreaterThanOrEqualToThreshold&quot;,\r\n            &quot;AlarmActions&quot;: [\r\n                &quot;Unimportant:Random:alarm:ELK2[10.1.1.2]-Root-Disk-Alert&quot;\r\n            ],\r\n            &quot;AlarmName&quot;: &quot;Unimportant:Random:alarm:ELK1[10.1.1.0]-Root-Alert&quot;,\r\n            &quot;Dimensions&quot;: [\r\n                {\r\n                    &quot;Name&quot;: &quot;path&quot;,\r\n                    &quot;Value&quot;: &quot;/&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;InstanceType&quot;,\r\n                    &quot;Value&quot;: &quot;m5.2xlarge&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;fstype&quot;,\r\n                    &quot;Value&quot;: &quot;ext4&quot;\r\n                }\r\n            ],\r\n            &quot;DatapointsToAlarm&quot;: 3,\r\n            &quot;MetricName&quot;: &quot;disk_used_percent&quot;\r\n        },\r\n        {\r\n            &quot;EvaluationPeriods&quot;: 3,\r\n            &quot;ComparisonOperator&quot;: &quot;GreaterThanOrEqualToThreshold&quot;,\r\n            &quot;AlarmActions&quot;: [\r\n                &quot;Unimportant:Random:alarm:ELK2[10.1.1.2]&quot;\r\n            ],\r\n            &quot;AlarmName&quot;: &quot;Unimportant:Random:alarm:ELK2[10.1.1.2]&quot;,\r\n            &quot;Dimensions&quot;: [\r\n                {\r\n                    &quot;Name&quot;: &quot;path&quot;,\r\n                    &quot;Value&quot;: &quot;/&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;InstanceType&quot;,\r\n                    &quot;Value&quot;: &quot;r5.2xlarge&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;fstype&quot;,\r\n                    &quot;Value&quot;: &quot;ext4&quot;\r\n                }\r\n            ],\r\n            &quot;DatapointsToAlarm&quot;: 3,\r\n            &quot;MetricName&quot;: &quot;disk_used_percent&quot;\r\n        }\r\n    ]\r\n    }\r\n\r\nSo when I Pass some Key1 &amp; value1 as a parameter **&quot;Name&quot;: &quot;InstanceType&quot;,** to the JQ probably using cat &lt;filename&gt; | jq &lt;required params here&gt; and output expected should be as below\r\n\r\n    m5.2xlarge\r\n    r5.2xlarge",
        "link": "https://stackoverflow.com/questions/60546107/using-jq-find-key-value-pair-based-on-another-key-value-pair",
        "title": "Using jq find key/value pair based on another key/value pair"
    },
    {
        "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": 1583503759,
                "post_id": 60562957,
                "comment_id": 107149987,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14796250,
                    "reputation": 35,
                    "user_id": 10685806,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/87fbb79540988e0858027cf4b628d893?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Olki",
                    "link": "https://stackoverflow.com/users/10685806/olki"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1583507481,
                "post_id": 60562957,
                "comment_id": 107152076,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1583521117,
                "creation_date": 1583521117,
                "answer_id": 60570086,
                "question_id": 60562957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution to the first part of the question as I understand it can be solved by using `from_entries`:\r\n```\r\n.[].methodResponse.params.param.value.struct.member\r\n| map( .value |= .string )\r\n| [from_entries]\r\n\r\n```\r\n\r\nIf you want to select a particular product or products, it would be easy to modify the above.\r\n\r\nThe second part of the question isn&#39;t too clear to me but I think that once you understand `from_entries`, you should be able to find a solution quite easily.\r\n",
                "title": "Extract Json properties from a array by value and transform to a new json structure with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583521117,
        "creation_date": 1583493253,
        "question_id": 60562957,
        "body_markdown": "my input json looks like this:\r\n\r\n    [{\r\n       &quot;methodResponse&quot;:{\r\n          &quot;params&quot;:{\r\n             &quot;param&quot;:{\r\n                &quot;value&quot;:{\r\n                   &quot;struct&quot;:{\r\n                      &quot;member&quot;:[\r\n                         {\r\n                            &quot;name&quot;:&quot;severity&quot;,\r\n                            &quot;value&quot;:{\r\n                               &quot;string&quot;:&quot;Low&quot;\r\n                            }\r\n                         },\r\n                         {\r\n                            &quot;name&quot;:&quot;product&quot;,\r\n                            &quot;value&quot;:{\r\n                               &quot;string&quot;:&quot;p1&quot;\r\n                            }\r\n                         }                        \r\n                      ]\r\n                   }\r\n                }\r\n             }\r\n          }\r\n       }\r\n    }]\r\n\r\nI want to extract each &quot;member&quot; entry to a new json object by filtering via &quot;name&quot; value.\r\n\r\nOutput should be like:\r\n\r\n    [\r\n      {\r\n        &quot;severity&quot;: &quot;Low&quot;,\r\n        &quot;product&quot;: &quot;p1&quot;\r\n      }\r\n    ]\r\n\r\nThe order of the member items can change.\r\n\r\nI&#39;m able to select the values by the &quot;name&quot; value but it doesnt work if the ordering of the member items changed. \r\n\r\n    [.[].methodResponse.params.param.value.struct.member[] | select(.name == &quot;severity&quot;).value.string, select(.name == &quot;product&quot;).value.string] | [{severity:.[0], product:.[1]}]\r\n\r\nAnother problem is if a member wasnt found by the name value. if a member wasnt found by the name it should print null for the missing member value-&gt;  &quot;missingmemberName&quot;: null\r\n\r\n      [\r\n          {\r\n            &quot;severity&quot;: &quot;Low&quot;,\r\n            &quot;product&quot;: &quot;p1&quot;,\r\n            &quot;missingmemberName&quot;: null\r\n          }\r\n        ]\r\n\r\nhttps://jqplay.org/s/CthSsOCQ-Y\r\n\r\nThanks for any help\r\n",
        "link": "https://stackoverflow.com/questions/60562957/extract-json-properties-from-a-array-by-value-and-transform-to-a-new-json-struct",
        "title": "Extract Json properties from a array by value and transform to a new json structure with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "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": 1583513034,
                "post_id": 60568266,
                "comment_id": 107154924,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1583519911,
                "creation_date": 1583519911,
                "answer_id": 60569834,
                "question_id": 60568266,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The good news is that the objects in the input stream can be processed separately,\r\nso assuming the stream consists of valid JSON objects, a solution can be presented as a one-liner:\r\n```\r\n.ans as $ans | with_entries(select((.key | test(&quot;^Option&quot;)) and .value == $ans | not))\r\n```",
                "title": "Removing entry from JSON file if the key matches another key in the same array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1592276019,
        "creation_date": 1583512885,
        "last_edit_date": 1592276019,
        "question_id": 60568266,
        "body_markdown": "I have a JSON file that has some quiz questions, they&#39;re formatted like this:\r\n\r\n```\r\n{\r\n  &quot;ques&quot;: &quot;What is the meaning of life?&quot;,\r\n  &quot;ans&quot;: &quot;42&quot;,\r\n  &quot;Option1&quot;: &quot;123&quot;,\r\n  &quot;Option2&quot;: &quot;456&quot;,\r\n  &quot;Option3&quot;: &quot;789&quot;,\r\n  &quot;Option4&quot;: &quot;42&quot;,\r\n}\r\n{\r\n  &quot;ques&quot;: &quot;What isn&#39;t the meaning of life?&quot;,\r\n  &quot;ans&quot;: &quot;Something&quot;,\r\n  &quot;Option1&quot;: &quot;something else&quot;,\r\n  &quot;Option2&quot;: &quot;another thing&quot;,\r\n  &quot;Option3&quot;: &quot;Something&quot;,\r\n  &quot;Option4&quot;: &quot;Yet another thing&quot;,\r\n  &quot;Option5&quot;: &quot;One last thing&quot;\r\n}\r\n```\r\n\r\nI want to iterate through the file, and compare the &quot;Option X&quot; key to the &quot;ans&quot; key, and if it matches, remove that line. So in the example above the output would look like this:\r\n\r\n```\r\n{\r\n  &quot;ques&quot;: &quot;What is the meaning of life?&quot;,\r\n  &quot;ans&quot;: &quot;42&quot;,\r\n  &quot;Option1&quot;: &quot;123&quot;,\r\n  &quot;Option2&quot;: &quot;456&quot;,\r\n  &quot;Option3&quot;: &quot;789&quot;\r\n\r\n}\r\n{\r\n  &quot;ques&quot;: &quot;What isn&#39;t the meaning of life?&quot;,\r\n  &quot;ans&quot;: &quot;Something&quot;,\r\n  &quot;Option1&quot;: &quot;something else&quot;,\r\n  &quot;Option2&quot;: &quot;another thing&quot;,\r\n\r\n  &quot;Option4&quot;: &quot;Yet another thing&quot;,\r\n  &quot;Option5&quot;: &quot;One last thing&quot;\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60568266/removing-entry-from-json-file-if-the-key-matches-another-key-in-the-same-array-u",
        "title": "Removing entry from JSON file if the key matches another key in the same array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1583594322,
                "last_edit_date": 1583594322,
                "creation_date": 1583593575,
                "answer_id": 60578922,
                "question_id": 60578829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use the *update-assignment* operator (`|=`).\r\n```\r\n.cars |= map(select(.comments))\r\n```\r\n```\r\n.cars |= map(select(.comments and any(.comments[]; index(&quot;FooBar&quot;)) | not))\r\n```",
                "title": "select elements of an array and update it in-place"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583686136,
        "creation_date": 1583593001,
        "last_edit_date": 1583686136,
        "question_id": 60578829,
        "body_markdown": "Given the following JSON,\r\n\r\nI&#39;m trying to filter out items in the cars array where the item&#39;s comments array is null:\r\n\r\n    .cars[] |  select(.comments == null)\r\n\r\nor the item&#39;s comments array exists and any of the comments objects don&#39;t contain the value &quot;FooBar&quot;\r\n\r\n    .cars[] |  select( select(.comments != null) | (any(.comments[]; index(&quot;FooBar&quot;)) | not) )\r\n\r\nwhile retaining the original structure.\r\n\r\nWith jq I can figure out how to create the critera I want to filter down to but what I can&#39;t wrap my head around is how to make that apply to the top level items.\r\n\r\nJSON input:\r\n\r\n    {\r\n        &quot;person&quot;: {\r\n            &quot;first_name&quot;: &quot;Bob&quot;,\r\n            &quot;last_name&quot;: &quot;Smith&quot;\r\n        },\r\n        &quot;addresses&quot;: [\r\n            {\r\n                &quot;home&quot;: {\r\n                    &quot;line1&quot;: &quot;123&quot;,\r\n                    &quot;line2&quot;: &quot;A st.&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;work&quot;: {\r\n                    &quot;line1&quot;: &quot;456&quot;,\r\n                    &quot;line2&quot;: &quot;B st.&quot;\r\n                }\r\n            }\r\n        ],\r\n        &quot;cars&quot;: [\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Civic&quot;\r\n            },\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Accord&quot;\r\n            },\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Pilot&quot;,\r\n                &quot;comments&quot;: [\r\n                    &quot;Comment 1&quot;,\r\n                    &quot;Comment 2&quot;,\r\n                    &quot;FooBar&quot;\r\n                ]\r\n            },\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Passport&quot;,\r\n                &quot;comments&quot;: [\r\n                    &quot;Comment 3&quot;,\r\n                    &quot;Comment 4&quot;\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nJSON Outut, same as the input but the oject with the comment array containg the value &quot;FooBar&quot; is filtered out:\r\n\r\n    {\r\n        &quot;person&quot;: {\r\n            &quot;first_name&quot;: &quot;Bob&quot;,\r\n            &quot;last_name&quot;: &quot;Smith&quot;\r\n        },\r\n        &quot;addresses&quot;: [\r\n            {\r\n                &quot;home&quot;: {\r\n                    &quot;line1&quot;: &quot;123&quot;,\r\n                    &quot;line2&quot;: &quot;A st.&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;work&quot;: {\r\n                    &quot;line1&quot;: &quot;456&quot;,\r\n                    &quot;line2&quot;: &quot;B st.&quot;\r\n                }\r\n            }\r\n        ],\r\n        &quot;cars&quot;: [\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Civic&quot;\r\n            },\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Accord&quot;\r\n            },\r\n            {\r\n                &quot;make&quot;: &quot;Honda&quot;,\r\n                &quot;model&quot;: &quot;Passport&quot;,\r\n                &quot;comments&quot;: [\r\n                    &quot;Comment 3&quot;,\r\n                    &quot;Comment 4&quot;\r\n                ]\r\n            }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/60578829/select-elements-of-an-array-and-update-it-in-place",
        "title": "select elements of an array and update it in-place"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1583604427,
                "last_edit_date": 1583604427,
                "creation_date": 1583603950,
                "answer_id": 60580623,
                "question_id": 60580306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Below is a brief explanation from JQ&#39;s manual on why this happens.\r\n&gt; the expression `[1,2,3]` is not using a built-in syntax for comma-separated arrays, but is instead applying the `[]` operator (collect results) to the expression `1,2,3` (which produces three different results).\r\n\r\nUsing a variable you can circumvent this issue.\r\n```\r\n.spaces[] | .ext_ids[] as $e | [.account_name, $e] | @csv\r\n```",
                "title": "json to csv issue using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1583647789,
        "creation_date": 1583601957,
        "last_edit_date": 1583647789,
        "question_id": 60580306,
        "body_markdown": "I using jq to convert below json to CSV according to my necessity\r\n\r\nmy json is:\r\n\r\n```\r\n{\r\n    &quot;id&quot;: 39,\r\n    &quot;max_x&quot;: null,\r\n    &quot;max_y&quot;: null,\r\n    &quot;min_x&quot;: null,\r\n    &quot;min_y&quot;: null,\r\n    &quot;name&quot;: &quot;L1&quot;,\r\n    &quot;space_count&quot;: 159,\r\n    &quot;spaces&quot;: [\r\n               {\r\n            &quot;account_name&quot;: &quot;Westpac&quot;,\r\n            &quot;ext_ids&quot;: [\r\n                &quot;5d6043ce3b1a6903ba000021&quot;,\r\n                &quot;5d6043ce3b1a6903ba000022&quot;\r\n            ],\r\n            &quot;gla&quot;: 232,\r\n            &quot;gross_rent&quot;: 493565.04000000004,\r\n            &quot;id&quot;: 8955,\r\n            &quot;lease_end_time&quot;: &quot;2021-09-15T00:00:00.000Z&quot;,\r\n            &quot;map_unit_no&quot;: &quot;GD030A&quot;,\r\n            &quot;mat_excl_gst&quot;: 0,\r\n            &quot;mat_growth_rate&quot;: null,\r\n            &quot;mat_month&quot;: &quot;January-2020&quot;,\r\n            &quot;net_rent&quot;: 337459.2,\r\n            &quot;unit_no&quot;: &quot;030A&quot;,\r\n            &quot;vertices&quot;: [\r\n            ]\r\n        }\r\n    ],\r\n    &quot;svg&quot;: null\r\n}\r\n```\r\n\r\nI try to convert to CSV By using this code in terminal:\r\n\r\n```\r\ncat data1.json | jq -r &#39;.spaces[] | [.account_name,.ext_ids[]] | @csv&#39; | tr -d &#39;&quot;&#39; &gt;&gt; output.csv\r\n```\r\nresult is:\r\n\r\n```\r\nWestpac,5d6043ce3b1a6903ba000021,5d6043ce3b1a6903ba000022\r\n```\r\nBut I need to have this result:\r\n```\r\nWestpac,5d6043ce3b1a6903ba000021\r\nWestpac,5d6043ce3b1a6903ba000022\r\n```\r\nCould you please guid me?\r\n",
        "link": "https://stackoverflow.com/questions/60580306/json-to-csv-issue-using-jq",
        "title": "json to csv issue using jq"
    },
    {
        "tags": [
            "json",
            "numbers",
            "jq",
            "data-extraction"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1583618728,
                "last_edit_date": 1583618728,
                "creation_date": 1583618040,
                "answer_id": 60582542,
                "question_id": 60582492,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way that can easily be adapted to different requirements: \r\n\r\n```\r\ndef extractNumber: gsub(&quot;[^0-9]&quot;;&quot;&quot;) | tonumber;\r\n\r\nmap( map_values(extractNumber) )\r\n```\r\n## A generalization\r\n\r\n```\r\ndef extractNumber:\r\n  . as $in \r\n  | gsub(&quot;[^0-9]&quot;;&quot;&quot;)\r\n  | if length == 0 then $in else tonumber end;\r\n\r\nwalk(if type == &quot;object&quot; then map_values(extractNumber) else . end)\r\n```\r\n",
                "title": "How can a string value be transformed and cast to number using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583620427,
        "creation_date": 1583617560,
        "last_edit_date": 1583620427,
        "question_id": 60582492,
        "body_markdown": "Just trying to figure out how can this simple JSON fragment\r\n\r\n    [{ &quot;rooms&quot;: &quot;2 Rooms&quot; }, { &quot;rooms&quot;: &quot;3 Rooms&quot; }]\r\n\r\nbe transformed to\r\n\r\n    [{ &quot;rooms&quot;: 2 }, { &quot;rooms&quot;: 3 }]\r\n\r\nI found in the documentations the reference to functions supporting regexp, but I cannot write more than this\r\n\r\n    [.[] | { &quot;rooms&quot;: .rooms } ]",
        "link": "https://stackoverflow.com/questions/60582492/how-can-a-string-value-be-transformed-and-cast-to-number-using-jq",
        "title": "How can a string value be transformed and cast to number using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1583679622,
                "post_id": 60586783,
                "comment_id": 107190617,
                "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": 1583708499,
                "post_id": 60586783,
                "comment_id": 107198268,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583685418,
                "creation_date": 1583685418,
                "answer_id": 60589668,
                "question_id": 60586783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In that case you might want to create your object inside the `if` statement:\r\n\r\n    echo &#39;{&quot;id&quot;: 1}&#39; | jq &#39;if .id == 1 then {} else {newId: .id} end&#39;",
                "title": "Is there a special value to omit fields from jq output?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1583789855,
                "last_edit_date": 1583789855,
                "creation_date": 1583686133,
                "answer_id": 60589768,
                "question_id": 60586783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I now went with a solution where I conditionally add the fields in the end. Looks a little overkill for such a small object, but if you&#39;re dealing with bigger objects with a lot of additional fields, it&#39;s a very clean way.\r\n\r\n```bash\r\necho &#39;{&quot;id&quot;: 1, &quot;more&quot;: &quot;fields&quot;}&#39; \\\r\n| jq &#39;.id as $id\r\n       | {newMore: .more} \r\n       | if $id == 1 then . else . + {newId: $id} end\r\n     &#39;\r\n```",
                "title": "Is there a special value to omit fields from jq output?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583689092,
                "last_edit_date": 1583689092,
                "creation_date": 1583687630,
                "answer_id": 60590009,
                "question_id": 60586783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could adopt the convention that, if a key&#39;s value is `null` (or `nan`), the key can be deleted.  To delete all the null-valued keys, you can use `map_values(select(. != null))` (or `map_values(select(isnan|not))`).\r\n\r\nThus, using your example, we find:\r\n\r\n```\r\n$ echo &#39;{&quot;id&quot;: 1}&#39; | jq &#39;{newId: (if .id == 1 then null else .id end)} | map_values( select(. != null))&#39;\r\n{}\r\n```\r\n\r\nand:\r\n```\r\n$ echo &#39;{&quot;id&quot;: 1}&#39; | jq &#39;{newId: (if .id == 1 then nan else .id end)} | map_values( select(isnan|not))&#39;\r\n{}\r\n```\r\n\r\n\r\n",
                "title": "Is there a special value to omit fields from jq output?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583688752,
                "creation_date": 1583688752,
                "answer_id": 60590201,
                "question_id": 60586783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq 1.5 or later, you can use `empty` as the &quot;special value&quot; as follows:\r\n\r\n    echo &#39;{&quot;id&quot;: 1}&#39; | jq &#39;. as $in \r\n      | reduce &quot;newId&quot; as $k (.; .[$k] = if .id == 1 then empty else .id end)&#39;\r\n\r\nThe point is that you can handle indefinitely many keys this way; for example, if you have a list, $l, of key names to be added conditionally, you would write: `reduce $l[] as $k ...`",
                "title": "Is there a special value to omit fields from jq output?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583708401,
                "creation_date": 1583708401,
                "answer_id": 60592881,
                "question_id": 60586783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `empty` as the special value along with `// {}`:\r\n\r\n```\r\n$ echo &#39;{&quot;id&quot;: 1}&#39; | jq &#39;{newId: (if .id == 1 then empty else .id end) } // {} &#39;\r\n{}\r\n```\r\n\r\nThis technique can also be used add a field conditionally, e.g.\r\n```\r\n$ echo &#39;{&quot;id&quot;: 1}&#39; | jq &#39;. += ({newId: (if .id == 1 then empty else .id end) } // {})&#39;\r\n{\r\n  &quot;id&quot;: 1\r\n}\r\n\r\n```\r\n\r\n",
                "title": "Is there a special value to omit fields from jq output?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1583789855,
        "creation_date": 1583665118,
        "last_edit_date": 1583789660,
        "question_id": 60586783,
        "body_markdown": "I can easily conditionally set a field to `null`:\r\n\r\n```sh\r\necho &#39;{&quot;id&quot;: 1, &quot;more&quot;: &quot;fields&quot;}&#39; \\\r\n  | jq &#39;{newId: (if .id == 1 then null else .id end), newMore: .more}&#39;\r\n```\r\nyields\r\n```json\r\n{\r\n  &quot;newId&quot;: null,\r\n  &quot;newMore&quot;: &quot;fields&quot;\r\n}\r\n```\r\n\r\n\r\nBut how can I conditionally delete it? I&#39;m looking for something like:\r\n\r\n```sh\r\necho &#39;{&quot;id&quot;: 1, &quot;more&quot;: &quot;fields&quot;}&#39; \\\r\n  | jq &#39;{\r\n          newId: (if .id == 1 then &lt;special-value&gt; else .id end), \r\n          newMore: .more\r\n       }&#39;\r\n```\r\nto yield\r\n```json\r\n{\r\n  &quot;newMore&quot;: &quot;fields&quot;\r\n}\r\n```\r\n\r\nDoes such a `&lt;special-value&gt;` exist? If not, what are other viable solutions? They should ideally also be usable for large objects with many additional and nested fields.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60586783/is-there-a-special-value-to-omit-fields-from-jq-output",
        "title": "Is there a special value to omit fields from jq output?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1583799405,
                "creation_date": 1583799405,
                "answer_id": 60609987,
                "question_id": 60609883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On the right-hand side of `|=`, the `.` doesn&#39;t refer to each Boolean value output by the left-hand side. It refers to the path *to* each value produced by the left-hand side.\r\n\r\nThe filter `(..|select(type==&quot;boolean&quot;)) |= if . then 1 else 0 end`, given your input, is equivalent to\r\n\r\n    .[0] |= if . then 1 else 0 end | \r\n    .[1] |= if . then 1 else 0 end |\r\n    .[2][0] |= if . then 1 else 0 end | ...\r\n",
                "title": "jq - how |= operator works?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1583885235,
                "creation_date": 1583885235,
                "answer_id": 60627555,
                "question_id": 60609883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Any assignment, whether it&#39;s via `=`, `|=` or any other, does not change the context as a result of the assignment. It just updates the selected value and passes along the original `.` input. And as chepner points out, the expression expanded out is just a sequence of assignments, none of which changes the context.\r\n\r\nIf you wanted to get just the mapped out values, you wouldn&#39;t want to do an assignment here and just do a regular pipe.\r\n\r\n    .. | select(type==&quot;boolean&quot;) | if . then 1 else 0 end",
                "title": "jq - how |= operator works?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1583885235,
        "creation_date": 1583798589,
        "last_edit_date": 1583802403,
        "question_id": 60609883,
        "body_markdown": "In the [JQ Manual][1], there is an Update-assignment: **|=** filter and its example.\r\n\r\n```\r\njq &#39;(..|select(type==&quot;boolean&quot;)) |= if . then 1 else 0 end&#39;\r\nInput\t[true,false,[5,true,[true,[false]],false]]\r\nOutput\t[1,0,[5,1,[1,[0]],0]]\r\n```\r\n\r\nWhy this does not produce a JSON stream below but maintains the original nested list format?\r\n```\r\n1\r\n0\r\n1\r\n1\r\n0\r\n0\r\n```\r\n\r\nFor me, **(..|select(type==&quot;boolean&quot;))** produces:\r\n```\r\ntrue\r\nfalse\r\ntrue\r\ntrue\r\nfalse\r\nfalse\r\n```\r\n\r\nThen applying **|= if . then 1 else 0 end** would not produce this?\r\n```\r\n1\r\n0\r\n1\r\n1\r\n0\r\n0\r\n```\r\n\r\nPlease help understand how **|= ** operation maintains can maintain the format of the input.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/60609883/jq-how-operator-works",
        "title": "jq - how |= operator works?"
    },
    {
        "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": 1,
                "creation_date": 1583823321,
                "post_id": 60612468,
                "comment_id": 107234504,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10351454,
                    "reputation": 130,
                    "user_id": 7644509,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c5c32a7cc985a79458b019178f3d2cac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user7644509",
                    "link": "https://stackoverflow.com/users/7644509/user7644509"
                },
                "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": 1583862119,
                "post_id": 60612468,
                "comment_id": 107253124,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1583823188,
                "creation_date": 1583823188,
                "answer_id": 60612728,
                "question_id": 60612468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would you try the following:\r\n```\r\njq &#39;(.list[].b.&quot;1&quot;)=&quot;changed&quot;&#39; file.json\r\n```\r\nOutput:\r\n```\r\n{\r\n  &quot;href&quot;: &quot;1234&quot;,\r\n  &quot;list&quot;: [\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;dummy&quot;: &quot;thing&quot;\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;0&quot;: &quot;thing&quot;,\r\n        &quot;1&quot;: &quot;changed&quot;,\r\n        &quot;2&quot;: &quot;thing&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "Linux Update JSON with Array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1583862068,
        "creation_date": 1583821484,
        "last_edit_date": 1583862068,
        "question_id": 60612468,
        "body_markdown": "How would I update a JSON with an array nested inside? I got stuck trying out with jq using. It cuts off items in &quot;b&quot; so only 1 is inside it.\r\n```\r\njq &#39;.items[1].b.&quot;1&quot; = &quot;changed&quot;&#39; &lt;&lt;&lt; cat file.json\r\n```\r\n\r\nSo example if a json the following is like:\r\n```\r\n{\r\n\t&quot;href&quot;: &quot;1234&quot;,\r\n\t&quot;list&quot;: [{\r\n\t\t&quot;a&quot;: {\r\n\t\t\t&quot;dummy&quot;: &quot;thing&quot;\r\n\t\t},\r\n\t\t&quot;b&quot;: {\r\n\t\t\t&quot;0&quot;: &quot;thing&quot;,\r\n\t\t\t&quot;1&quot;: &quot;thing&quot;, &lt;--- ex. I want to change this\r\n\t\t\t&quot;2&quot;: &quot;thing&quot;\r\n\t\t}\r\n\t}]\r\n}\r\n```\r\n**Desired Result**\r\n\r\n```\r\n# Result that I want\r\n{\r\n\t&quot;href&quot;: &quot;1234&quot;,\r\n\t&quot;list&quot;: [{\r\n\t\t&quot;a&quot;: {\r\n\t\t\t&quot;dummy&quot;: &quot;thing&quot;\r\n\t\t},\r\n\t\t&quot;b&quot;: {\r\n\t\t\t&quot;0&quot;: &quot;thing&quot;,\r\n\t\t\t&quot;1&quot;: &quot;changed&quot;, &lt;--- this changed\r\n\t\t\t&quot;2&quot;: &quot;thing&quot;\r\n\t\t}\r\n\t}]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/60612468/linux-update-json-with-array",
        "title": "Linux Update JSON with Array"
    },
    {
        "tags": [
            "json",
            "regex",
            "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": 1583834236,
                "post_id": 60614991,
                "comment_id": 107238720,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9940502,
                    "reputation": 27,
                    "user_id": 7357285,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/298fcdbf71b7fba1d505612e2212d254?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user7357285",
                    "link": "https://stackoverflow.com/users/7357285/user7357285"
                },
                "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": 1583849724,
                "post_id": 60614991,
                "comment_id": 107246492,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1583833869,
                "creation_date": 1583833869,
                "answer_id": 60615103,
                "question_id": 60614991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use the following : \r\n\r\n    .data.tls.result.handshake_log.server_certificates.certificate.parsed.issuer_dn \\\r\n     | select(length &gt; 8)\r\n\r\nYou can [try it here](https://jqplay.org/s/wugoDnIbJv).",
                "title": "Using jq search value using regex"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1583834365,
                "creation_date": 1583834365,
                "answer_id": 60615237,
                "question_id": 60614991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use:\r\n\r\n    test(&quot;[A-Z]{8}&quot;)",
                "title": "Using jq search value using regex"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1583834365,
        "creation_date": 1583833539,
        "question_id": 60614991,
        "body_markdown": "I have this json object and I am trying to find a way to use regex in jq to search value in `issuer_dn` that is more than 8 characters. A regex like `[A-Z]{8}` should work but I am unable to get results. I am still learning jq and if there is any other tool that can be used then please share. \r\n\r\n    {\r\n      &quot;ip&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;tls&quot;: {\r\n          &quot;status&quot;: &quot;success&quot;,\r\n          &quot;protocol&quot;: &quot;tls&quot;,\r\n          &quot;result&quot;: {\r\n            &quot;handshake_log&quot;: {\r\n              &quot;server_hello&quot;: {\r\n                &quot;version&quot;: {\r\n                  &quot;name&quot;: &quot;TLSv1.2&quot;,\r\n                  &quot;value&quot;: 771\r\n                },\r\n                &quot;random&quot;: &quot;hhdshfhhdhfhshdh&quot;,\r\n                &quot;session_id&quot;: &quot;hjdsfyyueujhfjaskdfjjl&quot;,\r\n                &quot;cipher_suite&quot;: {\r\n                  &quot;hex&quot;: &quot;0xC014&quot;,\r\n                  &quot;name&quot;: &quot;TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA&quot;,\r\n                  &quot;value&quot;: 49172\r\n                },\r\n                &quot;compression_method&quot;: 0,\r\n                &quot;ocsp_stapling&quot;: false,\r\n                &quot;ticket&quot;: false,\r\n                &quot;secure_renegotiation&quot;: true,\r\n                &quot;heartbeat&quot;: false,\r\n                &quot;extended_master_secret&quot;: false\r\n              },\r\n              &quot;server_certificates&quot;: {\r\n                &quot;certificate&quot;: {\r\n                  &quot;raw&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC==&quot;,\r\n                  &quot;parsed&quot;: {\r\n                    &quot;version&quot;: 3,\r\n                    &quot;serial_number&quot;: &quot;1234567890&quot;,\r\n                    &quot;signature_algorithm&quot;: {\r\n                      &quot;name&quot;: &quot;SHA256-RSA&quot;,\r\n                      &quot;oid&quot;: &quot;1.2.840.113549.1.1.11&quot;\r\n                    },\r\n                    &quot;issuer&quot;: {\r\n                      &quot;common_name&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;country&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;locality&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;province&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;organization&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;organizational_unit&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ]\r\n                    },\r\n                    &quot;issuer_dn&quot;: &quot;C=ABCD, ST=ABCD, L=ABCD, O=ABCD, OU=ABCD, CN=ABCD&quot;,\r\n                    &quot;validity&quot;: {\r\n                      &quot;start&quot;: &quot;2020-02-01T01:09:22Z&quot;,\r\n                      &quot;end&quot;: &quot;2021-02-01T03:09:22Z&quot;,\r\n                      &quot;length&quot;: 7883663\r\n                    },\r\n                    &quot;subject&quot;: {\r\n                      &quot;common_name&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;country&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;locality&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;province&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;organization&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ],\r\n                      &quot;organizational_unit&quot;: [\r\n                        &quot;ABC&quot;\r\n                      ]\r\n                    },\r\n                    &quot;subject_dn&quot;: &quot;C=ABCD, ST=ABCD, L=ABCD, O=ABCD, OU=ABCD, CN=ABCD&quot;,\r\n                    &quot;subject_key_info&quot;: {\r\n                      &quot;key_algorithm&quot;: {\r\n                        &quot;name&quot;: &quot;RSA&quot;\r\n                      },\r\n                      &quot;rsa_public_key&quot;: {\r\n                        &quot;exponent&quot;: 65537,\r\n                        &quot;modulus&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC&quot;,\r\n                        &quot;length&quot;: 2048\r\n                      },\r\n                      &quot;fingerprint_sha256&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;\r\n                    },\r\n                    &quot;extensions&quot;: {\r\n                      &quot;basic_constraints&quot;: {\r\n                        &quot;is_ca&quot;: true\r\n                      },\r\n                      &quot;authority_key_id&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                      &quot;subject_key_id&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;\r\n                    },\r\n                    &quot;signature&quot;: {\r\n                      &quot;signature_algorithm&quot;: {\r\n                        &quot;name&quot;: &quot;SHA256-RSA&quot;,\r\n                        &quot;oid&quot;: &quot;1.2.840.113549.1.1.11&quot;\r\n                      },\r\n                      &quot;value&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC&quot;,\r\n                      &quot;valid&quot;: true,\r\n                      &quot;self_signed&quot;: true\r\n                    },\r\n                    &quot;fingerprint_md5&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;fingerprint_sha1&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;fingerprint_sha256&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;tbs_noct_fingerprint&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;spki_subject_fingerprint&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;tbs_fingerprint&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;validation_level&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                    &quot;redacted&quot;: false\r\n                  }\r\n                },\r\n                &quot;validation&quot;: {\r\n                  &quot;browser_trusted&quot;: false,\r\n                  &quot;browser_error&quot;: &quot;x509: failed to load system roots and no roots provided&quot;\r\n                }\r\n              },\r\n              &quot;server_key_exchange&quot;: {\r\n                &quot;ecdh_params&quot;: {\r\n                  &quot;curve_id&quot;: {\r\n                    &quot;name&quot;: &quot;secp256r1&quot;,\r\n                    &quot;id&quot;: 23\r\n                  },\r\n                  &quot;server_public&quot;: {\r\n                    &quot;x&quot;: {\r\n                      &quot;value&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                      &quot;length&quot;: 256\r\n                    },\r\n                    &quot;y&quot;: {\r\n                      &quot;value&quot;: &quot;73hh3g39920jfjj38723bb3993hh3774994002&quot;,\r\n                      &quot;length&quot;: 256\r\n                    }\r\n                  }\r\n                },\r\n                &quot;digest&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC&quot;,\r\n                &quot;signature&quot;: {\r\n                  &quot;raw&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC&quot;,\r\n                  &quot;type&quot;: &quot;rsa&quot;,\r\n                  &quot;valid&quot;: true,\r\n                  &quot;signature_and_hash_type&quot;: {\r\n                    &quot;signature_algorithm&quot;: &quot;rsa&quot;,\r\n                    &quot;hash_algorithm&quot;: &quot;sha256&quot;\r\n                  },\r\n                  &quot;tls_version&quot;: {\r\n                    &quot;name&quot;: &quot;TLSv1.2&quot;,\r\n                    &quot;value&quot;: 771\r\n                  }\r\n                }\r\n              },\r\n              &quot;client_key_exchange&quot;: {\r\n                &quot;ecdh_params&quot;: {\r\n                  &quot;curve_id&quot;: {\r\n                    &quot;name&quot;: &quot;secp256r1&quot;,\r\n                    &quot;id&quot;: 23\r\n                  },\r\n                  &quot;client_public&quot;: {\r\n                    &quot;x&quot;: {\r\n                      &quot;value&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC=&quot;,\r\n                      &quot;length&quot;: 256\r\n                    },\r\n                    &quot;y&quot;: {\r\n                      &quot;value&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC=&quot;,\r\n                      &quot;length&quot;: 256\r\n                    }\r\n                  },\r\n                  &quot;client_private&quot;: {\r\n                    &quot;value&quot;: &quot;dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC=&quot;,\r\n                    &quot;length&quot;: 32\r\n                  }\r\n                }\r\n              },\r\n              &quot;client_finished&quot;: {\r\n                &quot;verify_data&quot;: &quot;dGVzdCBkY&quot;\r\n              },\r\n              &quot;server_finished&quot;: {\r\n                &quot;verify_data&quot;: &quot;dGVzdCBkY&quot;\r\n              },\r\n              &quot;key_material&quot;: {\r\n                &quot;master_secret&quot;: {\r\n                  &quot;value&quot;: &quot;dGVzdCBkY&quot;,\r\n                  &quot;length&quot;: 48\r\n                },\r\n                &quot;pre_master_secret&quot;: {\r\n                  &quot;value&quot;: &quot;dGVzdCBkY&quot;,\r\n                  &quot;length&quot;: 32\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;timestamp&quot;: &quot;2020-02-9T07:14:47Z&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60614991/using-jq-search-value-using-regex",
        "title": "Using jq search value using regex"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583862034,
                "creation_date": 1583862034,
                "answer_id": 60623117,
                "question_id": 60622466,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over the input objects one a time from `inputs` and append it to the `components` using the `reduce` function\r\n\r\n    jq -n &#39;reduce inputs as $d (.; .components += $d )&#39; file{1..3}.json",
                "title": "Merge json files - Concatenate into a single dict json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583863710,
                "creation_date": 1583863710,
                "answer_id": 60623540,
                "question_id": 60622466,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simply use `add`, e.g.\r\n\r\n    jq -s &#39;{components: add}&#39; file{1..3}.json\r\n\r\nor:\r\n\r\n    jq -n &#39;{components: [inputs]|add}&#39; file{1..3}.json",
                "title": "Merge json files - Concatenate into a single dict json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1583921379,
        "creation_date": 1583859566,
        "question_id": 60622466,
        "body_markdown": "here are 3 JSON files\r\n\r\nFile1\r\n```\r\n{\r\n  &quot;component1&quot;: [\r\n  ]\r\n}\r\n```\r\n\r\nFile2\r\n```\r\n{\r\n  &quot;component2&quot;: [\r\n  ]\r\n}\r\n```\r\nFile3\r\n```\r\n{\r\n  &quot;component3&quot;: [\r\n  ]\r\n}\r\n```\r\n\r\nDon&#39;t find the jq command line that would give this JSON file as jq output:\r\n```\r\n{\r\n  &quot;components&quot;: {\r\n     &quot;component1&quot;: [\r\n      ],\r\n     &quot;component2&quot;: [\r\n      ],\r\n     &quot;component3&quot;: [\r\n      ]\r\n   }\r\n}\r\n```\r\nMany thanks for your support\r\nBest Regards.\r\n",
        "link": "https://stackoverflow.com/questions/60622466/merge-json-files-concatenate-into-a-single-dict-json-file",
        "title": "Merge json files - Concatenate into a single dict json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1583863788,
                "last_edit_date": 1583863788,
                "creation_date": 1583862720,
                "answer_id": 60623285,
                "question_id": 60623116,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you&#39;re looking for `select` and addition operator (`+`).\r\n```\r\n.plays[].tasks[]\r\n| select(.hosts | has(&quot;192.169.1.70&quot;))\r\n| .task + .hosts.&quot;192.169.1.70&quot;\r\n```\r\n[REPL demo](https://jqplay.org/s/Ym6NF5gwFh)",
                "title": "How do I extract by key in an object, on a sibling?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583902010,
        "creation_date": 1583862028,
        "last_edit_date": 1583902010,
        "question_id": 60623116,
        "body_markdown": "How can I use **jq** to qualify filters on just some key values and reshape a hierarchy?\r\n\r\n### this is the input, from an Ansible log:\r\n\r\n(the log format was by setting env variable `ANSIBLE_STDOUT_CALLBACK=json`)\r\n\r\nI want to associate the `name` with the `msg`, but only for host `192.169.1.170`.\r\n\r\n\r\n````\r\n{\r\n    &quot;plays&quot;: [\r\n        {\r\n            &quot;tasks&quot;: [\r\n                {\r\n                    &quot;hosts&quot;: {\r\n                        &quot;192.169.1.70&quot;: {\r\n                            &quot;msg&quot;: &quot;inventory_hostname:192.169.1.70:&quot;\r\n                        },\r\n                        &quot;dontcare&quot;: {\r\n                            &quot;msg&quot;: &quot;dont want to see this:&quot;\r\n                        }\r\n                    },\r\n                    &quot;task&quot;: {\r\n                        &quot;name&quot;: &quot;debug inventory_hostname&quot;\r\n                    }\r\n                },\r\n                {\r\n                    &quot;hosts&quot;: {\r\n                        &quot;192.169.1.70&quot;: {\r\n                            &quot;msg&quot;: &quot;All items completed&quot;\r\n                        }\r\n                    },\r\n                    &quot;task&quot;: {\r\n                        &quot;name&quot;: &quot;install system-level components&quot;\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n\r\n````\r\n\r\n### desired output:\r\n\r\n\r\n````\r\n{\r\n  &quot;name&quot;: &quot;debug inventory_hostname&quot;,\r\n  &quot;msg&quot;: &quot;inventory_hostname:192.169.1.70:&quot;\r\n},\r\n{\r\n  &quot;name&quot;: &quot;install system-level components&quot;,\r\n  &quot;msg&quot;: &quot;All items completed&quot;\r\n}\r\n\r\n````\r\n\r\nI can extract some data, but I can&#39;t nest the sibling host msg, and I can&#39;t limit my search to just my host of interest, `192.169.1.70`:\r\n\r\n`jq &#39;.plays[] | .tasks[] | .task,.hosts&#39; ansible.json`\r\n\r\n````\r\n{\r\n  &quot;name&quot;: &quot;debug inventory_hostname&quot;\r\n}\r\n{\r\n  &quot;192.169.1.70&quot;: {\r\n    &quot;msg&quot;: &quot;inventory_hostname:192.169.1.70:&quot;\r\n  },\r\n  &quot;dontcare&quot;: {\r\n    &quot;msg&quot;: &quot;dont want to see this:&quot;\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;install system-level components&quot;\r\n}\r\n{\r\n  &quot;192.169.1.70&quot;: {\r\n    &quot;msg&quot;: &quot;All items completed&quot;\r\n  }\r\n}\r\n\r\n````\r\n\r\nWhenever I try something to qualify the hosts key I want, `.hosts[&quot;192.169.1.170&quot;]` or `.hosts.192.169.1.170` or `.hosts{&quot;192.169.1.170&quot;}`, `.hosts(&quot;192.169.1.170&quot;)`, I get either `null` or compile errors.  Most of the sample jq code concerns filtering arrays, not accessing hashmaps/dictionaries.\r\n\r\nAnd, how would I grab the sibling data for the name and bring in the same object, as above?",
        "link": "https://stackoverflow.com/questions/60623116/how-do-i-extract-by-key-in-an-object-on-a-sibling",
        "title": "How do I extract by key in an object, on a sibling?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 214932,
                    "reputation": 17434,
                    "user_id": 469210,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/592987f474ee562a63b8391e2e2b3c18?s=256&d=identicon&r=PG",
                    "display_name": "borrible",
                    "link": "https://stackoverflow.com/users/469210/borrible"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1583935820,
                "post_id": 60637859,
                "comment_id": 107279792,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1583939921,
                "creation_date": 1583939921,
                "answer_id": 60639286,
                "question_id": 60637859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -n &#39;[inputs]&#39; &lt;in.jsonl &gt;out.json\r\n```\r\n\r\n...or, as [suggested by @borrible](https://stackoverflow.com/questions/60637859/convert-sequence-of-json-objects-to-json-array#comment107279792_60637859):\r\n\r\n```\r\njq --slurp . &lt;in.jsonl &gt;out.json\r\n```",
                "title": "Convert sequence of JSON lines (JSONL) to JSON array"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1583947871,
                "creation_date": 1583947871,
                "answer_id": 60641566,
                "question_id": 60637859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the task at hand, using jq&#39;s &quot;slurp&quot; option or `[inputs]` entails a potentially huge waste of resources.  \r\n\r\nA trivial but efficient solution can be implemented in awk as follows:\r\n```\r\nawk &#39;BEGIN {print &quot;[&quot;;} NF==0{next;} n==&quot;&quot; {print;n++;next;} {print &quot;,&quot;; print;} END {print &quot;]&quot;}&#39;\r\n```\r\nAn equivalent efficient solution in jq is possible using `foreach` and `inputs`, and is left as an exercise.\r\n",
                "title": "Convert sequence of JSON lines (JSONL) to JSON array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1748934154,
                "creation_date": 1748934154,
                "answer_id": 79650764,
                "question_id": 60637859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alternatively with `sed`:\r\n\r\n```\r\necho [; sed &#39;$!s/$/,/&#39; input.jsonl; echo ]\r\n```\r\n\r\nor from stdin:\r\n\r\n```\r\ncat input.jsonl | ( echo [; sed &#39;$!s/$/,/&#39;; echo ] )\r\n```\r\n\r\nHere the `$!` in `sed` operates on all line except the last one: https://stackoverflow.com/questions/947404/sed-line-range-all-but-the-last-line",
                "title": "Convert sequence of JSON lines (JSONL) to JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1748934154,
        "creation_date": 1583935350,
        "last_edit_date": 1584090767,
        "question_id": 60637859,
        "body_markdown": "I have a file where each line is a JSON object. I&#39;d like to convert the file to a JSON array.\r\n\r\nThe file looks something like this:\r\n\r\n    {&quot;address&quot;:&quot;email1@foo.bar.com&quot;, &quot;topic&quot;:&quot;Some topic.&quot;}\r\n    {&quot;address&quot;:&quot;email2@foo.bar.com&quot;, &quot;topic&quot;:&quot;Another topic.&quot;}\r\n    {&quot;address&quot;:&quot;email3@foo.bar.com&quot;, &quot;topic&quot;:&quot;Yet another topic.&quot;}\r\n\r\nI&#39;m using bash and jq.\r\n\r\nI tried \r\n\r\n    jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1]&#39; my_file\r\n\r\nBut that just treats each line as a string creating a JSON array of strings.\r\n\r\n    [\r\n      &quot;{\\&quot;address\\&quot;:\\&quot;email1@foo.bar.com\\&quot;, \\&quot;topic\\&quot;:\\&quot;Some topic.\\&quot;}&quot;,\r\n      &quot;{\\&quot;address\\&quot;:\\&quot;email2@foo.bar.com\\&quot;, \\&quot;topic\\&quot;:\\&quot;Another topic.\\&quot;}&quot;,\r\n      &quot;{\\&quot;address\\&quot;:\\&quot;email3@foo.bar.com\\&quot;, \\&quot;topic\\&quot;:\\&quot;Yet another topic.\\&quot;}&quot;\r\n    ]\r\n\r\n\r\nI&#39;d like to have:\r\n\r\n    [\r\n      {&quot;address&quot;:&quot;email1@foo.bar.com&quot;, &quot;topic&quot;:&quot;Some topic.&quot;},\r\n      {&quot;address&quot;:&quot;email2@foo.bar.com&quot;, &quot;topic&quot;:&quot;Another topic.&quot;},\r\n      {&quot;address&quot;:&quot;email3@foo.bar.com&quot;, &quot;topic&quot;:&quot;Yet another topic.&quot;}\r\n    ]\r\n",
        "link": "https://stackoverflow.com/questions/60637859/convert-sequence-of-json-lines-jsonl-to-json-array",
        "title": "Convert sequence of JSON lines (JSONL) to JSON array"
    },
    {
        "tags": [
            "json",
            "jq",
            "inner-product"
        ],
        "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": 1583953956,
                "post_id": 60642449,
                "comment_id": 107289694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1583953212,
                "last_edit_date": 1583953212,
                "creation_date": 1583952789,
                "answer_id": 60642745,
                "question_id": 60642449,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A one-liner solution:\r\n\r\n    reduce .apps[] as $x (0; . + ($x | .memory * .instances))\r\n\r\nOr more elegantly:\r\n\r\n    def sigma(s): reduce s as $x (0; . + $x);\r\n\r\n    sigma(.apps[] | .memory * .instances)",
                "title": "jq sum and multiply values to get an aggregate"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584015188,
        "creation_date": 1583951424,
        "last_edit_date": 1584015188,
        "question_id": 60642449,
        "body_markdown": "Given the following JSON, is there a way to get the aggregated memory (sum of all memory values multiplied by the number of instances in each case) with a `jq` query?\r\n\r\n\r\n    {\r\n      &quot;apps&quot;: [\r\n        {\r\n          &quot;memory&quot;: 512,\r\n          &quot;instances&quot;: 3\r\n        },\r\n        {\r\n          &quot;memory&quot;: 256,\r\n          &quot;instances&quot;: 1\r\n        },\r\n        {\r\n          &quot;memory&quot;: 128,\r\n          &quot;instances&quot;: 6\r\n        },\r\n        {\r\n          &quot;memory&quot;: 1024,\r\n          &quot;instances&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n\r\nIn this example it should perform the following operation:\r\n\r\n    512*3 + 256*1 + 128*6 + 1024*2\r\nso it should give me `4608` in total.\r\n\r\nJust for the record, I am using command line `jq` in CentOS8:\r\n\r\n    jq --version\r\n    jq-1.5\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60642449/jq-sum-and-multiply-values-to-get-an-aggregate",
        "title": "jq sum and multiply values to get an aggregate"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "makefile",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1583958123,
                "creation_date": 1583958123,
                "answer_id": 60643902,
                "question_id": 60643862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i think it means `.ami_id_packer` rather than `ami_id_packer` assume your json looks something like \r\n\r\n```\r\n{\r\n&quot;ami_id_packer&quot;: ...\r\n}\r\n```\r\n\r\nplus since you are in Makefile, $ needs to be escaped, it should be `$$ami`",
                "title": "Interpolate JQ variables in make file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583959494,
        "creation_date": 1583957879,
        "last_edit_date": 1583959494,
        "question_id": 60643862,
        "body_markdown": "I&#39;m using this command to replace jq variables with shell variables but getting this error \r\n\r\n    jq: error: ami_id_packer/0 is not defined at &lt;top-level&gt;, line 1:\r\n\r\nI&#39;m using this code \r\n\r\n    replace :=  `cat terraform/terraform.tfvars.json | jq -c --arg ami &quot;33&quot; &#39;.ami_id_packer=$ami&#39; ` set_ami:\r\n\t\t\t@echo $(replace)\r\n\r\nthe same command is working fine when I run it in bash, I&#39;m messing my head around it from a very long time it would be great if someone from the community can help.\r\n\r\nThanks in Advance\r\n",
        "link": "https://stackoverflow.com/questions/60643862/interpolate-jq-variables-in-make-file",
        "title": "Interpolate JQ variables in make file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1583975990,
                "post_id": 60646268,
                "comment_id": 107296285,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1583976724,
                "creation_date": 1583976724,
                "answer_id": 60646493,
                "question_id": 60646268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on the detailed requirements, you will probably want something like:\r\n\r\n    .recordset[0] | .rowsAffected[0] | .size\r\n\r\n",
                "title": "How to parse the json object to get &quot;size&quot; value from first object itself as mentioned in attached image"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1583997913,
        "creation_date": 1583974282,
        "last_edit_date": 1583997913,
        "question_id": 60646268,
        "body_markdown": "[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/GmG7T.png\r\nI want to get value from first object like size in below pic.\r\n",
        "link": "https://stackoverflow.com/questions/60646268/how-to-parse-the-json-object-to-get-size-value-from-first-object-itself-as-men",
        "title": "How to parse the json object to get &quot;size&quot; value from first object itself as mentioned in attached image"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1584003194,
                "creation_date": 1584003194,
                "answer_id": 60650503,
                "question_id": 60650347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    select(.requested_reviewers != [])",
                "title": "How to use jq to not show a json data if a field is an empty array?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1584003925,
                "last_edit_date": 1584003925,
                "creation_date": 1584003450,
                "answer_id": 60650565,
                "question_id": 60650347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;select(.requested_reviewers | length &gt; 0)&#39;\r\n```\r\n\r\nhttps://jqplay.org/s/Cw-nbWwmjz",
                "title": "How to use jq to not show a json data if a field is an empty array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1584003925,
        "creation_date": 1584002465,
        "last_edit_date": 1584002937,
        "question_id": 60650347,
        "body_markdown": "I have some github data in json format like so:\r\n\r\n\r\n    \r\n\r\n```\r\n{\r\n  &quot;id&quot;: 18535,\r\n  &quot;node_id&quot;: &quot;MDExhN0M8877883&quot;,\r\n  &quot;number&quot;: 747,\r\n  &quot;state&quot;: &quot;closed&quot;,\r\n  &quot;locked&quot;: false,\r\n  &quot;title&quot;: &quot;Generate cordova protos&quot;,\r\n  &quot;user&quot;: {\r\n    &quot;login&quot;: &quot;Superhacker&quot;\r\n  },\r\n  &quot;body&quot;: &quot;Simple PR&quot;,\r\n  &quot;created_at&quot;: &quot;2018-05-02T07:43:39Z&quot;,\r\n  &quot;updated_at&quot;: &quot;2018-07-21T02:09:14Z&quot;,\r\n  &quot;closed_at&quot;: &quot;2018-05-02T07:54:56Z&quot;,\r\n  &quot;merge_commit_sha&quot;: &quot;4bf92c0332c66999999b6c0a766e&quot;,\r\n  &quot;assignee&quot;: null,\r\n  &quot;assignees&quot;: [],\r\n  &quot;requested_reviewers&quot;: [],\r\n  &quot;requested_teams&quot;: [],\r\n  &quot;labels&quot;: [],\r\n  &quot;milestone&quot;: null,\r\n  &quot;draft&quot;: false,\r\n  &quot;author_association&quot;: &quot;CONTRIBUTOR&quot;\r\n}\r\n```\r\nI want to NOT showing the json strings when the `requested_reviewers` is empty. \r\n\r\nI have tried several ways\r\n\r\n\r\n1. `echo &lt;the json string above&gt; | jq &#39;.requested_reviewers | select(. != &quot;&quot;)`\r\n\r\nIt shows `[]`\r\n\r\n\r\n\r\n2. `echo &lt;the json string above&gt; | jq &#39;.requested_reviewers | select(! empty)`\r\n\r\nIt gave a syntax error.\r\n\r\n\r\n\r\n3. `echo &lt;the json string above&gt; | jq &#39;.requested_reviewers | select(. != empty)`\r\n\r\nNow `jq` does not print out anything as I wanted.\r\n\r\nBut if I feed a json with non empty `requested_reviewers`, it also does not print anything.\r\n\r\nBesides I don&#39;t want to just print out the field. I want to be able to see the entire json string. \r\n\r\nHow can I achieve my goal with `jq`?\r\n\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60650347/how-to-use-jq-to-not-show-a-json-data-if-a-field-is-an-empty-array",
        "title": "How to use jq to not show a json data if a field is an empty array?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584032997,
                "creation_date": 1584032997,
                "answer_id": 60658831,
                "question_id": 60658461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; for example the first 2\r\n \r\n    .clients |= .[0:2]\r\n\r\nwhich can be abbreviated to: \r\n\r\n    .clients |= .[:2]",
                "title": "jq: Extract the first elements of a list within an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584032997,
        "creation_date": 1584031418,
        "question_id": 60658461,
        "body_markdown": "Suppose I have a JSON file, with one object like this:\r\n\r\n```\r\n{\r\n  &quot;title&quot;: &quot;List of clients&quot;,\r\n  &quot;year&quot;: 2020,\r\n  &quot;clients&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;C0&quot;,\r\n      &quot;address&quot;: &quot;A0&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;C1&quot;,\r\n      &quot;address&quot;: &quot;A1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;C2&quot;,\r\n      &quot;address&quot;: &quot;A2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;C3&quot;,\r\n      &quot;address&quot;: &quot;A4&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;C4&quot;,\r\n      &quot;address&quot;: &quot;A5&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nand I want the **same** object (with all members, whatever they are, there could be more, there could be less), but only **the first n clients**, for example the first 2.\r\n\r\nHow should I express that with jq?\r\n",
        "link": "https://stackoverflow.com/questions/60658461/jq-extract-the-first-elements-of-a-list-within-an-object",
        "title": "jq: Extract the first elements of a list within an object"
    },
    {
        "tags": [
            "arrays",
            "query-optimization",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1584040182,
                "last_edit_date": 1584040182,
                "creation_date": 1584036050,
                "answer_id": 60659597,
                "question_id": 60659110,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In three lines:\r\n```\r\n.[]\r\n| [.foo] + (.bar[]|[.])\r\n| @csv\r\n\r\n```\r\n\r\nor maybe less obscurely:\r\n```\r\n.[]\r\n| .bar[] as $bar\r\n| [.foo, $bar] \r\n| @csv\r\n```",
                "title": "jq condensing sub array permutation query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1584040182,
        "creation_date": 1584034113,
        "question_id": 60659110,
        "body_markdown": "I intend to extract a csv with a row for each sub array item. \r\nGiven a json array with a sub array. e.g. like this one:\r\n\r\n    [\r\n      {\r\n         &quot;foo&quot;: 108, \r\n         &quot;bar&quot;: [&quot;a&quot;,&quot;b&quot;]\r\n      },\r\n      {   \r\n         &quot;foo&quot;: 201, \r\n         &quot;bar&quot;: [&quot;c&quot;,&quot;d&quot;]\r\n      }\r\n    ] \r\n\r\n\r\nIt is possible to fetch the data by utilizing an intermediate object. \r\n\r\n    .[] | { &quot;y&quot;: .foo,  &quot;x&quot;: .bar[] }| [.y,.x]  | @csv\r\n\r\n\r\nhttps://jqplay.org/s/922RlkbFNA\r\n\r\n\r\nBut I&#39;d like to express it in a less elaborate form. \r\nHowever the following does not work :( :  \r\n\r\n    .[] | [ (.foo,  .bar[]) ]  | @csv\r\n\r\n\r\n*PS: I struggle to find a fitting headline*",
        "link": "https://stackoverflow.com/questions/60659110/jq-condensing-sub-array-permutation-query",
        "title": "jq condensing sub array permutation query"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1584041402,
                "creation_date": 1584041402,
                "answer_id": 60660743,
                "question_id": 60660059,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;[.games[] | select(.files[] | contains(&quot;ogv&quot;))] | unique | .[]&#39; foo.json\r\n```\r\nor, since what I really want is just the `id`,\r\n```\r\njq -r &#39;[.games[] | select(.files[] | contains(&quot;ogv&quot;)) | .id] | unique | .[]&#39; foo.json\r\n```",
                "title": "Selecting an element based on a search of a subelement array returns the element once for each matching item in the array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1584338315,
                "last_edit_date": 1584338315,
                "creation_date": 1584090509,
                "answer_id": 60667607,
                "question_id": 60660059,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `any` would be more efficient than relying on `unique`. E.g.\r\n\r\n    jq -r &#39;.games[] | select(any(.files[]; test(&quot;ogv&quot;)))&#39;",
                "title": "Selecting an element based on a search of a subelement array returns the element once for each matching item in the array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1584338315,
        "creation_date": 1584038231,
        "question_id": 60660059,
        "body_markdown": "Given the json\r\n```\r\n{ &quot;games&quot;: [\r\n{\r\n    &quot;id&quot;:1,\r\n    &quot;files&quot;: [ &quot;foo.mp4&quot; ]\r\n},\r\n{\r\n    &quot;id&quot;:2,\r\n    &quot;files&quot;: [ &quot;foo.ogv&quot;,  &quot;bar.ogv&quot; ]\r\n},\r\n{\r\n    &quot;id&quot;:3,\r\n    &quot;files&quot;: [ &quot;bar.ogv&quot; ]\r\n}\r\n]}\r\n```\r\nand the command\r\n`jq -r &#39;.games[] | select(.files[] | contains(&quot;ogv&quot;))&#39; foo.json`, `json` outputs an element once for every time it matches `ogv` in the subelement array. How do I get `jq` to output each matching element only once?",
        "link": "https://stackoverflow.com/questions/60660059/selecting-an-element-based-on-a-search-of-a-subelement-array-returns-the-element",
        "title": "Selecting an element based on a search of a subelement array returns the element once for each matching item in the array"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "packer"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584040752,
                "creation_date": 1584040752,
                "answer_id": 60660602,
                "question_id": 60660305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following jq program:\r\n\r\n```\r\n.artifact_id\r\n| [ split(&quot;,&quot;)[] \r\n    | (split(&quot;:&quot;) | {(.[0]): .[1] } ) ]\r\n| add    \r\n```\r\n\r\nproduces:\r\n\r\n```\r\n{\r\n  &quot;ca-central-1&quot;: &quot;ami-02420*&quot;,\r\n  &quot;us-east-1&quot;: &quot;ami-06a4*&quot;,\r\n  &quot;us-west-1&quot;: &quot;ami-078cf*&quot;\r\n}\r\n```\r\n",
                "title": "Using jq to build another json object with this string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1584040752,
        "creation_date": 1584039427,
        "question_id": 60660305,
        "body_markdown": "Currently I am using packer to copy AWS AMIs to multiple regions and then spitting out the AMI IDs using Packer&#39;s post processor: https://packer.io/docs/post-processors/manifest.html.\r\n\r\nHere is a sample of the output:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n  &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n  &quot;build_time&quot;: 1584037532,\r\n  &quot;files&quot;: null,\r\n  &quot;artifact_id&quot;: &quot;ca-central-1:ami-02420*,us-east-1:ami-06a4*,us-west-1:ami-078cf*&quot;,\r\n  &quot;packer_run_uuid&quot;: &quot;&quot;,\r\n  &quot;custom_data&quot;: null\r\n}\r\n```\r\n\r\n\r\nI&#39;d like to use jq to be able to build a new json in this format:\r\n```\r\n{\r\n  &quot;ca-central&quot;: &quot;ami_id&quot;,\r\n  &quot;us-east-1&quot;: &quot;ami_id&quot;,\r\n  &quot;us-west-1&quot;: &quot;ami_id&quot;\r\n}\r\n```\r\n\r\nWould anyone be able to help me with the jq command to use for this?",
        "link": "https://stackoverflow.com/questions/60660305/using-jq-to-build-another-json-object-with-this-string",
        "title": "Using jq to build another json object with this string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584064660,
                "creation_date": 1584064660,
                "answer_id": 60663918,
                "question_id": 60663178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no need to use shell looping.  That is, everything can be done using jq.\r\n\r\nFor example, using the invocation:\r\n\r\n    jq -f users-logins.jq --argfile users users.json logins.json\r\n\r\nwhere users-logins.jq contains:\r\n\r\n```\r\nINDEX($users[]; .id) as $udict\r\n| map( if $udict[.user_id] then . + $udict[.user_id] else empty end)\r\n| map( {user_id, time, email, first_name, last_name} )\r\n```\r\nthe output using the sample inputs would be:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;user_id&quot;: &quot;5ce722b803b54f03f745cdf45d579920&quot;,\r\n    &quot;time&quot;: &quot;2019-10-29T20:03:18.894006Z&quot;,\r\n    &quot;email&quot;: &quot;foo@gmail.com&quot;,\r\n    &quot;first_name&quot;: &quot;John&quot;,\r\n    &quot;last_name&quot;: &quot;Doe&quot;\r\n  }\r\n]\r\n```",
                "title": "Match and merge from multiple files with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584064660,
        "creation_date": 1584056816,
        "last_edit_date": 1584060015,
        "question_id": 60663178,
        "body_markdown": "I have a directory with a bunch of &quot;logins&quot; json files like this:\r\n\r\n```\r\n[\r\n {\r\n    &quot;user_id&quot;: &quot;5ce722b803b54f03f745cdf45d579920&quot;,\r\n    &quot;time&quot;: &quot;2019-10-29T20:03:18.894006Z&quot;\r\n  },\r\n  {\r\n    &quot;user_id&quot;: &quot;5ce722b858f3e80e6e85aad3113a1665&quot;,\r\n    &quot;time&quot;: &quot;2019-10-29T20:11:32.4843Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nIn another directory I have a bunch of &quot;users&quot; json files like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;5ce722b803b54f03f745cdf45d579920&quot;,\r\n    &quot;email&quot;: &quot;foo@gmail.com&quot;,\r\n    &quot;first_name&quot;: &quot;John&quot;,\r\n    &quot;last_name&quot;: &quot;Doe&quot;,\r\n    &quot;enabled&quot;: true,\r\n    &quot;created_at&quot;: &quot;2019-06-13T17:07:17.2925Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2019-06-13T17:15:20.903085Z&quot;,\r\n    &quot;groups&quot;: {\r\n      &quot;count&quot;: 1,\r\n      &quot;shortlist&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;5d0282c5d5d6063286140e864a0c6506&quot;,\r\n          &quot;name&quot;: &quot;cool users&quot;,\r\n          &quot;description&quot;: &quot;cool users&quot;,\r\n          &quot;locked&quot;: true\r\n        }\r\n      ]\r\n    },\r\n    &quot;avatar&quot;: &quot;&quot;,\r\n    &quot;role_id&quot;: &quot;5d0282c488bba9ebc62df8b3c38571a9&quot;,\r\n    &quot;company_uid&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;5d0284fdec62d47039e7119013b0aa2c&quot;,\r\n    &quot;email&quot;: &quot;bar@gmail.com&quot;,\r\n    &quot;first_name&quot;: &quot;Jane&quot;,\r\n    &quot;last_name&quot;: &quot;Doe&quot;,\r\n    &quot;enabled&quot;: true,\r\n    &quot;created_at&quot;: &quot;2019-06-13T17:16:45.210018Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2019-06-13T17:16:45.210018Z&quot;,\r\n    &quot;groups&quot;: {\r\n      &quot;count&quot;: 1,\r\n      &quot;shortlist&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;5d0282c5d5d6063286140e864a0c6506&quot;,\r\n          &quot;name&quot;: &quot;cool users&quot;,\r\n          &quot;description&quot;: &quot;cool users&quot;,\r\n          &quot;locked&quot;: true\r\n        }\r\n      ]\r\n    },\r\n    &quot;avatar&quot;: &quot;&quot;,\r\n    &quot;role_id&quot;: &quot;5d0282c488bba9ebc62df8b3c38571a9&quot;,\r\n    &quot;company_uid&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\nWhat I&#39;m trying to do with jq is:\r\n\r\n 1. For each `user_id` in the &quot;Logins&quot; files, I want to find a matching `id` in the &quot;Users&quot; files.\r\n 2. I want to merge those two object together.\r\n\r\nThe intended outcome is another json file(s), which contains login and corresponding user data. As a bonus, I only want the email first and last name from &quot;Users&quot;.\r\n\r\nEnd result would be something like this:\r\n\r\n```\r\n[\r\n {\r\n    &quot;user_id&quot;: &quot;5ce722b803b54f03f745cdf45d579920&quot;,\r\n    &quot;time&quot;: &quot;2019-10-29T20:03:18.894006Z&quot;,\r\n    &quot;email&quot;: &quot;foo@gmail.com&quot;,\r\n    &quot;first_name&quot;: &quot;John&quot;,\r\n    &quot;last_name&quot;: &quot;Doe&quot;\r\n  }\r\n}\r\n```\r\n\r\nI&#39;ve tried variations of the below, but end up with what looks like an infinite loop or something. I know my for loops are wrong, just not sure how to work with multiple files like this.\r\n\r\n```\r\nlastlogins=&quot;/last10/*.json&quot;\r\nusers=&quot;/users/*.json&quot;\r\nfor ll in $lastlogins; do\r\n  for user in $users; do\r\n    userid=$(jq -r &#39;.[].user_id&#39; $ll)\r\n    jq -c --arg userid &quot;$userid&quot; &#39;.[] | select(.id == $userid)&#39; $user\r\n  done\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/60663178/match-and-merge-from-multiple-files-with-jq",
        "title": "Match and merge from multiple files with jq"
    },
    {
        "tags": [
            "json",
            "templates",
            "jinja2",
            "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": 1584095395,
                "post_id": 60667763,
                "comment_id": 107337354,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584107092,
                "creation_date": 1584107092,
                "answer_id": 60671622,
                "question_id": 60667763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be impractical to implement a jq-only solution, but jq can certainly help, e.g. the following works in your case:\r\n```\r\njq &#39;.clients[] |= (.webOrigins = &quot;{{clients.\\(.clientId).webOrigins}}&quot;)&#39; |\r\n    sed &#39;/&quot;webOrigins&quot;:/ { s/&quot;[{][{]/{{/; s/[}][}]&quot;$/}}/; }&#39;\r\n```",
                "title": "jq command to replace array value with non-json value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584177878,
        "creation_date": 1584091162,
        "last_edit_date": 1584177878,
        "question_id": 60667763,
        "body_markdown": "I need a jq command to replace array values with non-json standard values i.e. in the following json input I need to replace the &quot;webOrigins&quot; array values with a non-json value, which is a Jinja2 template variable replacement as per the second json block below.\r\n\r\n**Input** (`example.json`)\r\n\r\n    {\r\n       &quot;clients&quot;: [\r\n         {\r\n            &quot;clientId&quot;: &quot;abc&quot;,\r\n            &quot;webOrigins&quot;: [ &quot;/&quot;, &quot;/api&quot; ]\r\n         },\r\n         {\r\n            &quot;clientId&quot;: &quot;xyz&quot;,\r\n            &quot;webOrigins&quot;: [ ]\r\n         }\r\n       ]\r\n    }\r\n\r\n**Desired Output**\r\n\r\n    {\r\n       &quot;clients&quot;: [\r\n         {\r\n            &quot;clientId&quot;: &quot;abc&quot;,\r\n            &quot;webOrigins&quot;: {{clients.abc.webOrigins}}\r\n         },\r\n         {\r\n            &quot;clientId&quot;: &quot;xyz&quot;,\r\n            &quot;webOrigins&quot;: {{clients.xyz.webOrigins}}\r\n         }\r\n       ]\r\n    }\r\n\r\nMy current attempt of shell script calling jq to loop through the input json and replace with template variable is this \r\n\r\n    for clientId in $(jq -r &#39;.clients[] | .clientId&#39; example.json)\r\n    do\r\n      jq &#39;(.clients[] | select(.clientId == &quot;&#39;${clientId}&#39;&quot;) | .webOrigins) |= {{ clients[&#39;\\&#39;${clientId}\\&#39;&#39;].webOrigins | default([]) }}&#39; example.json &gt; tmp.j2; mv -f tmp.j2 example.json\r\n    done\r\n\r\nBut fails with the error:\r\n\r\n    jq: error: syntax error, unexpected &#39;{&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    (.clients[] | select(.clientId == &quot;abc&quot;) | .webOrigins) |= {{ clients[&#39;abc&#39;].webOrigins | default([]) }}                                                            \r\n    jq: 1 compile error\r\n\r\nOf course if I add double quotes around the template variable to make the replacement variable valid json the script works but I need the value to not have quotes.",
        "link": "https://stackoverflow.com/questions/60667763/jq-command-to-replace-array-value-with-non-json-value",
        "title": "jq command to replace array value with non-json value"
    },
    {
        "tags": [
            "shell",
            "jenkins",
            "jenkins-pipeline",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584128164,
                "last_edit_date": 1584128164,
                "creation_date": 1584124670,
                "answer_id": 60675661,
                "question_id": 60671276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    script{\r\n        sh &quot;&quot;&quot;\r\n            upload_id=\\$(cat output_file.json | jq -r &#39;.upload_id&#39;)\r\n            echo &quot;\\${upload_id}&quot;\r\n        &quot;&quot;&quot;\r\n    }\r\n\r\nYou need to modify the script block as above and also need to escape $-sign to avoid this error. But dont know where you are using `upload_id` and where you are getting `release_url`",
                "title": "How to pass jq parameter in Jenkinsfile"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1584128913,
        "creation_date": 1584105688,
        "last_edit_date": 1584128913,
        "question_id": 60671276,
        "body_markdown": "Please help me to resolve this issue.\r\nI am getting issue while executing below commands under steps in jenkinsfile.\r\n\r\nsteps{\r\n\r\n                sh &quot;curl -s -L https://github.com/stedolan/jq/releases/download/jq-1.5/jq-linux64 &gt; ./jq&quot;\r\n                sh &quot;chmod +x ./jq&quot;\r\n                sh &quot;curl -X POST --header &#39;Content-Type: application/json&#39; --header &#39;Accept: application/json&#39; --header &#39;X-API-Token: xxxxxxxx&#39; &#39;https://api.appcenter.ms/v0.1/apps/raghu/${app_name}/release_uploads&#39; &gt;&gt; output_file.json&quot;\r\n                sh &quot;cat output_file.json&quot;\r\n                \r\n                script{\r\n                    upload_id=$(cat output_file.json | jq -r &#39;.upload_id&#39;)\r\n                    echo &quot;${upload_id}&quot;\r\n                }\r\n            }\r\n\r\n[Pipeline] End of Pipeline\r\ngroovy.lang.MissingPropertyException: No such property: output for class: groovy.lang.Binding\r\n\tat groovy.lang.Binding.getVariable(Binding.java:63)\r\n\tat org.jenkinsci.plugins.scriptsecurity.sandbox.groovy.SandboxInterceptor.onGetProperty(SandboxInterceptor.java:264)\r\n\tat org.kohsuke.groovy.sandbox.impl.Checker$6.call(Checker.java:289)\r\n\tat org.kohsuke.groovy.sandbox.impl.Checker.checkedGetProperty(Checker.java:293)\r\n\tat org.kohsuke.groovy.sandbox.impl.Checker.checkedGetProperty(Checker.java:269)\r\n\tat org.kohsuke.groovy.sandbox.impl.Checker.checkedGetProperty(Checker.java:269)\r\n\tat org.kohsuke.groovy.sandbox.impl.Checker.checkedGetProperty(Checker.java:269)\r\n\tat com.cloudbees.groovy.cps.sandbox.SandboxInvoker.getProperty(SandboxInvoker.java:29)\r\n\tat com.cloudbees.groovy.cps.impl.PropertyAccessBlock.rawGet(PropertyAccessBlock.java:20)\r\n\tat WorkflowScript.run(WorkflowScript:25)\r\n\tat ___cps.transform___(Native Method)\r\n\tat com.cloudbees.groovy.cps.impl.PropertyishBlock$ContinuationImpl.get(PropertyishBlock.java:74)\r\n\tat com.cloudbees.groovy.cps.LValueBlock$GetAdapter.receive(LValueBlock.java:30)\r\n\tat com.cloudbees.groovy.cps.impl.PropertyishBlock$ContinuationImpl.fixName(PropertyishBlock.java:66)\r\n\tat sun.reflect.GeneratedMethodAccessor8670.invoke(Unknown Source)\r\n\tat sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)\r\n\tat java.lang.reflect.Method.invoke(Method.java:498)\r\n\tat com.cloudbees.groovy.cps.impl.ContinuationPtr$ContinuationImpl.receive(ContinuationPtr.java:72)\r\n\tat com.cloudbees.groovy.cps.impl.ConstantBlock.eval(ConstantBlock.java:21)\r\n\tat com.cloudbees.groovy.cps.Next.step(Next.java:83)\r\n\tat com.cloudbees.groovy.cps.Continuable$1.call(Continuable.java:174)\r\n\tat com.cloudbees.groovy.cps.Continuable$1.call(Continuable.java:163)\r\n\tat org.codehaus.groovy.runtime.GroovyCategorySupport$ThreadCategoryInfo.use(GroovyCategorySupport.java:129)\r\n\tat org.codehaus.groovy.runtime.GroovyCategorySupport.use(GroovyCategorySupport.java:268)\r\n\tat com.cloudbees.groovy.cps.Continuable.run0(Continuable.java:163)\r\n\tat org.jenkinsci.plugins.workflow.cps.SandboxContinuable.access$101(SandboxContinuable.java:34)\r\n\tat org.jenkinsci.plugins.workflow.cps.SandboxContinuable.lambda$run0$0(SandboxContinuable.java:59)\r\n\tat org.jenkinsci.plugins.scriptsecurity.sandbox.groovy.GroovySandbox.runInSandbox(GroovySandbox.java:136)\r\n\tat org.jenkinsci.plugins.workflow.cps.SandboxContinuable.run0(SandboxContinuable.java:58)\r\n\tat org.jenkinsci.plugins.workflow.cps.CpsThread.runNextChunk(CpsThread.java:174)\r\n\tat org.jenkinsci.plugins.workflow.cps.CpsThreadGroup.run(CpsThreadGroup.java:347)\r\n\tat org.jenkinsci.plugins.workflow.cps.CpsThreadGroup.access$200(CpsThreadGroup.java:93)\r\n\tat org.jenkinsci.plugins.workflow.cps.CpsThreadGroup$2.call(CpsThreadGroup.java:259)\r\n\tat org.jenkinsci.plugins.workflow.cps.CpsThreadGroup$2.call(CpsThreadGroup.java:247)\r\n\tat org.jenkinsci.plugins.workflow.cps.CpsVmExecutorService$2.call(CpsVmExecutorService.java:64)\r\n\tat java.util.concurrent.FutureTask.run(FutureTask.java:266)\r\n\tat hudson.remoting.SingleLaneExecutorService$1.run(SingleLaneExecutorService.java:131)\r\n\tat jenkins.util.ContextResettingExecutorService$1.run(ContextResettingExecutorService.java:28)\r\n\tat jenkins.security.ImpersonatingExecutorService$1.run(ImpersonatingExecutorService.java:59)\r\n\tat java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)\r\n\tat java.util.concurrent.FutureTask.run(FutureTask.java:266)\r\n\tat java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)\r\n\tat java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)\r\n\tat java.lang.Thread.run(Thread.java:748)\r\nFinished: FAILURE",
        "link": "https://stackoverflow.com/questions/60671276/how-to-pass-jq-parameter-in-jenkinsfile",
        "title": "How to pass jq parameter in Jenkinsfile"
    },
    {
        "tags": [
            "json",
            "jq",
            "karate"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584118497,
                "last_edit_date": 1584118497,
                "creation_date": 1584118087,
                "answer_id": 60674328,
                "question_id": 60673463,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My answer makes use of what the manual describes as a &quot;shortcut syntax&quot; for [object construction](https://stedolan.github.io/jq/manual/v1.6/#TypesandValues). It creates two objects and then adds them together. The square brackets at the beginning and end put the output in an array.\r\n\r\n    jq &#39;[.[].elements[].steps[]|{name} + (.result|{status})]&#39;\r\n\r\n[![enter image description here][1]][1]\r\n\r\nThis is equivalent, for what it&#39;s worth. The definition of `map(x)` [in the manual](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions) explains why.\r\n\r\n    jq &#39;map(.elements[].steps[]|{name} + (.result|{status}))&#39;\r\n\r\n[![ic][2]][2]\r\n\r\n\r\n  [1]: https://i.sstatic.net/FBAwY.png\r\n  [2]: https://i.sstatic.net/o6NSF.png",
                "title": "jq: transform json results from karate surfire-reports getting a simpler steps status"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584122481,
        "creation_date": 1584114383,
        "last_edit_date": 1592644375,
        "question_id": 60673463,
        "body_markdown": "I was wondering how it was possible to transform json using jq, but I didn&#39;t quite understand how to get a desired result; starting from this content (which I get from a [surfire-report](https://maven.apache.org/surefire/maven-surefire-report-plugin/) by a [karate](https://github.com/intuit/karate) test automation):\n## The source:\n``` json\n[\n    {\n        &quot;line&quot;: 1,\n        &quot;elements&quot;: [\n            {\n                &quot;line&quot;: 3,\n                &quot;name&quot;: &quot;&quot;,\n                &quot;description&quot;: &quot;&quot;,\n                &quot;type&quot;: &quot;background&quot;,\n                &quot;keyword&quot;: &quot;Background&quot;,\n                &quot;steps&quot;: [\n                    {\n                        &quot;name&quot;: &quot;url &#39;http:\\/\\/be-service.test.svc.cluster.local\\/SVC_INTERFACE_V1&#39;&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 256885,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;*&quot;,\n                        &quot;line&quot;: 4,\n                        &quot;doc_string&quot;: {\n                            &quot;content_type&quot;: &quot;&quot;,\n                            &quot;value&quot;: &quot;10:54:12.945 karate.env&quot;,\n                            &quot;line&quot;: 4\n                        }\n                    }\n                ]\n            },\n            {\n                &quot;line&quot;: 9,\n                &quot;name&quot;: &quot;&quot;,\n                &quot;description&quot;: &quot;&quot;,\n                &quot;id&quot;: &quot;SoapEsbBackEnd1&quot;,\n                &quot;type&quot;: &quot;scenario&quot;,\n                &quot;keyword&quot;: &quot;Scenario&quot;,\n                &quot;steps&quot;: [\n                    {\n                        &quot;name&quot;: &quot;request&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 92526141,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;Given&quot;,\n                        &quot;line&quot;: 11,\n                        &quot;doc_string&quot;: {\n                            &quot;content_type&quot;: &quot;&quot;,\n                            &quot;value&quot;: &quot;&lt;soap:Envelope xmlns:soap=\\&quot;http:\\/\\/schemas.xmlsoap.org\\/soap\\/envelope\\/\\&quot;&gt;\\n   &lt;\\/soap:Envelope&gt;&quot;,\n                            &quot;line&quot;: 11\n                        }\n                    },\n                    {\n                        &quot;name&quot;: &quot;header Content-Type = &#39;application\\/soap+xml; charset=utf-8&#39;&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 1834255,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;And&quot;,\n                        &quot;line&quot;: 74\n                    },\n                    {\n                        &quot;name&quot;: &quot;method post&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 102112259,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;When&quot;,\n                        &quot;line&quot;: 76,\n                        &quot;doc_string&quot;: {\n                            &quot;content_type&quot;: &quot;&quot;,\n                            &quot;value&quot;: &quot;10:54:13.140 request:\\n1 &gt; POST http:\\/\\/be-service.test.svc.cluster.local\\/SVC_INTERFACE_V1&quot;,\n                            &quot;line&quot;: 76\n                        }\n                    },\n                    {\n                        &quot;name&quot;: &quot;status 200&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 49328,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;Then&quot;,\n                        &quot;line&quot;: 77\n                    },\n                    {\n                        &quot;name&quot;: &quot;def envelope = response[&#39;soapenv:Envelope&#39;]&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 591138,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;*&quot;,\n                        &quot;line&quot;: 79\n                    },\n                    {\n                        &quot;name&quot;: &quot;def body = response[&#39;soapenv:Envelope&#39;][&#39;_&#39;][&#39;soapenv:Body&#39;]&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 470207,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;*&quot;,\n                        &quot;line&quot;: 81\n                    },\n                    {\n                        &quot;name&quot;: &quot;def result = body[&#39;NS1:monitoraggioJBossResponse&#39;]._&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 354671,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;*&quot;,\n                        &quot;line&quot;: 83\n                    },\n                    {\n                        &quot;name&quot;: &quot;def esito = result.esito&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 296656,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;*&quot;,\n                        &quot;line&quot;: 87\n                    },\n                    {\n                        &quot;name&quot;: &quot;match esito == &#39;ERR&#39;&quot;,\n                        &quot;result&quot;: {\n                            &quot;duration&quot;: 249327,\n                            &quot;status&quot;: &quot;passed&quot;\n                        },\n                        &quot;match&quot;: {\n                            &quot;location&quot;: &quot;karate&quot;,\n                            &quot;arguments&quot;: []\n                        },\n                        &quot;keyword&quot;: &quot;*&quot;,\n                        &quot;line&quot;: 89\n                    }\n                ],\n                &quot;tags&quot;: [\n                    {\n                        &quot;name&quot;: &quot;@esb&quot;,\n                        &quot;line&quot;: 6\n                    },\n                    {\n                        &quot;name&quot;: &quot;@esb_svc_monitoraggio_ko&quot;,\n                        &quot;line&quot;: 6\n                    },\n                    {\n                        &quot;name&quot;: &quot;@ko&quot;,\n                        &quot;line&quot;: 6\n                    }\n                ]\n            }\n        ],\n        &quot;name&quot;: &quot;features\\/esb-be1.feature&quot;,\n        &quot;description&quot;: &quot;esb be first request&quot;,\n        &quot;id&quot;: &quot;esb-be-first-request&quot;,\n        &quot;keyword&quot;: &quot;Feature&quot;,\n        &quot;uri&quot;: &quot;features\\/esb-be1.feature&quot;\n    }\n]\n```\n\n## &#160;What I want to get: \n``` json\n    [\n        { &quot;name&quot;:  &quot;url &#39;http://be-service.test.svc.cluster.local/SVC_INTERFACE_V1&#39;&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;request&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;header Content-Type = &#39;application/soap+xml; charset=utf-8&#39;&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;method post&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;status 200&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;def envelope = response[&#39;soapenv:Envelope&#39;]&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;def body = response[&#39;soapenv:Envelope&#39;][&#39;_&#39;][&#39;soapenv:Body&#39;]&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;def result = body[&#39;NS1:monitoraggioJBossResponse&#39;]._&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;def esito = result.esito&quot; , &quot;status&quot;: &quot;passed&quot; },\n        { &quot;name&quot;:  &quot;match esito == &#39;ERR&#39;&quot; , &quot;status&quot;: &quot;passed&quot; }\n    ]\n```\n## &#160;What I&#39;ve tried since now: \n``` sh \n$ cat $JSON_FILE | jq &#39;.[].elements[].steps[].name,.[].elements[].steps[].result.status&#39;                                                   \n&quot;url &#39;http://be-service.test.svc.cluster.local/SVC_INTERFACE_V1&#39;&quot;\n&quot;request&quot;\n&quot;header Content-Type = &#39;application/soap+xml; charset=utf-8&#39;&quot;\n&quot;method post&quot;\n&quot;status 200&quot;\n&quot;def envelope = response[&#39;soapenv:Envelope&#39;]&quot;\n&quot;def body = response[&#39;soapenv:Envelope&#39;][&#39;_&#39;][&#39;soapenv:Body&#39;]&quot;\n&quot;def result = body[&#39;NS1:monitoraggioJBossResponse&#39;]._&quot;\n&quot;def esito = result.esito&quot;\n&quot;match esito == &#39;ERR&#39;&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n&quot;passed&quot;\n```\n\n",
        "link": "https://stackoverflow.com/questions/60673463/jq-transform-json-results-from-karate-surfire-reports-getting-a-simpler-steps-s",
        "title": "jq: transform json results from karate surfire-reports getting a simpler steps status"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1584120362,
                "creation_date": 1584120362,
                "answer_id": 60674855,
                "question_id": 60673754,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the -r flag.\r\n\r\nHere is the explanation in [the manual](https://stedolan.github.io/jq/manual/v1.6/#Invokingjq):\r\n\r\n&gt; `--raw-output / -r`: With this option, if the filter&#39;s result is a string then it will be written directly to standard output rather than\r\n&gt; being formatted as a JSON string with quotes.\r\n\r\n    jq -r &#39;.events[] | [.mydata.id, .mydata.account] | @csv&#39;\r\n\r\nYields\r\n\r\n    &quot;123456&quot;,&quot;21234&quot;\r\n    &quot;123457&quot;,&quot;21234&quot;\r\n\r\n",
                "title": "Why is JQ treating arrays as a single field in CSV output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1584120362,
        "creation_date": 1584115674,
        "question_id": 60673754,
        "body_markdown": "With the following input file:\r\n\r\n```\r\n{\r\n  &quot;events&quot;: [\r\n    {\r\n      &quot;mydata&quot;: {\r\n        &quot;id&quot;: &quot;123456&quot;,\r\n        &quot;account&quot;: &quot;21234&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;mydata&quot;: {\r\n        &quot;id&quot;: &quot;123457&quot;,\r\n        &quot;account&quot;: &quot;21234&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhen I run it through this JQ filter, \r\n\r\n`jq &quot;.events[] | [.mydata.id, .mydata.account]&quot;  events.json`\r\n\r\nI get a set of arrays:\r\n\r\n```\r\n[\r\n  &quot;123456&quot;,\r\n  &quot;21234&quot;\r\n]\r\n[\r\n  &quot;123457&quot;,\r\n  &quot;21234&quot;\r\n]\r\n```\r\n\r\nWhen I put this output through the @csv filter to create CSV output:\r\n\r\n\r\n`jq &quot;.events[] | [.mydata.id, .mydata.account] | @csv&quot;  events.json`\r\n\r\n I get a CSV file with one record per row:\r\n\r\n```\r\n&quot;\\&quot;123456\\&quot;,\\&quot;21234\\&quot;&quot;\r\n&quot;\\&quot;123457\\&quot;,\\&quot;21234\\&quot;&quot;\r\n```\r\n\r\nI would like CSV file with two records per row, like this:\r\n\r\n```\r\n&quot;123456&quot;,&quot;21234&quot;\r\n&quot;123457&quot;,&quot;21234&quot;\r\n```\r\n\r\nWhat am I doing wrong?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60673754/why-is-jq-treating-arrays-as-a-single-field-in-csv-output",
        "title": "Why is JQ treating arrays as a single field in CSV output?"
    },
    {
        "tags": [
            "json",
            "pandas",
            "export-to-csv",
            "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": 1584122619,
                "post_id": 60674867,
                "comment_id": 107349715,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17969095,
                    "reputation": 65,
                    "user_id": 13058320,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c51da95e296cf353a346fc9a2c4e2263?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jd258b",
                    "link": "https://stackoverflow.com/users/13058320/jd258b"
                },
                "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": 1584122796,
                "post_id": 60674867,
                "comment_id": 107349776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1584125267,
                "last_edit_date": 1584125267,
                "creation_date": 1584124681,
                "answer_id": 60675665,
                "question_id": 60674867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\ndef expand($keys):\r\n    . as $in\r\n    | reduce $keys[] as $k ( [{}];\r\n        map(. + { \r\n            ($k): ($in[$k] | if type == &quot;array&quot; then .[] else . end)\r\n        })\r\n    ) | .[];\r\n(.[0] | keys_unsorted) as $h\r\n| $h, (.[] | expand($h) | [.[$h[]]]) | @csv\r\n```\r\n&lt;sup&gt;[REPL demo](https://jqplay.org/s/vbXq4wojZE)&lt;/sup&gt;",
                "title": "Json to CSV issues"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584128805,
                "last_edit_date": 1584128805,
                "creation_date": 1584128352,
                "answer_id": 60676378,
                "question_id": 60674867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple jq solution which is also a bit more generic than needed here:\r\n\r\n```\r\n[&quot;Name&quot;, &quot;Car&quot;, &quot;Location&quot;],\r\n(.[]\r\n | [.Name] + (.Car|..|scalars|[.]) + (.Location|..|scalars|[.]))\r\n| @csv\r\n```",
                "title": "Json to CSV issues"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1584312058,
        "creation_date": 1584120413,
        "last_edit_date": 1584312058,
        "question_id": 60674867,
        "body_markdown": "I am using pandas to normalize some json data.  I am getting stuck on this issue when more than 1 section is either an object or an array.\r\n\r\nIf i use the record_path on Car it breaks on the second.  \r\n\r\nAny pointers on how to get something like this to create a line in the csv per Car and per Location?\r\n\r\n\r\n\r\n```\r\n[\r\n    {\r\n        &quot;Name&quot;: &quot;John Doe&quot;,\r\n        &quot;Car&quot;: [\r\n            &quot;Car1&quot;,\r\n            &quot;Car2&quot;\r\n        ],\r\n        &quot;Location&quot;: &quot;Texas&quot;\r\n    },\r\n    {\r\n        &quot;Name&quot;: &quot;Jane Roe&quot;,\r\n        &quot;Car&quot;: &quot;Car1&quot;,            \r\n        &quot;Location&quot;: [\r\n            &quot;Illinois&quot;,\r\n            &quot;Kansas&quot;\r\n        ]\r\n    }\r\n]\r\n\r\n```\r\n\r\nHere is the output\r\n```\r\nName,Car,Location\r\nJohn Doe,&quot;[&#39;Car1&#39;, &#39;Car2&#39;]&quot;,Texas\r\nJane Roe,Car1,&quot;[&#39;Illinois&#39;, &#39;Kansas&#39;]&quot;\r\n```\r\n\r\n\r\nHere is the code:\r\n```\r\nwith open(&#39;file.json&#39;) as data_file:\r\n    data = json.load(data_file)\r\ndf = pd.io.json.json_normalize(data, errors=&#39;ignore&#39;)\r\n```\r\n\r\n\r\nWould like it to end up like this:\r\n```\r\nName,Car,Location\r\nJohn Doe,Car1,Texas\r\nJohn Doe,Car2,Texas\r\nJane Roe,Car1,Illinois\r\nJane Roe,Car1,Kansas\r\n```\r\n\r\nThe answers worked great until I ran into a json file with extra data. This what a file looks like with the extra values.\r\n```\r\n{\r\n    Customers:[\r\n    {\r\n        &quot;Name&quot;: &quot;John Doe&quot;,\r\n        &quot;Car&quot;: [\r\n            &quot;Car1&quot;,\r\n            &quot;Car2&quot;\r\n        ],\r\n        &quot;Location&quot;: &quot;Texas&quot;,\r\n        &quot;Repairs: {\r\n            &quot;RepairLocations&quot;: {\r\n                &quot;RepairsCompleted&quot;:[\r\n                    &quot;Fix1&quot;,\r\n                    &quot;Fix2&quot;\r\n                ]\r\n            }\r\n        }\r\n    },\r\n    {\r\n        &quot;Name&quot;: &quot;Jane Roe&quot;,\r\n        &quot;Car&quot;: &quot;Car1&quot;,            \r\n        &quot;Location&quot;: [\r\n            &quot;Illinois&quot;,\r\n            &quot;Kansas&quot;\r\n        ]\r\n    }\r\n]\r\n}\r\n```\r\n\r\nHere is what I am going for. I think its the most readable in this format but anything would at least should all the keys\r\n```\r\nName,Car,Location,Repairs:RepairLocation\r\nJohn Doe,Car1,Texas,RepairsCompleted:Fix1\r\nJohn Doe,Car1,Texas,RepairsCompleted:Fix2\r\nJohn Doe,Car2,Texas,RepairsCompleted:Fix1\r\nJohn Doe,Car2,Texas,RepairsCompleted:Fix2\r\nJane Roe,Car1,Illinois,\r\nJane Roe,Car1,Kansas,\r\n```\r\n\r\nAny suggestions on getting this second part?",
        "link": "https://stackoverflow.com/questions/60674867/json-to-csv-issues",
        "title": "Json to CSV issues"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1584301807,
                "creation_date": 1584301807,
                "answer_id": 60696981,
                "question_id": 60696717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply have your `select()` refer to the nested field, that will return the whole top-level element.\n\n    $ cat testerr.json | jq &#39;select(.tunnel.source | contains (&quot;1.5.55.&quot;))&#39;\n    {\n      &quot;circuitIdNum&quot;: 1227,\n      &quot;description&quot;: &quot;9287-customer:vpn-2001227-(R2-Loopback0)&quot;,\n      &quot;interfaceId&quot;: &quot;1041&quot;,\n      &quot;ipv4&quot;: {\n        &quot;aclEgress&quot;: &quot;rot-out&quot;,\n        &quot;addr&quot;: &quot;23.77.175.253/31&quot;,\n        &quot;bgpNeighbor&quot;: &quot;21.44.175.252&quot;\n      },\n      &quot;loadInterval&quot;: 30,\n      &quot;remoteRouter&quot;: &quot;R2-Loopback0&quot;,\n      &quot;shortName&quot;: &quot;rot&quot;,\n      &quot;tunnel&quot;: {\n        &quot;destination&quot;: &quot;22.22.18.15&quot;,\n        &quot;source&quot;: &quot;1.5.55.5&quot;\n      }\n    }\n",
                "title": "jq return all arrays that match one field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1584304687,
        "creation_date": 1584300066,
        "last_edit_date": 1584304687,
        "question_id": 60696717,
        "body_markdown": "I am trying to grab all the arrays that match an element but am having trouble returning everything. \r\n\r\n\r\nData\r\n```\r\ncat testerr.json | jq .&#39;&#39;\r\n\r\n{\r\n  &quot;circuitIdNum&quot;: 1226,\r\n  &quot;description&quot;: &quot;9287-customer:vpn-2001226-(R1-Loopback0)&quot;,\r\n  &quot;interfaceId&quot;: &quot;1040&quot;,\r\n  &quot;ipv4&quot;: {\r\n    &quot;aclEgress&quot;: &quot;rot-out&quot;,\r\n    &quot;addr&quot;: &quot;55.44.53.191/31&quot;,\r\n    &quot;bgpNeighbor&quot;: &quot;33.567.53.190&quot;\r\n  },\r\n  &quot;loadInterval&quot;: 30,\r\n  &quot;remoteRouter&quot;: &quot;R1-Loopback0&quot;,\r\n  &quot;shortName&quot;: &quot;rot&quot;,\r\n  &quot;tunnel&quot;: {\r\n    &quot;destination&quot;: &quot;94.252.78.14&quot;,\r\n    &quot;source&quot;: &quot;66.52.5.4&quot;\r\n  }\r\n}\r\n{\r\n  &quot;circuitIdNum&quot;: 1227,\r\n  &quot;description&quot;: &quot;9287-customer:vpn-2001227-(R2-Loopback0)&quot;,\r\n  &quot;interfaceId&quot;: &quot;1041&quot;,\r\n  &quot;ipv4&quot;: {\r\n    &quot;aclEgress&quot;: &quot;rot-out&quot;,\r\n    &quot;addr&quot;: &quot;23.77.175.253/31&quot;,\r\n    &quot;bgpNeighbor&quot;: &quot;21.44.175.252&quot;\r\n  },\r\n  &quot;loadInterval&quot;: 30,\r\n  &quot;remoteRouter&quot;: &quot;R2-Loopback0&quot;,\r\n  &quot;shortName&quot;: &quot;rot&quot;,\r\n  &quot;tunnel&quot;: {\r\n    &quot;destination&quot;: &quot;22.22.18.15&quot;,\r\n    &quot;source&quot;: &quot;1.5.55.5&quot;\r\n  }\r\n}\r\n```\r\n\r\nThis kind of works but only provides Destination and Source. \r\n\r\n\r\n```\r\ncat testerr.json | jq .&#39;tunnel | select(.source | contains (&quot;1.5.55.&quot;))&#39;\r\n\r\n{\r\n  &quot;destination&quot;: &quot;22.22.18.15&quot;,\r\n  &quot;source&quot;: &quot;1.5.55.5&quot;\r\n}\r\n```\r\n\r\nInstead of only reply the tunnel section I want it to return the full array. \r\n\r\n```\r\n{\r\n  &quot;circuitIdNum&quot;: 1227,\r\n  &quot;description&quot;: &quot;9287-customer:vpn-2001227-(R2-Loopback0)&quot;,\r\n  &quot;interfaceId&quot;: &quot;1041&quot;,\r\n  &quot;ipv4&quot;: {\r\n    &quot;aclEgress&quot;: &quot;rot-out&quot;,\r\n    &quot;addr&quot;: &quot;23.77.175.253/31&quot;,\r\n    &quot;bgpNeighbor&quot;: &quot;21.44.175.252&quot;\r\n  },\r\n  &quot;loadInterval&quot;: 30,\r\n  &quot;remoteRouter&quot;: &quot;R2-Loopback0&quot;,\r\n  &quot;shortName&quot;: &quot;rot&quot;,\r\n  &quot;tunnel&quot;: {\r\n    &quot;destination&quot;: &quot;22.22.18.15&quot;,\r\n    &quot;source&quot;: &quot;1.5.55.5&quot;\r\n  }\r\n}\r\n```\r\n\r\nMy attempts are all over the place atm. Im not sure how to call the top level and search elements a few levels in. Thanks",
        "link": "https://stackoverflow.com/questions/60696717/jq-return-all-arrays-that-match-one-field",
        "title": "jq return all arrays that match one field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1584356527,
                "last_edit_date": 1584356527,
                "creation_date": 1584353379,
                "answer_id": 60703974,
                "question_id": 60703876,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select objects where `.overview.title` contains `Env Vars`, extract `.uuid` out of them, make arrays of UUID and title pairs, and feed them to `@csv` filter.\r\n```\r\n.[]\r\n| .overview.title as $t \r\n| select($t | index(&quot;Env Vars&quot;)) \r\n| [.uuid, $t]\r\n| @csv\r\n```\r\nNote that you need to specify `-r`/`--raw-output` flag on the command line for jq to yield valid CSV.",
                "title": "select object by nested field&#39;s value and extract a first level field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584358411,
        "creation_date": 1584352992,
        "last_edit_date": 1584358411,
        "question_id": 60703876,
        "body_markdown": "I have the following json:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;uuid&quot;: &quot;rvbrc7y6a5d6xpz37av534zv3a&quot;,\r\n    &quot;templateUuid&quot;: &quot;101&quot;,\r\n    &quot;trashed&quot;: &quot;N&quot;,\r\n    &quot;createdAt&quot;: &quot;2018-07-26T05:48:51Z&quot;,\r\n    &quot;updatedAt&quot;: &quot;2018-07-27T00:26:35Z&quot;,\r\n    &quot;changerUuid&quot;: &quot;Y7WX2RXJ35GCLLERQA2T74CKNM&quot;,\r\n    &quot;itemVersion&quot;: 3,\r\n    &quot;vaultUuid&quot;: &quot;awn3jry3oo55xdcfgs7bnlyioa&quot;,\r\n    &quot;overview&quot;: {\r\n      &quot;ps&quot;: 0,\r\n      &quot;title&quot;: &quot;Env Vars - CSP 1&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;uuid&quot;: &quot;xtf3vdsnw5ardldytwh6edihzu&quot;,\r\n    &quot;templateUuid&quot;: &quot;001&quot;,\r\n    &quot;trashed&quot;: &quot;N&quot;,\r\n    &quot;createdAt&quot;: &quot;2013-10-15T01:29:57Z&quot;,\r\n    &quot;updatedAt&quot;: &quot;2016-11-22T20:57:47Z&quot;,\r\n    &quot;changerUuid&quot;: &quot;Y7WX2RXJ35GCLLERQA2T74CKNM&quot;,\r\n    &quot;itemVersion&quot;: 1,\r\n    &quot;vaultUuid&quot;: &quot;qmorozyspqhb26kr4z7nbt7hpy&quot;,\r\n    &quot;overview&quot;: {\r\n      &quot;URLs&quot;: [\r\n        {\r\n          &quot;u&quot;: &quot;https://example.com&quot;\r\n        }\r\n      ],\r\n      &quot;ainfo&quot;: &quot;*******@gmail.com&quot;,\r\n      &quot;ps&quot;: 72,\r\n      &quot;title&quot;: &quot;https://example.com&quot;,\r\n      &quot;url&quot;: &quot;https://example.com&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThere are another ~500 objects in the array which I need to parse. Three of the objects have an `.overview.title` which contains the string &quot;Env Vars&quot;.\r\n\r\nIm trying to use `jq` to get the output to look like:\r\n\r\n```text\r\n&quot;rvbrc7y6a5d6xpz37av534zv3a&quot;, &quot;Env Vars - CSP 1&quot;\r\n&quot;another uuid&quot;, &quot;Env Vars - CSP 2&quot;\r\n&quot;yet another uuid&quot;, &quot;Env vars - CSP n&quot;\r\n```\r\n\r\nIve tried a few different things including:\r\n\r\n- `cat list.json | jq -c &#39;.[] | .uuid, .overview.title&#39;`\r\n\r\n- `cat list.json | jq -c &#39;.[].overview.title | select(contains(&quot;Env Var&quot;))&#39;`\r\n\r\nAnd a lot of different variations of the above.\r\nThis is the first time Ive had to use `jq` in anger so it&#39;s pretty new to me. The `jq` doco wasn&#39;t very helpful tbh.\r\n\r\nWould like to buy a clue please.",
        "link": "https://stackoverflow.com/questions/60703876/select-object-by-nested-fields-value-and-extract-a-first-level-field",
        "title": "select object by nested field&#39;s value and extract a first level field"
    },
    {
        "tags": [
            "shell",
            "variables",
            "jenkins-pipeline",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16987534,
                    "reputation": 39,
                    "user_id": 12287941,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/761a98871a4ec51ace47cb26e2e781c2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Raghunath Dhara",
                    "link": "https://stackoverflow.com/users/12287941/raghunath-dhara"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584364955,
                "post_id": 60706792,
                "comment_id": 107406702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10259402,
                    "reputation": 28176,
                    "user_id": 7571258,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/fBP6e.png?s=256",
                    "display_name": "zett42",
                    "link": "https://stackoverflow.com/users/7571258/zett42"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584370021,
                "post_id": 60706792,
                "comment_id": 107409220,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16987534,
                    "reputation": 39,
                    "user_id": 12287941,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/761a98871a4ec51ace47cb26e2e781c2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Raghunath Dhara",
                    "link": "https://stackoverflow.com/users/12287941/raghunath-dhara"
                },
                "reply_to_user": {
                    "account_id": 10259402,
                    "reputation": 28176,
                    "user_id": 7571258,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/fBP6e.png?s=256",
                    "display_name": "zett42",
                    "link": "https://stackoverflow.com/users/7571258/zett42"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584381045,
                "post_id": 60706792,
                "comment_id": 107414354,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10259402,
                    "reputation": 28176,
                    "user_id": 7571258,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/fBP6e.png?s=256",
                    "display_name": "zett42",
                    "link": "https://stackoverflow.com/users/7571258/zett42"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584381894,
                "post_id": 60706792,
                "comment_id": 107414649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16987534,
                    "reputation": 39,
                    "user_id": 12287941,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/761a98871a4ec51ace47cb26e2e781c2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Raghunath Dhara",
                    "link": "https://stackoverflow.com/users/12287941/raghunath-dhara"
                },
                "reply_to_user": {
                    "account_id": 10259402,
                    "reputation": 28176,
                    "user_id": 7571258,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/fBP6e.png?s=256",
                    "display_name": "zett42",
                    "link": "https://stackoverflow.com/users/7571258/zett42"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584383419,
                "post_id": 60706792,
                "comment_id": 107415236,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584367330,
                "creation_date": 1584367330,
                "answer_id": 60707404,
                "question_id": 60706792,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can easily do this intrinsically in Jenkins Pipeline to avoid all of the issues with subprocess execution. First, read in and parse the JSON file:\r\n\r\n    upload_info = readJSON(file: &#39;output_file.json&#39;)\r\n\r\nThen, you can access the returned values in the assigned `upload_info` Map normally:\r\n\r\n    upload_id = upload_info[&#39;upload_id&#39;]",
                "title": "Not getting variable value in jenkinsfile"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1584598977,
                "last_edit_date": 1584598977,
                "creation_date": 1584384306,
                "answer_id": 60711607,
                "question_id": 60706792,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language: lang-groovy --&gt;\r\n\r\nI would strongly recommend to go with [Matt&#39;s answer][1], because it is the cleanest way.\r\n\r\nAnyway, there are situations where there is no other choice than to use the shell, so here is the shell way:\r\n\r\n    script {\r\n        def upload_id = sh label: &#39;&#39;, \r\n                           script: &#39;echo $(cat output_file.json | jq -r \\&#39;.upload_id\\&#39;)&#39;, \r\n                           returnStdout: true\n        upload_id = upload_id.trim()  // remove extraneous whitespace\r\n        sh &quot;echo \\&quot;$upload_id\\&quot;&quot;\r\n    }\r\n\r\nI&#39;ve already linked to a more [detailed answer of mine](https://stackoverflow.com/a/60450130/7571258) but you were probably not getting it to work, because you are using a declarative pipeline. In declarative pipeline, you have to use a `script` block to be able to store return values of steps.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/60707404/7571258",
                "title": "Not getting variable value in jenkinsfile"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1584598977,
        "creation_date": 1584364870,
        "last_edit_date": 1584367456,
        "question_id": 60706792,
        "body_markdown": "I am using the below `Jenkinsfile`. It is printing the value of `upload_id` when it is executing with the `jq` command, but when printing the value it is showing `null`.\r\n\r\nPlease help me to fix this variable issue.\r\n\r\n    sh label: &#39;&#39;, script: &#39;upload_id=$(cat output_file.json | jq -r \\&#39;.upload_id\\&#39;)&#39;\r\n    sh &quot;echo \\&quot;$upload_id\\&quot;&quot;**\r\n\r\nOutput :\r\n&gt;[Pipeline] sh\r\ncat output_file.json\r\njq -r .upload_id\r\nupload_id=8f304c6d-804b-440a-xxxx**\r\n[Pipeline] sh\r\necho upload_id : null\r\nupload_id : null  \r\n[Pipeline] }",
        "link": "https://stackoverflow.com/questions/60706792/not-getting-variable-value-in-jenkinsfile",
        "title": "Not getting variable value in jenkinsfile"
    },
    {
        "tags": [
            "python",
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9732276,
                    "reputation": 18186,
                    "user_id": 7216865,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/X90W9.png?s=256",
                    "display_name": "Maurice Meyer",
                    "link": "https://stackoverflow.com/users/7216865/maurice-meyer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584369021,
                "post_id": 60707733,
                "comment_id": 107408735,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9545182,
                    "reputation": 29,
                    "user_id": 7091577,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/d6ad0763719a32423b39275ac09e15dd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chinchan",
                    "link": "https://stackoverflow.com/users/7091577/chinchan"
                },
                "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": 1584369123,
                "post_id": 60707733,
                "comment_id": 107408793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584369171,
                "post_id": 60707733,
                "comment_id": 107408814,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15663519,
                    "reputation": 2694,
                    "user_id": 11301900,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/379144423dcd4ee76202d0efeda9fdc7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AMC",
                    "link": "https://stackoverflow.com/users/11301900/amc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584393535,
                "post_id": 60707733,
                "comment_id": 107418954,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1584369886,
                "last_edit_date": 1584369886,
                "creation_date": 1584368952,
                "answer_id": 60707799,
                "question_id": 60707733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ditch python and use [tag:jq] instead.\r\n```\r\njq -rn --argjson in &quot;$DescribeProfession&quot; &#39;$in.Descriptions[].Name&#39;\r\n```\r\nor,\r\n```\r\njq -r &#39;.Descriptions[].Name&#39; &lt;&lt;&lt;$DescribeProfession\r\n```\r\nor with other alternative ways of feeding a string to a program&#39;s stdin.",
                "title": "Multiple values for a particular key - JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1584369084,
                "creation_date": 1584369084,
                "answer_id": 60707836,
                "question_id": 60707733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re printing the Name property `DescribeProfession[&#39;Descriptions&#39;][0][&#39;Name&#39;]` which means the first element from `&#39;Descriptions&#39;` array.\r\n\r\nYou should loop through the array and print all `DescribeProfession[&#39;Descriptions&#39;][i][&#39;Name&#39;]`",
                "title": "Multiple values for a particular key - JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584369369,
                "creation_date": 1584369369,
                "answer_id": 60707905,
                "question_id": 60707733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, you need to loop over all the elements of the `&quot;Descriptions&quot;` value. Second, you should pass the JSON as an argument, not interpolate it into the Python script.\r\n\r\n    python -c &#39;import json,sys; print(&quot;\\n&quot;.join(x[&quot;Name&quot;] for x in json.loads(sys.argv[1])[&quot;Descriptions&quot;]))&#39; &quot;$DescribeProfession&quot;\r\n\r\nPython is not a great choice for writing shell one-liners, though it&#39;s much simpler if you embed newlines into the argument.\r\n\r\n    python -c &#39;\r\n    import json, sys\r\n    d = json.loads(sys.argv[1])\r\n    for x in d[&quot;Descriptions&quot;]:\r\n      print(x[&quot;Name&quot;])\r\n    &#39; &quot;$DescribeProfession&quot;",
                "title": "Multiple values for a particular key - JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666425103,
        "creation_date": 1584368686,
        "last_edit_date": 1666425103,
        "question_id": 60707733,
        "body_markdown": "JSON Format:\r\n```\r\n{\r\n  &quot;Descriptions&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;Doctor&quot;,\r\n      &quot;AttributeDescriptions&quot;: [],\r\n      &quot;TypeName&quot;: &quot;Professional&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;Pilot&quot;,\r\n      &quot;AttributeDescriptions&quot;: [\r\n        {\r\n          &quot;AttributeValue&quot;: &quot;&quot;,\r\n          &quot;AttributeName&quot;: &quot;&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nAbove JSON value is assigned to a variable `DescribeProfession` in a shell script. \r\n\r\nMy intention is to list all the values of &quot;Name&quot; key. \r\nWhen I use the below python code, it only prints first value . ie., Doctor. But I need all the three values, \r\n```\r\nDoctor\r\nTeacher\r\nPilot\r\n```\r\n```\r\npython -c &quot;import json; DescribeProfession=json.loads(&#39;$(echo $DescribeProfession)&#39;); print(DescribeProfession[&#39;Descriptions&#39;][0][&#39;Name&#39;])\r\n```\r\nI&#39;m really new to Python scripting.Could you please help me to correct this python script to print all the values of key &quot;Name&quot; from JSON. ",
        "link": "https://stackoverflow.com/questions/60707733/multiple-values-for-a-particular-key-json",
        "title": "Multiple values for a particular key - JSON"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1584432015,
                "last_edit_date": 1584432015,
                "creation_date": 1584427837,
                "answer_id": 60717460,
                "question_id": 60715658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution can be obtained using the same technique shown in one of the answers to the [similar question you already asked][1].  The only difference is fulfilling your requirements in the case where the &quot;Repairs&quot; key does not exist:\r\n\r\n```\r\n[&quot;Name&quot;, &quot;Car&quot;, &quot;Location&quot;, &quot;Repairs:RepairLocation&quot;],\r\n(.[]\r\n | [.Name]\r\n    + (.Car|..|scalars|[.])\r\n    + (.Location|..|scalars|[.])\r\n    + (.Repairs|..|scalars\r\n       | [if . == null then . else &quot;RepairsCompleted:\\(.)&quot; end]) )\r\n| @csv\r\n```\r\n\r\n## Avoiding the repetition with a helper function\r\n\r\n```\r\ndef s: .. | scalars | [.];\r\n```\r\n```\r\n[&quot;Name&quot;, &quot;Car&quot;, &quot;Location&quot;, &quot;Repairs:RepairLocation&quot;],\r\n(.[]\r\n | [.Name] \r\n    + (.Car|s)\r\n    + (.Location|s) \r\n    + (.Repairs|s|map(if . == null then . else &quot;RepairsCompleted:\\(.)&quot; end)))\r\n| @csv\r\n```\r\n  [1]: https://stackoverflow.com/questions/60674867/json-to-csv-issues",
                "title": "JQ to CSV issues"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1584432043,
        "creation_date": 1584413758,
        "last_edit_date": 1584432043,
        "question_id": 60715658,
        "body_markdown": "I previously got some help on here for some jq to csv issues.  I ran into an issue where a few json files had some extra values that breaks the jq command\r\n\r\nHere is the json data.  The repairs section is what breaks the jq command\r\n```\r\n[\r\n    {\r\n        &quot;Name&quot;: &quot;John Doe&quot;,\r\n        &quot;Car&quot;: [\r\n            &quot;Car1&quot;,\r\n            &quot;Car2&quot;\r\n        ],\r\n        &quot;Location&quot;: &quot;Texas&quot;,\r\n        &quot;Repairs: {\r\n            &quot;RepairLocations&quot;: {\r\n                &quot;RepairsCompleted&quot;:[\r\n                    &quot;Fix1&quot;,\r\n                    &quot;Fix2&quot;\r\n                ]\r\n            }\r\n        }\r\n    },\r\n    {\r\n        &quot;Name&quot;: &quot;Jane Roe&quot;,\r\n        &quot;Car&quot;: &quot;Car1&quot;,            \r\n        &quot;Location&quot;: [\r\n            &quot;Illinois&quot;,\r\n            &quot;Kansas&quot;\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nHere is the command \r\n```\r\ndef expand($keys):\r\n    . as $in\r\n    | reduce $keys[] as $k ( [{}];\r\n        map(. + { \r\n            ($k): ($in[$k] | if type == &quot;array&quot; then .[] else . end)\r\n        })\r\n    ) | .[];\r\n(.[0] | keys_unsorted) as $h\r\n| $h, (.[] | expand($h) | [.[$h[]]]) | @csv\r\n```\r\n\r\nThis is the end result i am trying to get. This data isnt actual data.\r\n```\r\nName,Car,Location,Repairs:RepairLocation\r\nJohn Doe,Car1,Texas,RepairsCompleted:Fix1\r\nJohn Doe,Car1,Texas,RepairsCompleted:Fix2\r\nJohn Doe,Car2,Texas,RepairsCompleted:Fix1\r\nJohn Doe,Car2,Texas,RepairsCompleted:Fix2\r\nJane Roe,Car1,Illinois,\r\nJane Roe,Car1,Kansas,\r\n```\r\n\r\nAny advice on this would be great.  I am struggling to figure jq out",
        "link": "https://stackoverflow.com/questions/60715658/jq-to-csv-issues",
        "title": "JQ to CSV issues"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584449772,
                "last_edit_date": 1584449772,
                "creation_date": 1584442316,
                "answer_id": 60720854,
                "question_id": 60720039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`INDEX`](https://stedolan.github.io/jq/manual/v1.6/#SQL-StyleOperators):\r\n```\r\njq -n &#39;INDEX(inputs; .key) | map_values(del(.key))&#39; &quot;${file_names[@]}&quot;\r\n```",
                "title": "How to consolidate JSON records from multiple files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1584449772,
        "creation_date": 1584439348,
        "question_id": 60720039,
        "body_markdown": "I have a list of file names as shell variable and their contents like below\r\n\r\n    file_names=(&#39;one.json&#39; &#39;two.json&#39;)\r\n\r\none.json:\r\n\r\n    {\r\n      \t  &quot;key&quot;:&quot;k1&quot;,\r\n          &quot;host&quot;: &quot;..&quot;,\r\n          &quot;name&quot;: &quot;..&quot;    \r\n    }\r\n\r\ntwo.json:\r\n\r\n    {\r\n    \t  &quot;key&quot;:&quot;k2&quot;,\r\n          &quot;host&quot;: &quot;..&quot;,\r\n          &quot;name&quot;: &quot;..&quot;\r\n    }\r\n\r\nI want to create a consolidate file with all the contents from the above files. There can be more than 2 files. In the consolidate file the `key` value will become the outer level key of the JSON record. eg:\r\n\r\n    {\r\n    \t&quot;k1&quot;: {\r\n          &quot;host&quot;: &quot;..&quot;,\r\n          &quot;name&quot;: &quot;..&quot;   \r\n      \t},\r\n      \t&quot;k2&quot;: {\r\n          &quot;host&quot;: &quot;..&quot;,\r\n          &quot;name&quot;: &quot;..&quot;   \r\n        }\r\n    }\r\n\r\nHow can I achieve this using jq ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60720039/how-to-consolidate-json-records-from-multiple-files-using-jq",
        "title": "How to consolidate JSON records from multiple files using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 101994,
                    "reputation": 9734,
                    "user_id": 274030,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8fd910b4f7c7baabc22976dc6b29b744?s=256&d=identicon&r=PG",
                    "display_name": "Everett",
                    "link": "https://stackoverflow.com/users/274030/everett"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1584461525,
                "post_id": 60725881,
                "comment_id": 107441136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2406515,
                    "reputation": 3151,
                    "user_id": 2102831,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bef47f9d3de3728375b542a229ef7a5f?s=256&d=identicon&r=PG",
                    "display_name": "secghost",
                    "link": "https://stackoverflow.com/users/2102831/secghost"
                },
                "reply_to_user": {
                    "account_id": 101994,
                    "reputation": 9734,
                    "user_id": 274030,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8fd910b4f7c7baabc22976dc6b29b744?s=256&d=identicon&r=PG",
                    "display_name": "Everett",
                    "link": "https://stackoverflow.com/users/274030/everett"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584461845,
                "post_id": 60725881,
                "comment_id": 107441285,
                "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": 1584462194,
                "post_id": 60725881,
                "comment_id": 107441449,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2406515,
                    "reputation": 3151,
                    "user_id": 2102831,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bef47f9d3de3728375b542a229ef7a5f?s=256&d=identicon&r=PG",
                    "display_name": "secghost",
                    "link": "https://stackoverflow.com/users/2102831/secghost"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584462852,
                "post_id": 60725881,
                "comment_id": 107441784,
                "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": 1584463536,
                "post_id": 60725881,
                "comment_id": 107442140,
                "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": 1,
                "creation_date": 1584464103,
                "post_id": 60725881,
                "comment_id": 107442412,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2406515,
                    "reputation": 3151,
                    "user_id": 2102831,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bef47f9d3de3728375b542a229ef7a5f?s=256&d=identicon&r=PG",
                    "display_name": "secghost",
                    "link": "https://stackoverflow.com/users/2102831/secghost"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584464879,
                "post_id": 60725881,
                "comment_id": 107442784,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5868390,
                    "reputation": 23877,
                    "user_id": 4621513,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/uCfJK.png?s=256",
                    "display_name": "mkrieger1",
                    "link": "https://stackoverflow.com/users/4621513/mkrieger1"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584477577,
                "post_id": 60725881,
                "comment_id": 107447843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2406515,
                    "reputation": 3151,
                    "user_id": 2102831,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bef47f9d3de3728375b542a229ef7a5f?s=256&d=identicon&r=PG",
                    "display_name": "secghost",
                    "link": "https://stackoverflow.com/users/2102831/secghost"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584534818,
                "post_id": 60725881,
                "comment_id": 107464873,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1584537545,
                "last_edit_date": 1584537545,
                "creation_date": 1584464427,
                "answer_id": 60726952,
                "question_id": 60725881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes that the Front and Back objects are presented in that order on STDIN or in a file; with this assumption, the following program should be invoked with the -n command-line option.\r\n\r\n```\r\ninput as $front\r\n| input as $back\r\n| ($back|INDEX(.Back[]; .IP) | map_values({Host,Info})) as $dict\r\n| $front\r\n| .Front[]\r\n  |= reduce ($dict | keys_unsorted[]) as $k (.;\r\n       if (.Groups | contains($k)) then . + $dict[$k] else . end)\r\n\r\n```\r\n\r\nI’ve used `reduce` to iterate over the IP values as doing so provides flexibility in case you want to handle conflicts in some particular way.\r\n\r\n## Invocation\r\n\r\nOne possibility:\r\n\r\n    jq -n -f program.jq input.json\r\n\r\n",
                "title": "How to merge data within a JSON file using contains as the match?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1584537545,
        "creation_date": 1584460503,
        "last_edit_date": 1584535137,
        "question_id": 60725881,
        "body_markdown": "I have a text file that contains the following JSON output. I would like to be able to merge the data whenever &quot;IP&quot; is contained within Groups. I would like to use jq or sed/awk.  I am open to any other bash commands.\r\n\r\n    {&quot;Front&quot;:[\r\n    {&quot;Name&quot;:&quot;new.domain.com-80&quot;, &quot;Out&quot;:&quot;8.8.8.8&quot;, &quot;In&quot;:&quot;192.168.2.2:80&quot;, &quot;W Name&quot;:&quot;new.domain.com-80&quot;, &quot;Groups&quot;:&quot;192.168.3.29:80 192.168.3.30:80&quot;},\r\n    {&quot;Name&quot;:&quot;new.domain.com -443&quot;, &quot;Out&quot;:&quot;8.8.8.8&quot;, &quot;In&quot;:&quot;192.168.2.2:443&quot;, &quot;W Name&quot;:&quot;new.domain.com-443&quot;, &quot;Groups&quot;:&quot;192.168.3.29:443 192.168.3.30:443&quot;}\r\n    ]}\r\n    {&quot;Back&quot;:[\r\n    {&quot;REC&quot;:&quot;&quot;, &quot;IP&quot;:&quot;192.168.3.30&quot;, &quot;Host&quot;:&quot;new2.domain.com&quot;, &quot;Info&quot;:&quot;Worker5 MD: Data source - Owner: Q&quot;},\r\n    {&quot;REC&quot;:&quot;Q&quot;, &quot;IP&quot;:&quot;192.168.3.29&quot;, &quot;Host&quot;:&quot;new3.domain.com&quot;, &quot;Info&quot;:&quot;Worker5 MD: Data source - Owner: Q&quot;},\r\n    {&quot;REC&quot;:&quot;Q&quot;}\r\n    ]}\r\n\r\n \r\nIf IP is contained within Groups then add Host &amp; Info.\r\nWe can ignore REC\r\n \r\n\r\nExpected Output:\r\n\r\n\r\n    {&quot;Front&quot;:[\r\n    {&quot;Name&quot;:&quot;new.domain.com-80&quot;, &quot;Out&quot;:&quot;8.8.8.8&quot;, &quot;In&quot;:&quot;192.168.2.2:80&quot;, &quot;W Name&quot;:&quot;new.domain.com-80&quot;, &quot;Groups&quot;:&quot;192.168.3.29:80 192.168.3.30:80&quot;, &quot;Host&quot;:&quot;new2.domain.com,new3.domain.com&quot;, &quot;Info&quot;:&quot;Worker5 MD: Data source - Owner: Q,Worker5 MD: Data source - Owner: Q&quot;},\r\n    {&quot;Name&quot;:&quot;new.domain.com-443&quot;, &quot;Out&quot;:&quot;8.8.8.8&quot;, &quot;In&quot;:&quot;192.168.2.2:443&quot;, &quot;W Name&quot;:&quot;new.domain.com-443&quot;, &quot;Groups&quot;:&quot;192.168.3.29:443 192.168.3.30:443&quot;, &quot;Host&quot;:&quot;new2.domain.com,new3.domain.com&quot;, &quot;Info&quot;:&quot;Worker5 MD: Data source - Owner: Q,Worker5 MD: Data source - Owner: Q&quot;}\r\n    ]}",
        "link": "https://stackoverflow.com/questions/60725881/how-to-merge-data-within-a-json-file-using-contains-as-the-match",
        "title": "How to merge data within a JSON file using contains as the match?"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1584466591,
                "creation_date": 1584466591,
                "answer_id": 60727462,
                "question_id": 60727371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ already has a builtin for that\r\n```\r\njq -n env &gt; env.json\r\n```",
                "title": "output environment variables as key-value pairs in a JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584514876,
        "creation_date": 1584466231,
        "last_edit_date": 1584514876,
        "question_id": 60727371,
        "body_markdown": "It seems that with jq I would have to loop around for each variable and append this to a growing json file, but I would need to have variables on both the field name side and the value side?\r\n\r\nAny solutions or suggestions would be helpful.",
        "link": "https://stackoverflow.com/questions/60727371/output-environment-variables-as-key-value-pairs-in-a-json-object",
        "title": "output environment variables as key-value pairs in a JSON object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1584471992,
                "creation_date": 1584471992,
                "answer_id": 60728770,
                "question_id": 60727891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your case differs from [the one you found](https://stackoverflow.com/a/42428521/7839189) because you are putting objects into an array. Try this modification of Jeff Mercado&#39;s solution.\r\n\r\n    jq &#39;reduce .[] as $i ({}; .[$i.type] += [$i])&#39;",
                "title": "Use jq to convert an array to an object by non-unique keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586256614,
                "last_edit_date": 1586256614,
                "creation_date": 1586256077,
                "answer_id": 61078145,
                "question_id": 60727891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another possible way using `group_by()` on the `.type` field and then create the final result with `.type` as the key\r\n    \r\n    jq &#39;group_by(.type)[] | { (.[0].type) : . }&#39;\r\n\r\nThe only difference in this approach, is `group_by()` does a sort by the `.type` field before producing the result, so the order of keys will be different.\r\n",
                "title": "Use jq to convert an array to an object by non-unique keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1586256614,
        "creation_date": 1584468238,
        "question_id": 60727891,
        "body_markdown": "I have a JSON array like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Bo&quot;,\r\n    &quot;type&quot;: &quot;dog&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Roxer&quot;,\r\n    &quot;type&quot;: &quot;dog&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Paws&quot;,\r\n    &quot;type&quot;: &quot;cat&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m trying to convert it to an object keyed by `type`, like this:\r\n\r\n```json\r\n{\r\n  &quot;dog&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Bo&quot;,\r\n      &quot;type&quot;: &quot;dog&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Roxer&quot;,\r\n      &quot;type&quot;: &quot;dog&quot;\r\n    }\r\n  ],\r\n  &quot;cat&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Paws&quot;,\r\n      &quot;type&quot;: &quot;cat&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI found [this answer](https://stackoverflow.com/a/42428521/1377021) which uses map, but it assumes the `type` is unique and doesn&#39;t convert it to an array:\r\n\r\n```\r\nreduce .[] as $i ({}; .[$i.type] = $i)\r\n```\r\n\r\nThe first time a value is inserted, it should be inserted as `[$i]`. Any other time, it should append `[] + $i`.",
        "link": "https://stackoverflow.com/questions/60727891/use-jq-to-convert-an-array-to-an-object-by-non-unique-keys",
        "title": "Use jq to convert an array to an object by non-unique keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1584523767,
                "post_id": 60736491,
                "comment_id": 107459562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user12971978"
                },
                "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": 1584524107,
                "post_id": 60736491,
                "comment_id": 107459716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17882859,
                    "reputation": 2715,
                    "user_id": 12991188,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/DoevZ.jpg?s=256",
                    "display_name": "Digvijay S",
                    "link": "https://stackoverflow.com/users/12991188/digvijay-s"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584525007,
                "post_id": 60736491,
                "comment_id": 107460124,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user12971978"
                },
                "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": 1584526263,
                "post_id": 60736491,
                "comment_id": 107460768,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1584525242,
                "creation_date": 1584525242,
                "answer_id": 60737043,
                "question_id": 60736491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; in the following file, i need to get all lines that do not have in\r\n&gt; them the following pattern:\r\n&gt; \r\n&gt; `\\&quot;\\d\\d\\d\\&quot;:[`\r\n\r\nWhat about \r\n\r\n    awk &#39;$0 ~ /\\\\&quot;\\\\d\\\\d\\\\d\\\\&quot;:\\[/ {next;}{print;}&#39; test.txt | awk &#39;$0 ~ /memo/ {next;}{print;}&#39; | awk &#39;$0 ~ /notice/ {next;}{print;}&#39;\r\n\r\n&gt; {\r\n&gt;       },\r\n&gt;       &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;1\\&quot;,\\&quot;401\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/\r\n&gt; O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot;\r\n&gt; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n&gt;     }\r\n&gt;     {\r\n&gt;       },\r\n&gt;       &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;2\\&quot;,\\&quot;424\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;v\\&quot;,\\&quot;UK\\&quot;],[\\&quot;9\\&quot;,\\&quot;Euy/\r\n&gt; O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot;\r\n&gt; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n&gt;     }\r\n&gt;     {\r\n&gt;       },\r\n&gt;       &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;3\\&quot;,\\&quot;432\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;9\\&quot;,\\&quot;Euy/\r\n&gt; O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;v\\&quot;,\\&quot;R2\\&quot;]],[\\&quot;\r\n&gt; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n&gt;     }\r\n&gt;     {\r\n&gt;       },\r\n&gt;       &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;888\\&quot;,\\&quot;532\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;v\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/\r\n&gt; O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot;\r\n&gt; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n&gt;     }\r\n\r\n\r\nmaybe you still need to clean up some brackets.\r\n",
                "title": "extract lines from a file that do not fulfill certain criteria"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584527881,
                "last_edit_date": 1584527881,
                "creation_date": 1584526659,
                "answer_id": 60737435,
                "question_id": 60736491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Decode all `message`s, select those which do not contain any key matching `\\d{3}`, and extract their `id`s.\r\n```\r\njq &#39;.message | fromjson | select(any(keys_unsorted[]; test(&quot;[0-9]{3}&quot;)) | not) .id&#39; file\r\n```",
                "title": "extract lines from a file that do not fulfill certain criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1666590466,
        "creation_date": 1584523032,
        "last_edit_date": 1666590466,
        "question_id": 60736491,
        "body_markdown": "in the following file, i need to get all lines that do not have in them  the following pattern:\r\n\r\n ```\r\n\\&quot;\\d\\d\\d\\&quot;:[\r\n```\r\n\r\ni do not want the line  `&quot;memo&quot;: {` or `&quot;notice&quot;: &quot;delivered on 17&quot;`, i just want the lines that have `\\&quot;\\d\\d\\d\\&quot;:[`, but instead they have `\\&quot;\\d\\d\\&quot;:[`, or `\\&quot;\\s\\d\\d\\&quot;:[` etc. How could this be done with sed or awk, or even better with jq?\r\n\r\n i just need the lines that do not have in them the `\\&quot;\\d\\d\\d\\&quot;:[` pattern, for example `\\&quot;42 \\&quot;:[` should be reported. Each message line, must have `\\&quot;\\d\\d\\d\\&quot;:[` and not any other variation. For example `\\&quot;42a\\&quot;:[` is also wrong, and should be reported\r\n```\r\n{\r\n  &quot;memo&quot;: {\r\n    &quot;notice&quot;: &quot;delivered on 17&quot;\r\n  },\r\n  &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;1\\&quot;,\\&quot;401\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n}\r\n{\r\n  &quot;memo&quot;: {\r\n    &quot;notice&quot;: &quot;delivered on 190&quot;\r\n  },\r\n  &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;2\\&quot;,\\&quot;424\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;v\\&quot;,\\&quot;UK\\&quot;],[\\&quot;9\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n}\r\n{\r\n  &quot;memo&quot;: {\r\n    &quot;notice&quot;: &quot;delivered on 734&quot;\r\n  },\r\n  &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;3\\&quot;,\\&quot;432\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;9\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;v\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n}\r\n{\r\n  &quot;memo&quot;: {\r\n    &quot;notice&quot;: &quot;delivered on 1092&quot;\r\n  },\r\n  &quot;message&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;888\\&quot;,\\&quot;5 2\\&quot;:[[\\&quot; 0\\&quot;,[\\&quot;v\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;Euy/ O\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;],[\\&quot;g\\&quot;,\\&quot;R2\\&quot;]],[\\&quot; 1\\&quot;,[\\&quot;a\\&quot;,\\&quot;UK\\&quot;],[\\&quot;b\\&quot;,\\&quot;LO\\&quot;],[\\&quot;c\\&quot;,\\&quot;20160811\\&quot;]]]}&quot;\r\n}\r\n```\r\nas an output, I need the id value of the lines that have these problems.\r\n\r\nexpected output of the above: `id: 888` since in this line there is the erroneous `\\&quot;5 2\\&quot;:[`\r\n",
        "link": "https://stackoverflow.com/questions/60736491/extract-lines-from-a-file-that-do-not-fulfill-certain-criteria",
        "title": "extract lines from a file that do not fulfill certain criteria"
    },
    {
        "tags": [
            "json",
            "sum",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18000791,
                    "reputation": 21,
                    "user_id": 13082785,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/95ca4701103e652ba823e87b26db204c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nono100pi",
                    "link": "https://stackoverflow.com/users/13082785/nono100pi"
                },
                "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": 1584556540,
                "post_id": 60740988,
                "comment_id": 107475702,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584559914,
                "last_edit_date": 1584559914,
                "creation_date": 1584540713,
                "answer_id": 60741324,
                "question_id": 60740988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Group by CIS, for each group sum splits and put the result into a new object along with CIS value.\r\n```\r\n$ jq &#39;[.[].order[].orderInfo[]] | group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}&#39; file\r\n{\r\n  &quot;CIS&quot;: 698435,\r\n  &quot;split&quot;: 4.5\r\n}\r\n{\r\n  &quot;CIS&quot;: 918839,\r\n  &quot;split&quot;: 6.5\r\n}\r\n```",
                "title": "aggregate similar objects summing a field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1584604716,
                "creation_date": 1584604716,
                "answer_id": 60752995,
                "question_id": 60740988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks a lot, it works !\r\n\r\n\r\n    user@machine:~$ cat /tmp/export/export_200519110544.json | jq &#39;[.order[].orderInfo[] ]   |  group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}&#39;\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 14\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 7\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 7\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 7\r\n    }",
                "title": "aggregate similar objects summing a field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1584604716,
        "creation_date": 1584539439,
        "last_edit_date": 1584560684,
        "question_id": 60740988,
        "body_markdown": "I&#39;m trying to do that with `jq`\r\n\r\njson input file (shorten) :\r\n\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 3\r\n    }   \r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1.5\r\n    } \r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 4.5\r\n    } \r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 2\r\n    }\r\n\r\nI would like to have for my shell script:\r\n\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 4.5\r\n    } \r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 6.5\r\n    }\r\n\r\nHow can I do to make the sum of all split value for a specific key CIS ?\r\n\r\nI have try group_by with unsuccessfully\r\n\r\n```\r\ncat input.json | jq -r &#39;.&#39;\r\n```\r\n\r\nps: before that I do a replacement\r\n\r\n    cat /tmp/test.json |\r\n     jq -r &#39; if (.order[].orderInfo[].scannedCIS) != (0) then\r\n     ( &quot;replace &quot; + (.order[].orderInfo[].CIS|tostring) + &quot; with &quot; +\r\n     (.order[].orderInfo[].scannedCIS|tostring)) else null end &#39;\r\n\r\njq --version : jq-1.5-1-a5b5cbeode\r\n\r\nThe real file look like this:\r\n\r\n\r\n    cat /tmp/export/export_200519110544.json | jq -rs &#39;.[].order[].orderInfo[] |  { CIS:.CIS , split:.split }      &#39;\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 653397,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 698435,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 918839,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n    {\r\n      &quot;CIS&quot;: 603564,\r\n      &quot;split&quot;: 1\r\n    }\r\n\r\nthe input format seems to be identical, but i get an error.\r\n\r\n    cat /tmp/export/export_200519110544.json | jq -rs &#39;.[].order[].orderInfo[] |  { CIS:.CIS , split:.split } | group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}     &#39;\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index number with string &quot;CIS&quot;\r\n\r\ncat /tmp/export/export_200519110544.json \r\n\r\n    {&quot;order&quot;:[{&quot;customerId&quot;:0,&quot;medicalStructureId&quot;:0,&quot;calendarId&quot;:0,&quot;calendarStartDate&quot;:&quot;20200224&quot;,&quot;userLogin&quot;:&quot;jlemoule&quot;,&quot;endOfRefillTS&quot;:1582106743807,&quot;refillStatus&quot;:&quot;FULL&quot;,&quot;orderInfo&quot;:[{&quot;boxDay&quot;:0,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:1,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:2,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:3,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:4,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:5,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:6,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:653397,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;AMLODIPINO CINFA 5 mg COMPRIMIDOS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006533970&quot;,&quot;lot&quot;:&quot;BN4171&quot;,&quot;expDay&quot;:1,&quot;expMonth&quot;:9,&quot;expYear&quot;:21},{&quot;boxDay&quot;:0,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:1,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:2,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:3,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:4,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:5,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:6,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:false,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21},{&quot;boxDay&quot;:0,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:1,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:2,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:3,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:4,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:5,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:6,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:918839,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;KEPPRA 500 mg COMPRIMIDOS RECUBIERTOS CON PELICULA&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;918839&quot;,&quot;lot&quot;:&quot;273460&quot;,&quot;expDay&quot;:31,&quot;expMonth&quot;:8,&quot;expYear&quot;:21},{&quot;boxDay&quot;:0,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:1,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:2,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:3,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:4,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:5,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:6,&quot;boxPeriod&quot;:1,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:0,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:1,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:2,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:3,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:4,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:5,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23},{&quot;boxDay&quot;:6,&quot;boxPeriod&quot;:2,&quot;boxSubDivision&quot;:1,&quot;split&quot;:1.0,&quot;ifNecessary&quot;:false,&quot;reconditionnable&quot;:true,&quot;specialProtocol&quot;:false,&quot;surplus&quot;:false,&quot;CIS&quot;:603564,&quot;scannedCIS&quot;:0,&quot;scannedCISLabel&quot;:&quot;BROMAZEPAM NORMON 1,5 mg CAPSULAS DURAS EFG&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;8470006035641&quot;,&quot;lot&quot;:&quot;321&quot;,&quot;expDay&quot;:0,&quot;expMonth&quot;:2,&quot;expYear&quot;:23}],&quot;orderExtBoxInfo&quot;:[{&quot;nbBoxes&quot;:1,&quot;CIS&quot;:698435,&quot;scannedCIS&quot;:698435,&quot;scannedCISLabel&quot;:&quot;PECTOX LISINA 2,7 g granulado&quot;,&quot;fromReimportCIS&quot;:0,&quot;CIP&quot;:&quot;698435&quot;,&quot;lot&quot;:&quot;19019&quot;,&quot;expDay&quot;:30,&quot;expMonth&quot;:11,&quot;expYear&quot;:21}]}]}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60740988/aggregate-similar-objects-summing-a-field",
        "title": "aggregate similar objects summing a field"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584599147,
                "last_edit_date": 1584599147,
                "creation_date": 1584547317,
                "answer_id": 60743241,
                "question_id": 60741567,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Newer versions of JQ populates an internal array (`$ARGS.positional`) with arguments given after `--args` on command-line, you can use it.\r\n```\r\njq &#39;{all: [{($ARGS.positional[]): .}] | add}&#39; file --args &quot;${values[@]}&quot;\r\n```\r\nOn older versions, you can use this approach:\r\n```\r\nprintf &#39;&quot;%s&quot;\\n&#39; &quot;${values[@]}&quot; |\r\n    jq &#39;{all: [{(inputs): .}] | add}&#39; file -\r\n```\r\nBut note that this is not as reliable as the above one, I highly recommend updating JQ.",
                "title": "Generate nested JSON using array elements as keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1598372257,
        "creation_date": 1584541519,
        "last_edit_date": 1598372257,
        "question_id": 60741567,
        "body_markdown": "I have a file with the below contents and a shell variable with some keys. I want to create nested JSON using all keys.\r\neg:\r\n\r\n    file.json:\r\n    {\r\n        &quot;name&quot;:&quot;..&quot;,\r\n        &quot;value&quot;:&quot;..&quot;\r\n    }\r\n\r\nshell variable which contains list of keys:\r\n\r\n    values=(&#39;one&#39; &#39;two&#39; &#39;three&#39;)\r\n\r\nI want to create a variable like below:\r\n\r\n    {\r\n       &quot;all&quot;:{\r\n            &quot;one&quot;:  {\r\n                &quot;name&quot;:&quot;..&quot;,\r\n                &quot;value&quot;:&quot;..&quot;\r\n            },\r\n            &quot;two&quot;:  {\r\n                &quot;name&quot;:&quot;..&quot;,\r\n                &quot;value&quot;:&quot;..&quot;\r\n            },\r\n            &quot;three&quot;:  {\r\n                &quot;name&quot;:&quot;..&quot;,\r\n                &quot;value&quot;:&quot;..&quot;\r\n            }\r\n       }\r\n    }\r\n\r\nI tried to pass the values are `--arg` to JQ, but it didnt work. JQ version: 1.5.",
        "link": "https://stackoverflow.com/questions/60741567/generate-nested-json-using-array-elements-as-keys",
        "title": "Generate nested JSON using array elements as keys"
    },
    {
        "tags": [
            "gitlab",
            "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": 3,
                "creation_date": 1584570007,
                "post_id": 60748198,
                "comment_id": 107480558,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9169958,
                    "reputation": 15198,
                    "user_id": 6817913,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ba3f6e2c5c1425b1de4cc6b033941131?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Miha",
                    "link": "https://stackoverflow.com/users/6817913/miha"
                },
                "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": 1584572401,
                "post_id": 60748198,
                "comment_id": 107481263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9169958,
                    "reputation": 15198,
                    "user_id": 6817913,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ba3f6e2c5c1425b1de4cc6b033941131?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Miha",
                    "link": "https://stackoverflow.com/users/6817913/miha"
                },
                "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": 1584573006,
                "post_id": 60748198,
                "comment_id": 107481399,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1584577587,
                "creation_date": 1584577587,
                "answer_id": 60749300,
                "question_id": 60748198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Figured out and thanks @oguzismail for pointing on the right direction\r\n\r\nhere are the two ways that worked for me:\r\n\r\n- with `jq @csv`:\r\n```\r\n&gt; echo $(jq -r &#39;.myfield&#39; sourcefile.json |jq @csv)\r\n\r\nresult:\r\n\r\n&quot;\\&quot;10.149.46\\&quot;,\\&quot;10.149.35\\&quot;,\\&quot;10.149.45\\&quot;&quot;\r\n```\r\n\r\nOR\r\n\r\n- with `jq tostring`:\r\n\r\n```\r\n&gt; echo $(jq -r &#39;.myfield&#39; sourcefile.json |jq tostring)\r\n\r\nresult:\r\n\r\n&quot;[\\&quot;10.149.46\\&quot;,\\&quot;10.149.35\\&quot;,\\&quot;10.149.35\\&quot;]&quot;\r\n```",
                "title": "jq - how to convert an array to a comma separated list of strings in a .gitlab-ci.yml file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584602892,
        "creation_date": 1584569544,
        "last_edit_date": 1584602892,
        "question_id": 60748198,
        "body_markdown": "I am trying to achieve with jq a conversion from this input:\r\n\r\n```\r\n    [\r\n         &quot;10.149.46&quot;,\r\n         &quot;10.149.35&quot;,\r\n         &quot;10.149.45&quot;\r\n       ]\r\n```\r\n\r\nto something like a list of strings, see below:\r\n\r\n```\r\n&quot;10.149.46&quot;,&quot;10.149.35&quot;,&quot;10.149.45&quot;\r\n```\r\n\r\nAs I am trying to achieve this and store it in a variable in `.gitlab-ci.yml` to be honest any alternative will be appreciated, not necessarily using `jq`\r\n\r\nFor more clarity...\r\n\r\nValues are stored in a file `sourcefile.json` and under the field `myfield` in a format like:\r\n\r\n```\r\n  {\r\n  &quot;myfield&quot;: [\r\n         &quot;10.149.46&quot;,\r\n         &quot;10.149.35&quot;,\r\n         &quot;10.149.45&quot;\r\n  ],\r\n  &quot;otherfield&quot;: &quot;othervalue&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/60748198/jq-how-to-convert-an-array-to-a-comma-separated-list-of-strings-in-a-gitlab-c",
        "title": "jq - how to convert an array to a comma separated list of strings in a .gitlab-ci.yml file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584580223,
                "creation_date": 1584580223,
                "answer_id": 60749597,
                "question_id": 60749204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your file is stored as j.json\r\n\r\n    [{\r\n                    &quot;content&quot;: &quot;Apples&quot;,\r\n                    &quot;_id&quot;: &quot;7OLZ&quot;,\r\n                    &quot;type&quot;: &quot;fruit&quot;\r\n            },\r\n            {\r\n                    &quot;content&quot;: &quot;Oranges&quot;,\r\n                    &quot;_id&quot;: &quot;5BHY&quot;,\r\n                    &quot;type&quot;: &quot;fruit&quot;\r\n            },\r\n            {\r\n                    &quot;content&quot;: &quot;Pears&quot;,\r\n                    &quot;_id&quot;: &quot;DJQD&quot;,\r\n                    &quot;type&quot;: &quot;fruit&quot;\r\n            }\r\n    ]\r\n\r\n\r\nthis command will help. \r\n\r\n    jq &#39;.[] | [.content] | join(&quot;,&quot;) &#39;    j.json\r\n\r\n",
                "title": "jq to merge several objects in an array to one"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584585354,
                "creation_date": 1584585354,
                "answer_id": 60750167,
                "question_id": 60749204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My solution puts all of the values for the &quot;content&quot; key into an array and then joins the elements of the array with a space.\r\n\r\n    jq &#39;[.[] | .content ]|join(&quot; &quot;)&#39;\r\n\r\nOutput: `&quot;Apples Oranges Pears&quot;`\r\n\r\nGiven that [the definition of map(x)](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions) is `[.[] | x]`, this is equivalent.\r\n\r\n    jq &#39;map(.content)|join(&quot; &quot;)&#39;",
                "title": "jq to merge several objects in an array to one"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584594195,
                "creation_date": 1584594195,
                "answer_id": 60751185,
                "question_id": 60749204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to be able to combine just the fruit values \r\n\r\nPresumably therefore you will want to check `.type`, e.g.\r\n\r\n    jq -r &#39;map(select(.type==&quot;fruit&quot;).content) | join(&quot; &quot;)&#39;\r\n\r\n",
                "title": "jq to merge several objects in an array to one"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1584594195,
        "creation_date": 1584576773,
        "last_edit_date": 1584584317,
        "question_id": 60749204,
        "body_markdown": "I have a series of json files that I want to extract some information from and stick into CSVs using jq. The data I need look something like this:\r\n\r\n```\r\n[{&quot;content&quot;:&quot;Apples&quot;,&quot;_id&quot;:&quot;7OLZ&quot;,&quot;type&quot;:&quot;fruit}, \r\n{&quot;content&quot;:&quot;Oranges&quot;,&quot;_id&quot;:&quot;5BHY&quot;,&quot;type&quot;:&quot;fruit&quot;},\r\n{&quot;content&quot;:&quot;Pears&quot;,&quot;_id&quot;:&quot;DJQD&quot;,&quot;type&quot;:&quot;fruit&quot;}]\r\n\r\n```\r\nI want to be able to combine just the fruit values into a string without the other keys and occupy one cell in a spreadsheet. The files can also have a variable number of fruits in the array.\r\n\r\n```&quot;Apples Oranges Pears&quot;```\r\n\r\nIs this doable? [This post](https://stackoverflow.com/questions/50569174/jq-merge-arrays-inside-object) on SO comes close, I think, but as someone who doesn&#39;t work with json data or jq a whole lot, I couldn&#39;t piece together what the solution was actually doing. \r\n\r\nMany thanks for any insight",
        "link": "https://stackoverflow.com/questions/60749204/jq-to-merge-several-objects-in-an-array-to-one",
        "title": "jq to merge several objects in an array to one"
    },
    {
        "tags": [
            "arrays",
            "json",
            "string",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584599538,
                "post_id": 60751522,
                "comment_id": 107486874,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1584600480,
                "creation_date": 1584600480,
                "answer_id": 60752147,
                "question_id": 60751522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would you please try the following:\r\n```\r\ngeoInfo=$(jq &quot;(.[].country[] | select(.name == \\&quot;CN\\&quot;) | .nr) = 1&quot; &lt;&lt;&lt;&quot;$geoInfo&quot;)\r\n```",
                "title": "jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;name&quot; SOLVED"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584651217,
                "creation_date": 1584651217,
                "answer_id": 60764900,
                "question_id": 60751522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just forget all of this! I&#39;m terribly sorry. The errors i got was for a statement in the else section and I was changing the query in the then section. Probably worked to long on the code yesterday. my first solution had a small mistake after changing the `.nr=` to  `&quot;nr&quot;:` it worked:\r\n\r\ngeoInfo=&quot;$( jq --arg country ${tmpGeo[0]} --arg count $count -r &#39;.country | map( if .name == $country then . + { &quot;nr&quot;: $count } else . end )&#39;&lt;&lt;&lt;&quot;${geoInfo}&quot; )&quot;",
                "title": "jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;name&quot; SOLVED"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1584651328,
        "creation_date": 1584596542,
        "last_edit_date": 1584651328,
        "question_id": 60751522,
        "body_markdown": "I&#39;m trying to make a JSON collection of country, region, city, org, ip of intrusion attempts.\r\n\r\nMy JSON test info:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;total&quot;: 0,\r\n    &quot;country&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;CN&quot;,\r\n        &quot;nr&quot;: 0,\r\n        &quot;region&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Beijing&quot;,\r\n            &quot;nr&quot;: 0,\r\n            &quot;City&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Haidian&quot;,\r\n                &quot;nr&quot;: 0,\r\n                &quot;Organisation&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;AS45090 Shenzhen Tencent Computer Systems Company Limited&quot;,\r\n                    &quot;nr&quot;: 0,\r\n                    &quot;IPS&quot;: [\r\n                      {\r\n                        &quot;192.144.207.22&quot;: 0\r\n                      }\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;NL&quot;,\r\n        &quot;nr&quot;: 0,\r\n        &quot;region&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Noord Holland&quot;,\r\n            &quot;nr&quot;: 0,\r\n            &quot;City&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Amsterdam&quot;,\r\n                &quot;nr&quot;: 0,\r\n                &quot;Organisation&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;FEAS&quot;,\r\n                    &quot;nr&quot;: 0,\r\n                    &quot;IPS&quot;: [\r\n                      {\r\n                        &quot;192.162.1.1&quot;: 0\r\n                      }\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n }\r\n]\r\n```\r\nI load the existing json (test) string into ```$geoInfo```. Now i&#39;m trying to change the nr value in the object where```&quot;name&quot;: &quot;CN&quot;```\r\n\r\ni have tested two sollutions:\r\n\r\n```geoInfo=&quot;$( jq --arg country ${tmpGeo[0]} --arg count $count -r &#39;.country | map( if .name == $country then . + { .nr=$count } else . end )&#39;&lt;&lt;&lt;&quot;${geoInfo}&quot; )&quot;```\r\n\r\nAnd\r\n\r\n`geoInfo=&quot;$( jq --arg country ${tmpGeo[0]} --arg count $count -r &#39;.country | select(.[].name == &quot;CN&quot;) | .nr) = $count&#39;&lt;&lt;&lt;&quot;${geoInfo}&quot; )&quot;`\r\n\r\nWith both solutions I get:\r\n```jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;name&quot;```\r\n\r\nI use jq version 1.6.\r\n\r\nWhat is going wrong?",
        "link": "https://stackoverflow.com/questions/60751522/jq-error-at-stdin1-cannot-index-array-with-string-name-solved",
        "title": "jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;name&quot; SOLVED"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4214104,
                    "reputation": 5940,
                    "user_id": 3450914,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/ds01u.jpg?s=256",
                    "display_name": "Kraken",
                    "link": "https://stackoverflow.com/users/3450914/kraken"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584610461,
                "post_id": 60753892,
                "comment_id": 107490711,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18006805,
                    "reputation": 33,
                    "user_id": 13087396,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f314ea7eadfc90592d24ae25a2655122?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Js_good",
                    "link": "https://stackoverflow.com/users/13087396/js-good"
                },
                "reply_to_user": {
                    "account_id": 4214104,
                    "reputation": 5940,
                    "user_id": 3450914,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/ds01u.jpg?s=256",
                    "display_name": "Kraken",
                    "link": "https://stackoverflow.com/users/3450914/kraken"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1584615484,
                "post_id": 60753892,
                "comment_id": 107493089,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1584615025,
                "last_edit_date": 1584615025,
                "creation_date": 1584610528,
                "answer_id": 60754360,
                "question_id": 60753892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For each result separate value field and add it to metric in a new object; and update the array with them.\r\n```\r\njq &#39;.result[] |= {metric: (.metric + {value})}&#39; file\r\n```",
                "title": "move a field into its neighbor"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1584615025,
        "creation_date": 1584608761,
        "last_edit_date": 1584611101,
        "question_id": 60753892,
        "body_markdown": "I would like to merge some nested objects in array but without pointing elements numbers because CPU numbers may vary.\r\nDEsired output may be similar. I would like to end up with metric and value as one object which allow me to present it in one log line.\r\n\r\nCan somebody give me a hand here.\r\n\r\nRegards, Jay\r\n\r\n**Initial output:**\r\n```\r\n{\r\n  &quot;resultType&quot;: &quot;vector&quot;,\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu10&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;iowait&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;8,466666666790843&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu11&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;nice&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu9&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;steal&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu6&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;steal&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu8&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;nice&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu1&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;softirq&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;1,233333333414824&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu4&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;guest&quot;\r\n      },\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n**Desired output:**\r\n```\r\n{\r\n  &quot;resultType&quot;: &quot;vector&quot;,\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu10&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;iowait&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;8,466666666790843&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu11&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;nice&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu9&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;steal&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu6&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;steal&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu8&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;nice&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu1&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;softirq&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;1,233333333414824&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;metric&quot;: {\r\n        &quot;cpu&quot;: &quot;cpu4&quot;,\r\n        &quot;instance&quot;: &quot;hostname-1&quot;,\r\n        &quot;job&quot;: &quot;node&quot;,\r\n        &quot;mode&quot;: &quot;guest&quot;\r\n      &quot;value&quot;: [\r\n        1584371948,\r\n        66,\r\n        &quot;0&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/60753892/move-a-field-into-its-neighbor",
        "title": "move a field into its neighbor"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588735715,
                "creation_date": 1588735715,
                "answer_id": 61626880,
                "question_id": 60770621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With ***jq*** you can :\r\n\r\n - store a temporary value in a variable using `. as $VARIABLENAME`\r\n - iterate over a array  using `map`\r\n - overwrite value with `|=`\r\n - apply a condition on every value of array and return the logical or using `any`\r\n\r\nA possible solution can be :\r\n\r\n    jq &#39; . as $alluser | \r\n       { &quot;admin&quot; : \r\n           $alluser |map(if .roles| any( . == &quot;admin&quot;) then .roles|= empty else empty end),\r\n          &quot;users&quot;  : \r\n           $alluser |map(if .roles| any( . == &quot;admin&quot;) then empty else .roles|= empty end) } &#39; \\\r\n      your_datas.json\r\n\r\nps :\r\n  manual of jq is here \r\n   https://stedolan.github.io/jq/manual/\r\n",
                "title": "splitting JSON into two different objects using identifier"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588735715,
        "creation_date": 1584692199,
        "last_edit_date": 1584699219,
        "question_id": 60770621,
        "body_markdown": "I have some JSON which looks like:\r\n\r\n    [\r\n       {\r\n          &quot;username&quot;: &quot;saurabhu&quot;,\r\n          &quot;tenant_name&quot;: &quot;abc_c1e3e096-6e95-4b84&quot;,\r\n          &quot;project_domain_name&quot;: &quot;aa&quot;,\r\n          &quot;user_domain_name&quot;: &quot;aa&quot;,\r\n          &quot;password&quot;: &quot;saurabhp&quot;,\r\n          &quot;roles&quot;: [\r\n             &quot;admin&quot;\r\n          ]\r\n       },\r\n       {\r\n          &quot;username&quot;: &quot;saurabhu&quot;,\r\n          &quot;tenant_name&quot;: &quot;def_c1e3e096-6e95-4b84&quot;,\r\n          &quot;project_domain_name&quot;: &quot;aa&quot;,\r\n          &quot;user_domain_name&quot;: &quot;aa&quot;,\r\n          &quot;password&quot;: &quot;saurabhp&quot;,\r\n          &quot;roles&quot;: [\r\n             &quot;ResellerAdmin&quot;,\r\n             &quot;heat_stack_owner&quot;,\r\n             &quot;Member&quot;\r\n          ]\r\n       },\r\n       {\r\n          &quot;username&quot;: &quot;saurabhu&quot;,\r\n          &quot;tenant_name&quot;: &quot;c_c1e3e096-6e95-4b84&quot;,\r\n          &quot;project_domain_name&quot;: &quot;aa&quot;,\r\n          &quot;user_domain_name&quot;: &quot;aa&quot;,\r\n          &quot;password&quot;: &quot;saurabhp&quot;,\r\n          &quot;roles&quot;: [\r\n             &quot;ResellerAdmin&quot;,\r\n             &quot;heat_stack_owner&quot;,\r\n             &quot;Member&quot;\r\n          ]\r\n       }\r\n    ]\r\n    \r\nI want to format it like:\r\n\r\n    {\r\n    \t&quot;fool&quot;: {\r\n            &quot;admin&quot;: {\r\n                &quot;username&quot;: &quot;admin&quot;,\r\n                &quot;password&quot;: &quot;pa55word&quot;,\r\n                &quot;tenant_name&quot;: &quot;demo&quot;\r\n            },\r\n            &quot;users&quot;: [\r\n                {\r\n                    &quot;username&quot;: &quot;normal_user&quot;,\r\n                    &quot;password&quot;: &quot;password&quot;,\r\n                    &quot;user_domain_name&quot;: &quot;Default&quot;,\r\n                    &quot;project_name&quot;: &quot;normal_project&quot;,\r\n                    &quot;project_domain_name&quot;: &quot;Default&quot;\r\n                },\r\n    \t\t\t{\r\n    \t\t\t\t&quot;username&quot;: &quot;normal_user2&quot;,\r\n                    &quot;password&quot;: &quot;password&quot;,\r\n                    &quot;user_domain_name&quot;: &quot;Default&quot;,\r\n                    &quot;project_name&quot;: &quot;normal_project&quot;,\r\n                    &quot;project_domain_name&quot;: &quot;Default&quot;\r\n    \t\t\t}\r\n    \t\t]\t\t\r\n    \t}\r\n    }\r\n\r\nI am able to split it into a single object based on the admin role using this:\r\n \r\n    .[] | if .roles[]==&quot;admin&quot; then {&quot;username&quot;,&quot;password&quot;,project_name: .tenant_name} else {&quot;username&quot;,&quot;password&quot;, &quot;user_domain_name&quot;, project_name: .tenant_name, &quot;project_domain_name&quot; } end\r\n\r\nbut how can I achieve the desired output?",
        "link": "https://stackoverflow.com/questions/60770621/splitting-json-into-two-different-objects-using-identifier",
        "title": "splitting JSON into two different objects using identifier"
    },
    {
        "tags": [
            "json",
            "recursion",
            "tree",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584808301,
                "last_edit_date": 1584808301,
                "creation_date": 1584717970,
                "answer_id": 60777006,
                "question_id": 60776523,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you need to define a custom recursive function for this, like below; which assumes that all files have a non-empty `history`.\r\n```\r\ndef f(pfix):\r\n    ( [ pfix, .name ] | join(&quot;/&quot;) ) as $path |\r\n    ( .files[] | .history[] as $hist | [ $path, .name, $hist[] ] ),\r\n    ( .subDirs[] | f($path) );\r\n.dirs[] | f(empty) | @csv\r\n```",
                "title": "how to flatten a tree and build a path from properties?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1584739179,
                "last_edit_date": 1584739179,
                "creation_date": 1584722824,
                "answer_id": 60778300,
                "question_id": 60776523,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an approach that neither uses recursion explicitly (*) nor relies on a recursive structure:\r\n\r\n```\r\ndef names($path):\r\n  reduce getpath($path[0:range(0; $path|length)]) as $v (&quot;&quot;;\r\n    if $v | type == &quot;object&quot; and has(&quot;name&quot;) then . + &quot;/&quot; + $v[&quot;name&quot;] else . end) ;\r\n\r\npaths as $p\r\n| getpath($p) as $v\r\n| select($v | objects | has(&quot;history&quot;))\r\n| [names($p), getpath($p + [&quot;name&quot;])]\r\n  + ($v[&quot;history&quot;][] | [.hash, .timestamp] )\r\n| @csv\r\n```\r\n\r\nThis produces &quot;absolute&quot; paths (e.g. &quot;/documents&quot;); omitting the leading &quot;/&quot; can be accomplished easily enough.\r\n\r\n---\r\n(*) `paths` is defined recursively but in a way that takes advantage of jq&#39;s tail-call optimization (TCO), which is only applied to arity-0 recursive functions.",
                "title": "how to flatten a tree and build a path from properties?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1584808301,
        "creation_date": 1584716025,
        "last_edit_date": 1584731162,
        "question_id": 60776523,
        "body_markdown": "My goal is it to flatten a filesystem like structure (nested directories) with history information for individual files into a csv file for further processing. [Here][1] is what i tried so far.\r\n\r\nThe simplified input looks like this:\r\n``` json\r\n{ &quot;dirs&quot;: [\r\n    { \r\n        &quot;name&quot;: &quot;documents&quot;,\r\n        &quot;files&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;foo.bar&quot;,\r\n                &quot;history&quot;: [\r\n                    { &quot;hash&quot;: &quot;123&quot;, &quot;timestamp&quot;: &quot;...&quot;},\r\n                    { &quot;hash&quot;: &quot;234&quot;, &quot;timestamp&quot;: &quot;...&quot;}\r\n                ]\r\n            }\r\n        ],\r\n        &quot;subDirs&quot;: [\r\n            { &quot;name&quot;: &quot;tmp&quot;, &quot;files&quot;: [...], &quot;subDirs&quot;: [...]\r\n            }\r\n        ]        \r\n    }\r\n]}\r\n```\r\n\r\nThe **tricky part** is that the csv file should contain full directory paths, not only the directory name. The desired output looks like this:\r\n\r\n``` csv\r\n&quot;documents&quot;,&quot;foo.bar&quot;,&quot;123&quot;,&quot;...&quot;\r\n&quot;documents&quot;,&quot;foo.bar&quot;,&quot;234&quot;,&quot;...&quot;\r\n&quot;documents&quot;,&quot;bar.baz&quot;,&quot;345&quot;,&quot;...&quot;\r\n&quot;documents&quot;,&quot;bar.baz&quot;,&quot;456&quot;,&quot;...&quot;\r\n&quot;documents/tmp&quot;,&quot;deleteme&quot;,&quot;567&quot;,&quot;...&quot;\r\n&quot;documents/tmp&quot;,&quot;deleteme&quot;,&quot;678&quot;,&quot;...&quot;\r\n```\r\n\r\nflattening most of the data by using `recurse` works using this query:\r\n```\r\n.dirs[] | recurse(.subDirs[]?) | . as $d | $d.files[]? as $f | $f.history[]? as $h | [$d.name, $f.name, $h.hash, $h.timestamp] | @csv\r\n```\r\n\r\n...but i cannot wrap my head around how i can preserve build the directory path. Any suggestions would be much appreciated.\r\n\r\n\r\n  [1]: https://jqplay.org/s/XoZXoqQPB_",
        "link": "https://stackoverflow.com/questions/60776523/how-to-flatten-a-tree-and-build-a-path-from-properties",
        "title": "how to flatten a tree and build a path from properties?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "curl",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725030,
                "post_id": 60778756,
                "comment_id": 107533778,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14872673,
                    "reputation": 176,
                    "user_id": 10739760,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-oQ2kbFXl8fs/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h8bftOFuazY7iCLAjraN6mw1a4Cg/mo/s256-rj/photo.jpg",
                    "display_name": "304techmaven",
                    "link": "https://stackoverflow.com/users/10739760/304techmaven"
                },
                "reply_to_user": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725425,
                "post_id": 60778756,
                "comment_id": 107533936,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725460,
                "post_id": 60778756,
                "comment_id": 107533952,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725516,
                "post_id": 60778756,
                "comment_id": 107533975,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14872673,
                    "reputation": 176,
                    "user_id": 10739760,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-oQ2kbFXl8fs/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h8bftOFuazY7iCLAjraN6mw1a4Cg/mo/s256-rj/photo.jpg",
                    "display_name": "304techmaven",
                    "link": "https://stackoverflow.com/users/10739760/304techmaven"
                },
                "reply_to_user": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725619,
                "post_id": 60778756,
                "comment_id": 107534027,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725711,
                "post_id": 60778756,
                "comment_id": 107534066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14872673,
                    "reputation": 176,
                    "user_id": 10739760,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-oQ2kbFXl8fs/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h8bftOFuazY7iCLAjraN6mw1a4Cg/mo/s256-rj/photo.jpg",
                    "display_name": "304techmaven",
                    "link": "https://stackoverflow.com/users/10739760/304techmaven"
                },
                "reply_to_user": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584725939,
                "post_id": 60778756,
                "comment_id": 107534158,
                "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": 1584727784,
                "post_id": 60778756,
                "comment_id": 107534900,
                "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": 1584727907,
                "post_id": 60778756,
                "comment_id": 107534954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14872673,
                    "reputation": 176,
                    "user_id": 10739760,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-oQ2kbFXl8fs/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h8bftOFuazY7iCLAjraN6mw1a4Cg/mo/s256-rj/photo.jpg",
                    "display_name": "304techmaven",
                    "link": "https://stackoverflow.com/users/10739760/304techmaven"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584736929,
                "post_id": 60778756,
                "comment_id": 107538344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584727627,
                "creation_date": 1584727627,
                "answer_id": 60779449,
                "question_id": 60778756,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Absolutely required to quote the shell variable:\r\n```bash\r\ncurl ... -d &quot;$JSON_STRING&quot; http://example.com/end/point\r\n```\r\nOtherwise, the shell will do word splitting, and the argument to -d becomes just `{&quot;url&quot;:`\r\n\r\n---\r\nas a side note, bash arrays can help with the readability:\r\n```bash\r\ncurl_url=&quot;http://${bucket}.s3.amazonaws.com/${key}&quot;\r\ntileset_id=&quot;username.filename&quot;\r\n\r\nJSON_STRING=$(\r\n    jq -n \\\r\n          --arg bn &quot;$curl_url&quot; \\\r\n          --arg on &quot;$tileset_id&quot; \\\r\n          &#39;{url: $bn, tileset: $on}&#39;\r\n)\r\n\r\ncurl_opts=(\r\n    -X POST\r\n    -H &quot;Content-Type: application/json&quot; \r\n    -H &quot;Cache-Control: no-cache&quot; \r\n    -d &quot;$JSON_STRING&quot;\r\n)\r\n\r\ncurl &quot;${curl_opts[@]}&quot; &#39;apiurl&#39;\r\n```\r\n\r\n\r\n",
                "title": "&quot;Unexpected end of JSON input&quot; error when trying to do curl POST command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584727627,
        "creation_date": 1584724822,
        "last_edit_date": 1584725554,
        "question_id": 60778756,
        "body_markdown": "I am having issues with sending the proper json data in a curl -X POST command. I have successfully run the POST command locally on my mac by copy and pasting the hardcoded values in but I am now trying to create a .sh script to automate this process. Upon running the code below I get this error:\r\n\r\n*{&quot;message&quot;:&quot;Unexpected end of JSON input&quot;}*\r\n\r\nHere is the output json from JSON_STRING with names made generic and nothing else changed: \r\n\r\n`{ &quot;url&quot;: &quot;api_url&quot;, &quot;tileset&quot;: &quot;username.filename&quot; }`\r\n\r\nOnce I can figure out how to properly format the json in the POST command I know it will work, but I can&#39;t seem to get the syntax right. Hoping a set of fresh/experience bash eyes will be able to catch my mistake:). Also, all variables that I have are correct and already been confirmed by running variable values in mac terminal. Thanks in advance for the help!\r\n\r\n\r\n```\r\n    curl_url=&quot;http://${bucket}.s3.amazonaws.com/${key}&quot;\r\n    echo $curl_url\r\n    \r\n    tileset_id=&quot;username.filename&quot;\r\n\r\n    JSON_STRING=$(jq -n \\\r\n                  --arg bn &quot;$curl_url&quot; \\\r\n                  --arg on &quot;$tileset_id&quot; \\\r\n                  &#39;{url: $bn, tileset: $on}&#39;)\r\n                  \r\n    echo $JSON_STRING\r\n    \r\n    curl -X POST -H &quot;Content-Type: application/json&quot; -H &quot;Cache-Control: no-cache&quot; -d $JSON_STRING &#39;apiurl&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/60778756/unexpected-end-of-json-input-error-when-trying-to-do-curl-post-command",
        "title": "&quot;Unexpected end of JSON input&quot; error when trying to do curl POST command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1584735071,
                "last_edit_date": 1584735071,
                "creation_date": 1584729002,
                "answer_id": 60779766,
                "question_id": 60778881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just select those whose status is DOWN. `with_entries` is there to retain original structure.\r\n```\r\nwith_entries(select(.value.status? == &quot;DOWN&quot;))\r\n```",
                "title": "how to select nested key if key is unknown"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1584735071,
        "creation_date": 1584725328,
        "last_edit_date": 1584729035,
        "question_id": 60778881,
        "body_markdown": "I have a very simple JSON like this:\r\n```\r\n{\r\n   &quot;status&quot;:&quot;DOWN&quot;,\r\n   &quot;FTPService&quot;:{\r\n      &quot;status&quot;:&quot;UP&quot;\r\n   },\r\n   &quot;mail&quot;:{\r\n      &quot;status&quot;:&quot;UP&quot;,\r\n      &quot;location&quot;:&quot;somehost.example.com:-1&quot;\r\n   },\r\n   &quot;diskSpace&quot;:{\r\n      &quot;status&quot;:&quot;UP&quot;,\r\n      &quot;total&quot;:2000396742656,\r\n      &quot;free&quot;:1213046730752,\r\n      &quot;threshold&quot;:10485760\r\n   },\r\n   &quot;db&quot;:{\r\n      &quot;status&quot;:&quot;DOWN&quot;,\r\n      &quot;database&quot;:&quot;Oracle&quot;,\r\n      &quot;schema&quot;:&quot;foo&quot;\r\n   },\r\n   &quot;refreshScope&quot;:{\r\n      &quot;status&quot;:&quot;UP&quot;\r\n   }\r\n}\r\n```\r\n\r\nKeys &quot;mail&quot;, &quot;diskspace&quot;, &quot;db&quot; etc. are unknown and could have any name. \r\n\r\nI&#39;d like to print all object whose status in not &quot;UP&quot; if the overall status is not &quot;UP&quot;.  The desired example output would be\r\n\r\n```\r\n&quot;db&quot;:{\r\n      &quot;status&quot;:&quot;DOWN&quot;,\r\n      &quot;database&quot;:&quot;Oracle&quot;,\r\n      &quot;schema&quot;:&quot;foo&quot;\r\n   },\r\n``` ",
        "link": "https://stackoverflow.com/questions/60778881/how-to-select-nested-key-if-key-is-unknown",
        "title": "how to select nested key if key is unknown"
    },
    {
        "tags": [
            "json",
            "jq",
            "influxdb"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1584870462,
                "last_edit_date": 1584870462,
                "creation_date": 1584822629,
                "answer_id": 60792940,
                "question_id": 60792617,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on your attempts, and the assumption that each object contain either `results` or `error`, this should do it:\r\n```\r\n( .results[0].series | .[0].columns, .[]?.values[] ) // [ .error ] | @csv\r\n```\r\n&lt;sup&gt;[REPL demo](https://jqplay.org/s/OQwpxvJ_lo)&lt;/sup&gt;",
                "title": "have jq detect errors in influxdb json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1584870462,
        "creation_date": 1584820586,
        "last_edit_date": 1584822994,
        "question_id": 60792617,
        "body_markdown": "I have a `jq` filter that converts (`influxdb`) json input to csv for further parsing. However, this filter fails when `influxdb` returns an error. I&#39;m trying to improve my jq filter to detect this, however I can&#39;t get this to work. I need something like https://stackoverflow.com/a/41829748 but can&#39;t seem to get this to work. Any ideas?\r\n\r\n**Example data**\r\n\r\n    {&quot;results&quot;:[{&quot;statement_id&quot;:0,&quot;series&quot;:[{&quot;name&quot;:&quot;energyv3&quot;,&quot;columns&quot;:[&quot;time&quot;,&quot;value&quot;],&quot;values&quot;:[[&quot;2015-07-30T23:59:00Z&quot;,56980800],[&quot;2015-07-31T23:59:00Z&quot;,95108400]]}]}]}\r\n    {&quot;error&quot;:&quot;error parsing query: found EOF, expected integer at line 1, char 34&quot;}\r\n\r\n**Desired outcome**\r\n\r\n    &quot;\\&quot;time\\&quot;,\\&quot;value\\&quot;&quot;\r\n    &quot;\\&quot;2015-07-30T23:59:00Z\\&quot;,56980800&quot;\r\n    &quot;\\&quot;2015-07-31T23:59:00Z\\&quot;,95108400&quot;\r\n    &quot;error parsing query: found EOF, expected integer at line 1, char 34&quot;\r\n\r\ni.e.\r\n\r\n1. For input with `.results` key: data formatted as csv (works OK)\r\n2. For input with `.error` key: only error string (doesn&#39;t work)\r\n\r\n\r\n**Current filter used**\r\n\r\n    select(.results) | (.results[0].series[0].columns), (.results[0].series[0].values[]) | @csv\r\n\r\n*Attempt to combine filters*\r\n\r\n    ((select(.error) | {error}) // null) + select(.results) | (.results[0].series[0].columns), (.results[0].series[0].values[]) | @csv\r\n",
        "link": "https://stackoverflow.com/questions/60792617/have-jq-detect-errors-in-influxdb-json-output",
        "title": "have jq detect errors in influxdb json output"
    },
    {
        "tags": [
            "json",
            "jq",
            "quotes"
        ],
        "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": 1584990925,
                "post_id": 60794179,
                "comment_id": 107606815,
                "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": 1584991118,
                "post_id": 60794179,
                "comment_id": 107606897,
                "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": 1584991154,
                "post_id": 60794179,
                "comment_id": 107606912,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584832022,
                "creation_date": 1584832022,
                "answer_id": 60794254,
                "question_id": 60794179,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to use the `-r` option to [`read`][1]:\r\n\r\n    while read -r line; do echo &quot;$line&quot; &gt; temp/&quot;$(date +%s%N)&quot;.json; done\r\n\r\nIt prevents interpreting backslash escapes.\r\n\r\nAnd you should quote your variables.\r\n\r\nSee the difference:\r\n\r\n```console\r\n$ read var &lt;&lt;&lt; &#39;quoted quotes: \\&quot;\\&quot;&#39;\r\n$ echo &quot;$var&quot;\r\nquoted quotes: &quot;&quot;\r\n$ read -r var &lt;&lt;&lt; &#39;quoted quotes: \\&quot;\\&quot;&#39;\r\n$ echo &quot;$var&quot;\r\nquoted quotes: \\&quot;\\&quot;\r\n```\r\n\r\nUsing `-r` with `read` is almost always what you want and really should have been the default behaviour.\r\n\r\n\r\n  [1]: https://www.gnu.org/software/bash/manual/bash.html#index-read",
                "title": "Why does my jq / read / echo pipeline remove backslashes?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1584834286,
        "creation_date": 1584831376,
        "last_edit_date": 1584834286,
        "question_id": 60794179,
        "body_markdown": "I am trying to split a large JSON file (~4 Mio elements) into separate files (one file per element).\r\n\r\nThe file kinda looks like this:\r\n```json\r\n{\r\n  &quot;books&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Professional JavaScript - \\&quot;The best guide\\&quot;&quot;,\r\n      &quot;authors&quot;: [\r\n        &quot;Nicholas C. Zakas&quot;\r\n      ],\r\n      &quot;edition&quot;: 3,\r\n      &quot;year&quot;: 2011\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Professional JavaScript&quot;,\r\n      &quot;authors&quot;: [\r\n        &quot;Nicholas C.Zakas&quot;\r\n      ],\r\n      &quot;edition&quot;: 2,\r\n      &quot;year&quot;: 2009\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Professional Ajax&quot;,\r\n      &quot;authors&quot;: [\r\n        &quot;Nicholas C. Zakas&quot;,\r\n        &quot;Jeremy McPeak&quot;,\r\n        &quot;Joe Fawcett&quot;\r\n      ],\r\n      &quot;edition&quot;: 2,\r\n      &quot;year&quot;: 2008\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nTo split each book into a separate file, I am using the following command:\r\n\r\n```sh\r\ncat books.json | jq -c -M &#39;.books[]&#39; | while read line; do echo $line &gt; temp/$(date +%s%N).json; done\r\n```\r\n\r\nFor the last two items, everything&#39;s ok, because the book title does not contain any quotes. However, in the first one, the `\\&quot;` get replaced by `&quot;` which leads to a broken JSON file, as the subsequent parser - of course - interprets the `&quot;` as a boundary of an element.\r\n\r\nI&#39;ve tried to use `jq -r`, but that did not help.\r\n\r\nI&#39;m using the jq version shipped by CentOS 7:\r\n```\r\n[root@machine]$ jq --version\r\njq-1.6\r\n\r\n```\r\n\r\nAny suggestions?",
        "link": "https://stackoverflow.com/questions/60794179/why-does-my-jq-read-echo-pipeline-remove-backslashes",
        "title": "Why does my jq / read / echo pipeline remove backslashes?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1584964931,
                "last_edit_date": 1584964931,
                "creation_date": 1584964531,
                "answer_id": 60813112,
                "question_id": 60812016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Original question\r\n\r\n&gt; How do I just get the port, banner, etc. for the specific service underneath the record which hit my condition?\r\n\r\nTo get just the &quot;port&quot; for the service matching the condition, you could modify your query:\r\n\r\n```\r\n.services[]\r\n| if .banner == &quot;FQMDAAICCg==&quot; then .port else empty end\r\n```\r\n\r\nEquivalently:\r\n\r\n```\r\n.services[]\r\n| select(.banner == &quot;FQMDAAICCg==&quot;)\r\n| .port\r\n```\r\n\r\n## Additional goal\r\n\r\n&gt; I want to end up in this example with &#39;8085&#39; + &#39;103.238.62.68&#39; \r\n\r\nIf you really want the two values in that format, you could write something along the following lines, invoking jq with the -r option:\r\n\r\n```\r\n.ip as $ip\r\n| (.services[] | select(.banner == &quot;FQMDAAICCg==&quot;) | .port) as $port\r\n| &quot;&#39;\\($port)&#39; + &#39;\\($ip)&#39;&quot;\r\n```\r\n\r\nor more briefly but less readably:\r\n```\r\n&quot;&#39;\\(.services[] | select(.banner == &quot;FQMDAAICCg==&quot;) | .port)&#39; + &#39;\\(.ip)&#39;&quot;\r\n```",
                "title": "JQ if then statement scope"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1585005921,
        "creation_date": 1584960292,
        "last_edit_date": 1585005921,
        "question_id": 60812016,
        "body_markdown": "I&#39;d like to use JQ to grab only the sub-records that match an if-then statement. When I use\r\n\r\n```jq &#39;if .services[].banner == &quot;FQMDAAICCg==&quot; then .services[].port else empty end```\r\n\r\nit grabs all of the ports for the record. (there are multiple services under each record and I want to restrict my then statement to only the services scope where I actually found the if condition).\r\n\r\nHow do I just get the port, banner, etc. for the specific service underneath the record which hit my condition?\r\n\r\nexample:\r\n\r\n```\r\n{\r\n  &quot;services&quot;: [\r\n    {\r\n      &quot;tls_detected&quot;: false,\r\n      &quot;banner_is_raw&quot;: true,\r\n      &quot;transport_protocol&quot;: &quot;tcp&quot;,\r\n      &quot;banner&quot;: &quot;PCFET0NUWVBFIEhU&quot;,\r\n      &quot;certificate&quot;: null,\r\n      &quot;timestamp&quot;: &quot;2020-03-22T00:38:01.074Z&quot;,\r\n      &quot;protocol&quot;: null,\r\n      &quot;port&quot;: 4444\r\n    },\r\n    {\r\n      &quot;tls_detected&quot;: false,\r\n      &quot;banner_is_raw&quot;: true,\r\n      &quot;transport_protocol&quot;: &quot;tcp&quot;,\r\n      &quot;banner&quot;: &quot;SFRUUC8xLjEgMzA&quot;,\r\n      &quot;certificate&quot;: null,\r\n      &quot;timestamp&quot;: &quot;2020-03-19T01:39:45.288Z&quot;,\r\n      &quot;protocol&quot;: null,\r\n      &quot;port&quot;: 8080\r\n    },\r\n    {\r\n      &quot;tls_detected&quot;: false,\r\n      &quot;banner_is_raw&quot;: true,\r\n      &quot;transport_protocol&quot;: &quot;tcp&quot;,\r\n      &quot;banner&quot;: &quot;FQMDAAICCg==&quot;,\r\n      &quot;certificate&quot;: null,\r\n      &quot;timestamp&quot;: &quot;2020-03-19T01:39:45.288Z&quot;,\r\n      &quot;protocol&quot;: null,\r\n      &quot;port&quot;: 8085\r\n    },\r\n    {\r\n      &quot;tls_detected&quot;: false,\r\n      &quot;banner_is_raw&quot;: false,\r\n      &quot;transport_protocol&quot;: &quot;tcp&quot;,\r\n      &quot;banner&quot;: &quot;Q2FjaGUtQ29ud&quot;,\r\n      &quot;certificate&quot;: null,\r\n      &quot;timestamp&quot;: &quot;2020-03-20T04:25:24Z&quot;,\r\n      &quot;protocol&quot;: &quot;http&quot;,\r\n      &quot;port&quot;: 8080\r\n    }\r\n  ],\r\n  &quot;ip&quot;: &quot;103.238.62.68&quot;,\r\n  &quot;autonomous_system&quot;: {\r\n    &quot;description&quot;: &quot;CHAPTECH-AS-AP Chaptech Pty Ltd&quot;,\r\n    &quot;asn&quot;: 133493,\r\n    &quot;routed_prefix&quot;: &quot;103.238.62.0/24&quot;,\r\n    &quot;country_code&quot;: &quot;AU&quot;,\r\n    &quot;name&quot;: &quot;CHAPTECH-AS-AP Chaptech Pty Ltd&quot;,\r\n    &quot;path&quot;: [\r\n      11164,\r\n      3491,\r\n      63956,\r\n      7594,\r\n      7594,\r\n      7594,\r\n      7594,\r\n      133493\r\n    ]\r\n  },\r\n  &quot;location&quot;: {\r\n    &quot;country_code&quot;: &quot;AU&quot;,\r\n    &quot;registered_country&quot;: &quot;Australia&quot;,\r\n    &quot;registered_country_code&quot;: &quot;AU&quot;,\r\n    &quot;continent&quot;: &quot;Oceania&quot;,\r\n    &quot;timezone&quot;: &quot;Australia/Sydney&quot;,\r\n    &quot;latitude&quot;: -33.494,\r\n    &quot;longitude&quot;: 143.2104,\r\n    &quot;country&quot;: &quot;Australia&quot;\r\n  }\r\n}\r\n```\r\n\r\nUpdate:\r\n\r\nThanks to peak but I couldn&#39;t get the additional goals bit working below. I ended up using\r\n```\r\njq &#39;select(.services[].banner == &quot;FQMDAAICCg==&quot;) | {port: .services[].port, banner: .services[].banner, ip: .ip}&#39; censys.json | jq &#39;if .banner == &quot;FQMDAAICCg==&quot; then .ip,.port else empty end&#39;\r\n```\r\nwhich is ugly but did the trick and still allowed me to stream the data to the first filter.",
        "link": "https://stackoverflow.com/questions/60812016/jq-if-then-statement-scope",
        "title": "JQ if then statement scope"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8181388,
                    "reputation": 2281,
                    "user_id": 6158454,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9bfd96a123ac6462b5ce2b12db1de71d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Patrick Mcvay",
                    "link": "https://stackoverflow.com/users/6158454/patrick-mcvay"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1584988140,
                "post_id": 60819321,
                "comment_id": 107605709,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16223207,
                    "reputation": 59,
                    "user_id": 11714278,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-C5ykWyyHSng/AAAAAAAAAAI/AAAAAAAAAA0/YAhM7fbElUU/s256-rj/photo.jpg",
                    "display_name": "Fred Kwebiha",
                    "link": "https://stackoverflow.com/users/11714278/fred-kwebiha"
                },
                "reply_to_user": {
                    "account_id": 8181388,
                    "reputation": 2281,
                    "user_id": 6158454,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9bfd96a123ac6462b5ce2b12db1de71d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Patrick Mcvay",
                    "link": "https://stackoverflow.com/users/6158454/patrick-mcvay"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584988769,
                "post_id": 60819321,
                "comment_id": 107605965,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16223207,
                    "reputation": 59,
                    "user_id": 11714278,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-C5ykWyyHSng/AAAAAAAAAAI/AAAAAAAAAA0/YAhM7fbElUU/s256-rj/photo.jpg",
                    "display_name": "Fred Kwebiha",
                    "link": "https://stackoverflow.com/users/11714278/fred-kwebiha"
                },
                "reply_to_user": {
                    "account_id": 8181388,
                    "reputation": 2281,
                    "user_id": 6158454,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9bfd96a123ac6462b5ce2b12db1de71d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Patrick Mcvay",
                    "link": "https://stackoverflow.com/users/6158454/patrick-mcvay"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584988787,
                "post_id": 60819321,
                "comment_id": 107605972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16223207,
                    "reputation": 59,
                    "user_id": 11714278,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-C5ykWyyHSng/AAAAAAAAAAI/AAAAAAAAAA0/YAhM7fbElUU/s256-rj/photo.jpg",
                    "display_name": "Fred Kwebiha",
                    "link": "https://stackoverflow.com/users/11714278/fred-kwebiha"
                },
                "reply_to_user": {
                    "account_id": 8181388,
                    "reputation": 2281,
                    "user_id": 6158454,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9bfd96a123ac6462b5ce2b12db1de71d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Patrick Mcvay",
                    "link": "https://stackoverflow.com/users/6158454/patrick-mcvay"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584988798,
                "post_id": 60819321,
                "comment_id": 107605977,
                "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": 1585002979,
                "post_id": 60819321,
                "comment_id": 107611236,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1585004037,
                "creation_date": 1585004037,
                "answer_id": 60822660,
                "question_id": 60819321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution to the problem as I understand it:\r\n\r\n```\r\nrange(0;length) as $i\r\n| .[$i]\r\n| [$i, .name, .id] +\r\n  ( range(0, .[&quot;categoryOptions.name&quot;]|length) as $j\r\n    | [ .[&quot;categoryOptions.name&quot;][$j], .[&quot;categoryOptions.id&quot;][$j] ] )\r\n| @csv\r\n```\r\n\r\nThis produces everything except the header row, the production of which is left as an exercise.\r\n\r\n## Invocation\r\n... would be along the lines of:\r\n\r\n    jq -r -f program.jq input.json",
                "title": "Columnar CSV Output from nested SON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585153807,
                "last_edit_date": 1585153807,
                "creation_date": 1585152776,
                "answer_id": 60852790,
                "question_id": 60819321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add onto @**peak&#39;s** solution\r\n\r\nThe final invocation ( with CSV header) may look like this:\r\n\r\n    jq -r -f program.jq input.json &gt; output.csv &amp;&amp; sed  -i &#39;1i &quot;key&quot;,&quot;name&quot;,&quot;id&quot;,&quot;categoryOptions.name&quot;,&quot;categoryOptions.id&quot;&#39; output.csv\r\n\r\nThe sed solution is picked from [here][1]\r\n\r\n\r\n  [1]: https://unix.stackexchange.com/questions/401670/how-to-add-headers-to-columns",
                "title": "Columnar CSV Output from nested SON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -4,
        "last_activity_date": 1585153807,
        "creation_date": 1584987174,
        "last_edit_date": 1585146370,
        "question_id": 60819321,
        "body_markdown": "```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)&quot;,\r\n    &quot;id&quot;: &quot;XOPEXepA7zg&quot;,\r\n    &quot;categoryOptions.name&quot;: [\r\n      &quot;0 -2 month&quot;,\r\n      &quot;&gt;2months-&lt;1 year&quot;,\r\n      &quot;&lt; 1 year&quot;,\r\n      &quot;(1 - 4) Years&quot;,\r\n      &quot;(1-9) Years&quot;\r\n    ],\r\n    &quot;categoryOptions.id&quot;: [\r\n      &quot;wfvXckoyaE9&quot;,\r\n      &quot;Yi2K2FUDa3B&quot;,\r\n      &quot;kKt6hryCX75&quot;,\r\n      &quot;A0B8w6HoZvV&quot;,\r\n      &quot;upbvx1IvICR&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Metadata:MER-2.0-ver KP-Results (Semi Annual)&quot;,\r\n    &quot;id&quot;: &quot;k9p3Ghbi6eW&quot;,\r\n    &quot;categoryOptions.name&quot;: [\r\n      &quot;Sex Workers&quot;,\r\n      &quot;People in prisons and other enclosed settings (Incarcerated Population) &quot;,\r\n      &quot;PWID..&quot;,\r\n      &quot;MSM&quot;,\r\n      &quot;Transgender&quot;\r\n    ],\r\n    &quot;categoryOptions.id&quot;: [\r\n      &quot;mwTwhESK21T&quot;,\r\n      &quot;eQjIwsDqbPy&quot;,\r\n      &quot;zYaPQA3uTiH&quot;,\r\n      &quot;vu0dG7psM5W&quot;,\r\n      &quot;Jyo9XWumVtZ&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Metadata:MER-2.0-ver PP-Results (Semi Annual)&quot;,\r\n    &quot;id&quot;: &quot;rkExsSSc3yI&quot;,\r\n    &quot;categoryOptions.name&quot;: [\r\n      &quot;Adolescents (10-24)&quot;,\r\n      &quot;Clients of  Sex Workers&quot;,\r\n      &quot;Displaced Persons&quot;,\r\n      &quot;Fishing communities&quot;,\r\n      &quot;Military and other Uniform Services&quot;\r\n    ],\r\n    &quot;categoryOptions.id&quot;: [\r\n      &quot;yWwp6xnt0pw&quot;,\r\n      &quot;jlKwW6DC023&quot;,\r\n      &quot;wF42hb47Z7J&quot;,\r\n      &quot;qkIUghy30Vl&quot;,\r\n      &quot;Vcuw6LkdAkk&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Metadata:MER-2.0-ver PREP_CURR-and-TX_ML (Semi Annual)&quot;,\r\n    &quot;id&quot;: &quot;ZYdO3FqQgo1&quot;,\r\n    &quot;categoryOptions.name&quot;: [\r\n      &quot;Adolescents (10-24)&quot;,\r\n      &quot;Clients of  Sex Workers&quot;,\r\n      &quot;Displaced Persons&quot;,\r\n      &quot;Fishing communities&quot;,\r\n      &quot;Military and other Uniform Services&quot;\r\n    ],\r\n    &quot;categoryOptions.id&quot;: [\r\n      &quot;yWwp6xnt0pw&quot;,\r\n      &quot;jlKwW6DC023&quot;,\r\n      &quot;wF42hb47Z7J&quot;,\r\n      &quot;qkIUghy30Vl&quot;,\r\n      &quot;Vcuw6LkdAkk&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Metadata:MER-2.0-ver SupplyChain-Results (Semi Annual)&quot;,\r\n    &quot;id&quot;: &quot;Cub0DEVWs3P&quot;,\r\n    &quot;categoryOptions.name&quot;: [\r\n      &quot;TLD 30-count bottles&quot;,\r\n      &quot;TLD 90-count bottles&quot;,\r\n      &quot;TLD 180-count bottles&quot;,\r\n      &quot;TLE/400 30-count bottles&quot;,\r\n      &quot;TLE/400 90-count bottles&quot;\r\n    ],\r\n    &quot;categoryOptions.id&quot;: [\r\n      &quot;dtmTsLvH2dk&quot;,\r\n      &quot;sOLj1z1XRxh&quot;,\r\n      &quot;SnkZTF4kThV&quot;,\r\n      &quot;sNnXSKiPvb5&quot;,\r\n      &quot;t3iPChPFIcd&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nExpected Output should be in csv format as below:\r\n\r\n**key,name,id,&quot;categoryOptions.name&quot;,&quot;categoryOptions.id&quot;**\r\n\r\n    0,Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual),XOPEXepA7zg,0 -2 month,wfvXckoyaE9\r\n\r\n    0,Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual),XOPEXepA7zg,&gt;2months-&lt;1 year,Yi2K2FUDa3B\r\n\r\n    1,Metadata:MER-2.0-ver KP-Results (Semi Annual),k9p3Ghbi6eW,Sex Workers,mwTwhESK21T\r\n\r\n    1,Metadata:MER-2.0-ver KP-Results (Semi Annual),k9p3Ghbi6eWPeople in prisons and other enclosed settings (Incarcerated Population),eQjIwsDqbPy\r\n\r\n2,Metadata:MER-2.0-ver PP-Results (Semi Annual),rkExsSSc3yI,Adolescents (10-24),yWwp6xnt0pw\r\n\r\n2,Metadata:MER-2.0-ver PP-Results (Semi Annual),rkExsSSc3yI,Clients of  Sex Workers,jlKwW6DC023\r\n\r\nupto  key4\r\n\r\nThe above input json came from here below:\r\n\r\n    cat /home/fred/Downloads/metadata/multiple-dataset-metadata.json\r\n    | jq &#39;[.dataSets[]\r\n    | {name: .name,id: .id,&quot;categoryOptions.name&quot;: [.dataSetElements[].dataElement.categoryCombo.categories[].categoryOptions\r\n    [].name],&quot;categoryOptions.id&quot;: [.dataSetElements[].dataElement.categoryCombo.categories[].categoryOptions[].id]}]&#39;",
        "link": "https://stackoverflow.com/questions/60819321/columnar-csv-output-from-nested-son",
        "title": "Columnar CSV Output from nested SON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585034877,
                "last_edit_date": 1585034877,
                "creation_date": 1585032600,
                "answer_id": 60826141,
                "question_id": 60826054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`map_values`](https://stedolan.github.io/jq/manual/v1.6/#map(x),map_values(x)).\r\n```\r\n$ jq &#39;.properties | map_values(.value)&#39; file\r\n{\r\n  &quot;p2&quot;: &quot;b&quot;,\r\n  &quot;p1&quot;: &quot;a&quot;,\r\n  &quot;p3&quot;: &quot;c&quot;\r\n}\r\n```",
                "title": "update fields with inner values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585034877,
        "creation_date": 1585032081,
        "last_edit_date": 1585032759,
        "question_id": 60826054,
        "body_markdown": "I have a json string like:\r\n```json\r\n    {\r\n        &quot;name&quot; : &quot;test&quot;,\r\n        &quot;properties&quot;: {\r\n            &quot;p2&quot;: {&quot;test&quot;: &quot;test&quot;, &quot;value&quot;: &quot;b&quot;},\r\n            &quot;p1&quot;: {&quot;value&quot;: &quot;a&quot;},\r\n            &quot;p3&quot;: {&quot;value&quot;: &quot;c&quot;}\r\n        }\r\n    }\r\n```\r\n\r\nand I want:\r\n```json\r\n{\r\n&quot;p2&quot; : &quot;b&quot;,\r\n&quot;p1&quot; : &quot;a&quot;,\r\n&quot;p3&quot; : &quot;c&quot;\r\n}\r\n```\r\nand the order doesn&#39;t matter, but the relation of keys and values must be the same as origin.\r\n\r\nI tried\r\n`jq &#39;.properties | (keys_unsorted, .[].value)&#39;` and it gives: \r\n```\r\n[\r\n  &quot;p2&quot;,\r\n  &quot;p1&quot;,\r\n  &quot;p3&quot;\r\n]\r\n&quot;b&quot;\r\n&quot;a&quot;\r\n&quot;c&quot;\r\n```\r\n\r\nthen I split the command into `jq &#39;.properties | keys_unsorted&#39;` and `jq &#39;.properties | .[].value&#39;`, do some editing by hands, and use `paste` command to join the results.\r\n\r\nDoes a more reasonable way exist?",
        "link": "https://stackoverflow.com/questions/60826054/update-fields-with-inner-values",
        "title": "update fields with inner values"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "aws-ssm"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585071798,
                "post_id": 60835672,
                "comment_id": 107635506,
                "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": 1585094126,
                "post_id": 60835672,
                "comment_id": 107643587,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1585068880,
        "creation_date": 1585068880,
        "question_id": 60835672,
        "body_markdown": "I have a JSON file which contains some parameter name and their values. The values are path to `AWS` SSM param store. I want to create another JSON file from the source file which will basically contain the actual values from param store based on the path.\r\neg:  \r\nsource.json\r\n\r\n    {\r\n      &quot;redis&quot;:{\r\n        &quot;cluster&quot;:{\r\n            &quot;host&quot;:&quot;{host_param_name}&quot;,\r\n            &quot;port&quot;:&quot;21&quot;,\r\n            &quot;username&quot;:&quot;{user_param_name}&quot;,\r\n            &quot;password&quot;:&quot;{password_param_name}&quot;\r\n        },\r\n        &quot;cluster2&quot;:{\r\n            &quot;host&quot;:&quot;{host_param_name}&quot;,\r\n            &quot;port&quot;:&quot;21&quot;,\r\n            &quot;username&quot;:&quot;{user_param_name}&quot;,\r\n            &quot;password&quot;:&quot;{password_param_name}&quot;\r\n        }\r\n      }\r\n    }\r\n\r\ntarget.json\r\n\r\n    {\r\n      &quot;redis&quot;:{\r\n        &quot;cluster&quot;:{\r\n            &quot;host&quot;:&quot;localhost&quot;,\r\n            &quot;port&quot;:&quot;21&quot;,\r\n            &quot;username&quot;:&quot;temp&quot;,\r\n            &quot;password&quot;:&quot;temp&quot;\r\n        },\r\n        &quot;cluster2&quot;:{\r\n            &quot;host&quot;:&quot;localhost&quot;,\r\n            &quot;port&quot;:&quot;21&quot;,\r\n            &quot;username&quot;:&quot;test&quot;,\r\n            &quot;password&quot;:&quot;temp&quot;\r\n        }\r\n    \r\n      }\r\n    \r\n    }\r\n\r\nSo, here in this case I want to call `aws ssm get-parameters --names &lt;name&gt;` for each param_name present inside the value field (for host, username and password) and replace them in the target.json file.\r\n\r\nI can do it by reading individual params and creating this. But is there any elegant way where we can basically iterate each field using `jq` and then call `aws ssm` command and replaces the value.\r\n`jq` version: `1.5`\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/60835672/invoke-aws-cli-based-on-param-value-from-a-json-file-using-jq",
        "title": "Invoke AWS CLI based on param value from a JSON file using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684823260,
                "last_edit_date": 1684823260,
                "creation_date": 1585106770,
                "answer_id": 60842598,
                "question_id": 60842509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [if/then/else/end][1] syntax itself is straightforward, but when you embed iterators within the subexpressions, you get the &quot;combinatorial&quot; behavior you noticed.  \r\n\r\nIn other words, each occurrence of `.[]` is expanded independently of the others when it is encountered.  \r\n\r\nPerhaps it will be easier to understand if you start with a single iterator, e.g.\r\n\r\n```sh\r\necho &#39;[0, 1, 2]&#39; | \r\n  jq &#39;.[] | if . == 0 then &quot;zero&quot; elif . == 1 then &quot;one&quot; else &quot;many&quot; end&#39;\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#if-then-else",
                "title": "Could you explain if then elif and else syntax of jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1684823260,
        "creation_date": 1585106051,
        "question_id": 60842509,
        "body_markdown": "I am a novice on jq. \r\nWhile studying if then else end syntax of jq manual,  I got strange result as follows: \r\n\r\n```java\r\n$ echo &#39;[0, 1, 2]&#39; | jq &#39;if .[] == 0 then &quot;zero&quot; elif .[] == 1 then &quot;one&quot; else &quot;many&quot; end&#39;\r\n&quot;zero&quot;\r\n&quot;many&quot;\r\n&quot;one&quot;\r\n&quot;many&quot;\r\n&quot;many&quot;\r\n&quot;one&quot;\r\n&quot;many&quot;\r\n```\r\n\r\nDoes anybody explain the above result?\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/60842509/could-you-explain-if-then-elif-and-else-syntax-of-jq",
        "title": "Could you explain if then elif and else syntax of jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1757979,
                    "reputation": 1405,
                    "user_id": 1605761,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/bKwVf.jpg?s=256",
                    "display_name": "Utsav Chokshi",
                    "link": "https://stackoverflow.com/users/1605761/utsav-chokshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585128278,
                "post_id": 60845947,
                "comment_id": 107651905,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1757979,
                    "reputation": 1405,
                    "user_id": 1605761,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/bKwVf.jpg?s=256",
                    "display_name": "Utsav Chokshi",
                    "link": "https://stackoverflow.com/users/1605761/utsav-chokshi"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585128483,
                "post_id": 60845947,
                "comment_id": 107652018,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "reply_to_user": {
                    "account_id": 1757979,
                    "reputation": 1405,
                    "user_id": 1605761,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/bKwVf.jpg?s=256",
                    "display_name": "Utsav Chokshi",
                    "link": "https://stackoverflow.com/users/1605761/utsav-chokshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585128547,
                "post_id": 60845947,
                "comment_id": 107652049,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1757979,
                    "reputation": 1405,
                    "user_id": 1605761,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/bKwVf.jpg?s=256",
                    "display_name": "Utsav Chokshi",
                    "link": "https://stackoverflow.com/users/1605761/utsav-chokshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585128747,
                "post_id": 60845947,
                "comment_id": 107652122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1757979,
                    "reputation": 1405,
                    "user_id": 1605761,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/bKwVf.jpg?s=256",
                    "display_name": "Utsav Chokshi",
                    "link": "https://stackoverflow.com/users/1605761/utsav-chokshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585128789,
                "post_id": 60845947,
                "comment_id": 107652142,
                "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": 1585128858,
                "post_id": 60845947,
                "comment_id": 107652166,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585138914,
                "last_edit_date": 1585138914,
                "creation_date": 1585130782,
                "answer_id": 60846589,
                "question_id": 60845947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Does not exactly match your expected output but you&#39;re probably looking for something like this:\r\n```\r\nmap({PutRequest: {Item: map_values({S: .})}})\r\n```\r\n&lt;sup&gt;[Demo](https://jqplay.org/s/1zmdv4U2Yk)&lt;/sup&gt;",
                "title": "jq: mapping json objects to another format schema"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1585138914,
        "creation_date": 1585128122,
        "last_edit_date": 1585135704,
        "question_id": 60845947,
        "body_markdown": "I need to transform an array of this kind of elements:\r\n\r\n    [\r\n      {\r\n        &quot;Field1&quot;: &quot;value1&quot;,\r\n        &quot;Field2&quot;: &quot;value2&quot;\r\n      },\r\n      {\r\n        &quot;Field1&quot;: &quot;value3&quot;,\r\n        &quot;Field2&quot;: &quot;value4&quot;\r\n      },\r\n      ...\r\n    ]\r\n\r\nTo:\r\n\r\n    [\r\n        &quot;PutRequest&quot;: {\r\n            &quot;Item&quot;: {\r\n                &quot;Field1&quot;: {\r\n                    &quot;S&quot;: &quot;value1&quot;\r\n                },\r\n                &quot;Field2&quot;: {\r\n                    &quot;S&quot;: &quot;value2&quot;\r\n                }\r\n            }\r\n        },\r\n        &quot;PutRequest&quot;: {\r\n            &quot;Item&quot;: {\r\n                &quot;Field1&quot;: {\r\n                    &quot;S&quot;: &quot;value3&quot;\r\n                },\r\n                &quot;Field2&quot;: {\r\n                    &quot;S&quot;: &quot;value4&quot;\r\n                }\r\n            }\r\n        },\r\n        ...\r\n    ]\r\n\r\nI was thinking about using `jq`, but I don&#39;t quite figure out how to get it.\r\n\r\n\r\n**EDIT**\r\n\r\nUp to now, I&#39;ve been able to get that:\r\n\r\n    [.[] | {&quot;Field1&quot;: {&quot;S&quot;: .Field1}, &quot;Field2&quot;: {&quot;S&quot;: .Field2}}]\r\n\r\n\r\nIs there any what to say: for each field add an like `key: {&quot;S&quot;: .value}`?\r\n\r\n**EDIT 2**\r\nUsing `map({PutRequest: {Item: map_values({S: .})}})` approach, it&#39;s generating me:\r\n\r\n     {\r\n        &quot;S&quot;: {\r\n          &quot;Field1&quot;: &quot;value1&quot;,\r\n          &quot;Field2&quot;: &quot;value2&quot;,\r\n        }\r\n    }\r\n\r\nI need: \r\n\r\n    &quot;Item&quot;: {\r\n        &quot;Field1&quot;: {\r\n            &quot;S&quot;: &quot;value3&quot;\r\n        },\r\n        &quot;Field2&quot;: {\r\n            &quot;S&quot;: &quot;value4&quot;\r\n        }\r\n    }\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/60845947/jq-mapping-json-objects-to-another-format-schema",
        "title": "jq: mapping json objects to another format schema"
    },
    {
        "tags": [
            "powershell",
            "docker",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13717922,
                    "reputation": 61814,
                    "user_id": 9898643,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74dbe0b3ffd7ff6f9c820103f99dc262?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Theo",
                    "link": "https://stackoverflow.com/users/9898643/theo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585136315,
                "post_id": 60848049,
                "comment_id": 107655371,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17839268,
                    "reputation": 536,
                    "user_id": 12957503,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ad5984b6b419733524be17dfc99e887a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stackoverflowusrone",
                    "link": "https://stackoverflow.com/users/12957503/stackoverflowusrone"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585136581,
                "post_id": 60848049,
                "comment_id": 107655505,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1880769,
                    "reputation": 24173,
                    "user_id": 1701026,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/7a7d16a281782ff56c0f3670f6ebe08a?s=256&d=identicon&r=PG",
                    "display_name": "iRon",
                    "link": "https://stackoverflow.com/users/1701026/iron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585138031,
                "post_id": 60848049,
                "comment_id": 107656193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244054,
                    "reputation": 25943,
                    "user_id": 1977871,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/96369eebd8de286a6d4b6db05c2bb1fc?s=256&d=identicon&r=PG",
                    "display_name": "VivekDev",
                    "link": "https://stackoverflow.com/users/1977871/vivekdev"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585138260,
                "post_id": 60848049,
                "comment_id": 107656299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1880769,
                    "reputation": 24173,
                    "user_id": 1701026,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/7a7d16a281782ff56c0f3670f6ebe08a?s=256&d=identicon&r=PG",
                    "display_name": "iRon",
                    "link": "https://stackoverflow.com/users/1701026/iron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585139470,
                "post_id": 60848049,
                "comment_id": 107656898,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13717922,
                    "reputation": 61814,
                    "user_id": 9898643,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74dbe0b3ffd7ff6f9c820103f99dc262?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Theo",
                    "link": "https://stackoverflow.com/users/9898643/theo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585154336,
                "post_id": 60848049,
                "comment_id": 107665395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 215377,
                    "reputation": 236747,
                    "user_id": 470005,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/09536b39b586f3ae555f8ce20d5d8bd1?s=256&d=identicon&r=PG",
                    "display_name": "Sergey Berezovskiy",
                    "link": "https://stackoverflow.com/users/470005/sergey-berezovskiy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1612963641,
                "post_id": 60848049,
                "comment_id": 116929337,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1585136598,
                "creation_date": 1585136598,
                "answer_id": 60848171,
                "question_id": 60848049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just pipe in `jq` to your `docker events` command.\r\n\r\n```\r\ndocker events --format &#39;{{json .}}&#39; | jq\r\n```\r\n\r\n[jq Documentation][1]\r\n\r\n\r\n  [1]: https://www.baeldung.com/linux/jq-command-json",
                "title": "Formatting json output from docker events"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1585213366,
                "last_edit_date": 1585213366,
                "creation_date": 1585139891,
                "answer_id": 60849023,
                "question_id": 60848049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the first answer form [Prettify json in powershell 3](https://stackoverflow.com/a/44593864/1701026):\r\n\r\n    $Json = &#39;{&quot;status&quot;:&quot;create&quot;,&quot;id&quot;:&quot;7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37&quot;,&quot;from&quot;:&quot;mcr.microsoft.com/dotnet/core/sdk:3.1&quot;,&quot;Type&quot;:&quot;container&quot;,&quot;Action&quot;:&quot;create&quot;,&quot;Actor&quot;:{&quot;ID&quot;:&quot;7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37&quot;,&quot;Attributes&quot;:{&quot;image&quot;:&quot;mcr.microsoft.com/dotnet/core/sdk:3.1&quot;,&quot;name&quot;:&quot;objective_bhaskara&quot;}},&quot;scope&quot;:&quot;local&quot;,&quot;time&quot;:1585135301,&quot;timeNano&quot;:1585135301351718800}&#39;\r\n    $PrettyJson = $Json | convertfrom-json | convertto-json -depth 100\r\n    $PrettyJson\r\n\r\nResult:\r\n\r\n    {\r\n      &quot;status&quot;: &quot;create&quot;,\r\n      &quot;id&quot;: &quot;7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37&quot;,\r\n      &quot;from&quot;: &quot;mcr.microsoft.com/dotnet/core/sdk:3.1&quot;,\r\n      &quot;Type&quot;: &quot;container&quot;,\r\n      &quot;Action&quot;: &quot;create&quot;,\r\n      &quot;Actor&quot;: {\r\n        &quot;ID&quot;: &quot;7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37&quot;,\r\n        &quot;Attributes&quot;: {\r\n          &quot;image&quot;: &quot;mcr.microsoft.com/dotnet/core/sdk:3.1&quot;,\r\n          &quot;name&quot;: &quot;objective_bhaskara&quot;\r\n        }\r\n      },\r\n      &quot;scope&quot;: &quot;local&quot;,\r\n      &quot;time&quot;: 1585135301,\r\n      &quot;timeNano&quot;: 1585135301351718800\r\n    }\r\n\r\n",
                "title": "Formatting json output from docker events"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1585455095,
        "creation_date": 1585136192,
        "last_edit_date": 1585455095,
        "question_id": 60848049,
        "body_markdown": "I want the docker events output to be more readable. \r\nAm on windows 10 pro, and on a powershell I run this command.\r\n\r\n&gt; docker events --format &quot;{{json .}}&quot;\r\n\r\nIn a different shell when I create a new container, \r\n\r\n&gt; docker create mcr.microsoft.com/dotnet/core/sdk:3.1\r\n\r\nI get some output in json format in the first shell. And that looks something like this.\r\n\r\n&gt; \r\n{&quot;status&quot;:&quot;create&quot;,&quot;id&quot;:&quot;7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37&quot;,&quot;from&quot;:&quot;mcr.microsoft.com/dotnet/core/sdk:3.1&quot;,&quot;Type&quot;:&quot;container&quot;,&quot;Action&quot;:&quot;create&quot;,&quot;Actor&quot;:{&quot;ID&quot;:&quot;7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37&quot;,&quot;Attributes&quot;:{&quot;image&quot;:&quot;mcr.microsoft.com/dotnet/core/sdk:3.1&quot;,&quot;name&quot;:&quot;objective_bhaskara&quot;}},&quot;scope&quot;:&quot;local&quot;,&quot;time&quot;:1585135301,&quot;timeNano&quot;:1585135301351718800}\r\n\r\nMy question is, is there a better way to format that? What should I do to the command \r\n\r\n&gt; docker events --format &quot;{{json .}}&quot; \r\n\r\nSo that it will be formatted in a more readable way. Is there something to pipe that output so that it may look something like the following. I used some online formatter to get to this.\r\n\r\n[![docker event output formatted][1]][1]\r\n\r\n\r\n**UPDATE**\r\n\r\nIts now resolved.\r\n\r\nAs per @Vijay&#39;s [answer][2], I first installed [jq][3]. The steps are:\r\n\r\n 1. Ran power shell as admin.\r\n\r\n 2. Ran the command [choco install jq][4]\r\n\r\n 3. Opened a new command prompt **NOT** powershell. Somehow power shell did not work.\r\n\r\n 4. Issue a command to listen to [docker events][5]. \r\n\r\n 5. If the output has to be [formatted][6], use the command. Also append jq as follows. Note the double quotes(&quot;). Single quotes(&#39;) did not work.\r\n\r\n&gt; docker events --format &quot;{{json .}}&quot; | jq\r\n\r\n 6. Open another prompt and run the following command. This can be a powershell if you wish.\r\n\r\n&gt; docker run hello-world\r\n \r\n 7. You should now see formatted json output streaming real time.\r\n\r\n\r\n \r\n\r\n\r\n  [1]: https://i.sstatic.net/CdKAL.png\r\n  [2]: https://stackoverflow.com/a/60848171/1977871\r\n  [3]: https://stedolan.github.io/jq/download/\r\n  [4]: https://chocolatey.org/packages/jq\r\n  [5]: https://docs.docker.com/engine/reference/commandline/events/\r\n  [6]: https://docs.docker.com/engine/reference/commandline/events/#format-the-output",
        "link": "https://stackoverflow.com/questions/60848049/formatting-json-output-from-docker-events",
        "title": "Formatting json output from docker events"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585223014,
                "last_edit_date": 1585223014,
                "creation_date": 1585165642,
                "answer_id": 60856313,
                "question_id": 60849816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one solution:\r\n```\r\n[(.rows|length) as $n\r\n | (.headers|length) as $hl\r\n | range(0; $n) as $r\r\n | range(0; $hl) as $h\r\n | {row: .rows[$r],\r\n    header: .headers[$h],\r\n    value:  .data[$r * $hl + $h] }\r\n]\r\n```",
                "title": "jq: Data denormalisation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585223014,
        "creation_date": 1585142766,
        "question_id": 60849816,
        "body_markdown": "I have this json:\r\n\r\n    {\r\n\t  &quot;headers&quot;: [&quot;x&quot;, &quot;y&quot;, &quot;z&quot;],\r\n\t  &quot;data&quot;: [1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n\t  &quot;rows&quot;: [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]\r\n    }\r\nand I&#39;d like to end up with this:\r\n```\r\n[{\r\n\t&quot;row&quot;: &quot;a&quot;,\r\n\t&quot;header&quot;: &quot;x&quot;,\r\n\t&quot;value&quot;: 1\r\n}, {\r\n\t&quot;row&quot;: &quot;a&quot;,\r\n\t&quot;header&quot;: &quot;y&quot;,\r\n\t&quot;value&quot;: 2\r\n}, {\r\n\t&quot;row&quot;: &quot;a&quot;,\r\n\t&quot;header&quot;: &quot;z&quot;,\r\n\t&quot;value&quot;: 3\r\n}, {\r\n\t&quot;row&quot;: &quot;b&quot;,\r\n\t&quot;header&quot;: &quot;x&quot;,\r\n\t&quot;value&quot;: 4\r\n}, {\r\n\t&quot;row&quot;: &quot;b&quot;,\r\n\t&quot;header&quot;: &quot;y&quot;,\r\n\t&quot;value&quot;: 5\r\n}, {\r\n\t&quot;row&quot;: &quot;b&quot;,\r\n\t&quot;header&quot;: &quot;z&quot;,\r\n\t&quot;value&quot;: 6\r\n}, {\r\n\t&quot;row&quot;: &quot;c&quot;,\r\n\t&quot;header&quot;: &quot;x&quot;,\r\n\t&quot;value&quot;: 7\r\n}, {\r\n\t&quot;row&quot;: &quot;c&quot;,\r\n\t&quot;header&quot;: &quot;y&quot;,\r\n\t&quot;value&quot;: 8\r\n}, {\r\n\t&quot;row&quot;: &quot;c&quot;,\r\n\t&quot;header&quot;: &quot;z&quot;,\r\n\t&quot;value&quot;: 9\r\n}]\r\n```\r\n\r\nHow do I do it? I&#39;ve tinkered with nested `foreach` until my head exploded. jq is so cool but so different. Here&#39;s how I would do it in PHP:\r\n\r\n```\r\n$jsonString = &#39;{\r\n\t&quot;headers&quot;: [&quot;x&quot;, &quot;y&quot;, &quot;z&quot;],\r\n\t&quot;data&quot;: [1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n\t&quot;rows&quot;: [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]\r\n}&#39;;\r\n$json = json_decode($jsonString);\r\n$output = [];\r\n$k = 0;\r\nforeach($json-&gt;rows as $r) {\r\n    foreach($json-&gt;headers as $h) {\r\n        $p = new stdClass();\r\n        $p-&gt;row = $r;\r\n        $p-&gt;header = $h;\r\n        $p-&gt;value = $json-&gt;data[$k];\r\n        $output[] = $p;\r\n        $k++;\r\n    }\r\n}\r\necho json_encode($output);\r\n```\r\nThanks!",
        "link": "https://stackoverflow.com/questions/60849816/jq-data-denormalisation",
        "title": "jq: Data denormalisation"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4680926,
                    "reputation": 2582,
                    "user_id": 3789665,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/7d5056811ad441fd0b4a755da45d83d4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "greybeard",
                    "link": "https://stackoverflow.com/users/3789665/greybeard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585151460,
                "post_id": 60850556,
                "comment_id": 107663780,
                "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": 1585154051,
                "post_id": 60850556,
                "comment_id": 107665247,
                "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": 1585154136,
                "post_id": 60850556,
                "comment_id": 107665283,
                "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": 1585154335,
                "post_id": 60850556,
                "comment_id": 107665393,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 183182,
                    "reputation": 77525,
                    "user_id": 418413,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/e459bf8123c85dc2c708ee8210c0320b?s=256&d=identicon&r=PG",
                    "display_name": "kojiro",
                    "link": "https://stackoverflow.com/users/418413/kojiro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585154335,
                "post_id": 60850556,
                "comment_id": 107665394,
                "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": 1585154363,
                "post_id": 60850556,
                "comment_id": 107665413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 183182,
                    "reputation": 77525,
                    "user_id": 418413,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/e459bf8123c85dc2c708ee8210c0320b?s=256&d=identicon&r=PG",
                    "display_name": "kojiro",
                    "link": "https://stackoverflow.com/users/418413/kojiro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585154659,
                "post_id": 60850556,
                "comment_id": 107665557,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585159910,
                "creation_date": 1585159910,
                "answer_id": 60854870,
                "question_id": 60850556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An unauthenticated request against https://ip-api.com/#105.154.81.106 using a user agent like a browser gives a nice webpage with content. A similar request using a commandline client like curl or wget...\r\n\r\n    $ curl -s --dump-header headers &quot;https://ip-api.com/#105.154.81.106&quot; &gt; output\r\n\r\nYou can examine the output and headers in depth.\r\n\r\n    $ cat output \r\n    {\r\n      &quot;status&quot; : &quot;fail&quot;,\r\n      &quot;message&quot;: &quot;SSL unavailable for this endpoint, order a key at https://members.ip-api.com/&quot;\r\n    }\r\n\r\nIt looks like JSON, but it is colored in my terminal.\r\n\r\n    $ cat -e output \r\n    ^[[39m{$\r\n      ^[[96m&quot;status&quot;^[[39m : ^[[92m&quot;fail&quot;^[[39m,$\r\n      ^[[96m&quot;message&quot;^[[39m: ^[[92m&quot;SSL unavailable for this endpoint, order a key at https://members.ip-api.com/&quot;^[[39m$\r\n    }$\r\n\r\nThere are ansi escape sequences. Let&#39;s see if the headers are revealing:\r\n\r\n    $ cat headers\r\n    HTTP/1.1 403 Forbidden\r\n    Date: Wed, 25 Mar 2020 18:06:15 GMT\r\n    Content-Type: text/plain; charset=utf-8\r\n    Content-Length: 163\r\n    Access-Control-Allow-Origin: *\r\n    X-Ttl: 47\r\n    X-Rl: 42\r\n\r\nWell, the Content-Type is plain text, not json, so it&#39;s not _wrong_, exactly, but it is surprising. More interesting, though, is that we got a *403*. That message _order a key at https://members.ip-api.com/_ is the real meat, though.\r\n\r\nClearly, the intent here is that you should get a key and make an _authenticated_ request against the API.\r\n\r\nYou can clear the ansi sequences using a tool like [ansifilter](https://gitlab.com/saalen/ansifilter)\r\n\r\n    $ ansifilter output | jq -r .message\r\n    SSL unavailable for this endpoint, order a key at https://members.ip-api.com/\r\n\r\nBut there are no guarantees that this API will continue to &quot;work&quot; this way in the future.",
                "title": "Extracting data out of text from an API with bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1585163552,
                "creation_date": 1585163552,
                "answer_id": 60855823,
                "question_id": 60850556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The correct endpoint for JSON, according to the [API docs](https://ip-api.com/docs/api:json):\r\n\r\n````\r\nhttp://ip-api.com/json\r\n````\r\nSo you can try this (non-https):\r\n````\r\ncurl -s http://ip-api.com/json/105.154.81.106 |  jq &#39;.&#39; \r\n````\r\n\r\nAlso stated in the docs:\r\n\r\n````\r\nHuman usage\r\n\r\nYou can call ip-api.com, without /json/, from cURL, Wget and other CLI HTTP clients and get colourized, pretty printed JSON\r\n````",
                "title": "Extracting data out of text from an API with bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1585163552,
        "creation_date": 1585145354,
        "last_edit_date": 1585155039,
        "question_id": 60850556,
        "body_markdown": "I have a challenge, but I don&#39;t find any information, including here, about the command *jq*. I had tried *curl* to access the page with a json application API. So I use | to run both, but it always show a error.\r\n\r\n    curl -s &quot;https://ip-api.com/#105.154.81.106&quot; |  jq &#39;.&#39; \r\n\r\nAfter all, I had read that &#39;.&#39; comes every content, but the only thing that return is:\r\n\r\n    parse error: Invalid numeric literal at line 1, column 2",
        "link": "https://stackoverflow.com/questions/60850556/extracting-data-out-of-text-from-an-api-with-bash",
        "title": "Extracting data out of text from an API with bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585175609,
                "creation_date": 1585175609,
                "answer_id": 60858354,
                "question_id": 60858118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It can be done by invoking `jq` two times like this:\r\n\r\n    jq -c &#39;.[]&#39; *.json | jq -s\r\n\r\n### How it works\r\n\r\n`*.json` is evaluated by the shell and replaced with the list of matching files. `jq` gets the names of all JSON files in the current directory as arguments. It reads them one by one and runs the program `.[]` on the JSONs they contain.\r\n\r\nEach JSON file contains an array. `.[]` extracts the items from the array and dumps them.&lt;br&gt;\r\n`-c` tells `jq` to output each value (the items extracted by `.[]`) on a single line.\r\n\r\nThe output of the first `jq` command is composed of one line for each object from the arrays stored in the input files.\r\n\r\nThis output is then fed to the second `jq` command whose `-s` argument tells it to read everything (it normally reads one JSON at a time) and put all the objects it decodes from the input JSONs into an array. This is exactly what you want.",
                "title": "Merge a list of json files containing JSON arrays"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1585180011,
                "creation_date": 1585180011,
                "answer_id": 60859038,
                "question_id": 60858118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    jq -s &#39;add&#39; file1.json file2.json\r\n\r\nUsing `-s`lurp mode makes `jq` handle multiple inputs in a single pass, concatenating them into an array that contains your two arrays. We can merge them into a single one by transforming the input array with the `add` filter which yields the sum of each element as if using `+`; using it on arrays returns a single array with all the elements of both arrays.",
                "title": "Merge a list of json files containing JSON arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1585180011,
        "creation_date": 1585174235,
        "last_edit_date": 1585174665,
        "question_id": 60858118,
        "body_markdown": "I have a list of json files like:\r\n\r\n    file1.json\r\n    [\r\n      {obj1}\r\n    ]\r\n    \r\n    file2.json\r\n    [\r\n      {obj2}\r\n    ]\r\n\r\n\r\nand I want to merge them all into one file:\r\n\r\n    [\r\n      {obj1},\r\n      {obj2}\r\n    ]\r\n\r\nHow can I achieve this using jq?",
        "link": "https://stackoverflow.com/questions/60858118/merge-a-list-of-json-files-containing-json-arrays",
        "title": "Merge a list of json files containing JSON arrays"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585191800,
                "creation_date": 1585191800,
                "answer_id": 60860427,
                "question_id": 60858369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If a straightforward, two-line solution is what you&#39;re looking for, then jq is a good choice:\r\n\r\n    (INDEX($A[]; .URL) | map_values(.Position)) as $dict\r\n    | map( .PreviousPosition = $dict[ .URL ] )\r\n\r\nThis is perhaps more straightforward than it looks, as the expression in the first line is a commonly found idiom (namely `INDEX(...) | map_values(...)`) for creating a dictionary.  In the first line, it is assumed that $A holds the JSON in data-A.json.\r\n\r\nThe second line just applies the lookup rule specified in the question.\r\n\r\nThe only tricky bit here is getting the command-line invocation right.  The following will suffice:\r\n\r\n    jq --argfile A data-A.json -f program.jq data-B.json\r\n\r\nwhere program.jq contains the above two-line program.\r\n\r\n",
                "title": "Compare 2 JSON-files and create a new key if values match"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585192590,
        "creation_date": 1585175687,
        "last_edit_date": 1585192590,
        "question_id": 60858369,
        "body_markdown": "I have 2 sets of JSON-files looking like below, `data-A.json` and `data-B.json`. \r\n\r\nI need to somehow compare the key `URL` in `data-A.json` with the same key in `data-B.json`. Where there is a match take data from the key `Position` in `data-A.json` and write to new key `PreviousPosition` in `data-B.json`. If there is no matching `URL`, write a null value for this new key in `data-B.json`\r\n\r\nPlease see examples:\r\n\r\n**data-A.json**\r\n\r\n    [\r\n        {\r\n            &quot;Position&quot;: &quot;1&quot;,\r\n            &quot;TrackName&quot;: &quot;One hit wonder&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/xyz123&quot;\r\n        },\r\n        {\r\n            &quot;Position&quot;: &quot;2&quot;,\r\n            &quot;TrackName&quot;: &quot;Random song&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/123qwe&quot;\r\n        },\r\n        {\r\n            &quot;Position&quot;: &quot;3&quot;,\r\n            &quot;TrackName&quot;: &quot;Dueling banjos&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/asd456&quot;\r\n        }\r\n    ]\r\n\r\n**data-B.json**\r\n\r\n    [\r\n        {\r\n            &quot;Position&quot;: &quot;1&quot;,\r\n            &quot;TrackName&quot;: &quot;Rocket&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/nbs678&quot;\r\n        },\r\n        {\r\n            &quot;Position&quot;: &quot;2&quot;,\r\n            &quot;TrackName&quot;: &quot;Dueling banjos&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/asd456&quot;\r\n        },\r\n        {\r\n            &quot;Position&quot;: &quot;3&quot;,\r\n            &quot;TrackName&quot;: &quot;One hit wonder&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/xyz123&quot;\r\n        }\r\n    ]\r\n\r\n(desired) **data-B.json**\r\n\r\n    [\r\n        {\r\n            &quot;Position&quot;: &quot;1&quot;,\r\n            &quot;TrackName&quot;: &quot;Rocket&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/nbs678&quot;,\r\n            &quot;PreviousPosition&quot;: null\r\n        },\r\n        {\r\n            &quot;Position&quot;: &quot;2&quot;,\r\n            &quot;TrackName&quot;: &quot;Dueling banjos&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/asd456&quot;,\r\n            &quot;PreviousPosition&quot;: &quot;3&quot;\r\n        },\r\n            {\r\n            &quot;Position&quot;: &quot;3&quot;,\r\n            &quot;TrackName&quot;: &quot;One hit wonder&quot;,\r\n            &quot;URL&quot;: &quot;https://domain.local/xyz123&quot;,\r\n            &quot;PreviousPosition&quot;: &quot;1&quot;\r\n        }\r\n    ]\r\n\r\nI have done some mediocre attemps to solve this using [jq][1] with no luck. Also tried some PowerShell and Python but I just can&#39;t figure it out.\r\n\r\nAny suggestions?\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/60858369/compare-2-json-files-and-create-a-new-key-if-values-match",
        "title": "Compare 2 JSON-files and create a new key if values match"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585228484,
                "creation_date": 1585228484,
                "answer_id": 60868137,
                "question_id": 60863656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;Is there any way to pipeline above two commands?\r\n\r\nWe can make use of the `split --filter` option:\r\n\r\n    jq -c &#39;.[]&#39; csvjson.json |\r\n    split -l25 --filter=&#39;jq --slurp &quot;map({PutRequest: {Item: map_values({S: .})}})&quot; &gt;$FILE.json&#39; - output",
                "title": "shell script: use pipelines instead of files for batch processing"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585228484,
        "creation_date": 1585212644,
        "question_id": 60863656,
        "body_markdown": "I&#39;m using these two commands in order to process a huge single sequence of json objects:\r\n\r\n    $ jq -c &#39;.[]&#39; csvjson.json | split -l 25 - splitted\r\n\r\nAbove command, creates several `splitted-*` files, containing 25 lines each one.\r\n\r\n    $ jq --slurp &#39;map({PutRequest: {Item: map_values({S: .})}})&#39; splitted-n &gt; output-n.json\r\n\r\nIs there any way to pipeline above two commands?",
        "link": "https://stackoverflow.com/questions/60863656/shell-script-use-pipelines-instead-of-files-for-batch-processing",
        "title": "shell script: use pipelines instead of files for batch processing"
    },
    {
        "tags": [
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1585220053,
                "last_edit_date": 1585220053,
                "creation_date": 1585219624,
                "answer_id": 60865506,
                "question_id": 60865446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Its a minor typo, the `sub()` function along with the other functions in `jq` takes arguments separated by `;` and not `,` which is an operator in the context of `jq`. It should have been written as \r\n\r\n    sub(&quot;b&quot;; &quot;f&quot;)\r\n\r\nThe error is likely because the runtime wasn&#39;t able to match the your call to to the actual signature of the `sub()` function.",
                "title": "Using &quot;sub()&quot; in jq v1.6 errors in &quot;sub is not defined&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1585303708,
        "creation_date": 1585219434,
        "last_edit_date": 1585303708,
        "question_id": 60865446,
        "body_markdown": "i keep running into the error &quot;sub is not defined&quot; when using jq version 1.6\r\n\r\nfor example: `&quot;bar&quot; | sub(&quot;b&quot;,&quot;f&quot;)`\r\n(see on jqplay: https://jqplay.org/s/ggmuK5WvZF)\r\n\r\nhere is a link to the documentation: https://stedolan.github.io/jq/manual/v1.6/#sub(regex;tostring)sub(regex;string;flags)\r\n\r\n\r\nwhat am i doing wrong?",
        "link": "https://stackoverflow.com/questions/60865446/using-sub-in-jq-v1-6-errors-in-sub-is-not-defined",
        "title": "Using &quot;sub()&quot; in jq v1.6 errors in &quot;sub is not defined&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq",
            "slack"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14023100,
                    "reputation": 869,
                    "user_id": 10128864,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GLXFR.jpg?s=256",
                    "display_name": "R. Barrett",
                    "link": "https://stackoverflow.com/users/10128864/r-barrett"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585242210,
                "post_id": 60871796,
                "comment_id": 107698765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5513612,
                    "reputation": 33143,
                    "user_id": 4379151,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kOLJQ.jpg?s=256",
                    "display_name": "Erik Kalkoken",
                    "link": "https://stackoverflow.com/users/4379151/erik-kalkoken"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585260124,
                "post_id": 60871796,
                "comment_id": 107706014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14023100,
                    "reputation": 869,
                    "user_id": 10128864,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GLXFR.jpg?s=256",
                    "display_name": "R. Barrett",
                    "link": "https://stackoverflow.com/users/10128864/r-barrett"
                },
                "reply_to_user": {
                    "account_id": 5513612,
                    "reputation": 33143,
                    "user_id": 4379151,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kOLJQ.jpg?s=256",
                    "display_name": "Erik Kalkoken",
                    "link": "https://stackoverflow.com/users/4379151/erik-kalkoken"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585262102,
                "post_id": 60871796,
                "comment_id": 107706682,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1585262000,
                "creation_date": 1585262000,
                "answer_id": 60877228,
                "question_id": 60871796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So many thanks to one of my buddies who is an SRE, he was able to point me in the right direction. When trying to read something from a `secrets.json` it wasn&#39;t specifying the $message_1. But now if you replace the \r\n```bash\r\n--data &#39;{&quot;text&quot;:&quot;$message_1&quot;}&#39;\r\n```\r\n\r\nwith \r\n\r\n```bash\r\n--data &quot;{\\&quot;text\\&quot;:\\&quot;$message_1\\&quot;}&quot;\r\n```\r\nyou can then call the messages from within another file without exposing them. \r\nThis makes any links you may need to put in the message more secure as well as they are not hardcoded to the message. ",
                "title": "Trying to Load A Message Payload from a JSON File in Bash to Send to Slack Channel"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585262000,
        "creation_date": 1585240134,
        "last_edit_date": 1585249084,
        "question_id": 60871796,
        "body_markdown": "So I am trying to send a message to a specific slack channel using a `secrets.json` file to specify the payloads for both messages and the web-hook URL. I am able to post things to the message but it does not load the message as a payload even though the payload variable is set correctly. How can I load message payloads within the curl command I am specifying?\r\n\r\nHere is the code:\r\n```bash\r\n richardbarret@1152-MBP  ~/Git/SalesforceCLI/Integration/Slack   master ●  ./automated_messages.sh                                                      ✔  1488  10:48:42\r\nhttps://hooks.slack.com/services/XXXXXXXXX/XXXXXXX/XXXXXX\r\nWebhook Variable is Working.\r\ninvalid_payload%                                                                                                                                                                   richardbarret@1152-MBP  ~/Git/SalesforceCLI/Integration/Slack   master ●  cat automated_messages.sh                                                    ✔  1489  10:48:59\r\n#!/bin/bash\r\n# ===========================================================\r\n# Created By: Richard Barrett\r\n# Organization: Mirantis\r\n# Department: Customer Success Operation\r\n# Purpose: Send Message to Slack Channel\r\n# Date: 03/20/2020\r\n# ===========================================================\r\n\r\n# System Variables\r\nwebhook_url=$(cat secrets.json | jq &quot;.slack_config.slack_target_url&quot; | tr -d \\&quot;)\r\necho $webhook_url\r\nprintf &quot;Webhook Variable is Working.\\n&quot;\r\n\r\nmessage_1=$(cat secrets.json | jq &quot;.slack_messages.message_1&quot; | tr -d \\&quot;)\r\nmessage_2=$(cat secrets.json | jq &quot;.slack_messages.message_2&quot; | tr -d \\&quot;)\r\nmessage_3=$(cat secrets.json | jq &quot;.slack_messages.message_3&quot; | tr -d \\&quot;)\r\n\r\n# Use Messages in this command syntax\r\n# Example\r\n# curl -X POST -H &#39;Content-type: application/json&#39; --data &#39;{&quot;text&quot;:&quot;TEST TEXT BODY&quot;}&#39; $webhook_url\r\n\r\n# General Message:\r\ncurl -X POST -H &#39;Content-type: application/json&#39; --data &#39;{&quot;text&quot;:&quot;$message_1&quot;}&#39; $webhook_url\r\n\r\n# Messages for Handover:\r\n#curl -X POST -H &#39;Content-type: application/json&#39; --data &#39;{&quot;text&quot;:&quot;Handovers: https://mirantis.my.salesforce.com/XXXXXXXXXXXXXXX&quot;}&#39; $webhook_url\r\n\r\n# Message for All Change Requests:\r\n#curl -X POST -H &#39;Content-type: application/json&#39; --data &#39;{&quot;text&quot;:&quot;All Change Requests: https://mirantis.my.salesforce.com/XXXXXXXXXXXX&quot;}&#39; $webhook_url\r\n\r\n# Message for Change Requests in Ready to Execute\r\n# curl -X POST -H &#39;Content-type: application/json&#39; --data &#39;{&quot;text&quot;:&quot;All CRs in Ready to Execute:&quot;}&#39; $webhook_url\r\n```\r\n\r\nI fixed the `Invalid Payload` because I forgot to use the `&quot;text&quot;:` option within the `--data` so I know that is not the issue. When I run the above script all that get&#39;s posted it the following:\r\n[![enter image description here][1]][1]\r\n\r\n\r\nSo I tried deleting the quotations around `$message_1` and got the message:\r\n```\r\nWebhook Variable is Working.\r\ninvalid_payload%\r\n```\r\n\r\nI deleted the Webhook response because it has a slack token. \r\nThe webhook works, but the messages are not loading in the payload curl for the --data for some odd reason. \r\n\r\nThe `secrets.json` looks like this:\r\n```bash\r\n{\r\n    &quot;slack_config&quot;: {\r\n        &quot;slack_target_url&quot;: &quot;https://hooks.slack.com/services/XXXXXXX/XXXXXXXXXXX/XXXXXXXXXXXXXXX&quot;\r\n    },\r\n    &quot;slack_messages&quot;: {\r\n        &quot;message_1&quot;: &quot;SLACK_MESSAGE_1 Testing Secrets Calls from secrets.json File&quot;,\r\n        &quot;message_3&quot;: &quot;SLACK_MESSAGE_3 Testing Secrets Calls from secrets.json File&quot;,\r\n        &quot;message_2&quot;: &quot;SLACK_MESSAGE_2 Testing Secrets Calls from secrets.json File&quot;\r\n    }\r\n}\r\n```\r\n\r\n  [1]: https://i.sstatic.net/XTLqw.png",
        "link": "https://stackoverflow.com/questions/60871796/trying-to-load-a-message-payload-from-a-json-file-in-bash-to-send-to-slack-chann",
        "title": "Trying to Load A Message Payload from a JSON File in Bash to Send to Slack Channel"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1585250102,
                "last_edit_date": 1585250102,
                "creation_date": 1585249842,
                "answer_id": 60874486,
                "question_id": 60874368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the error message is clear enough. You can&#39;t index strings with strings, you need to select objects.\r\n\r\nAssuming `LoadBalancerGroup` is always an object, and a null `name` being ignored is not a concern:\r\n```\r\n.. | objects | .LoadBalancerGroup.name // empty\r\n```",
                "title": "Cannot index string with string while using recursion"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585250102,
        "creation_date": 1585249313,
        "last_edit_date": 1585250057,
        "question_id": 60874368,
        "body_markdown": "I&#39;m attempting to parse this sample json using jq \r\n\r\n```\r\n{\r\n  &quot;config&quot;: {\r\n    &quot;env-1&quot;: {\r\n      &quot;LoadBalancerGroup&quot;: {\r\n        &quot;Algorithm&quot;: &quot;weighted-round-robin&quot;,\r\n        &quot;LBGroupMembers&quot;: [\r\n          {\r\n            &quot;Server&quot;: &quot;10.183.191.131&quot;\r\n          },\r\n          {\r\n            &quot;Server&quot;: &quot;10.183.191.153&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;LBG-https&quot;,\r\n        &quot;state&quot;: {\r\n          &quot;opstate&quot;: &quot;up&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nenv-1 key will vary, and I need to access using recursion (..) or similar technique\r\n\r\nI&#39;m stuck on the following error which is likely related to searching non hash nodes \r\n\r\n```\r\ncat recursion.json | jq  &#39; ..|.[&quot;LoadBalancerGroup&quot;]|.&quot;name&quot;?&#39; | jq .\r\njq: error (at &lt;stdin&gt;:20): Cannot index string with string &quot;LoadBalancerGroup&quot;\r\nnull\r\nnull\r\n&quot;LBG-https&quot;\r\nnull\r\n```\r\n\r\ntrying select(type == &quot;object&quot; and has(&quot;name&quot;))) and other suggestions have not solved this issue, and I&#39;d appreciate any suggestions.\r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60874368/cannot-index-string-with-string-while-using-recursion",
        "title": "Cannot index string with string while using recursion"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1585276018,
                "creation_date": 1585276018,
                "answer_id": 60879138,
                "question_id": 60878877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your data, and using the -r command-line option, the following program produces the output shown below:\r\n```\r\n[.[]]\r\n| map(select(.status == &quot;ok&quot;))\r\n| (max_by( .tag | sub(&quot;group-&quot;;&quot;&quot;) | tonumber) | .tag) as $mx\r\n| .[]\r\n| select(.tag==$mx)\r\n| &quot;City: \\(.name)&quot;\r\n```\r\nOutput:\r\n```\r\nCity: Singapore\r\nCity: New York\r\n```\r\nIf you want the cities listed in alphabetical order, then you can add the appropriate `sort_by` filter to the jq pipeline.",
                "title": "Parsing Json nested objects in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585276018,
        "creation_date": 1585274024,
        "question_id": 60878877,
        "body_markdown": "I&#39;m accessing an API that returns JSON with nested objects like this:\r\n\r\n```\r\n{\r\n  &quot;9273&quot;: {\r\n    &quot;status&quot;: &quot;ok&quot;,\r\n    &quot;tag&quot;: &quot;group-8&quot;,\r\n    &quot;name&quot;: &quot;London&quot;\r\n  },\r\n  &quot;4029&quot;: {\r\n    &quot;status&quot;: &quot;unknown&quot;,\r\n    &quot;tag&quot;: &quot;group-12&quot;,\r\n    &quot;name&quot;: &quot;Tokyo&quot;\r\n  },\r\n  &quot;6322&quot;: {\r\n    &quot;status&quot;: &quot;ok&quot;,\r\n    &quot;tag&quot;: &quot;group-12&quot;,\r\n    &quot;name&quot;: &quot;Singapore&quot;\r\n  },\r\n  &quot;1038&quot;: {\r\n    &quot;status&quot;: &quot;unknown&quot;,\r\n    &quot;tag&quot;: &quot;group-19&quot;,\r\n    &quot;name&quot;: &quot;Melbourne&quot;\r\n  },\r\n  &quot;2938&quot;: {\r\n    &quot;status&quot;: &quot;ok&quot;,\r\n    &quot;tag&quot;: &quot;group-12&quot;,\r\n    &quot;name&quot;: &quot;New York&quot;\r\n  }\r\n}\r\n```\r\n\r\nI&#39;m trying to parse the JSON using `jq`, `regex`, `sed` etc. in a Bash script, filter it on `status` (ok) and `tag` (highest group with an &#39;ok&#39;), and flatten the matching objects to get a multi-line sorted string value of their `name` along with a static prefix (e.g. City).\r\n\r\nDesired output below:\r\n\r\n```\r\nCity: New York\r\nCity: Singapore\r\n```\r\n\r\nI&#39;ll appreciate any help in working this out.",
        "link": "https://stackoverflow.com/questions/60878877/parsing-json-nested-objects-in-bash",
        "title": "Parsing Json nested objects in Bash"
    },
    {
        "tags": [
            "json",
            "sorting",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585335906,
                "last_edit_date": 1585335906,
                "creation_date": 1585323018,
                "answer_id": 60889140,
                "question_id": 60886010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To specify the keys and their order:\r\n \r\n     { beka, alma, paprika, korte }\r\n\r\n## Caveat\r\n\r\nThis only works for keys with &quot;ordinary&quot; names.  For example, since `end` is a jq keyword, you would have to write:\r\n\r\n    { &quot;end&quot;: .end}\r\n\r\nfor a key named &quot;end&quot;, at least using extant versions of jq.",
                "title": "sort keys in arbitrary order"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585335906,
        "creation_date": 1585312090,
        "last_edit_date": 1585314133,
        "question_id": 60886010,
        "body_markdown": "For a side-project I want to sort the keys of a JSON with jq, and come up with the following solution:\r\n\r\n```\r\ndef add_property_prefix:\r\n    if .key == &quot;beka&quot; then &quot;01__&quot;+.key\r\n    elif .key == &quot;alma&quot; then &quot;02__&quot;+.key\r\n    elif .key == &quot;paprika&quot; then &quot;03__&quot;+.key\r\n    elif .key == &quot;korte&quot; then &quot;04__&quot;+.key\r\n    else .key end\r\n;\r\n\r\ndef del_property_prefix:\r\n    .key | sub(&quot;^[0-9]{2}__&quot;; &quot;&quot;)\r\n;\r\n\r\nto_entries\r\n| map({ key: add_property_prefix, value: .value })\r\n| sort_by(.key)\r\n| map({ key: del_property_prefix, value: .value })\r\n| from_entries\r\n```\r\n\r\nAnd the input JSON looks like this:\r\n```json\r\n{\r\n    &quot;alma&quot;: 1,\r\n    &quot;beka&quot;: 2,\r\n    &quot;paprika&quot;: 3,\r\n    &quot;korte&quot;: 4\r\n}\r\n```\r\n\r\n([jq play link][1])\r\n\r\nWhile this works, I have more than 10 keys and the `add_property_prefix` function is really bloaty because of this.\r\n\r\n**The question: is there a way to make sorting list less redundant?**\r\n\r\nI was thinking of some kind of map, but I don&#39;t know jq that much to figure out a more elegant solution.\r\n\r\n[1]: https://jqplay.org/jq?q=def%20add_property_prefix%3A%20if%20.key%20%3D%3D%20%22beka%22%20then%20%2201__%22%2B.key%20elif%20.key%20%3D%3D%20%22alma%22%20then%20%2202__%22%2B.key%20elif%20.key%20%3D%3D%20%22paprika%22%20then%20%2203__%22%2B.key%20elif%20.key%20%3D%3D%20%22korte%22%20then%20%2204__%22%2B.key%20else%20.key%20end%3B%20def%20del_property_prefix%3A%20.key%20%7C%20sub(%22%5E%5B0-9%5D%7B2%7D__%22%3B%20%22%22)%3B%20to_entries%20%7C%20map(%7B%20key%3A%20add_property_prefix%2C%20value%3A%20.value%20%7D)%20%7C%20sort_by(.key)%20%7C%20map(%7B%20key%3A%20del_property_prefix%2C%20value%3A%20.value%20%7D)%20%7C%20from_entries&amp;j=%7B%22alma%22%3A1%2C%22beka%22%3A2%2C%22paprika%22%3A3%2C%22korte%22%3A4%7D",
        "link": "https://stackoverflow.com/questions/60886010/sort-keys-in-arbitrary-order",
        "title": "sort keys in arbitrary order"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17824751,
                    "reputation": 1591,
                    "user_id": 12946233,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3eb8769c902185761b3a9b4eea320f54?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rolf82",
                    "link": "https://stackoverflow.com/users/12946233/rolf82"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585319046,
                "post_id": 60887677,
                "comment_id": 107725003,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1932078,
                    "reputation": 473,
                    "user_id": 1741264,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/90781b338636c70831f8375377de3b4f?s=256&d=identicon&r=PG",
                    "display_name": "JuanD",
                    "link": "https://stackoverflow.com/users/1741264/juand"
                },
                "reply_to_user": {
                    "account_id": 17824751,
                    "reputation": 1591,
                    "user_id": 12946233,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3eb8769c902185761b3a9b4eea320f54?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rolf82",
                    "link": "https://stackoverflow.com/users/12946233/rolf82"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585319402,
                "post_id": 60887677,
                "comment_id": 107725244,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1932078,
                    "reputation": 473,
                    "user_id": 1741264,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/90781b338636c70831f8375377de3b4f?s=256&d=identicon&r=PG",
                    "display_name": "JuanD",
                    "link": "https://stackoverflow.com/users/1741264/juand"
                },
                "reply_to_user": {
                    "account_id": 17824751,
                    "reputation": 1591,
                    "user_id": 12946233,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3eb8769c902185761b3a9b4eea320f54?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rolf82",
                    "link": "https://stackoverflow.com/users/12946233/rolf82"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585320340,
                "post_id": 60887677,
                "comment_id": 107725780,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585321491,
                "creation_date": 1585321491,
                "answer_id": 60888650,
                "question_id": 60887677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `[]` instead of `null` doesn&#39;t bother you:\r\n```\r\nmap(.subCategories |=\r\n  map({name, subCategories: (.subCategories // [] |\r\n    map({name}))}))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Ra6iOY47qf)&lt;/sup&gt;",
                "title": "parsing through nested arrays with null"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585322016,
        "creation_date": 1585318109,
        "last_edit_date": 1585322016,
        "question_id": 60887677,
        "body_markdown": "When I curl an API and get the following data (sample data):\r\n\r\n```\r\n[\r\n  {\r\n    &quot;identifier&quot;: &quot;IdNum&quot;,\r\n    &quot;name&quot;: &quot;TopCatA&quot;,\r\n    &quot;subCategories&quot;: [\r\n      {\r\n        &quot;categoryId&quot;: &quot;19232&quot;,\r\n        &quot;identifier&quot;: &quot;83434&quot;,\r\n        &quot;name&quot;: &quot;Mens&quot;,\r\n        &quot;sequence&quot;: 10,\r\n        &quot;attributes&quot;: {\r\n          &quot;PrimaryFaceOutImage&quot;: &quot;prod1&quot;,\r\n          &quot;PrimaryHoverImage&quot;: &quot;model1&quot;,\r\n          &quot;categoryLabel&quot;: &quot;Mens Clothing &amp; Accessories&quot;,\r\n          &quot;viewall&quot;: &quot;false&quot;\r\n        },\r\n        &quot;subCategories&quot;: [\r\n          {\r\n            &quot;categoryId&quot;: &quot;23423423&quot;,\r\n            &quot;identifier&quot;: &quot;456456456&quot;,\r\n            &quot;name&quot;: &quot;Shirts&quot;,\r\n            &quot;categoryImage&quot;: &quot;gfhhfghfg&quot;,\r\n            &quot;sequence&quot;: 1,\r\n            &quot;attributes&quot;: {\r\n              &quot;CategoryGroupType&quot;: &quot;features&quot;,\r\n              &quot;PrimaryFaceOutImage&quot;: &quot;false&quot;,\r\n              &quot;viewall&quot;: &quot;false&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;categoryId&quot;: &quot;3423423&quot;,\r\n            &quot;identifier&quot;: &quot;234234234234&quot;,\r\n            &quot;name&quot;: &quot;Jeans&quot;,\r\n            &quot;categoryImage&quot;: &quot;sdfadsf-sdfas-asdf-sdfasdf&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;categoryId&quot;: &quot;234234234&quot;,\r\n        &quot;identifier&quot;: &quot;45345&quot;,\r\n        &quot;name&quot;: &quot;Womens&quot;,\r\n        &quot;sequence&quot;: 12,\r\n        &quot;attributes&quot;: {\r\n          &quot;PrimaryFaceOutImage&quot;: &quot;prod1&quot;,\r\n          &quot;PrimaryHoverImage&quot;: &quot;model1&quot;,\r\n          &quot;categoryLabel&quot;: &quot;Womens Clothing &amp; Accessories&quot;,\r\n          &quot;viewall&quot;: &quot;false&quot;\r\n        },\r\n        &quot;subCategories&quot;: [\r\n          {\r\n            &quot;categoryId&quot;: &quot;23423423&quot;,\r\n            &quot;identifier&quot;: &quot;456456456&quot;,\r\n            &quot;name&quot;: &quot;Shirts&quot;,\r\n            &quot;categoryImage&quot;: &quot;gfhhfghfg&quot;,\r\n            &quot;sequence&quot;: 1,\r\n            &quot;attributes&quot;: {\r\n              &quot;CategoryGroupType&quot;: &quot;features&quot;,\r\n              &quot;PrimaryFaceOutImage&quot;: &quot;false&quot;,\r\n              &quot;viewall&quot;: &quot;false&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;categoryId&quot;: &quot;3423423&quot;,\r\n            &quot;identifier&quot;: &quot;234234234234&quot;,\r\n            &quot;name&quot;: &quot;Jeans&quot;,\r\n            &quot;categoryImage&quot;: &quot;sdfadsf-sdfas-asdf-sdfasdf&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;categoryId&quot;: &quot;23423423&quot;,\r\n        &quot;identifier&quot;: &quot;SOME_SALE&quot;,\r\n        &quot;name&quot;: &quot;Sale&quot;,\r\n        &quot;sequence&quot;: 23,\r\n        &quot;attributes&quot;: {\r\n          &quot;PrimaryFaceOutImage&quot;: &quot;prod1&quot;,\r\n          &quot;PrimaryHoverImage&quot;: &quot;model1&quot;,\r\n          &quot;viewall&quot;: &quot;false&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;identifier&quot;: &quot;IdNum&quot;,\r\n    &quot;name&quot;: &quot;TopCatB&quot;,\r\n    &quot;subCategories&quot;: [\r\n      {\r\n        &quot;categoryId&quot;: &quot;234234&quot;,\r\n        &quot;identifier&quot;: &quot;45345&quot;,\r\n        &quot;name&quot;: &quot;Boys&quot;,\r\n        &quot;sequence&quot;: 43,\r\n        &quot;attributes&quot;: {\r\n          &quot;PrimaryFaceOutImage&quot;: &quot;prod1&quot;,\r\n          &quot;PrimaryHoverImage&quot;: &quot;model1&quot;,\r\n          &quot;categoryLabel&quot;: &quot;Boys Clothing &amp; Accessories&quot;,\r\n          &quot;viewall&quot;: &quot;false&quot;\r\n        },\r\n        &quot;subCategories&quot;: [\r\n          {\r\n            &quot;categoryId&quot;: &quot;23423423&quot;,\r\n            &quot;identifier&quot;: &quot;456456456&quot;,\r\n            &quot;name&quot;: &quot;Shirts&quot;,\r\n            &quot;categoryImage&quot;: &quot;gfhhfghfg&quot;,\r\n            &quot;sequence&quot;: 1,\r\n            &quot;attributes&quot;: {\r\n              &quot;CategoryGroupType&quot;: &quot;features&quot;,\r\n              &quot;viewall&quot;: &quot;false&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;categoryId&quot;: &quot;3423423&quot;,\r\n            &quot;identifier&quot;: &quot;234234234234&quot;,\r\n            &quot;name&quot;: &quot;Jeans&quot;,\r\n            &quot;categoryImage&quot;: &quot;sdfadsf-sdfas-asdf-sdfasdf&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;categoryId&quot;: &quot;345234&quot;,\r\n        &quot;identifier&quot;: &quot;345345345&quot;,\r\n        &quot;name&quot;: &quot;Girls&quot;,\r\n        &quot;sequence&quot;: 10,\r\n        &quot;attributes&quot;: {\r\n          &quot;PrimaryFaceOutImage&quot;: &quot;prod1&quot;,\r\n          &quot;categoryLabel&quot;: &quot;Girls Clothing &amp; Accessories&quot;,\r\n          &quot;viewall&quot;: &quot;false&quot;\r\n        },\r\n        &quot;subCategories&quot;: [\r\n          {\r\n            &quot;categoryId&quot;: &quot;23423423&quot;,\r\n            &quot;identifier&quot;: &quot;456456456&quot;,\r\n            &quot;name&quot;: &quot;Shirts&quot;,\r\n            &quot;categoryImage&quot;: &quot;gfhhfghfg&quot;,\r\n            &quot;sequence&quot;: 1,\r\n            &quot;attributes&quot;: {\r\n              &quot;CategoryGroupType&quot;: &quot;features&quot;,\r\n              &quot;viewall&quot;: &quot;false&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;categoryId&quot;: &quot;3423423&quot;,\r\n            &quot;identifier&quot;: &quot;234234234234&quot;,\r\n            &quot;name&quot;: &quot;Jeans&quot;,\r\n            &quot;categoryImage&quot;: &quot;sdfadsf-sdfas-asdf-sdfasdf&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;categoryId&quot;: &quot;23423423&quot;,\r\n        &quot;identifier&quot;: &quot;SOME_SALE&quot;,\r\n        &quot;name&quot;: &quot;Sale&quot;,\r\n        &quot;sequence&quot;: 45,\r\n        &quot;attributes&quot;: {\r\n          &quot;PrimaryFaceOutImage&quot;: &quot;prod1&quot;,\r\n          &quot;categoryLabel&quot;: &quot;Sale&quot;,\r\n          &quot;displaySoldOut&quot;: &quot;true&quot;,\r\n          &quot;viewall&quot;: &quot;false&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\n\r\nI am trying to apply a jq filter so as to be left with only the names and values of all the subcategories while maintaining the nested structure and having BOTH TopCatA and TopCatB in the final output.  The issue is that one of the subcategories (sale) doesnt have subcategories like the other ones (Mens, Womens) so I get the `Cannot iterate over null (null)` message.\r\n\r\nI have tried a few different jq filters but cant seem to get the nesting to preserve.  The end result I&#39;m looking for is to get something like this:\r\n\r\n```\r\n[\r\n    {\r\n      &quot;identifier&quot;: &quot;IdNum&quot;,\r\n      &quot;name&quot;: &quot;TopCatA&quot;,\r\n      &quot;subCategories&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Mens&quot;,\r\n          &quot;subCategories&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Shirts&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Jeans&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Womens&quot;,\r\n          &quot;subCategories&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Shirts&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Jeans&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Sale&quot;\r\n          &quot;subCategories&quot;: NULL\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n```\r\n\r\nHere&#39;s some of the jq queries I&#39;ve tried:\r\n\r\n`cat ~/temp/testData.json | jq --tab &#39;[.[] | {name: .name, subCat1: [.subCategories[].name], subCat2: [.subCategories[].subCategories[]?.name]} ]&#39;` &lt;--not useful as nesting is lost\r\n\r\nI am trying to accomplish this via only filters and pipes as I am not too strong with doing selects in jq.",
        "link": "https://stackoverflow.com/questions/60887677/parsing-through-nested-arrays-with-null",
        "title": "parsing through nested arrays with null"
    },
    {
        "tags": [
            "json",
            "sorting",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585325383,
                "creation_date": 1585325383,
                "answer_id": 60889827,
                "question_id": 60889135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on [peak&#39;s answer to your other question](https://stackoverflow.com/a/60889140/10248678):\r\n```\r\n{ beka, alma, paprika, korte } + .\r\n```",
                "title": "Sort keys in arbitrary order and keeping unknown keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585325383,
        "creation_date": 1585323001,
        "question_id": 60889135,
        "body_markdown": "Follow-up question to [sort keys in arbitrary order][1]:\r\n\r\nWith the help of [oguz ismail][2] I can sort an object based on the keys even in non-alphabetical order ([accepted solution][3], [online demo][4]):\r\n\r\n```bash\r\n$ echo &#39;{ &quot;alma&quot;: 1, &quot;beka&quot;: 2, &quot;paprika&quot;: 3, &quot;korte&quot;: 4, &quot;cekla&quot;: 5 }&#39; | jq &#39;. as $in | reduce (&quot;beka&quot;, &quot;alma&quot;, &quot;paprika&quot;, &quot;korte&quot;) as $k ({}; .[$k] = $in[$k])&#39;\r\n{\r\n  &quot;beka&quot;: 2,\r\n  &quot;alma&quot;: 1,\r\n  &quot;paprika&quot;: 3,\r\n  &quot;korte&quot;: 4\r\n}\r\n\r\n```\r\n\r\nEven though the code is quite elegant, it removes all non-listed keys.\r\n\r\n**Question: How can I keep unknown keys in the output at the end of the JSON to have the following output?**\r\n\r\n```json\r\n{\r\n  &quot;beka&quot;: 2,\r\n  &quot;alma&quot;: 1,\r\n  &quot;paprika&quot;: 3,\r\n  &quot;korte&quot;: 4,\r\n  &quot;cekla&quot;: 5\r\n}\r\n```\r\n\r\n[1]: https://stackoverflow.com/questions/60886010/sort-keys-in-arbitrary-order\r\n[2]: https://stackoverflow.com/users/10248678/oguz-ismail\r\n[3]: https://stackoverflow.com/a/60886427/1423815\r\n[4]: https://jqplay.org/s/wj2hohQK2F",
        "link": "https://stackoverflow.com/questions/60889135/sort-keys-in-arbitrary-order-and-keeping-unknown-keys",
        "title": "Sort keys in arbitrary order and keeping unknown keys"
    }
]