[
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 82252,
                    "reputation": 3812,
                    "user_id": 231415,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/bfcb5d47507e07d1c0dadf6903db0a2b?s=256&d=identicon&r=PG",
                    "display_name": "martinr",
                    "link": "https://stackoverflow.com/users/231415/martinr"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1261605612,
                "post_id": 1955505,
                "comment_id": 1867813,
                "content_license": "CC BY-SA 2.5"
            },
            {
                "owner": {
                    "account_id": 55732,
                    "reputation": 76995,
                    "user_id": 166949,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://i.sstatic.net/tIFie.png?s=256",
                    "display_name": "steveha",
                    "link": "https://stackoverflow.com/users/166949/steveha"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1262048681,
                "post_id": 1955505,
                "comment_id": 1886953,
                "content_license": "CC BY-SA 2.5"
            },
            {
                "owner": {
                    "account_id": 18259,
                    "reputation": 6068,
                    "user_id": 41688,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/24b1ed0d2cd5db2f9ea46b8c38b5c4f7?s=256&d=identicon&r=PG",
                    "display_name": "BryanH",
                    "link": "https://stackoverflow.com/users/41688/bryanh"
                },
                "edited": false,
                "score": 74,
                "creation_date": 1359994569,
                "post_id": 1955505,
                "comment_id": 20541426,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3021,
                    "reputation": 416311,
                    "user_id": 4279,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/d92ce60d3a4cbe03598e27c2e8dee69d?s=256&d=identicon&r=PG",
                    "display_name": "jfs",
                    "link": "https://stackoverflow.com/users/4279/jfs"
                },
                "reply_to_user": {
                    "account_id": 18259,
                    "reputation": 6068,
                    "user_id": 41688,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/24b1ed0d2cd5db2f9ea46b8c38b5c4f7?s=256&d=identicon&r=PG",
                    "display_name": "BryanH",
                    "link": "https://stackoverflow.com/users/41688/bryanh"
                },
                "edited": false,
                "score": 27,
                "creation_date": 1369925084,
                "post_id": 1955505,
                "comment_id": 24280259,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 472677,
                    "reputation": 10588,
                    "user_id": 881286,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/b41dab40ea4b4c8c1da7368315806fa9?s=256&d=identicon&r=PG",
                    "display_name": "Diosney",
                    "link": "https://stackoverflow.com/users/881286/diosney"
                },
                "edited": false,
                "score": 21,
                "creation_date": 1416262493,
                "post_id": 1955505,
                "comment_id": 42500081,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 274743,
                    "reputation": 2129,
                    "user_id": 567162,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/9e4fb9d8bb60c90b6ebb7606feb13c82?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "D-Klotz",
                    "link": "https://stackoverflow.com/users/567162/d-klotz"
                },
                "reply_to_user": {
                    "account_id": 472677,
                    "reputation": 10588,
                    "user_id": 881286,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/b41dab40ea4b4c8c1da7368315806fa9?s=256&d=identicon&r=PG",
                    "display_name": "Diosney",
                    "link": "https://stackoverflow.com/users/881286/diosney"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1446832286,
                "post_id": 1955505,
                "comment_id": 54923351,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 366776,
                    "reputation": 7134,
                    "user_id": 712526,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/06e3c4065e9d08da698b4f4de3959294?s=256&d=identicon&r=PG",
                    "display_name": "jpaugh",
                    "link": "https://stackoverflow.com/users/712526/jpaugh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447890160,
                "post_id": 1955505,
                "comment_id": 55352161,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 193310,
                    "reputation": 405,
                    "user_id": 434965,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/2080d95d98c8116ed8399a7107038256?s=256&d=identicon&r=PG",
                    "display_name": "Vinay",
                    "link": "https://stackoverflow.com/users/434965/vinay"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1481642576,
                "post_id": 1955505,
                "comment_id": 69453132,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 472677,
                    "reputation": 10588,
                    "user_id": 881286,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/b41dab40ea4b4c8c1da7368315806fa9?s=256&d=identicon&r=PG",
                    "display_name": "Diosney",
                    "link": "https://stackoverflow.com/users/881286/diosney"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531423063,
                "post_id": 1955505,
                "comment_id": 89602702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1605316,
                    "reputation": 9718,
                    "user_id": 1485527,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5fefc19b7875e951c7ea9bfdfc06676d?s=256&d=identicon&r=PG",
                    "display_name": "jschnasse",
                    "link": "https://stackoverflow.com/users/1485527/jschnasse"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1536577811,
                "post_id": 1955505,
                "comment_id": 91460178,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1427177,
                    "reputation": 1599,
                    "user_id": 1350377,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/19c1cfc1d2b60e07c05f0ed252248f4c?s=256&d=identicon&r=PG",
                    "display_name": "Grkxbvn",
                    "link": "https://stackoverflow.com/users/1350377/grkxbvn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548739011,
                "post_id": 1955505,
                "comment_id": 95638794,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2262332,
                    "reputation": 401,
                    "user_id": 1992064,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/54c1d7f4dcd2a316ff54eb4aa6f2a50f?s=256&d=identicon&r=PG",
                    "display_name": "Brian Carcich",
                    "link": "https://stackoverflow.com/users/1992064/brian-carcich"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1559855664,
                "post_id": 1955505,
                "comment_id": 99560447,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2262332,
                    "reputation": 401,
                    "user_id": 1992064,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/54c1d7f4dcd2a316ff54eb4aa6f2a50f?s=256&d=identicon&r=PG",
                    "display_name": "Brian Carcich",
                    "link": "https://stackoverflow.com/users/1992064/brian-carcich"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559856137,
                "post_id": 1955505,
                "comment_id": 99560592,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2564721,
                    "reputation": 12048,
                    "user_id": 2225104,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/195de66794c596e35bc145c80e9f5515?s=256&d=identicon&r=PG",
                    "display_name": "BitTickler",
                    "link": "https://stackoverflow.com/users/2225104/bittickler"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592868876,
                "post_id": 1955505,
                "comment_id": 110573846,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 367746,
                    "reputation": 25570,
                    "user_id": 714112,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/83b2bbbdc0f34ed6148dab188c6bb987?s=256&d=identicon&r=PG",
                    "display_name": "Sridhar Sarnobat",
                    "link": "https://stackoverflow.com/users/714112/sridhar-sarnobat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1720222063,
                "post_id": 1955505,
                "comment_id": 138778705,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1787,
                "is_accepted": true,
                "score": 1781,
                "last_activity_date": 1644323429,
                "last_edit_date": 1644323429,
                "creation_date": 1261605570,
                "answer_id": 1955555,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are a number of tools specifically designed for the purpose of manipulating JSON from the command line, and will be a lot easier and more reliable than doing it with Awk, such as [`jq`][1]:\r\n\r\n    curl -s &#39;https://api.github.com/users/lambda&#39; | jq -r &#39;.name&#39;\r\n\r\nYou can also do this with tools that are likely already installed on your system, like Python using the [`json` module][3], and so avoid any extra dependencies, while still having the benefit of a proper JSON parser. The following assume you want to use UTF-8, which the original JSON should be encoded in and is what most modern terminals use as well:\r\n\r\nPython 3:\r\n\r\n    curl -s &#39;https://api.github.com/users/lambda&#39; | \\\r\n        python3 -c &quot;import sys, json; print(json.load(sys.stdin)[&#39;name&#39;])&quot;\r\n\r\nPython 2:\r\n\r\n    export PYTHONIOENCODING=utf8\r\n    curl -s &#39;https://api.github.com/users/lambda&#39; | \\\r\n        python2 -c &quot;import sys, json; print json.load(sys.stdin)[&#39;name&#39;]&quot;\r\n\r\n## Frequently Asked Questions\r\n\r\n### Why not a pure shell solution?\r\n\r\nThe standard [POSIX/Single Unix Specification shell](https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html) is a very limited language which doesn&#39;t contain facilities for representing sequences (list or arrays) or associative arrays (also known as hash tables, maps, dicts, or objects in some other languages). This makes representing the result of parsing JSON somewhat tricky in portable shell scripts. There are [somewhat hacky ways to do it](https://stackoverflow.com/questions/688849/associative-arrays-in-shell-scripts), but many of them can break if keys or values contain certain special characters.\r\n\r\nBash 4 and later, zsh, and ksh have support for arrays and associative arrays, but these shells are not universally available (macOS stopped updating Bash at Bash 3, due to a change from GPLv2 to GPLv3, while many Linux systems don&#39;t have zsh installed out of the box). It&#39;s possible that you could write a script that would work in either Bash 4 or zsh, one of which is available on most macOS, Linux, and BSD systems these days, but it would be tough to write a shebang line that worked for such a polyglot script.\r\n\r\nFinally, writing a full fledged JSON parser in shell would be a significant enough dependency that you might as well just use an existing dependency like jq or Python instead. It&#39;s not going to be a one-liner, or even small five-line snippet, to do a good implementation.\r\n\r\n### Why not use awk, sed, or grep?\r\n\r\nIt is possible to use these tools to do some quick extraction from JSON with a known shape and formatted in a known way, such as one key per line. There are several examples of suggestions for this in other answers.\r\n\r\nHowever, these tools are designed for line based or record based formats; they are not designed for recursive parsing of matched delimiters with possible escape characters.\r\n\r\nSo these quick and dirty solutions using awk/sed/grep are likely to be fragile, and break if some aspect of the input format changes, such as collapsing whitespace, or adding additional levels of nesting to the JSON objects, or an escaped quote within a string. A solution that is robust enough to handle all JSON input without breaking will also be fairly large and complex, and so not too much different than adding another dependency on `jq` or Python.\r\n\r\nI have had to deal with large amounts of customer data being deleted due to poor input parsing in a shell script before, so I never recommend quick and dirty methods that may be fragile in this way. If you&#39;re doing some one-off processing, see the other answers for suggestions, but I still highly recommend just using an existing tested JSON parser.\r\n\r\n## Historical notes\r\n\r\nThis answer originally recommended [jsawk][2], which should still work, but is a little more cumbersome to use than `jq`, and depends on a standalone JavaScript interpreter being installed which is less common than a Python interpreter, so the above answers are probably preferable:\r\n\r\n    curl -s &#39;https://api.github.com/users/lambda&#39; | jsawk -a &#39;return this.name&#39;\r\n\r\nThis answer also originally used the Twitter API from the question, but that API no longer works, making it hard to copy the examples to test out, and the new Twitter API requires API keys, so I&#39;ve switched to using the GitHub API which can be used easily without API keys.  The first answer for the original question would be:\r\n\r\n    curl &#39;http://twitter.com/users/username.json&#39; | jq -r &#39;.text&#39;\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: http://github.com/micha/jsawk\r\n  [3]: https://docs.python.org/2/library/json.html",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 124,
                "is_accepted": false,
                "score": 121,
                "last_activity_date": 1651444092,
                "last_edit_date": 1651444092,
                "creation_date": 1261607325,
                "answer_id": 1955668,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [Python&#39;s JSON support][1] instead of using AWK!\r\n\r\nSomething like this:\r\n\r\n&lt;!-- language: lang-sh --&gt;\r\n\r\n    curl -s http://twitter.com/users/username.json | \\\r\n        python -c &quot;import json,sys;obj=json.load(sys.stdin);print(obj[&#39;name&#39;]);&quot;\r\n\r\n[macOS v12.3 (Monterey) removed `/usr/bin/python`][2], so we must use `/usr/bin/python3` for macOS v12.3 and later.\r\n\r\n    curl -s http://twitter.com/users/username.json | \\\r\n        python3 -c &quot;import json,sys;obj=json.load(sys.stdin);print(obj[&#39;name&#39;]);&quot;\r\n\r\n  [1]: http://docs.python.org/library/json.html\r\n  [2]: https://developer.apple.com/documentation/macos-release-notes/macos-12_3-release-notes#Python\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 82,
                "is_accepted": false,
                "score": 81,
                "last_activity_date": 1261613281,
                "creation_date": 1261613281,
                "answer_id": 1956034,
                "question_id": 1955505,
                "content_license": "CC BY-SA 2.5",
                "body_markdown": "You&#39;ve asked how to shoot yourself in the foot and I&#39;m here to provide the ammo:\r\n\r\n    curl -s &#39;http://twitter.com/users/username.json&#39; | sed -e &#39;s/[{}]/&#39;&#39;/g&#39; | awk -v RS=&#39;,&quot;&#39; -F: &#39;/^text/ {print $2}&#39;\r\n\r\nYou could use `tr -d &#39;{}&#39;` instead of `sed`. But leaving them out completely seems to have the desired effect as well.\r\n\r\nIf you want to strip off the outer quotes, pipe the result of the above through `sed &#39;s/\\(^&quot;\\|&quot;$\\)//g&#39;`\r\n\r\nI think others have sounded sufficient alarm. I&#39;ll be standing by with a cell phone to call an ambulance. Fire when ready.",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1651444342,
                "last_edit_date": 1651444342,
                "creation_date": 1261613328,
                "answer_id": 1956038,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way you can do it with [AWK][1]:\r\n\r\n    curl -sL &#39;http://twitter.com/users/username.json&#39; | awk -F&quot;,&quot; -v k=&quot;text&quot; &#39;{\r\n        gsub(/{|}/,&quot;&quot;)\r\n        for(i=1;i&lt;=NF;i++){\r\n            if ( $i ~ k ){\r\n                print $i\r\n            }\r\n        }\r\n    }&#39;\r\n\r\n  [1]: https://en.wikipedia.org/wiki/AWK\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1651444387,
                "last_edit_date": 1651444387,
                "creation_date": 1303897611,
                "answer_id": 5802161,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Version which uses Ruby and http://flori.github.com/json/\r\n\r\n    &lt; file.json ruby -e &quot;require &#39;rubygems&#39;; require &#39;json&#39;; puts JSON.pretty_generate(JSON[STDIN.read]);&quot;\r\n\r\nOr more concisely:\r\n\r\n    &lt; file.json ruby -r rubygems -r json -e &quot;puts JSON.pretty_generate(JSON[STDIN.read]);&quot;",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 167,
                "is_accepted": false,
                "score": 157,
                "last_activity_date": 1651444597,
                "last_edit_date": 1651444597,
                "creation_date": 1307865855,
                "answer_id": 6320876,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following [martinr&#39;s and][1] [Boecko&#39;s lead][2]: \r\n\r\n    curl -s &#39;http://twitter.com/users/username.json&#39; | python -mjson.tool\r\n\r\nThat will give you an extremely [grep][3]-friendly output. Very convenient:\r\n\r\n    curl -s &#39;http://twitter.com/users/username.json&#39; | python -mjson.tool | grep my_key\r\n\r\n  [1]: https://stackoverflow.com/questions/1955505/parsing-json-with-unix-tools/1955668#1955668\r\n  [2]: https://stackoverflow.com/questions/1955505/parsing-json-with-unix-tools/5802161#5802161\r\n  [3]: https://en.wikipedia.org/wiki/Grep\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 344,
                "is_accepted": false,
                "score": 338,
                "last_activity_date": 1395907967,
                "last_edit_date": 1395907967,
                "creation_date": 1311809086,
                "answer_id": 6852427,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To quickly extract the values for a particular key, I personally like to use &quot;grep -o&quot;, which only returns the regex&#39;s match.  For example, to get the &quot;text&quot; field from tweets, something like:\r\n\r\n    grep -Po &#39;&quot;text&quot;:.*?[^\\\\]&quot;,&#39; tweets.json\r\n\r\nThis regex is more robust than you might think; for example, it deals fine with strings having embedded commas and escaped quotes inside them. I think with a little more work you could make one that is actually guaranteed to extract the value, if it&#39;s atomic.  (If it has nesting, then a regex can&#39;t do it of course.)\r\n\r\nAnd to further clean (albeit keeping the string&#39;s original escaping) you can use something like: `| perl -pe &#39;s/&quot;text&quot;://; s/^&quot;//; s/&quot;,$//&#39;`.  (I did this for [this analysis][1].)\r\n\r\nTo all the haters who insist you should use a real JSON parser -- yes, that is essential for correctness, but\r\n\r\n  1. To do a really quick analysis, like counting values to check on data cleaning bugs or get a general feel for the data, banging out something on the command line is faster.  Opening an editor to write a script is distracting.\r\n  2. `grep -o` is orders of magnitude faster than the Python standard `json` library, at least when doing this for tweets (which are ~2 KB each).  I&#39;m not sure if this is just because `json` is slow (I should compare to yajl sometime); but in principle, a regex should be faster since it&#39;s finite state and much more optimizable, instead of a parser that has to support recursion, and in this case, spends lots of CPU building trees for structures you don&#39;t care about.  (If someone wrote a finite state transducer that did proper (depth-limited) JSON parsing, that would be fantastic!  In the meantime we have &quot;grep -o&quot;.)\r\n\r\nTo write maintainable code, I always use a real parsing library.  I haven&#39;t tried [jsawk][2], but if it works well, that would address point #1.\r\n\r\nOne last, wackier, solution: I wrote a script that uses Python `json` and extracts the keys you want, into tab-separated columns; then I pipe through a wrapper around `awk` that allows named access to columns.  [In here: the json2tsv and tsvawk scripts][3].  So for this example it would be:\r\n\r\n    json2tsv id text &lt; tweets.json | tsvawk &#39;{print &quot;tweet &quot; $id &quot; is: &quot; $text}&#39;\r\n\r\nThis approach doesn&#39;t address #2, is more inefficient than a single Python script, and it&#39;s a little brittle: it forces normalization of newlines and tabs in string values, to play nice with awk&#39;s field/record-delimited view of the world.  But it does let you stay on the command line, with more correctness than `grep -o`.\r\n\r\n  [1]: https://gist.github.com/1024217\r\n  [2]: https://github.com/micha/jsawk\r\n  [3]: https://github.com/brendano/tsvutils",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 199,
                "is_accepted": false,
                "score": 197,
                "last_activity_date": 1651444759,
                "last_edit_date": 1651444759,
                "creation_date": 1323176753,
                "answer_id": 8400375,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On the basis that some of the recommendations here (especially in the comments) suggested the use of Python, I was disappointed not to find an example.\r\n\r\nSo, here&#39;s a one-liner to get a single value from some JSON data. It assumes that you are piping the data in (from somewhere) and so should be useful in a scripting context.\r\n\r\n    echo &#39;{&quot;hostname&quot;:&quot;test&quot;,&quot;domainname&quot;:&quot;example.com&quot;}&#39; | python -c &#39;import json,sys;obj=json.load(sys.stdin);print obj[&quot;hostname&quot;]&#39;\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1323214743,
                "creation_date": 1323214743,
                "answer_id": 8408487,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can try something like this - \r\n\r\n    curl -s &#39;http://twitter.com/users/jaypalsingh.json&#39; | \r\n    awk -F=&quot;:&quot; -v RS=&quot;,&quot; &#39;$1~/&quot;text&quot;/ {print}&#39;",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 54,
                "is_accepted": false,
                "score": 53,
                "last_activity_date": 1712889755,
                "last_edit_date": 1712889755,
                "creation_date": 1323488972,
                "answer_id": 8454238,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# Update (2020)\r\n\r\nMy biggest issue with external tools (e.g., Python) was that you have to deal with package managers and dependencies to install them.\r\n\r\nHowever, now that we have `jq` as a standalone, static tool that&#39;s easy to install cross-platform via [GitHub Releases][1] and Webi ([webinstall.dev/jq][2]), I&#39;d recommend that:\r\n\r\nMac, Linux:\r\n\r\n```bash\r\ncurl -sS https://webi.sh/jq | bash\r\n```\r\n\r\nWindows 10:\r\n\r\n```bash\r\ncurl.exe -A MS https://webi.ms/jq | powershell\r\n```\r\n\r\n**Cheat Sheet**: https://webinstall.dev/jq\r\n\r\n# Original (2011)\r\n\r\n[TickTick][3] is a JSON parser written in bash (less than 250 lines of code).\r\n\r\nHere&#39;s the author&#39;s snippet from his article, *[Imagine a world where Bash supports JSON][4]*:\r\n\r\n    #!/bin/bash\r\n    . ticktick.sh\r\n\r\n    ``\r\n      people = {\r\n        &quot;Writers&quot;: [\r\n          &quot;Rod Serling&quot;,\r\n          &quot;Charles Beaumont&quot;,\r\n          &quot;Richard Matheson&quot;\r\n        ],\r\n        &quot;Cast&quot;: {\r\n          &quot;Rod Serling&quot;: { &quot;Episodes&quot;: 156 },\r\n          &quot;Martin Landau&quot;: { &quot;Episodes&quot;: 2 },\r\n          &quot;William Shatner&quot;: { &quot;Episodes&quot;: 2 }\r\n        }\r\n      }\r\n    ``\r\n\r\n    function printDirectors() {\r\n      echo &quot;  The ``people.Directors.length()`` Directors are:&quot;\r\n\r\n      for director in ``people.Directors.items()``; do\r\n        printf &quot;    - %s\\n&quot; ${!director}\r\n      done\r\n    }\r\n\r\n    `` people.Directors = [ &quot;John Brahm&quot;, &quot;Douglas Heyes&quot; ] ``\r\n    printDirectors\r\n\r\n    newDirector=&quot;Lamont Johnson&quot;\r\n    `` people.Directors.push($newDirector) ``\r\n    printDirectors\r\n\r\n    echo &quot;Shifted: &quot;``people.Directors.shift()``\r\n    printDirectors\r\n\r\n    echo &quot;Popped: &quot;``people.Directors.pop()``\r\n    printDirectors\r\n\r\n  [1]: https://github.com/stedolan/jq/releases/\r\n  [2]: https://webinstall.dev/jq\r\n  [3]: https://github.com/kristopolous/TickTick\r\n  [4]: http://9ol.es/TheEmperorsNewClothes.html\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1334155690,
                "creation_date": 1334155690,
                "answer_id": 10108392,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use [`jshon`][1]:\r\n\r\n    curl &#39;http://twitter.com/users/username.json&#39; | jshon -e text\r\n\r\n\r\n  [1]: http://kmkeen.com/jshon/",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1651445260,
                "last_edit_date": 1651445260,
                "creation_date": 1355112787,
                "answer_id": 13794892,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve done this, &quot;parsing&quot; a JSON response for a particular value, as follows:\r\n\r\n    curl $url | grep $var | awk &#39;{print $2}&#39; | sed s/\\&quot;//g\r\n\r\nClearly, $url here would be the Twitter URL, and $var would be &quot;text&quot; to get the response for that variable.\r\n\r\nReally, I think the only thing I&#39;m doing the OP has left out is grep for the line with the specific variable he seeks. AWK grabs the second item on the line, and with sed I strip the quotes.\r\n\r\nSomeone smarter than I am could probably do the whole think with AWK or grep.\r\n\r\nNow, you could do it all with just sed:\r\n\r\n    curl $url | sed &#39;/text/!d&#39; | sed s/\\&quot;text\\&quot;://g | sed s/\\&quot;//g | sed s/\\ //g\r\n\r\nThus, no AWK, no grep...I don&#39;t know why I didn&#39;t think of that before. Hmmm...\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 26,
                "is_accepted": false,
                "score": 26,
                "last_activity_date": 1651445578,
                "last_edit_date": 1651445578,
                "creation_date": 1358976949,
                "answer_id": 14489827,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Parsing JSON with PHP CLI\r\n\r\nIt is arguably off-topic, but since precedence reigns, this question remains incomplete without a mention of our trusty and faithful [PHP][1], am I right?\r\n\r\nIt is using the same example JSON, but let’s assign it to a variable to reduce obscurity.\r\n\r\n    export JSON=&#39;{&quot;hostname&quot;:&quot;test&quot;,&quot;domainname&quot;:&quot;example.com&quot;}&#39;\r\n\r\nNow for PHP goodness, it is using [file_get_contents][2] and the [php://stdin][3] stream wrapper.\r\n\r\n    echo $JSON | php -r &#39;echo json_decode(file_get_contents(&quot;php://stdin&quot;))-&gt;hostname;&#39;\r\n\r\nOr as pointed out using [fgets][4] and the already opened stream at CLI constant [STDIN][5].\r\n\r\n    echo $JSON | php -r &#39;echo json_decode(fgets(STDIN))-&gt;hostname;&#39;\r\n\r\n  [1]: https://en.wikipedia.org/wiki/PHP\r\n  [2]: http://php.net/manual/en/function.file-get-contents.php\r\n  [3]: http://php.net/manual/en/wrappers.php.php\r\n  [4]: http://www.php.net/manual/en/function.fgets.php\r\n  [5]: http://php.net/manual/en/features.commandline.io-streams.php\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 153,
                "is_accepted": false,
                "score": 153,
                "last_activity_date": 1651474495,
                "last_edit_date": 1651474495,
                "creation_date": 1369922367,
                "answer_id": 16838234,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just [download `jq` binary for your platform](http://stedolan.github.io/jq/download/) and run (`chmod +x jq`):\r\n\r\n    $ curl &#39;https://twitter.com/users/username.json&#39; | ./jq -r &#39;.name&#39;\r\n\r\nIt extracts `&quot;name&quot;` attribute from the json object.\r\n\r\n[`jq` homepage](http://stedolan.github.io/jq/) says it is like `sed` for JSON data.",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1651445975,
                "last_edit_date": 1651445975,
                "creation_date": 1369933741,
                "answer_id": 16842104,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Someone who also has XML files, might want to look at my [Xidel][1]. It is a command-line interface, dependency-free [JSONiq][2] processor. (I.e., it also supports XQuery for XML or JSON processing.)\r\n\r\nThe example in the question would be:\r\n\r\n     xidel -e &#39;json(&quot;http://twitter.com/users/username.json&quot;)(&quot;name&quot;)&#39;\r\n\r\nOr with my own, nonstandard extension syntax:\r\n\r\n     xidel -e &#39;json(&quot;http://twitter.com/users/username.json&quot;).name&#39;\r\n\r\n  [1]: http://videlibri.sourceforge.net/xidel.html\r\n  [2]: http://www.jsoniq.org/\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 151,
                "is_accepted": false,
                "score": 149,
                "last_activity_date": 1651446166,
                "last_edit_date": 1651446166,
                "creation_date": 1377616282,
                "answer_id": 18469304,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Using Node.js\r\n\r\nIf the system has [Node.js][1] installed, it&#39;s possible to use the `-p` print and `-e` evaluate script flags with [`JSON.parse`][2] to pull out any value that is needed.\r\n\r\nA simple example using the JSON string `{ &quot;foo&quot;: &quot;bar&quot; }` and pulling out the value of &quot;foo&quot;:\r\n\r\n&lt;!-- language: lang-sh --&gt;\r\n\r\n    node -pe &#39;JSON.parse(process.argv[1]).foo&#39; &#39;{ &quot;foo&quot;: &quot;bar&quot; }&#39;\r\n\r\nOutput:\r\n\r\n    bar\r\n\r\nBecause we have access to `cat` and other utilities, we can use this for files:\r\n\r\n    node -pe &#39;JSON.parse(process.argv[1]).foo&#39; &quot;$(cat foobar.json)&quot;\r\n\r\nOutput:\r\n\r\n    bar\r\n\r\nOr any other format such as an URL that contains JSON:\r\n\r\n&lt;!-- language: lang-sh --&gt;\r\n\r\n    node -pe &#39;JSON.parse(process.argv[1]).name&#39; &quot;$(curl -s https://api.github.com/users/trevorsenior)&quot;\r\n\r\nOutput:\r\n\r\n    Trevor Senior\r\n\r\n  [1]: https://stackoverflow.com/questions/tagged/node.js\r\n  [2]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1651446308,
                "last_edit_date": 1651446308,
                "creation_date": 1391376481,
                "answer_id": 21516469,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Parsing JSON is painful in a shell script. With a more appropriate language, create a tool that extracts JSON attributes in a way consistent with shell scripting conventions. You can use your new tool to solve the immediate shell scripting problem and then add it to your kit for future situations.\r\n\r\nFor example, consider a tool *jsonlookup* such that if I say `jsonlookup access token id` it will return the attribute *id* defined within the attribute *token* defined within the attribute *access* from standard input, which is presumably JSON data. If the attribute doesn&#39;t exist, the tool returns nothing (exit status 1). If the parsing fails, exit status 2 and a message to standard error. If the lookup succeeds, the tool prints the attribute&#39;s value.\r\n\r\nHaving created a Unix tool for the precise purpose of extracting JSON values you can easily use it in shell scripts:\r\n\r\n    access_token=$(curl &lt;some horrible crap&gt; | jsonlookup access token id)\r\n\r\nAny language will do for the implementation of *jsonlookup*. Here is a fairly concise Python version:\r\n\r\n    #!/usr/bin/python\r\n\r\n    import sys\r\n    import json\r\n\r\n    try: rep = json.loads(sys.stdin.read())\r\n    except:\r\n        sys.stderr.write(sys.argv[0] + &quot;: unable to parse JSON from stdin\\n&quot;)\r\n        sys.exit(2)\r\n    for key in sys.argv[1:]:\r\n        if key not in rep:\r\n            sys.exit(1)\r\n        rep = rep[key]\r\n    print rep\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 51,
                "is_accepted": false,
                "score": 51,
                "last_activity_date": 1651536646,
                "last_edit_date": 1651536646,
                "creation_date": 1391666012,
                "answer_id": 21595107,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Using Bash with Python\r\n\r\nCreate a Bash function in your *.bashrc* file:\r\n\r\n    function getJsonVal () {\r\n        python -c &quot;import json,sys;sys.stdout.write(json.dumps(json.load(sys.stdin)$1))&quot;;\r\n    }\r\n\r\nThen\r\n\r\n    curl &#39;http://twitter.com/users/username.json&#39; | getJsonVal &quot;[&#39;text&#39;]&quot;\r\n\r\nOutput:\r\n\r\n    My status\r\n\r\nHere is the same function, but with error checking.\r\n\r\n    function getJsonVal() {\r\n       if [ \\( $# -ne 1 \\) -o \\( -t 0 \\) ]; then\r\n           cat &lt;&lt;EOF\r\n    Usage: getJsonVal &#39;key&#39; &lt; /tmp/\r\n     -- or --\r\n     cat /tmp/input | getJsonVal &#39;key&#39;\r\n    EOF\r\n           return;\r\n       fi;\r\n       python -c &quot;import json,sys;sys.stdout.write(json.dumps(json.load(sys.stdin)$1))&quot;;\r\n    }\r\n\r\nWhere $# -ne 1 makes sure at least 1 input, and -t 0 make sure you are redirecting from a pipe.\r\n\r\nThe nice thing about this implementation is that you can access nested JSON values and get JSON content in return! =)\r\n\r\nExample:\r\n\r\n    echo &#39;{&quot;foo&quot;: {&quot;bar&quot;: &quot;baz&quot;, &quot;a&quot;: [1,2,3]}}&#39; |  getJsonVal &quot;[&#39;foo&#39;][&#39;a&#39;][1]&quot;\r\n\r\nOutput:\r\n\r\n    2\r\n\r\nIf you want to be really fancy, you could pretty print the data:\r\n\r\n    function getJsonVal () {\r\n        python -c &quot;import json,sys;sys.stdout.write(json.dumps(json.load(sys.stdin)$1, sort_keys=True, indent=4))&quot;;\r\n    }\r\n\r\n    echo &#39;{&quot;foo&quot;: {&quot;bar&quot;: &quot;baz&quot;, &quot;a&quot;: [1,2,3]}}&#39; |  getJsonVal &quot;[&#39;foo&#39;]&quot;\r\n    {\r\n        &quot;a&quot;: [\r\n            1,\r\n            2,\r\n            3\r\n        ],\r\n        &quot;bar&quot;: &quot;baz&quot;\r\n    }\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1651446858,
                "last_edit_date": 1651446858,
                "creation_date": 1396342672,
                "answer_id": 22781151,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For more complex JSON parsing, I suggest using the Python *jsonpath* module (by Stefan Goessner) -\r\n\r\n1. Install it -\r\n\r\n    ```lang-none\r\n    sudo easy_install -U jsonpath\r\n    ```\r\n\r\n2. Use it -\r\n\r\n    Example file.json (from http://goessner.net/articles/JsonPath) -\r\n\r\n    ```lang-none\r\n    { &quot;store&quot;: {\r\n        &quot;book&quot;: [\r\n          { &quot;category&quot;: &quot;reference&quot;,\r\n            &quot;author&quot;: &quot;Nigel Rees&quot;,\r\n            &quot;title&quot;: &quot;Sayings of the Century&quot;,\r\n            &quot;price&quot;: 8.95\r\n          },\r\n          { &quot;category&quot;: &quot;fiction&quot;,\r\n            &quot;author&quot;: &quot;Evelyn Waugh&quot;,\r\n            &quot;title&quot;: &quot;Sword of Honour&quot;,\r\n            &quot;price&quot;: 12.99\r\n          },\r\n          { &quot;category&quot;: &quot;fiction&quot;,\r\n            &quot;author&quot;: &quot;Herman Melville&quot;,\r\n            &quot;title&quot;: &quot;Moby Dick&quot;,\r\n            &quot;isbn&quot;: &quot;0-553-21311-3&quot;,\r\n            &quot;price&quot;: 8.99\r\n          },\r\n          { &quot;category&quot;: &quot;fiction&quot;,\r\n            &quot;author&quot;: &quot;J. R. R. Tolkien&quot;,\r\n            &quot;title&quot;: &quot;The Lord of the Rings&quot;,\r\n            &quot;isbn&quot;: &quot;0-395-19395-8&quot;,\r\n            &quot;price&quot;: 22.99\r\n          }\r\n        ],\r\n        &quot;bicycle&quot;: {\r\n          &quot;color&quot;: &quot;red&quot;,\r\n          &quot;price&quot;: 19.95\r\n        }\r\n      }\r\n    }\r\n    ```\r\n\r\n    Parse it (extract all book titles with price &lt; 10) -\r\n\r\n    ```lang-none\r\n    cat file.json | python -c &quot;import sys, json, jsonpath; print &#39;\\n&#39;.join(jsonpath.jsonpath(json.load(sys.stdin), &#39;store.book[?(@.price &lt; 10)].title&#39;))&quot;\r\n    ```\r\n\r\n    Will output -\r\n\r\n    ```lang-none\r\n    Sayings of the Century\r\n    Moby Dick\r\n    ```\r\n\r\n    *Note*: The above command line does not include error checking. For a full solution with error checking, you should create a small Python script, and wrap the code with *try-except*.\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1427487955,
                "last_edit_date": 1427487955,
                "creation_date": 1410725549,
                "answer_id": 25837557,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is a good usecase for [pythonpy](https://pypi.python.org/pypi/pythonpy):\r\n\r\n    curl &#39;http://twitter.com/users/username.json&#39; | py &#39;json.load(sys.stdin)[&quot;name&quot;]&#39;",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 37,
                "is_accepted": false,
                "score": 35,
                "last_activity_date": 1651446994,
                "last_edit_date": 1651446994,
                "creation_date": 1414679932,
                "answer_id": 26655887,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is using standard Unix tools available on most [distributions][1]. It also works well with backslashes (\\\\) and quotes (&quot;).\r\n\r\n***Warning***: This doesn&#39;t come close to the power of [jq][2] and will only work with very simple JSON objects. It&#39;s an attempt to answer to the original question and in situations where you can&#39;t install additional tools.\r\n\r\n    function parse_json()\r\n    {\r\n        echo $1 | \\\r\n        sed -e &#39;s/[{}]/&#39;&#39;/g&#39; | \\\r\n        sed -e &#39;s/&quot;, &quot;/&#39;\\&quot;,\\&quot;&#39;/g&#39; | \\\r\n        sed -e &#39;s/&quot; ,&quot;/&#39;\\&quot;,\\&quot;&#39;/g&#39; | \\\r\n        sed -e &#39;s/&quot; , &quot;/&#39;\\&quot;,\\&quot;&#39;/g&#39; | \\\r\n        sed -e &#39;s/&quot;,&quot;/&#39;\\&quot;---SEPERATOR---\\&quot;&#39;/g&#39; | \\\r\n        awk -F=&#39;:&#39; -v RS=&#39;---SEPERATOR---&#39; &quot;\\$1~/\\&quot;$2\\&quot;/ {print}&quot; | \\\r\n        sed -e &quot;s/\\&quot;$2\\&quot;://&quot; | \\\r\n        tr -d &quot;\\n\\t&quot; | \\\r\n        sed -e &#39;s/\\\\&quot;/&quot;/g&#39; | \\\r\n        sed -e &#39;s/\\\\\\\\/\\\\/g&#39; | \\\r\n        sed -e &#39;s/^[ \\t]*//g&#39; | \\\r\n        sed -e &#39;s/^&quot;//&#39;  -e &#39;s/&quot;$//&#39;\r\n    }\r\n\r\n\r\n    parse_json &#39;{&quot;username&quot;:&quot;john, doe&quot;,&quot;email&quot;:&quot;john@doe.com&quot;}&#39; username\r\n    parse_json &#39;{&quot;username&quot;:&quot;john doe&quot;,&quot;email&quot;:&quot;john@doe.com&quot;}&#39; email\r\n\r\n    --- outputs ---\r\n\r\n    john, doe\r\n    johh@doe.com\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Linux_distribution\r\n  [2]: https://stackoverflow.com/questions/1955505/parsing-json-with-unix-tools/26655887#answer-1955555\r\n\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1651447106,
                "last_edit_date": 1651447106,
                "creation_date": 1417715259,
                "answer_id": 27300595,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A two-liner which uses Python. It works particularly well if you&#39;re writing a single .sh file and you don&#39;t want to depend on another .py file. It also leverages the usage of pipe `|`. `echo &quot;{\\&quot;field\\&quot;: \\&quot;value\\&quot;}&quot;` can be replaced by anything printing a JSON file to standard output.\r\n\r\n    echo &quot;{\\&quot;field\\&quot;: \\&quot;value\\&quot;}&quot; | python -c &#39;import sys, json\r\n    print(json.load(sys.stdin)[&quot;field&quot;])&#39;\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1432526683,
                "last_edit_date": 1432526683,
                "creation_date": 1432525550,
                "answer_id": 30430917,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[Here is a good reference](http://www.staff.science.uu.nl/~oostr102/docs/nawk/nawk_toc.html). In this case:\r\n\r\n    curl &#39;http://twitter.com/users/username.json&#39; | sed -e &#39;s/[{}]/&#39;&#39;/g&#39; | awk -v k=&quot;text&quot; &#39;{n=split($0,a,&quot;,&quot;); for (i=1; i&lt;=n; i++) { where = match(a[i], /\\&quot;text\\&quot;/); if(where) {print a[i]} }  }&#39;",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1651447271,
                "last_edit_date": 1651447271,
                "creation_date": 1447856647,
                "answer_id": 33782551,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have the [PHP][1] interpreter installed:\r\n\r\n    php -r &#39;var_export(json_decode(`curl http://twitter.com/users/username.json`, 1));&#39;\r\n\r\nFor example:\r\n\r\nWe have a resource that provides JSON content with countries&#39; [ISO codes][2]: http://country.io/iso3.json and we can easily see it in a shell with curl:\r\n\r\n    curl http://country.io/iso3.json\r\n\r\nBut it looks not very convenient, and not readable. Better parse the JSON content and see a readable structure:\r\n\r\n    php -r &#39;var_export(json_decode(`curl http://country.io/iso3.json`, 1));&#39;\r\n\r\nThis code will print something like:\r\n\r\n    array (\r\n      &#39;BD&#39; =&gt; &#39;BGD&#39;,\r\n      &#39;BE&#39; =&gt; &#39;BEL&#39;,\r\n      &#39;BF&#39; =&gt; &#39;BFA&#39;,\r\n      &#39;BG&#39; =&gt; &#39;BGR&#39;,\r\n      &#39;BA&#39; =&gt; &#39;BIH&#39;,\r\n      &#39;BB&#39; =&gt; &#39;BRB&#39;,\r\n      &#39;WF&#39; =&gt; &#39;WLF&#39;,\r\n      &#39;BL&#39; =&gt; &#39;BLM&#39;,\r\n      ...\r\n\r\nIf you have nested arrays this output will looks much better...\r\n\r\n  [1]: https://en.wikipedia.org/wiki/PHP\r\n  [2]: https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1651447415,
                "last_edit_date": 1651447415,
                "creation_date": 1466585441,
                "answer_id": 37963014,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I used this to extract the video duration from ffprobe JSON output:\r\n\r\n    MOVIE_INFO=`ffprobe &quot;path/to/movie.mp4&quot;  -show_streams -show_format -print_format json -v quiet`\r\n    MOVIE_SECONDS=`echo &quot;$MOVIE_INFO&quot;|grep -w \\&quot;duration\\&quot; |tail -1 | cut -d\\&quot; -f4 |cut -d \\. -f 1`\r\n\r\nIt can be used to extract a value from any JSON file:\r\n\r\n    value=`echo &quot;$jsondata&quot; | grep -w \\&quot;key_name\\&quot; |tail -1 | cut -d\\&quot; -f4\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1472272664,
                "creation_date": 1472272664,
                "answer_id": 39177507,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If `pip` is avaiable on the system then:\r\n\r\n    $ pip install json-query\r\n\r\nExamples of usage:\r\n\r\n    $ curl -s http://0/file.json | json-query\r\n    {\r\n        &quot;key&quot;:&quot;value&quot;    \r\n    }\r\n\r\n    $ curl -s http://0/file.json | json-query my.key\r\n    value\r\n\r\n    $ curl -s http://0/file.json | json-query my.keys.\r\n    key_1\r\n    key_2\r\n    key_3\r\n\r\n    $ curl -s http://0/file.json | json-query my.keys.2\r\n    value_2",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1481912454,
                "last_edit_date": 1481912454,
                "creation_date": 1479672225,
                "answer_id": 40708779,
                "question_id": 1955505,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Unfortunately the top voted answer that uses `grep` returns the **full** match that didn&#39;t work in my scenario, but if you know the JSON format will remain constant you can use *lookbehind* and *lookahead* to extract just the desired values.\r\n\r\n\r\n    # echo &#39;{&quot;TotalPages&quot;:33,&quot;FooBar&quot;:&quot;he\\&quot;llo&quot;,&quot;anotherValue&quot;:100}&#39; | grep -Po &#39;(?&lt;=&quot;FooBar&quot;:&quot;)(.*?)(?=&quot;,)&#39;\r\n    he\\&quot;llo\r\n    # echo &#39;{&quot;TotalPages&quot;:33,&quot;FooBar&quot;:&quot;he\\&quot;llo&quot;,&quot;anotherValue&quot;:100}&#39; | grep -Po &#39;(?&lt;=&quot;TotalPages&quot;:)(.*?)(?=,)&#39;\r\n    33\r\n    #  echo &#39;{&quot;TotalPages&quot;:33,&quot;FooBar&quot;:&quot;he\\&quot;llo&quot;,&quot;anotherValue&quot;:100}&#39; | grep -Po &#39;(?&lt;=&quot;anotherValue&quot;:)(.*?)(?=})&#39;\r\n    100\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1651447628,
                "last_edit_date": 1651447628,
                "creation_date": 1490013112,
                "answer_id": 42903698,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Now that [PowerShell][1] is cross platform, I thought I&#39;d throw its way out there, since I find it to be fairly intuitive and extremely simple.\r\n\r\n    curl -s &#39;https://api.github.com/users/lambda&#39; | ConvertFrom-Json\r\n\r\n[ConvertFrom-Json][2] converts the JSON into a PowerShell custom object, so you can easily work with the properties from that point forward.  If you only wanted the &#39;id&#39; property for example, you&#39;d just do this:\r\n\r\n    curl -s &#39;https://api.github.com/users/lambda&#39; | ConvertFrom-Json | select -ExpandProperty id\r\n\r\nIf you wanted to invoke the whole thing from within Bash, then you&#39;d have to call it like this:\r\n\r\n    powershell &#39;curl -s &quot;https://api.github.com/users/lambda&quot; | ConvertFrom-Json&#39;\r\n\r\nOf course, there&#39;s a pure PowerShell way to do it without curl, which would be:\r\n\r\n    Invoke-WebRequest &#39;https://api.github.com/users/lambda&#39; | select -ExpandProperty Content | ConvertFrom-Json\r\n\r\nFinally, there&#39;s also [ConvertTo-Json][3] which converts a custom object to JSON just as easily.  Here&#39;s an example:\r\n\r\n    (New-Object PsObject -Property @{ Name = &quot;Tester&quot;; SomeList = @(&#39;one&#39;,&#39;two&#39;,&#39;three&#39;)}) | ConvertTo-Json\r\n\r\nWhich would produce nice JSON like this:\r\n\r\n    {\r\n    &quot;Name&quot;:  &quot;Tester&quot;,\r\n    &quot;SomeList&quot;:  [\r\n                     &quot;one&quot;,\r\n                     &quot;two&quot;,\r\n                     &quot;three&quot;\r\n                 ]\r\n}\r\n\r\nAdmittedly, using a Windows shell on Unix is somewhat sacrilegious, but PowerShell is really good at some things, and parsing JSON and XML are a couple of them.  This is the GitHub page for the cross platform version: *[PowerShell][4]*\r\n\r\n  [1]: https://en.wikipedia.org/wiki/PowerShell\r\n  [2]: https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.utility/convertfrom-json\r\n  [3]: https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.utility/convertto-json\r\n  [4]: https://github.com/PowerShell/PowerShell\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1652140273,
                "last_edit_date": 1652140273,
                "creation_date": 1493191823,
                "answer_id": 43627697,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is yet another Bash and Python hybrid answer. I posted this answer, because I wanted to process more complex JSON output, but, reducing the complexity of my bash application. I want to crack open the following JSON object from http://www.arcgis.com/sharing/rest/info?f=json in Bash:\r\n\r\n&lt;!-- language: javascript --&gt;\r\n\r\n    {\r\n      &quot;owningSystemUrl&quot;: &quot;http://www.arcgis.com&quot;,\r\n      &quot;authInfo&quot;: {\r\n        &quot;tokenServicesUrl&quot;: &quot;https://www.arcgis.com/sharing/rest/generateToken&quot;,\r\n        &quot;isTokenBasedSecurity&quot;: true\r\n      }\r\n    }\r\n\r\nIn the following example, I created my own implementation of `jq` and `unquote` leveraging Python. You&#39;ll note that once we import the Python object from `json` to a Python dictionary we can use Python syntax to navigate the dictionary. To navigate the above, the syntax is:\r\n\r\n - `data`\r\n - `data[ &quot;authInfo&quot; ]`\r\n - `data[ &quot;authInfo&quot; ][ &quot;tokenServicesUrl&quot; ]`\r\n\r\nBy using magic in Bash, we omit `data` and only supply the Python text to the right of data, i.e.\r\n\r\n - `jq`\r\n - `jq &#39;[ &quot;authInfo&quot; ]&#39;`\r\n - `jq &#39;[ &quot;authInfo&quot; ][ &quot;tokenServicesUrl&quot; ]&#39;`\r\n\r\nNote, with no parameters, jq acts as a JSON prettifier. With parameters, we can use Python syntax to extract anything we want from the dictionary including navigating subdictionaries and array elements.\r\n\r\nHere are the Bash Python hybrid functions:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    #!/bin/bash -xe\r\n\r\n    jq_py() {\r\n      cat &lt;&lt;EOF\r\n    import json, sys\r\n    data = json.load( sys.stdin )\r\n    print( json.dumps( data$1, indent = 4 ) )\r\n    EOF\r\n    }\r\n\r\n    jq() {\r\n      python -c &quot;$( jq_py &quot;$1&quot; )&quot;\r\n    }\r\n\r\n    unquote_py() {\r\n      cat &lt;&lt;EOF\r\n    import json,sys\r\n    print( json.load( sys.stdin ) )\r\n    EOF\r\n    }\r\n\r\n    unquote() {\r\n      python -c &quot;$( unquote_py )&quot;\r\n    }\r\n\r\nHere&#39;s a sample usage of the Bash Python functions:\r\n\r\n    curl http://www.arcgis.com/sharing/rest/info?f=json | tee arcgis.json\r\n    # {&quot;owningSystemUrl&quot;:&quot;https://www.arcgis.com&quot;,&quot;authInfo&quot;:{&quot;tokenServicesUrl&quot;:&quot;https://www.arcgis.com/sharing/rest/generateToken&quot;,&quot;isTokenBasedSecurity&quot;:true}}\r\n\r\n    cat arcgis.json | jq\r\n    # {\r\n    #     &quot;owningSystemUrl&quot;: &quot;https://www.arcgis.com&quot;,\r\n    #     &quot;authInfo&quot;: {\r\n    #         &quot;tokenServicesUrl&quot;: &quot;https://www.arcgis.com/sharing/rest/generateToken&quot;,\r\n    #         &quot;isTokenBasedSecurity&quot;: true\r\n    #     }\r\n    # }\r\n\r\n    cat arcgis.json | jq &#39;[ &quot;authInfo&quot; ]&#39;\r\n    # {\r\n    #     &quot;tokenServicesUrl&quot;: &quot;https://www.arcgis.com/sharing/rest/generateToken&quot;,\r\n    #     &quot;isTokenBasedSecurity&quot;: true\r\n    # }\r\n\r\n    cat arcgis.json | jq &#39;[ &quot;authInfo&quot; ][ &quot;tokenServicesUrl&quot; ]&#39;\r\n    # &quot;https://www.arcgis.com/sharing/rest/generateToken&quot;\r\n\r\n    cat arcgis.json | jq &#39;[ &quot;authInfo&quot; ][ &quot;tokenServicesUrl&quot; ]&#39; | unquote\r\n    # https://www.arcgis.com/sharing/rest/generateToken\r\n\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1651939729,
                "last_edit_date": 1651939729,
                "creation_date": 1505918012,
                "answer_id": 46324904,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If someone just wants to extract values from simple JSON objects without the need for nested structures, it is possible to use regular expressions without even leaving Bash.\r\n\r\nHere is a function I defined using bash regular expressions based on the [JSON standard][1]:\r\n\r\n    function json_extract() {\r\n      local key=$1\r\n      local json=$2\r\n\r\n      local string_regex=&#39;&quot;([^&quot;\\]|\\\\.)*&quot;&#39;\r\n      local number_regex=&#39;-?(0|[1-9][0-9]*)(\\.[0-9]+)?([eE][+-]?[0-9]+)?&#39;\r\n      local value_regex=&quot;${string_regex}|${number_regex}|true|false|null&quot;\r\n      local pair_regex=&quot;\\&quot;${key}\\&quot;[[:space:]]*:[[:space:]]*(${value_regex})&quot;\r\n\r\n      if [[ ${json} =~ ${pair_regex} ]]; then\r\n        echo $(sed &#39;s/^&quot;\\|&quot;$//g&#39; &lt;&lt;&lt; &quot;${BASH_REMATCH[1]}&quot;)\r\n      else\r\n        return 1\r\n      fi\r\n    }\r\n\r\nCaveats: objects and arrays are not supported as values, but all other value types defined in the standard are supported. Also, a pair will be matched no matter how deep in the JSON document it is as long as it has exactly the same key name.\r\n\r\nUsing the OP&#39;s example:\r\n\r\n    $ json_extract text &quot;$(curl &#39;http://twitter.com/users/username.json&#39;)&quot;\r\n    My status\r\n\r\n    $ json_extract friends_count &quot;$(curl &#39;http://twitter.com/users/username.json&#39;)&quot;\r\n    245\r\n\r\n  [1]: http://www.json.org/\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1651939850,
                "last_edit_date": 1651939850,
                "creation_date": 1510380597,
                "answer_id": 47234961,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is an easier way to get a property from a JSON string. Using a `package.json` file as an example, try this:\r\n\r\n    #!/usr/bin/env bash\r\n    my_val=&quot;$(json=$(&lt;package.json) node -pe &quot;JSON.parse(process.env.json)[&#39;version&#39;]&quot;)&quot;\r\n\r\nWe&#39;re using `process.env`, because this gets the file&#39;s contents into Node.js as a string without any risk of malicious contents escaping their quoting and being parsed as code.\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1651940059,
                "last_edit_date": 1651940059,
                "creation_date": 1516902664,
                "answer_id": 48449061,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is also a very simple, but powerful, JSON CLI processing tool, [fx][1].\r\n\r\n[![Example of JSON formatting in Bash terminal][2]][2]\r\n\r\n### Examples\r\n\r\nUse an anonymous function:\r\n\r\n    echo &#39;{&quot;key&quot;: &quot;value&quot;}&#39; | fx &quot;x =&gt; x.key&quot;\r\n\r\nOutput:\r\n\r\n    value\r\n\r\nIf you don&#39;t pass anonymous function parameter &amp;rarr; ..., code will be automatically transformed into an anonymous function. And you can get access to JSON by this keyword:\r\n\r\n    $ echo &#39;[1,2,3]&#39; | fx &quot;this.map(x =&gt; x * 2)&quot;\r\n    [2, 4, 6]\r\n\r\nOr just use dot syntax too:\r\n\r\n    echo &#39;{&quot;items&quot;: {&quot;one&quot;: 1}}&#39; | fx .items.one\r\n\r\nOutput:\r\n\r\n    1\r\n\r\nYou can pass any number of anonymous functions for reducing JSON:\r\n\r\n    echo &#39;{&quot;items&quot;: [&quot;one&quot;, &quot;two&quot;]}&#39; | fx &quot;this.items&quot; &quot;this[1]&quot;\r\n\r\nOutput:\r\n\r\n    two\r\n\r\nYou can update existing JSON using spread operator:\r\n\r\n    echo &#39;{&quot;count&quot;: 0}&#39; | fx &quot;{...this, count: 1}&quot;\r\n\r\nOutput:\r\n\r\n    {&quot;count&quot;: 1}\r\n\r\n**Just plain JavaScript**. There isn&#39;t any need to learn new syntax.\r\n\r\n----------\r\n\r\nLater version of fx has an interactive mode! -\r\n\r\n&lt;img src=&quot;https://i.sstatic.net/fplnB.gif&quot; width=&quot;530&quot;&gt;\r\n\r\n  [1]: https://github.com/antonmedv/fx\r\n  [2]: https://i.sstatic.net/OE1cE.png\r\n\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651940305,
                "last_edit_date": 1651940305,
                "creation_date": 1518449852,
                "answer_id": 48750064,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Niet][1] is a tool that helps you to extract data from a JSON or [YAML][2] file directly in your shell or Bash CLI.\r\n\r\n    pip install niet\r\n\r\nConsider a JSON file named *project.json* with the following contents:\r\n\r\n    {\r\n      project: {\r\n        meta: {\r\n          name: project-sample\r\n        }\r\n    }\r\n\r\nYou can use Niet like this:\r\n\r\n    PROJECT_NAME=$(niet project.json project.meta.name)\r\n    echo ${PROJECT_NAME}\r\n\r\nOutput:\r\n\r\n    project-sample\r\n\r\n  [1]: https://github.com/gr0und-s3ct0r/niet/\r\n  [2]: https://en.wikipedia.org/wiki/YAML\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1575572668,
                "last_edit_date": 1575572668,
                "creation_date": 1534161628,
                "answer_id": 51821898,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [bashJson][1]\r\n\r\nIt’s a wrapper for the Python&#39;s JSON module and can handle complex JSON data.\r\n\r\nLet&#39;s consider this exmaple JSON data from the file `test.json`\r\n\r\n    {\r\n    \t&quot;name&quot;:&quot;Test tool&quot;,\r\n    \t&quot;author&quot;:&quot;hack4mer&quot;,\r\n    \t&quot;supported_os&quot;:{\r\n    \t\t&quot;osx&quot;:{\r\n    \t\t    &quot;foo&quot;:&quot;bar&quot;,\r\n    \t\t    &quot;min_version&quot; : 10.12,\r\n    \t\t    &quot;tested_on&quot; : [10.1,10.13]\r\n    \t\t},\r\n    \t\t&quot;ubuntu&quot;:{\r\n    \t\t\t&quot;min_version&quot;:14.04,\r\n    \t\t\t&quot;tested_on&quot; : 16.04\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\n\r\nFollowing commands read data from this example JSON file\r\n\r\n    ./bashjson.sh test.json name\r\n\r\nPrints: Test Tool\r\n\r\n    ./bashjson.sh test.json supported_os osx foo\r\n\r\nPrints: bar\r\n\r\n    ./bashjson.sh test.json supported_os osx tested_on\r\n\r\nPrints: [10.1,10.13]\r\n\r\n  [1]: https://github.com/hack4mer/bashjson\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1651940719,
                "last_edit_date": 1651940719,
                "creation_date": 1539868890,
                "answer_id": 52875055,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can not use any of the answers here. Neither jq, shell arrays, declare, *grep -P*, lookbehind, lookahead, Python, Perl, Ruby, or even Bash, is available.\r\n\r\nThe remaining answers simply do not work well. JavaScript sounded familiar, but the tin says Nescaffe - so it is a no go, too :) Even if available, for my simple needs - they would be overkill and slow.\r\n\r\nYet, it is extremely important for me to get many variables from the JSON formatted reply of my modem. I am doing it in [Bourne shell][1] (`sh`) with a very trimmed down [BusyBox][2] at my routers! There aren&#39;t any problems using [AWK][3] alone: just set delimiters and read the data. For a single variable, that is all!\r\n\r\n    awk &#39;BEGIN { FS=&quot;\\&quot;&quot;; RS=&quot;,&quot; }; { if ($2 == &quot;login&quot;) {print $4} }&#39; test.json\r\n\r\nRemember I don&#39;t have any arrays? I had to assign within the AWK parsed data to the 11 variables which I need in a shell script. Wherever I looked, that was said to be an impossible mission. No problem with that, either.\r\n\r\nMy solution is simple. This code will:\r\n\r\n1) parse .json file from the question (actually, I have borrowed a working data sample from the most upvoted answer) and picked out the quoted data, plus\r\n2) create shell variables from within the awk assigning free named shell variable names.\r\n\r\n    eval $( curl -s &#39;https://api.github.com/users/lambda&#39; |\r\n    awk &#39; BEGIN { FS=&quot;\\&quot;&quot;; RS=&quot;,&quot; };\r\n    {\r\n        if ($2 == &quot;login&quot;) { print &quot;Login=\\&quot;&quot;$4&quot;\\&quot;&quot; }\r\n        if ($2 == &quot;name&quot;) { print &quot;Name=\\&quot;&quot;$4&quot;\\&quot;&quot; }\r\n        if ($2 == &quot;updated_at&quot;) { print &quot;Updated=\\&quot;&quot;$4&quot;\\&quot;&quot; }\r\n    }&#39; )\r\n    echo &quot;$Login, $Name, $Updated&quot;\r\n\r\nThere aren&#39;t any problems with blanks within. In my use, the same command parses a long single line output. As *eval* is used, this solution is suited for trusted data only.\r\n\r\nIt is simple to adapt it to pickup unquoted data. For a huge number of variables, a marginal speed gain can be achieved using *else if*. Lack of arrays obviously means: no multiple records without extra fiddling. But where arrays are available, adapting this solution is a simple task.\r\n\r\n@maikel&#39;s sed answer almost works (but I can not comment on it). For my nicely formatted data - it works. Not so much with the example used here (missing quotes throw it off). It is complicated and difficult to modify. Plus, I do not like having to make 11 calls to extract 11 variables. Why? I timed 100 loops extracting 9 variables: the sed function took 48.99 seconds and my solution took 0.91 second! Not fair? Doing just a single extraction of 9 variables: 0.51 vs. 0.02 second.\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Bourne_shell\r\n  [2]: https://en.wikipedia.org/wiki/BusyBox\r\n  [3]: https://en.wikipedia.org/wiki/AWK\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1669748943,
                "last_edit_date": 1669748943,
                "creation_date": 1553524627,
                "answer_id": 55340267,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I needed something in Bash that was short and would run without dependencies beyond vanilla [Linux LSB][1] and Mac OS for both Python&amp;nbsp;2.7 &amp; 3 and handle errors, e.g. would report JSON parse errors and missing property errors without spewing Python exceptions:\r\n\r\n    json-extract () {\r\n      if [[ &quot;$1&quot; == &quot;&quot; || &quot;$1&quot; == &quot;-h&quot; || &quot;$1&quot; == &quot;-?&quot; || &quot;$1&quot; == &quot;--help&quot; ]] ; then\r\n        echo &#39;Extract top level property value from json document&#39;\r\n        echo &#39;  Usage: json-extract &lt;property&gt; [ &lt;file-path&gt; ]&#39;\r\n        echo &#39;  Example 1: json-extract status /tmp/response.json&#39;\r\n        echo &#39;  Example 2: echo $JSON_STRING | json-extract status&#39;\r\n        echo &#39;  Status codes: 0 - success, 1 - json parse error, 2 - property missing&#39;\r\n      else\r\n        python -c $&#39;import sys, json;\\ntry: obj = json.load(open(sys.argv[2])); \\nexcept: sys.exit(1)\\ntry: print(obj[sys.argv[1]])\\nexcept: sys.exit(2)&#39; &quot;$1&quot; &quot;${2:-/dev/stdin}&quot;\r\n      fi\r\n    }\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Linux_Standard_Base\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1651940962,
                "last_edit_date": 1651940962,
                "creation_date": 1588615648,
                "answer_id": 61598788,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is the answer for shell nerds using the POSIX shell (with `local`) and `egrep`: [JSON.sh][1], 4.7 KB.\r\n\r\nThis thing has plenty of test cases, so it should be correct. It is also pipeable. It is used in the package manager for Bash, *bpkg*.\r\n\r\n  [1]: https://github.com/dominictarr/JSON.sh\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651940997,
                "last_edit_date": 1651940997,
                "creation_date": 1594387272,
                "answer_id": 62835220,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple approach for a Node.js-ready environment:\r\n\r\n    curl -L https://github.com/trentm/json/raw/master/lib/json.js &gt; json\r\n    chmod +x json\r\n    echo &#39;{&quot;hello&quot;:{&quot;hi&quot;:&quot;there&quot;}}&#39; | ./json &quot;hello.hi&quot;\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1610960685,
                "creation_date": 1610960685,
                "answer_id": 65771500,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One interesting tool that hasn&#39;t be covered in the existing answers is using [`gron` written in Go][1] which has a tagline that says **_Make JSON greppable!_** which is exactly what it does.\r\n\r\nSo essentially `gron` breaks down your JSON into discrete assignments see the absolute &#39;path&#39; to it. The primary advantage of it over other tools like `jq` would be to allow searching for the value without knowing how nested the record to search is present at, without breaking the original JSON structure\r\n\r\ne.g., I want to search for the `&#39;twitter_username&#39;` field from the following link, I just do\r\n\r\n```bash\r\n% gron &#39;https://api.github.com/users/lambda&#39; | fgrep &#39;twitter_username&#39;\r\njson.twitter_username = &quot;unlambda&quot;;\r\n% gron &#39;https://api.github.com/users/lambda&#39; | fgrep &#39;twitter_username&#39; | gron -u\r\n{\r\n  &quot;twitter_username&quot;: &quot;unlambda&quot;\r\n}\r\n```\r\nAs simple as that. Note how the `gron -u` (short for ungron) reconstructs the JSON back from the search path. The need for `fgrep` is just to filter your search to the paths needed and not let the search expression be evaluated as a regex, but as a fixed string (which is essentially `grep -F`)\r\n\r\nAnother example to search for a string to see where in the nested structure the record is under\r\n\r\n```bash\r\n% echo &#39;{&quot;foo&quot;:{&quot;bar&quot;:{&quot;zoo&quot;:{&quot;moo&quot;:&quot;fine&quot;}}}}&#39; | gron | fgrep &quot;fine&quot;\r\njson.foo.bar.zoo.moo = &quot;fine&quot;;\r\n```\r\n\r\nIt also supports streaming JSON with its `-s` command line flag, where you can continuously gron the input stream for a matching record. Also `gron` has zero runtime dependencies. You can [download a binary][2] for Linux, Mac, Windows or FreeBSD and run it.\r\n\r\nMore usage examples and trips can be found at the official Github page - [Advanced Usage][3]\r\n\r\nAs for why you one can use `gron` over other JSON parsing tools, see from author&#39;s note from the project page.\r\n\r\n### Why shouldn&#39;t I just use jq?\r\n\r\n&gt; jq is awesome, and a lot more powerful than gron, but with that power comes complexity. gron aims to make it easier to use the tools you already know, like grep and sed. \r\n\r\n\r\n  [1]: https://github.com/tomnomnom/gron\r\n  [2]: https://github.com/tomnomnom/gron/releases\r\n  [3]: https://github.com/tomnomnom/gron/blob/master/ADVANCED.mkd",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651941051,
                "last_edit_date": 1651941051,
                "creation_date": 1626126376,
                "answer_id": 68354208,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using PHP after `yum install php-cli`:\r\n\r\n```\r\nphp -r &quot; foreach(json_decode(file_get_contents(&#39;http://a.com/a.json&#39;), true) as \\$key =&gt; \\$value) echo \\$key.&#39;=&#39;.\\$value.\\&quot;\\n\\&quot; ; &quot;\r\n```\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1651941094,
                "last_edit_date": 1651941094,
                "creation_date": 1645111697,
                "answer_id": 71160907,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works for me if [Node.js][1] is installed:\r\n\r\n    node -pe &quot;require(&#39;${HOME}/.config/dev-utils.json&#39;).doToken&quot;\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Node.js\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1651941204,
                "last_edit_date": 1651941204,
                "creation_date": 1649781925,
                "answer_id": 71846406,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Parse using [Ruby][1] (the interpreter is available on all [macOS][2] versions by default in `/usr/bin/ruby`):\r\n\r\n    echo &quot;${JSON}&quot; | /usr/bin/ruby -e &#39;require &quot;json&quot;; puts JSON.parse(http://STDIN.read)[&quot;key1&quot;][&quot;nested_key_2&quot;];&#39;\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Ruby_%28programming_language%29\r\n  [2]: https://en.wikipedia.org/wiki/MacOS\r\n\r\n\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675521889,
                "last_edit_date": 1675521889,
                "creation_date": 1652297291,
                "answer_id": 72206625,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have multiple options.\r\nYou can use **trdsql** [1] for parsing and transforming JSON/CSV input. Following your example;\r\n```\r\ntrdsql &quot;select attr1,attr2 from sample.json&quot;\r\n```\r\n\r\nYou can also use where clause just like in SQL. Output in CSV, JSON etc. Very handy tool.\r\n\r\nTo my experience trdsql was a bit problematic when dealing with attribute nested values so I came to a solution using qp [2] when appropriate.\r\n\r\n```\r\ncat sample.json | qp &#39;select attr1, attr2.detail.name where attr3=10&#39;\r\n```\r\n\r\n*Notice there is no FROM.*\r\n\r\nFor viewing the results you may use the ultra fast command line json viewer tool, **jless** to view the output [3].\r\n\r\nThere is a new kid on the block from Clickhouse. You can see what it is capable of from [4].\r\n\r\n 1. https://github.com/noborus/trdsql\r\n 2. https://jless.io\r\n 3. https://github.com/f5io/qp\r\n 4. https://clickhouse.com/blog/extracting-converting-querying-local-files-with-sql-clickhouse-local\r\n\r\n",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1652896096,
                "last_edit_date": 1652896096,
                "creation_date": 1652895739,
                "answer_id": 72293735,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are looking for a **Native Mac solution** to parse JSON (No External Libraries etc...), then this is for you.\r\n\r\nThis information is based on an article here: https://www.macblog.org/parse-json-command-line-mac/\r\n\r\nIn short, since as far back as Mac OS Yosemite there is tool for running apple scripts called **osascript**, however if you pass the -l &#39;Javascript&#39; flag you can run javascript! Using JXA (JavaScript for Automation) is what this is called.\r\n\r\nAn example below of reading a JSON file for my own project.\r\n\r\n    DCMTK_JSON=$(curl -s https://formulae.brew.sh/api/bottle/dcmtk.json) # -s for silent mode\r\n    read -r -d &#39;&#39; JXA &lt;&lt;EOF\r\n    function run() {\r\n      var json = JSON.parse(\\`$DCMTK_JSON\\`);\r\n      return json.bottles.$2.url;\r\n    }\r\n    EOF\r\n    DOWNLOAD_URL=$( osascript -l &#39;JavaScript&#39; &lt;&lt;&lt; &quot;${JXA}&quot; )\r\n    echo &quot;DOWNLOAD_URL=${DOWNLOAD_URL}&quot;\r\n\r\nWhat is happening here is we are storing the ouput of the function into the variable JXA.  We can then simply run javascript to parse the JSON content with JSON.parse().  Then simply pass in the JXA variable that contains the script to the osascript tool so it can run the javascript. In my example the $2 refers to arm64_monterey if you test this.  The reason the javascript runs right away is because of the special function `run()`, which JXA looks for and will return its output when it finishes.\r\n\r\nNote that EOF (end of file) are used to handle multiple lines of text input, and the ending EOF can not have any spaces in front of it to work.\r\n\r\nYou can test if this will work for you by simply opening terminal and typing the command below\r\n\r\n    osascript -l &#39;JavaScript&#39; -e &#39;var app = Application.currentApplication(); app.includeStandardAdditions = true; app.displayDialog(&quot;Hello from JavaScript!&quot;);\r\n\r\nThis should bring up a pop up window that says hello from javascript",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667821003,
                "last_edit_date": 1667821003,
                "creation_date": 1667739348,
                "answer_id": 74336024,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "YAML processor [yq](https://mikefarah.gitbook.io/yq/)\r\n===\r\n\r\nConsider using [yq](https://mikefarah.gitbook.io/yq/) for JSON processing.\r\n`yq` is a lightweight and portable command-line YAML processor (and JSON is a subset of YAML).\r\nThe syntax is similar to `jq`. \r\n\r\nInput\r\n---\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Angel&quot;,\r\n  &quot;address&quot;: {\r\n    &quot;street&quot;: &quot;Stairway to&quot;,\r\n    &quot;city&quot;: &quot;Heaven&quot;\r\n  }\r\n}\r\n```\r\n\r\nusage example 1\r\n---\r\n\r\n`yq e &#39;.name&#39; $FILE`\r\n\r\n```text\r\nAngel\r\n```\r\n\r\nusage example 2\r\n---\r\n\r\n`yq` has a nice builtin feature to make JSON and YAML grep-able\r\n\r\n`yq --output-format props $FILE`\r\n\r\n```text\r\nname = Angel\r\naddress.street = Stairway to\r\naddress.city = Heaven\r\n\r\n```",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1678427363,
                "creation_date": 1678427363,
                "answer_id": 75692646,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```python\r\npip3 install jq\r\n\r\nparse() {\r\n  key=$1\r\n\r\n  python3 -c &quot;\r\nimport sys\r\nimport jq\r\nimport json\r\n\r\ninput = json.load(sys.stdin)\r\noutput = jq.compile(&#39;$key&#39;).input(input).all()\r\n\r\nif(isinstance(output, list)):\r\n    output = &#39; &#39;.join(output)\r\n\r\nprint(output)\r\n&quot;\r\n}\r\n\r\nname=$(aws emr describe-cluster --cluster-id $id | parse &quot;.Cluster.Name&quot;)\r\n\r\necho $name\r\n```",
                "title": "Parsing JSON with Unix tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701991963,
                "last_edit_date": 1701991963,
                "creation_date": 1701991193,
                "answer_id": 77623537,
                "question_id": 1955505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For python users with any python 3 env:\r\n```\r\npython -m json.tool\r\n\r\n```\r\nIt will take json input from stdin and print out json nicely. \r\n\r\nTo test, say you have a json file: test.json. And pass to grep to grep your_key:\r\n```\r\ncat test.json | python -m json.tool\r\ncat test.json | python -m json.tool | grep &#39;your_key&#39;\r\n```\r\nSay you have output from a curl:\r\n```\r\ncurl -s &#39;https://api.github.com/users/lambda&#39; | python -m json.tool\r\n```",
                "title": "Parsing JSON with Unix tools"
            }
        ],
        "is_answered": true,
        "answer_count": 47,
        "score": 1312,
        "last_activity_date": 1741509048,
        "creation_date": 1261604818,
        "last_edit_date": 1670073637,
        "question_id": 1955505,
        "body_markdown": "I&#39;m trying to parse JSON returned from a curl request, like so:\r\n\r\n    curl &#39;http://twitter.com/users/username.json&#39; |\r\n        sed -e &#39;s/[{}]/&#39;&#39;/g&#39; | \r\n        awk -v k=&quot;text&quot; &#39;{n=split($0,a,&quot;,&quot;); for (i=1; i&lt;=n; i++) print a[i]}&#39;\r\n\r\nThe above splits the JSON into fields, for example:\r\n    \r\n    % ...\r\n    &quot;geo_enabled&quot;:false\r\n    &quot;friends_count&quot;:245\r\n    &quot;profile_text_color&quot;:&quot;000000&quot;\r\n    &quot;status&quot;:&quot;in_reply_to_screen_name&quot;:null\r\n    &quot;source&quot;:&quot;web&quot;\r\n    &quot;truncated&quot;:false\r\n    &quot;text&quot;:&quot;My status&quot;\r\n    &quot;favorited&quot;:false\r\n    % ...\r\n\r\nHow do I print a specific field (denoted by the `-v k=text`)?",
        "link": "https://stackoverflow.com/questions/1955505/parsing-json-with-unix-tools",
        "title": "Parsing JSON with Unix tools"
    },
    {
        "tags": [
            "json",
            "ruby",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 450294,
                    "reputation": 6429,
                    "user_id": 845546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/619d799ef04f283adcc064f519153be0?s=256&d=identicon&r=PG",
                    "display_name": "Dave S.",
                    "link": "https://stackoverflow.com/users/845546/dave-s"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1357243586,
                "post_id": 14146297,
                "comment_id": 19591481,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2198573,
                    "reputation": 77,
                    "user_id": 1943621,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/0dedcd27b57e7099278eb82f76cc6523?s=256&d=identicon&r=PG",
                    "display_name": "Andrey Brindeyev",
                    "link": "https://stackoverflow.com/users/1943621/andrey-brindeyev"
                },
                "reply_to_user": {
                    "account_id": 450294,
                    "reputation": 6429,
                    "user_id": 845546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/619d799ef04f283adcc064f519153be0?s=256&d=identicon&r=PG",
                    "display_name": "Dave S.",
                    "link": "https://stackoverflow.com/users/845546/dave-s"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1357243678,
                "post_id": 14146297,
                "comment_id": 19591531,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1357244684,
                "last_edit_date": 1357244684,
                "creation_date": 1357244047,
                "answer_id": 14146485,
                "question_id": 14146297,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There is nothing wrong with splitting string and going through parts of it:\r\n\r\n    require &#39;json&#39;\r\n    \r\n    data1 = JSON.load(&#39;{&quot;status&quot;: &quot;fail&quot;, &quot;messages&quot;: [&quot;Out of capacity&quot;]}&#39;)\r\n    data2 = JSON.load(&#39;{&quot;status&quot;: &quot;success&quot;, &quot;messages&quot;: [], &quot;result&quot;: {&quot;node&quot;: {&quot;ip&quot;: &quot;1.2.3.4&quot;, &quot;description&quot;: &quot;&quot;, &quot;id&quot;: 974, &quot;name&quot;: &quot;VM#3&quot;}}}&#39;)\r\n    \r\n    def get_from_json(data, query)\r\n      query.split(&#39;.&#39;).inject(data) do |memo, key|\r\n        key = key.to_i if memo.is_a? Array\r\n        memo.fetch(key)\r\n      end\r\n    end\r\n    \r\n    get_from_json(data1, &#39;messages.0&#39;)        # =&gt; &quot;Out of capacity&quot;\r\n    get_from_json(data2, &#39;result.node.ip&#39;)    # =&gt; &quot;1.2.3.4&quot;\r\n",
                "title": "How to get a particular field from JSON in Ruby"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1357244844,
                "creation_date": 1357244844,
                "answer_id": 14146678,
                "question_id": 14146297,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Take a look at `jq` it might already do what you are looking for.\r\n\r\n    jq .messages[0]\r\n    jq .node.message.ip\r\n\r\nSee http://stedolan.github.com/jq/",
                "title": "How to get a particular field from JSON in Ruby"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1504638170,
        "creation_date": 1357243266,
        "last_edit_date": 1504638170,
        "question_id": 14146297,
        "body_markdown": "I need to implement a simple shell utility in Ruby which parses JSON from a file and return a particular field from it.\r\n\r\nJSON examples to be parsed:\r\n\r\n    {&quot;status&quot;: &quot;fail&quot;, &quot;messages&quot;: [&quot;Out of capacity&quot;]}\r\n\r\n    {&quot;status&quot;: &quot;success&quot;, &quot;messages&quot;: [], &quot;result&quot;: {&quot;node&quot;: {&quot;ip&quot;: &quot;1.2.3.4&quot;, &quot;description&quot;: &quot;&quot;, &quot;id&quot;: 974, &quot;name&quot;: &quot;VM#3&quot;}}}\r\n\r\nIdea is to create a CLI utility with two parameters: JSON file to read and field from JSON to extract:\r\n\r\n    ./get_json_field.rb ~/tmp.XXXXXX &#39;result.node.ip&#39;\r\n    ./get_json_field.rb ~/tmp.XXXXXX &#39;messages.0&#39;\r\n\r\n\r\nI&#39;m struggling how to map 2nd parameter to parsed JSON data structure in Ruby. I can write an iterator for sure, splitting string to an array using dot as separator an go through it item by item but this doesn&#39;t look like elegant solution.\r\n\r\nAny suggestions for more elegant way?",
        "link": "https://stackoverflow.com/questions/14146297/how-to-get-a-particular-field-from-json-in-ruby",
        "title": "How to get a particular field from JSON in Ruby"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 779,
                "is_accepted": true,
                "score": 774,
                "last_activity_date": 1588992021,
                "last_edit_date": 1588992021,
                "creation_date": 1378280521,
                "answer_id": 18608100,
                "question_id": 18592173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adapted from this post on [Processing JSON with jq][1], you can use the [`select(bool)`][2] like this:\r\n\r\n```bash\r\n$ jq &#39;.[] | select(.location==&quot;Stockholm&quot;)&#39; json\r\n{\r\n  &quot;location&quot;: &quot;Stockholm&quot;,\r\n  &quot;name&quot;: &quot;Walt&quot;\r\n}\r\n{\r\n  &quot;location&quot;: &quot;Stockholm&quot;,\r\n  &quot;name&quot;: &quot;Donald&quot;\r\n}\r\n```\r\n\r\n[1]: https://zerokspot.com/weblog/2013/07/18/processing-json-with-jq/\r\n[2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n\r\n",
                "title": "Select objects based on value of variable in object using jq"
            },
            {
                "up_vote_count": 333,
                "is_accepted": false,
                "score": 331,
                "last_activity_date": 1481002356,
                "last_edit_date": 1481002356,
                "creation_date": 1439182215,
                "answer_id": 31911811,
                "question_id": 18592173,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To obtain a stream of just the names:\r\n\r\n    $ jq &#39;.[] | select(.location==&quot;Stockholm&quot;) | .name&#39; json\r\n\r\nproduces:\r\n\r\n    &quot;Donald&quot;\r\n    &quot;Walt&quot;\r\n\r\nTo obtain a stream of corresponding (key name, &quot;name&quot; attribute) pairs, consider:\r\n\r\n    $ jq -c &#39;to_entries[]\r\n            | select (.value.location == &quot;Stockholm&quot;)\r\n            | [.key, .value.name]&#39; json\r\n\r\nOutput:\r\n\r\n    [&quot;FOO&quot;,&quot;Donald&quot;]\r\n    [&quot;BAR&quot;,&quot;Walt&quot;]\r\n\r\n\r\n\r\n",
                "title": "Select objects based on value of variable in object using jq"
            },
            {
                "up_vote_count": 66,
                "is_accepted": false,
                "score": 66,
                "last_activity_date": 1466017588,
                "creation_date": 1466017588,
                "answer_id": 37843822,
                "question_id": 18592173,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I had a similar related question:  What if you wanted the original object format back (with key names, e.g. FOO, BAR)?  \r\n\r\nJq provides `to_entries` and `from_entries` to convert between objects and key-value pair arrays.  That along with `map` around the select\r\n\r\n&gt; These functions convert between an object and an array of key-value\r\n&gt; pairs. If to_entries is passed an object, then for each k: v entry in\r\n&gt; the input, the output array includes {&quot;key&quot;: k, &quot;value&quot;: v}.\r\n&gt; \r\n&gt; from_entries does the opposite conversion, and with_entries(foo) is a\r\n&gt; shorthand for to_entries | map(foo) | from_entries, useful for doing\r\n&gt; some operation to all keys and values of an object. from_entries\r\n&gt; accepts key, Key, name, Name, value and Value as keys.\r\n\r\n\r\n    jq15 &lt; json &#39;to_entries | map(select(.value.location==&quot;Stockholm&quot;)) | from_entries&#39;\r\n    \r\n    {\r\n      &quot;FOO&quot;: {\r\n        &quot;name&quot;: &quot;Donald&quot;,\r\n        &quot;location&quot;: &quot;Stockholm&quot;\r\n      },\r\n      &quot;BAR&quot;: {\r\n        &quot;name&quot;: &quot;Walt&quot;,\r\n        &quot;location&quot;: &quot;Stockholm&quot;\r\n      }\r\n    }\r\n\r\nUsing the `with_entries` shorthand, this becomes:\r\n\r\n    jq15 &lt; json &#39;with_entries(select(.value.location==&quot;Stockholm&quot;))&#39;\r\n    {\r\n      &quot;FOO&quot;: {\r\n        &quot;name&quot;: &quot;Donald&quot;,\r\n        &quot;location&quot;: &quot;Stockholm&quot;\r\n      },\r\n      &quot;BAR&quot;: {\r\n        &quot;name&quot;: &quot;Walt&quot;,\r\n        &quot;location&quot;: &quot;Stockholm&quot;\r\n      }\r\n    }\r\n",
                "title": "Select objects based on value of variable in object using jq"
            },
            {
                "up_vote_count": 44,
                "is_accepted": false,
                "score": 44,
                "last_activity_date": 1643703786,
                "last_edit_date": 1643703786,
                "creation_date": 1601913628,
                "answer_id": 64212172,
                "question_id": 18592173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just try this one as a full copy paste in the shell and you will grasp it.\r\n\r\n    # pass the multiline string to the jq, use the jq to \r\n    # select the attribute named &quot;card_id&quot; \r\n    # ONLY if its neighbour attribute\r\n    # named &quot;card_id_type&quot; has the &quot;card_id_type-01&quot; value.\r\n    # jq -r means give me ONLY the value of the jq query no quotes aka raw\r\n\r\n\r\n    cat &lt;&lt; EOF | \\\r\n\t\tjq -r &#39;.[]| select (.card_id_type == &quot;card_id_type-01&quot;)|.card_id&#39;\r\n\t\t[  \r\n\t\t { &quot;card_id&quot;: &quot;id-00&quot;, &quot;card_id_type&quot;: &quot;card_id_type-00&quot;},\r\n\t\t { &quot;card_id&quot;: &quot;id-01&quot;, &quot;card_id_type&quot;: &quot;card_id_type-01&quot;},\r\n\t\t { &quot;card_id&quot;: &quot;id-02&quot;, &quot;card_id_type&quot;: &quot;card_id_type-02&quot;}\r\n\t\t]\r\n    EOF\r\n    # this ^^^ MUST start first on the line - no whitespace there !!!\r\n    # outputs:\r\n    # id-01\r\n\r\n   \r\n\r\n\r\n\r\nor with an aws cli command\r\n\r\n     # list my vpcs or\r\n     # list the values of the tags which names are &quot;Name&quot; \r\n     aws ec2 describe-vpcs | jq -r &#39;.| .Vpcs[].Tags[]\r\n            |select (.Key == &quot;Name&quot;) | .Value&#39;|sort  -nr\r\n\r\n\r\nNote that you could move up and down in the hierarchy both during the filtering phase and during the selecting phase : \r\n     \r\n    \r\n     kubectl get services --all-namespaces -o json | jq -r &#39;\r\n     .items[] | select( .metadata.name \r\n         | contains(&quot;my-srch-string&quot;)) | \r\n         { name: .metadata.name, ns: .metadata.namespace \r\n         , nodePort: .spec.ports[].nodePort\r\n         , port: .spec.ports[].port}\r\n     &#39;\r\n\r\n",
                "title": "Select objects based on value of variable in object using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1692487330,
                "creation_date": 1692487330,
                "answer_id": 76937384,
                "question_id": 18592173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Hopefully this helps others,   ive used jq in 100s of my own scripts, \r\nbut i fight with using vars in it every single time...  in this case below was only way i could get a number var to pass to it (ie single quotes around the arg/var):\r\n\r\n```\r\nid=26533\r\n\r\ncat mydata.json | jq -r --arg id &quot;$id&quot; &#39;.sensor[] |\r\nselect(.objid==&#39;$id&#39;).probe&#39;\r\n```",
                "title": "Select objects based on value of variable in object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 543,
        "last_activity_date": 1709206578,
        "creation_date": 1378210772,
        "last_edit_date": 1616841176,
        "question_id": 18592173,
        "body_markdown": "I have the following json file:\r\n\r\n    {\r\n        &quot;FOO&quot;: {\r\n            &quot;name&quot;: &quot;Donald&quot;,\r\n            &quot;location&quot;: &quot;Stockholm&quot;\r\n        },\r\n        &quot;BAR&quot;: {\r\n            &quot;name&quot;: &quot;Walt&quot;,\r\n            &quot;location&quot;: &quot;Stockholm&quot;\r\n        },\r\n        &quot;BAZ&quot;: {\r\n            &quot;name&quot;: &quot;Jack&quot;,\r\n            &quot;location&quot;: &quot;Whereever&quot;\r\n        }\r\n    }\r\n\r\nI am using jq and want to get the &quot;name&quot; elements of the objects where &#39;location&#39; is &#39;Stockholm&#39;. \r\n\r\nI know I can get all names by\r\n\r\n    cat json | jq .[] | jq .&quot;name&quot;\r\n    &quot;Jack&quot;\r\n    &quot;Walt&quot;\r\n    &quot;Donald&quot;\r\n\r\nBut I can&#39;t figure out how to print only certain objects, given the value of a sub key (here: `&quot;location&quot; : &quot;Stockholm&quot;`). ",
        "link": "https://stackoverflow.com/questions/18592173/select-objects-based-on-value-of-variable-in-object-using-jq",
        "title": "Select objects based on value of variable in object using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3302206,
                    "reputation": 73,
                    "user_id": 2778073,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03da3f68afdad79a9c5152d241049d03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cp_clegg",
                    "link": "https://stackoverflow.com/users/2778073/cp-clegg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1379114871,
                "post_id": 18796515,
                "comment_id": 27718672,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3708010,
                    "reputation": 4521,
                    "user_id": 3086014,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://www.gravatar.com/avatar/b953ab8d456b398c5adab0ac57830d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3086014",
                    "link": "https://stackoverflow.com/users/3086014/user3086014"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1395983380,
                "post_id": 18796515,
                "comment_id": 34596305,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1379365960,
                "last_edit_date": 1379365960,
                "creation_date": 1379116795,
                "answer_id": 18796928,
                "question_id": 18796515,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps this could work:\r\n\r\n    aws elb describe-load-balancers --region us-east-1 | jq &#39;.LoadBalancerDescriptions[] | select((.AvailabilityZones[] | select(. == &quot;us-east-1b&quot;)) == &quot;us-east-1b&quot;) | .CanonicalHostedZoneName, .AvailabilityZones&#39;\r\n\r\nI actually tested with an input like this:\r\n\r\n    {\r\n      &quot;LoadBalancerDescriptions&quot;: [\r\n        {\r\n          &quot;AvailabilityZones&quot;: [\r\n            &quot;us-east-1b&quot;,\r\n            &quot;us-east-1c&quot;,\r\n            &quot;us-east-1d&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd ran this command:\r\n\r\n    jq &#39;.LoadBalancerDescriptions[] | select((.AvailabilityZones[] | select(. == &quot;us-east-1b&quot;)) == &quot;us-east-1b&quot;)&#39; input_file\r\n\r\nThen I got:\r\n\r\n    {\r\n      &quot;AvailabilityZones&quot;: [\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1d&quot;\r\n      ]\r\n    }\r\n\r\nAnother for input:\r\n\r\n    {\r\n      &quot;LoadBalancerDescriptions&quot;: [\r\n        {\r\n          &quot;AvailabilityZones&quot;: [\r\n            &quot;us-east-1b&quot;,\r\n            &quot;us-east-1c&quot;,\r\n            &quot;us-east-1d&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;AvailabilityZones&quot;: [\r\n            &quot;us-east-1b&quot;,\r\n            &quot;us-east-1c&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;AvailabilityZones&quot;: [\r\n            &quot;us-east-1d&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;AvailabilityZones&quot;: [\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1c&quot;,\r\n        &quot;us-east-1d&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;AvailabilityZones&quot;: [\r\n        &quot;us-east-1b&quot;,\r\n        &quot;us-east-1c&quot;\r\n      ]\r\n    }\r\n\r\nYou probably could use the concept to validate if a key representing an array contains an element like it.\r\n\r\n\r\n",
                "title": "Using jq to parse json output of AWS CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1403161444,
        "creation_date": 1379113481,
        "last_edit_date": 1403161444,
        "question_id": 18796515,
        "body_markdown": "I would like to use jq (http://stedolan.github.io/jq/) to parse the json output from aws elb describe-load-balancers and return the name and AZs only where AvailabilityZones contains a specific value.\r\n\r\nHere is partial redacted json representing the source output:\r\n\r\n    {\r\n      &quot;LoadBalancerDescriptions&quot;: [\r\n        {\r\n        {\r\n          &quot;AvailabilityZones&quot;: [\r\n            &quot;us-east-1b&quot;,\r\n            &quot;us-east-1c&quot;,\r\n            &quot;us-east-1d&quot;\r\n          ],\r\n          &quot;CanonicalHostedZoneName&quot;: &quot;example.us-east-1.elb.amazonaws.com&quot;,\r\nI have only been able to get this to work when specifiying the full list of values for the AvailabilityZones key.\r\n\r\n    $ aws elb describe-load-balancers --region us-east-1 |jq &#39;.LoadBalancerDescriptions[] | select(.AvailabilityZones == [&quot;us-east-1b&quot;, &quot;us-east-1c&quot;, &quot;us-east-1d&quot;]) | .CanonicalHostedZoneName, .AvailabilityZones&#39;\r\n\r\nThe above works, but I want to just select if it contains a value for &quot;us-east-1b&quot;, regardless of the other values.",
        "link": "https://stackoverflow.com/questions/18796515/using-jq-to-parse-json-output-of-aws-cli",
        "title": "Using jq to parse json output of AWS CLI"
    },
    {
        "tags": [
            "json",
            "command-line",
            "data-manipulation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2183673,
                    "reputation": 13005,
                    "user_id": 1932588,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2hAxA.png?s=256",
                    "display_name": "Lee Meador",
                    "link": "https://stackoverflow.com/users/1932588/lee-meador"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1379368747,
                "post_id": 18837939,
                "comment_id": 27791652,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 246369,
                    "reputation": 2392,
                    "user_id": 520499,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/zBsjv.jpg?s=256",
                    "display_name": "MahanGM",
                    "link": "https://stackoverflow.com/users/520499/mahangm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1379369267,
                "post_id": 18837939,
                "comment_id": 27791823,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 344696,
                    "reputation": 7256,
                    "user_id": 677139,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/bcfc011a6e71684570b0c110f9db1616?s=256&d=identicon&r=PG",
                    "display_name": "Dreen",
                    "link": "https://stackoverflow.com/users/677139/dreen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1379421935,
                "post_id": 18837939,
                "comment_id": 27811965,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2071905,
                    "reputation": 12974,
                    "user_id": 1846192,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/f70fC.jpg?s=256",
                    "display_name": "Mathijs Flietstra",
                    "link": "https://stackoverflow.com/users/1846192/mathijs-flietstra"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1379601930,
                "post_id": 18837939,
                "comment_id": 27894406,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1379582200,
                "creation_date": 1379582200,
                "answer_id": 18890702,
                "question_id": 18837939,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `map` filter this way:\r\n\r\n    jq &#39;map(.[0])&#39;",
                "title": "Select nth element from multidimensional JSON array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1473969390,
                "last_edit_date": 1473969390,
                "creation_date": 1473969238,
                "answer_id": 39519328,
                "question_id": 18837939,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another option would be `jq &#39;[.[][0]]&#39;` \r\n\r\nthis gives the same result as using `map(.[0])`",
                "title": "Select nth element from multidimensional JSON array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501658302,
                "creation_date": 1501658302,
                "answer_id": 45454021,
                "question_id": 18837939,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **reduce**\r\n\r\n    reduce .[] as $k ( null; . + [$k[0]] )\r\n",
                "title": "Select nth element from multidimensional JSON array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 9,
        "last_activity_date": 1501658302,
        "creation_date": 1379368399,
        "last_edit_date": 1404458524,
        "question_id": 18837939,
        "body_markdown": "How can I use [`jq`][1] to transform this array of arrays:\r\n\r\n    [\r\n      [\r\n        &quot;sequence&quot;,\r\n        &quot;int&quot;\r\n      ],\r\n      [\r\n        &quot;time&quot;,\r\n        &quot;string&quot;\r\n      ],\r\n      ...\r\n    ]\r\n\r\nInto an array that contains the first (0) element from every subarray? Meaning to produce output like this:\r\n\r\n    [\r\n        &quot;sequence&quot;,\r\n        &quot;time&quot;,\r\n        ...\r\n    ]\r\n\r\nI was thinking to use `reduce xx as $item (...)` but I didnt manage to come up with anything useful.\r\n\r\n  [1]: http://stedolan.github.io/jq",
        "link": "https://stackoverflow.com/questions/18837939/select-nth-element-from-multidimensional-json-array-with-jq",
        "title": "Select nth element from multidimensional JSON array with jq"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1403160559,
                "creation_date": 1403160559,
                "answer_id": 24300438,
                "question_id": 18972180,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given your purpose you might have an easier time using the `paths` builtin to list all the paths in the input and then truncate at the desired depth:\r\n\r\n    $  echo &#39;{&quot;a&quot;:{&quot;b&quot;:{&quot;c&quot;:{&quot;d&quot;:true}}}}&#39; | jq -c &#39;[paths|.[0:2]]|unique&#39;\r\n    [[&quot;a&quot;],[&quot;a&quot;,&quot;b&quot;]]\r\n",
                "title": "Using jq to list keys in a JSON object"
            },
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1423738865,
                "last_edit_date": 1423738865,
                "creation_date": 1423624243,
                "answer_id": 28445937,
                "question_id": 18972180,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following should do exactly what you want\r\n\r\n    jq &#39;[(keys - [&quot;data&quot;])[] as $key | { ($key): .[$key] | keys }] | add&#39;\r\n\r\nThis will give the following output, using the input you described above:\r\n\r\n    {\r\n      &quot;acquisition_parameters&quot;: [\r\n        &quot;camera&quot;,\r\n        &quot;date&quot;,\r\n        &quot;laser&quot;\r\n      ],\r\n      &quot;software&quot;: [\r\n        &quot;branch&quot;,\r\n        &quot;commit&quot;,\r\n        &quot;repo&quot;\r\n      ]\r\n    }",
                "title": "Using jq to list keys in a JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501659194,
                "creation_date": 1501659194,
                "answer_id": 45454326,
                "question_id": 18972180,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another variation uing **reduce** and **setpath** which assumes you have a specific set of top-level keys you want to examine:\r\n\r\n      . as $v\r\n    | reduce (&quot;acquisition_parameters&quot;, &quot;software&quot;) as $k (\r\n         {}; setpath([$k]; $v[$k] | keys)\r\n      )\r\n        ",
                "title": "Using jq to list keys in a JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 17,
        "last_activity_date": 1501659194,
        "creation_date": 1379990962,
        "last_edit_date": 1423734570,
        "question_id": 18972180,
        "body_markdown": "I have a hierarchically deep JSON object created by a scientific instrument, so the file is somewhat large (1.3MB) and not readily readable by people. I would like to get a list of keys, up to a certain depth, for the JSON object. For example, given an input object like this\r\n\r\n    {\r\n        &quot;acquisition_parameters&quot;: {\r\n            &quot;laser&quot;: {\r\n                &quot;wavelength&quot;: {\r\n                    &quot;value&quot;: 632,\r\n                    &quot;units&quot;: &quot;nm&quot;\r\n                }\r\n            },\r\n            &quot;date&quot;: &quot;02/03/2525&quot;,\r\n            &quot;camera&quot;: {}\r\n        },\r\n        &quot;software&quot;: {\r\n            &quot;repo&quot;: &quot;github.com/username/repo&quot;,\r\n            &quot;commit&quot;: &quot;a7642f&quot;,\r\n            &quot;branch&quot;: &quot;develop&quot;\r\n        },\r\n        &quot;data&quot;: [{},{},{}]\r\n    }\r\n\r\n\r\nI would like an output like such.\r\n\r\n    {\r\n        &quot;acquisition_parameters&quot;: [\r\n            &quot;laser&quot;,\r\n            &quot;date&quot;,\r\n            &quot;camera&quot;\r\n        ],\r\n        &quot;software&quot;: [\r\n            &quot;repo&quot;,\r\n            &quot;commit&quot;,\r\n            &quot;branch&quot;\r\n        ]\r\n    }\r\n\r\nThis is mainly for the purpose of being able to enumerate what is in a JSON object. After processing the JSON objects from the instrument begin to diverge: for example, some may have a  field like `.frame.cross_section.stats.fwhm`, while others may have `.sample.species`, so it would be convenient to be able to interrogate the JSON object on the command line.",
        "link": "https://stackoverflow.com/questions/18972180/using-jq-to-list-keys-in-a-json-object",
        "title": "Using jq to list keys in a JSON object"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 134350,
                    "reputation": 39388,
                    "user_id": 336423,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/7F8Fe.jpg?s=256",
                    "display_name": "TGH",
                    "link": "https://stackoverflow.com/users/336423/tgh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1382069884,
                "post_id": 19441454,
                "comment_id": 28825811,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1403160779,
                "last_edit_date": 1403160779,
                "creation_date": 1403159873,
                "answer_id": 24300221,
                "question_id": 19441454,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In jq 1.4 you could do this:\r\n\r\n    $ jq &#39;..|.foo?&#39; file.json\r\n\r\nIf you&#39;re stuck with 1.3 you could use\r\n\r\n    $ jq &#39;recurse(if type == &quot;array&quot; or type == &quot;object&quot; then .[] else empty end) | if type == &quot;object&quot; then . else empty end | .foo&#39; file.json\r\n\r\nwhich is a bit of a mouthful...  That&#39;s why 1.4 has `..`, which recurses down through all iterables in `.`, and the `?` operator, which doesn&#39;t bother indexing that which can&#39;t be.",
                "title": "Json parsing on cli using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1546688658,
        "creation_date": 1382069563,
        "last_edit_date": 1403160044,
        "question_id": 19441454,
        "body_markdown": "Let&#39;s say I have the below json object:\r\n\r\n    {\r\n      &quot;d&quot;: {\r\n        &quot;e&quot;: {\r\n          &quot;bar&quot;: 2\r\n        }\r\n      },\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: {\r\n          &quot;c&quot;: {\r\n            &quot;foo&quot;: 1\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI want to get the value foo without typing `&#39;.a.b.c.foo&#39;` \r\n\r\nI realize I can do...\r\n`echo &#39;{ &quot;a&quot;:{&quot;b&quot;:{&quot;c&quot;:{ &quot;foo&quot;:1}}},&quot;d&quot;:{&quot;e&quot;:{&quot;bar&quot;:2}}}&#39; | jq &#39;.[][][].foo&#39;` but is there a recursive wild in jq? like **? I know for sure jq doesn&#39;t support *, is there a way to have jq support jsonpath?\r\nOr maybe even just another cli tool that does support json path?",
        "link": "https://stackoverflow.com/questions/19441454/json-parsing-on-cli-using-jq",
        "title": "Json parsing on cli using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4604,
                    "reputation": 4182,
                    "user_id": 6992,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://i.sstatic.net/czVZs.jpg?s=256",
                    "display_name": "Nano Taboada",
                    "link": "https://stackoverflow.com/users/6992/nano-taboada"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1382482656,
                "post_id": 19529688,
                "comment_id": 28975102,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 20079,
                    "reputation": 13206,
                    "user_id": 47604,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/acf93279ad98c7df6fddf5187da3adfd?s=256&d=identicon&r=PG",
                    "display_name": "xer0x",
                    "link": "https://stackoverflow.com/users/47604/xer0x"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1416548834,
                "post_id": 19529688,
                "comment_id": 42626194,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3576884,
                    "reputation": 623,
                    "user_id": 2985892,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FVDQw.jpg?s=256",
                    "display_name": "Gus",
                    "link": "https://stackoverflow.com/users/2985892/gus"
                },
                "reply_to_user": {
                    "account_id": 20079,
                    "reputation": 13206,
                    "user_id": 47604,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/acf93279ad98c7df6fddf5187da3adfd?s=256&d=identicon&r=PG",
                    "display_name": "xer0x",
                    "link": "https://stackoverflow.com/users/47604/xer0x"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509110266,
                "post_id": 19529688,
                "comment_id": 80899404,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 20079,
                    "reputation": 13206,
                    "user_id": 47604,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/acf93279ad98c7df6fddf5187da3adfd?s=256&d=identicon&r=PG",
                    "display_name": "xer0x",
                    "link": "https://stackoverflow.com/users/47604/xer0x"
                },
                "reply_to_user": {
                    "account_id": 3576884,
                    "reputation": 623,
                    "user_id": 2985892,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FVDQw.jpg?s=256",
                    "display_name": "Gus",
                    "link": "https://stackoverflow.com/users/2985892/gus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1509653690,
                "post_id": 19529688,
                "comment_id": 81117007,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 53,
                "is_accepted": false,
                "score": 52,
                "last_activity_date": 1393712507,
                "creation_date": 1393712507,
                "answer_id": 22121168,
                "question_id": 19529688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Who knows if you still need it, but here is the solution.\r\n\r\nOnce you get to the `--slurp` option, it&#39;s easy!\r\n\r\n    --slurp/-s:\r\n        Instead of running the filter for each JSON object in the input,\r\n        read the entire input stream into a large array and run the filter just once.\r\n\r\nThen the `+` operator will do what you want:\r\n\r\n    jq -s &#39;.[0] + .[1]&#39; config.json config-user.json\r\n\r\n(Note: if you want to merge inner objects instead of just overwriting the left file ones with the right file ones, you will need to do it manually)",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 141,
                "is_accepted": false,
                "score": 140,
                "last_activity_date": 1403159384,
                "creation_date": 1403159384,
                "answer_id": 24300110,
                "question_id": 19529688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `jq -s add`:\r\n\r\n    $ echo &#39;{&quot;a&quot;:&quot;foo&quot;,&quot;b&quot;:&quot;bar&quot;} {&quot;c&quot;:&quot;baz&quot;,&quot;a&quot;:0}&#39; | jq -s add\r\n    {\r\n      &quot;a&quot;: 0,\r\n      &quot;b&quot;: &quot;bar&quot;,\r\n      &quot;c&quot;: &quot;baz&quot;\r\n    }\r\n\r\nThis reads all JSON texts from stdin into an array (`jq -s` does that) then it &quot;reduces&quot; them.\r\n\r\n(`add` is defined as `def add: reduce .[] as $x (null; . + $x);`, which iterates over the input array&#39;s/object&#39;s values and adds them.  Object addition == merge.)",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 321,
                "is_accepted": true,
                "score": 321,
                "last_activity_date": 1581541549,
                "last_edit_date": 1581541549,
                "creation_date": 1406100433,
                "answer_id": 24904276,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since 1.4 this is now possible with the `*` operator. When given two objects, it will merge them recursively. For example,\r\n\r\n    jq -s &#39;.[0] * .[1]&#39; file1 file2\r\n\r\n**Important: Note the `-s (--slurp)` flag, which puts files in the same array.**\r\n\r\nWould get you:\r\n\r\n    {\r\n      &quot;value1&quot;: 200,\r\n      &quot;timestamp&quot;: 1382461861,\r\n      &quot;value&quot;: {\r\n        &quot;aaa&quot;: {\r\n          &quot;value1&quot;: &quot;v1&quot;,\r\n          &quot;value2&quot;: &quot;v2&quot;,\r\n          &quot;value3&quot;: &quot;v3&quot;,\r\n          &quot;value4&quot;: 4\r\n        },\r\n        &quot;bbb&quot;: {\r\n          &quot;value1&quot;: &quot;v1&quot;,\r\n          &quot;value2&quot;: &quot;v2&quot;,\r\n          &quot;value3&quot;: &quot;v3&quot;\r\n        },\r\n        &quot;ccc&quot;: {\r\n          &quot;value1&quot;: &quot;v1&quot;,\r\n          &quot;value2&quot;: &quot;v2&quot;\r\n        },\r\n        &quot;ddd&quot;: {\r\n          &quot;value3&quot;: &quot;v3&quot;,\r\n          &quot;value4&quot;: 4\r\n        }\r\n      },\r\n      &quot;status&quot;: 200\r\n    }\r\n\r\nIf you also want to get rid of the other keys (like your expected result), one way to do it is this:\r\n\r\n    jq -s &#39;.[0] * .[1] | {value: .value}&#39; file1 file2\r\n\r\nOr the presumably somewhat more efficient (because it doesn&#39;t merge any other values):\r\n\r\n    jq -s &#39;.[0].value * .[1].value | {value: .}&#39; file1 file2",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1597720305,
                "last_edit_date": 1597720305,
                "creation_date": 1439181795,
                "answer_id": 31911767,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, {&quot;value&quot;: .value} can be abbreviated to just {value}.\r\n\r\nSecond, the --argfile option (available in jq 1.4 and jq 1.5) may be of interest as it avoids having to use the --slurp option.\r\n\r\nPutting these together, the two objects in the two files can be combined in the specified way as follows:\r\n\r\n    $ jq -n --argfile o1 file1 --argfile o2 file2 &#39;$o1 * $o2 | {value}&#39;\r\n\r\nThe &#39;-n&#39; flag tells jq not to read from stdin, since inputs are coming from the --argfile options here.\r\n\r\n## Note on --argfile\r\nThe jq manual deprecates `--argfile` because its semantics are non-trivial: if the specified input file contains exactly one JSON entity, then that entity is read as is; otherwise, the items in the stream are wrapped in an array.  \r\n\r\nIf you are uncomfortable using --argfile, there are several alternatives you may wish to consider.  In doing so, be assured that using `--slurpfile` does not incur the inefficiencies of the `-s` command-line option when the latter is used with multiple files.",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 64,
                "is_accepted": false,
                "score": 64,
                "last_activity_date": 1598014013,
                "last_edit_date": 1598014013,
                "creation_date": 1458901046,
                "answer_id": 36218044,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s  a version that works recursively (using `*`) on an arbitrary number of objects:\r\n\r\n```lang-bash\r\necho &#39;{&quot;A&quot;: {&quot;a&quot;: 1}}&#39; &#39;{&quot;A&quot;: {&quot;b&quot;: 2}}&#39; &#39;{&quot;B&quot;: 3}&#39; |\\\r\n  jq --slurp &#39;reduce .[] as $item ({}; . * $item)&#39;\r\n\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  &quot;B&quot;: 3\r\n}\r\n```\r\n\r\n",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1572425466,
                "creation_date": 1572425466,
                "answer_id": 58621547,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can be used to merge any number of files specified on the command:\r\n\r\n`jq -rs &#39;reduce .[] as $item ({}; . * $item)&#39; file1.json file2.json file3.json ... file10.json`\r\n\r\nor this for any number of files\r\n\r\n`jq -rs &#39;reduce .[] as $item ({}; . * $item)&#39; ./*.json`\r\n\r\n",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 32,
                "is_accepted": false,
                "score": 32,
                "last_activity_date": 1646860271,
                "creation_date": 1646860271,
                "answer_id": 71416016,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No solution or comment given so far considers using `input` to access the second file. Employing it would render unnecessary the buildup of an additional structure to extract from, such as the all-embracing array when  using the `--slurp` (or `-s`) option, which features in almost all of the other approaches.\r\n\r\nTo merge two files on top level, simply add the second file from `input` to the first in `.` using `+`:\r\n~~~sh\r\njq &#39;. + input&#39; file1.json file2.json\r\n~~~\r\n\r\nTo merge two files recursively on all levels, do the same using `*` as operator instead:\r\n~~~sh\r\njq &#39;. * input&#39; file1.json file2.json\r\n~~~\r\n\r\nThat said, to recursively merge your two files, with both objects reduced to their `value` field, filter them first using `{value}`:\r\n~~~sh\r\njq &#39;{value} * (input | {value})&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;value&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;value1&quot;: &quot;v1&quot;,\r\n      &quot;value2&quot;: &quot;v2&quot;,\r\n      &quot;value3&quot;: &quot;v3&quot;,\r\n      &quot;value4&quot;: 4\r\n    },\r\n    &quot;bbb&quot;: {\r\n      &quot;value1&quot;: &quot;v1&quot;,\r\n      &quot;value2&quot;: &quot;v2&quot;,\r\n      &quot;value3&quot;: &quot;v3&quot;\r\n    },\r\n    &quot;ccc&quot;: {\r\n      &quot;value1&quot;: &quot;v1&quot;,\r\n      &quot;value2&quot;: &quot;v2&quot;\r\n    },\r\n    &quot;ddd&quot;: {\r\n      &quot;value3&quot;: &quot;v3&quot;,\r\n      &quot;value4&quot;: 4\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/74uEFcXXL-)\r\n\r\nNote that a solution which reduces only _after_ the merge, like `. * input | {value}` would, is shorter in code but resurrects the &quot;buildup of an additional structure to extract from&quot; futility again, which may produce a lot of overhead if the parts eventually cut off get big.\r\n\r\nIn order to operate on more than two files, either accordingly use `input` multiple times, or programmatically iterate over all of them using `inputs` instead, as in\r\n~~~sh\r\njq &#39;reduce inputs as $i (.; . * $i)&#39; file*.json\r\n~~~\r\nNote that in either case the first file is always accessed via the input context `.` while `input(s)` only addresses the _remaining_ files, i.e. starting from the second (unless, of course, the `--null-input` or `-n` option is given).\r\n\r\n\r\n\r\n\r\n",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1659643010,
                "last_edit_date": 1659643010,
                "creation_date": 1659642474,
                "answer_id": 73241522,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I didn&#39;t want to discard previous non-unique key in my objects\r\n\r\n```\r\njq -n &#39;{a:1, c:2}, {b:3, d:4}, {a:5,d:6}&#39; |\r\njq -s &#39;map(to_entries)|flatten|group_by(.key)|map({(.[0].key):map(.value)|add})|add&#39;\r\n{\r\n  &quot;a&quot;: 6,\r\n  &quot;b&quot;: 3,\r\n  &quot;c&quot;: 2,\r\n  &quot;d&quot;: 10\r\n}\r\n```\r\n\r\nor alternatively if you wanted to just keep an array of the values, remove the add after the extraction of the value `map(.value)|̶a̶d̶d̶`\r\n```\r\njq -n &#39;{a:1, c:2}, {b:3, d:4}, {a:5,d:6}&#39; |\r\njq -s &#39;map(to_entries)|flatten|group_by(.key)|map({(.[0].key):map(.value)})|add&#39;\r\n{\r\n  &quot;a&quot;: [1, 5],\r\n  &quot;b&quot;: [3],\r\n  &quot;c&quot;: [2],\r\n  &quot;d&quot;: [4, 6]\r\n}\r\n```\r\n\r\nTry removing each part of the command and see how each step modifies the array of objects... aka run these steps and see how the output changes\r\n\r\n```\r\nmap(to_entries)\r\nmap(to_entries)|flatten\r\nmap(to_entries)|flatten|group_by(.key)\r\nmap(to_entries)|flatten|group_by(.key)|map({(.[0].key):map(.value)})\r\nmap(to_entries)|flatten|group_by(.key)|map({(.[0].key):map(.value)})|add\r\n```",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1748931324,
                "creation_date": 1748931324,
                "answer_id": 79650707,
                "question_id": 19529688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Merging two JSONL files line by line**\r\n\r\nI came across this closely related use case which may be of interest to Googlers, suppose you have:\r\n\r\nin1.jsonl\r\n\r\n```\r\n{&quot;a&quot;:1, &quot;b&quot;:2}\r\n{&quot;a&quot;:3, &quot;b&quot;:4}\r\n```\r\n\r\nin2.jsonl\r\n\r\n```\r\n{&quot;c&quot;:5, &quot;d&quot;:6}\r\n{&quot;c&quot;:7, &quot;d&quot;:8}\r\n```\r\n\r\nand you want:\r\n\r\n```\r\n{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:5, &quot;d&quot;:6}\r\n{&quot;a&quot;:3, &quot;b&quot;:4, &quot;c&quot;:7, &quot;d&quot;:8}\r\n```\r\n\r\nI&#39;ve managed to do that with:\r\n\r\n```\r\npaste in1.jsonl in2.jsonl | jq &#39;. * input&#39;\r\n```\r\n\r\nThe way this works is that first it pastes the two JSONL into a weird JSONL-like format:\r\n\r\n```\r\n{&quot;a&quot;:1,&quot;b&quot;:2}   {&quot;c&quot;:5,&quot;d&quot;:6}\r\n{&quot;a&quot;:3,&quot;b&quot;:4}   {&quot;c&quot;:7,&quot;d&quot;:8}\r\n```\r\n\r\nbut jq doesn&#39;t care and treats that like JSONL. Then `input` pulls the next JSON out ahead of time, and then we merge the current one `.` with the next one from `input` with `*`.\r\n\r\nUnfortunately I couldn&#39;t get rid of the `paste` and do it in pure `jq`, but it&#39;s not too bad.\r\n\r\nTested on jq 1.7, Ubuntu 25.04.\r\n",
                "title": "How to merge 2 JSON objects from 2 files using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 265,
        "last_activity_date": 1748931324,
        "creation_date": 1382481827,
        "last_edit_date": 1604492339,
        "question_id": 19529688,
        "body_markdown": "I&#39;m using the [jq][1] tools (jq-json-processor) in shell script to parse json.\r\n\r\nI&#39;ve got 2 json files and **want to merge them into one unique file**\r\n\r\nHere the content of files:\r\n\r\n**file1**\r\n\r\n    {\r\n        &quot;value1&quot;: 200,\r\n        &quot;timestamp&quot;: 1382461861,\r\n        &quot;value&quot;: {\r\n            &quot;aaa&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;bbb&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;ccc&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            }\r\n        }\r\n    }\r\n\r\n**file2**\r\n\r\n    {\r\n        &quot;status&quot;: 200,\r\n        &quot;timestamp&quot;: 1382461861,\r\n        &quot;value&quot;: {\r\n            &quot;aaa&quot;: {\r\n                &quot;value3&quot;: &quot;v3&quot;,\r\n                &quot;value4&quot;: 4\r\n            },\r\n            &quot;bbb&quot;: {\r\n                &quot;value3&quot;: &quot;v3&quot;\r\n            },      \r\n            &quot;ddd&quot;: {\r\n                &quot;value3&quot;: &quot;v3&quot;,\r\n                &quot;value4&quot;: 4\r\n            }\r\n        }\r\n    }\r\n\r\n**expected result**\r\n\r\n    {\r\n        &quot;value&quot;: {\r\n            &quot;aaa&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;,\r\n                &quot;value3&quot;: &quot;v3&quot;,\r\n                &quot;value4&quot;: 4\r\n            },\r\n            &quot;bbb&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;,\r\n                &quot;value3&quot;: &quot;v3&quot;\r\n            },\r\n            &quot;ccc&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;,\r\n                &quot;value2&quot;: &quot;v2&quot;\r\n            },\r\n            &quot;ddd&quot;: {\r\n                &quot;value3&quot;: &quot;v3&quot;,\r\n                &quot;value4&quot;: 4\r\n            }\r\n        }\r\n    }\r\n\r\nI try a lot of combinations but the only result i get is the following, which is not the expected result:\r\n\r\n    {\r\n      &quot;ccc&quot;: {\r\n        &quot;value2&quot;: &quot;v2&quot;,\r\n        &quot;value1&quot;: &quot;v1&quot;\r\n      },\r\n      &quot;bbb&quot;: {\r\n        &quot;value2&quot;: &quot;v2&quot;,\r\n        &quot;value1&quot;: &quot;v1&quot;\r\n      },\r\n      &quot;aaa&quot;: {\r\n        &quot;value2&quot;: &quot;v2&quot;,\r\n        &quot;value1&quot;: &quot;v1&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;ddd&quot;: {\r\n        &quot;value4&quot;: 4,\r\n        &quot;value3&quot;: &quot;v3&quot;\r\n      },\r\n      &quot;bbb&quot;: {\r\n        &quot;value3&quot;: &quot;v3&quot;\r\n      },\r\n      &quot;aaa&quot;: {\r\n        &quot;value4&quot;: 4,\r\n        &quot;value3&quot;: &quot;v3&quot;\r\n      }\r\n    }\r\n\r\n\r\nUsing this command:\r\n\r\n    jq -s &#39;.[].value&#39; file1 file2\r\n\r\n  [1]: https://github.com/stedolan/jq",
        "link": "https://stackoverflow.com/questions/19529688/how-to-merge-2-json-objects-from-2-files-using-jq",
        "title": "How to merge 2 JSON objects from 2 files using jq?"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 197,
                "is_accepted": true,
                "score": 197,
                "last_activity_date": 1741190105,
                "last_edit_date": 1741190105,
                "creation_date": 1386665770,
                "answer_id": 20489951,
                "question_id": 19573517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [select][1] function to get only required entries:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq &#39;select(.geo != null)&#39; all.json\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
                "title": "jq Conditional output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 120,
        "last_activity_date": 1741190105,
        "creation_date": 1382638551,
        "last_edit_date": 1404458459,
        "question_id": 19573517,
        "body_markdown": "I&#39;m using [jq][1] to play with json. I was wondering how to conditionally print something in that.\r\n\r\nSay I am interested in a field call `geo`. I used the following command and find out there is only one entry whose `geo` is `null`:\r\n\r\n    % cat all.json | jq &#39;.geo != null&#39; | sort | uniq -c              \r\n       1 false\r\n    6891 true\r\n\r\nHow can I print out that entry only without printing everything else?\r\n\r\nDidn&#39;t see something like `print` command in the manual. And this doesn&#39;t work: `cat all.json | jq &#39;if .place == null then . end&#39;`. `jq` complained about syntax error.\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/19573517/jq-conditional-output",
        "title": "jq Conditional output"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1383216286,
                "creation_date": 1383216286,
                "answer_id": 19704355,
                "question_id": 19703940,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try to access to `result` object and inside it extract the `difficulty` value:\r\n\r\n    ./jq &#39;.result.difficulty&#39; status.txt\r\n\r\nIt yields:\r\n\r\n    28.20775972\r\n",
                "title": "Parsing json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1404458447,
        "creation_date": 1383215159,
        "last_edit_date": 1404458447,
        "question_id": 19703940,
        "body_markdown": "I am trying to get the difficulty value out of a JSON structure using jq on the linux command line:\r\n\r\n    ./jq &#39;{result: .difficulty}&#39; status.txt\r\n\r\n(The JSON is held in a file called status.txt - shown below) But try as I might I keep getting: \r\n\r\n    {\r\n      &quot;result&quot;: null\r\n    }\r\n\r\nReturned, can someone tell me what I am doing wrong?\r\n\r\n    {\r\n       &quot;result&quot;:{\r\n          &quot;version&quot;:1030000,\r\n          &quot;protocolversion&quot;:60001,\r\n          &quot;walletversion&quot;:60000,\r\n          &quot;balance&quot;:2600.00020000,\r\n          &quot;blocks&quot;:16042,\r\n          &quot;connections&quot;:6,\r\n          &quot;proxy&quot;:&quot;&quot;,\r\n          &quot;difficulty&quot;:28.20775972,\r\n          &quot;testnet&quot;:false,\r\n          &quot;keypoololdest&quot;:1382340615,\r\n          &quot;keypoolsize&quot;:94,\r\n          &quot;paytxfee&quot;:0.00000000,\r\n          &quot;mininput&quot;:0.00010000,\r\n          &quot;unlocked_until&quot;:0,\r\n          &quot;errors&quot;:&quot;&quot;\r\n       },\r\n       &quot;error&quot;:null,\r\n       &quot;id&quot;:&quot;curltest&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/19703940/parsing-json-using-jq",
        "title": "Parsing json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1400432,
                    "reputation": 2780,
                    "user_id": 1329321,
                    "user_type": "registered",
                    "accept_rate": 51,
                    "profile_image": "https://www.gravatar.com/avatar/c3c2bc221f92e4a674ac01510cf900f0?s=256&d=identicon&r=PG",
                    "display_name": "Mike Manfrin",
                    "link": "https://stackoverflow.com/users/1329321/mike-manfrin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1385329949,
                "post_id": 20181467,
                "comment_id": 30087020,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1206451,
                    "reputation": 171716,
                    "user_id": 1175966,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8d3d9dfbd040f9cbc1a6b82f0da2b345?s=256&d=identicon&r=PG",
                    "display_name": "charlietfl",
                    "link": "https://stackoverflow.com/users/1175966/charlietfl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1385330546,
                "post_id": 20181467,
                "comment_id": 30087232,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 83,
                "is_accepted": true,
                "score": 83,
                "last_activity_date": 1479925591,
                "last_edit_date": 1479925591,
                "creation_date": 1402967478,
                "answer_id": 24254365,
                "question_id": 20181467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this filter:\r\n\r\n    to_entries[] | [.key, .value]\r\n\r\n* `to_entries` converts an object to an array of key/value objects.  `[]` breaks up the array to each of the items in the array\r\n* then for each of the items, covert to an array containing the key and value.\r\n\r\nThis produces the following output:\r\n\r\n    [\r\n      &quot;123&quot;,\r\n      &quot;abc&quot;\r\n    ],\r\n    [\r\n      &quot;231&quot;,\r\n      &quot;dbh&quot;\r\n    ],\r\n    [\r\n      &quot;452&quot;,\r\n      &quot;xyz&quot;\r\n    ]\r\n\r\nThen you can use the `@csv` filter to convert the rows to CSV rows.\r\n\r\n    $ echo &#39;{&quot;123&quot;:&quot;abc&quot;,&quot;231&quot;:&quot;dbh&quot;,&quot;452&quot;:&quot;xyz&quot;}&#39; | jq -r &#39;to_entries[] | [.key, .value] | @csv&#39;\r\n    &quot;123&quot;,&quot;abc&quot;\r\n    &quot;231&quot;,&quot;dbh&quot;\r\n    &quot;452&quot;,&quot;xyz&quot;",
                "title": "How to map an object to arrays so it can be converted to csv?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1415265872,
                "creation_date": 1415265872,
                "answer_id": 26775754,
                "question_id": 20181467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Jeff answer is a good starting point, something closer to what you expect:\r\n\r\n    cat input.json | jq &#39;to_entries | map([.key, .value]|join(&quot;,&quot;))&#39;\r\n\r\n    [\r\n     &quot;123,abc&quot;,\r\n     &quot;231,dbh&quot;,\r\n     &quot;452,xyz&quot;\r\n    ]\r\n\r\nBut did not find a way to join using newline:\r\n\r\n    cat input.json | jq &#39;to_entries | map([.key, .value]|join(&quot;,&quot;))|join(&quot;\\n&quot;)&#39;\r\n\r\n    &quot;123,abc\\n231,dbh\\n452,xyz&quot;\r\n",
                "title": "How to map an object to arrays so it can be converted to csv?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1480568831,
                "last_edit_date": 1480568831,
                "creation_date": 1425063088,
                "answer_id": 28772223,
                "question_id": 20181467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s an example I ended up using this morning (processing PagerDuty alerts):\r\n\r\n    cat /tmp/summary.json | jq -r &#39;\r\n      .incidents\r\n      | map({desc: .trigger_summary_data.description, id:.id})\r\n      | group_by(.desc)\r\n      | map(length as $len\r\n      | {desc:.[0].desc, length: $len}) \r\n      | sort_by(.length) \r\n      | map([.desc, .length] | @csv)\r\n      | join(&quot;\\n&quot;) &#39;\r\n\r\nThis dumps a CVS-separated document that looks something like:\r\n```\r\n    &quot;[Triggered] Something annoyingly frequent&quot;,31\r\n    &quot;[Triggered] Even more frequent alert!&quot;,35\r\n    &quot;[No data] Stats Server is probably acting up&quot;,55\r\n```",
                "title": "How to map an object to arrays so it can be converted to csv?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1434717688,
                "creation_date": 1434717688,
                "answer_id": 30938403,
                "question_id": 20181467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    onecol2txt () {\r\n     awk &#39;BEGIN { RS=&quot;_end_&quot;; FS=&quot;\\n&quot;}\r\n       { for (i=2; i &lt;= NF; i++){\r\n           printf &quot;%s &quot;,$i \r\n           }\r\n         printf &quot;\\n&quot; \r\n       }&#39;\r\n    }\r\n    cat jsonfile | jq -r -c &#39;....,&quot;_end_&quot;&#39; | onecol2txt",
                "title": "How to map an object to arrays so it can be converted to csv?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1526382952,
                "creation_date": 1526382952,
                "answer_id": 50348818,
                "question_id": 20181467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try This \r\ngive same output you want\r\n\r\n    echo &#39;{&quot;123&quot;:&quot;abc&quot;,&quot;231&quot;:&quot;dbh&quot;,&quot;452&quot;:&quot;xyz&quot;}&#39; | jq -r &#39;to_entries | .[] | &quot;\\&quot;&quot; + .key + &quot;\\&quot;,\\&quot;&quot; + (.value | tostring)+ &quot;\\&quot;&quot;&#39;",
                "title": "How to map an object to arrays so it can be converted to csv?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 54,
        "last_activity_date": 1526382952,
        "creation_date": 1385329763,
        "last_edit_date": 1502588863,
        "question_id": 20181467,
        "body_markdown": "I&#39;m trying to convert an object that looks like this:\r\n\r\n    {\r\n      &quot;123&quot; : &quot;abc&quot;,\r\n      &quot;231&quot; : &quot;dbh&quot;,\r\n      &quot;452&quot; : &quot;xyz&quot;\r\n    }\r\n\r\nTo csv that looks like this:\r\n\r\n    &quot;123&quot;,&quot;abc&quot;\r\n    &quot;231&quot;,&quot;dbh&quot;\r\n    &quot;452&quot;,&quot;xyz&quot;\r\n\r\nI would prefer to use the command line tool [jq](http://stedolan.github.io/jq/manual/) but can&#39;t seem to figure out how to do the assignment. I managed to get the keys with `jq &#39;. | keys&#39; test.json` but couldn&#39;t figure out what to do next.\r\n\r\nThe problem is you can&#39;t convert a k:v object like this straight into csv with `@csv`. It needs to be an array so we need to convert to an array first.  If the keys were named, it would be simple but they&#39;re dynamic so its not so easy.",
        "link": "https://stackoverflow.com/questions/20181467/how-to-map-an-object-to-arrays-so-it-can-be-converted-to-csv",
        "title": "How to map an object to arrays so it can be converted to csv?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 404686,
                    "reputation": 36382,
                    "user_id": 773159,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4fcd72af6d7d5fdd28fc45289da3792a?s=256&d=identicon&r=PG",
                    "display_name": "Birei",
                    "link": "https://stackoverflow.com/users/773159/birei"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1385568015,
                "post_id": 20243696,
                "comment_id": 30198107,
                "content_license": "CC BY-SA 3.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": 1505595137,
                "post_id": 20243696,
                "comment_id": 79480233,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 228130,
                    "reputation": 656,
                    "user_id": 490240,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4c64a9d5c93890e5043388e0f8508fc5?s=256&d=identicon&r=PG",
                    "display_name": "jrw32982",
                    "link": "https://stackoverflow.com/users/490240/jrw32982"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611250814,
                "post_id": 20243696,
                "comment_id": 116397192,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1403158655,
                "creation_date": 1403158655,
                "answer_id": 24299930,
                "question_id": 20243696,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This:\r\n\r\n    declare -a things\r\n    things=($(jq tostring myfile.json) )\r\n    for x in &quot;${things[@]}&quot;; do\r\n        echo &quot;-metadata&quot; &quot;$x&quot;\r\n    done\r\n\r\nalmost works.  It splits things on whitespace.\r\n\r\nThis works:\r\n\r\n    declare -a things\r\n    OIFS=$IFS\r\n    IFS= things=($(jq -r &#39;tojson|tostring&#39; myfile.json) )\r\n    IFS=$OIFS\r\n    for x in &quot;${things[@]}&quot;; do\r\n        echo &quot;-metadata&quot; &quot;$x&quot;\r\n    done\r\n\r\nReally, we need a JSON-aware shell...  Something like ksh93&#39;s compound variables, but JSON-compatible.",
                "title": "jq cast result into bash array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1504642781,
        "creation_date": 1385558585,
        "last_edit_date": 1504642781,
        "question_id": 20243696,
        "body_markdown": "next to my attempt to parse a JSON response from curl using bash I now decided to give a try with jq.\r\nI have checked the documentation but I could not find a way to iterate trough the elements and &quot;do&quot; something.\r\n\r\nHere&#39;s an idea on what I am trying to achieve, cast the result from jq into an array, (it doesn&#39;t work)\r\n\r\n    __json=$($omd_response | ~/local-workspace/bash/jq -r &#39;[.]&#39;)\r\n    for x in &quot;${__json[@]}&quot;\r\n    do\r\n      echo &quot;-metadata&quot; $x\r\n    done\r\n\r\n\r\nAny other idea is much appreciated.\r\nThanks",
        "link": "https://stackoverflow.com/questions/20243696/jq-cast-result-into-bash-array",
        "title": "jq cast result into bash array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1385687440,
                "last_edit_date": 1385687440,
                "creation_date": 1385686539,
                "answer_id": 20276849,
                "question_id": 20276744,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "use `sed`:\r\n\r\n    sed -e &#39;s/&quot; /; /g; s/ &quot;/ /g; s/&quot;$/;&quot;/&#39; &lt;&lt;&lt; &#39;&quot;some value&quot; &quot;another value&quot; &quot;something else&quot;&#39;\r\n\r\n**OUTPUT:**\r\n\r\n    &quot;some value; another value; something else;&quot;\r\n\r\nuse sed `s` command for replacing the desire value\r\n\r\n",
                "title": "Convert quoted string list to specific format"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1385689814,
                "creation_date": 1385689814,
                "answer_id": 20277179,
                "question_id": 20276744,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thanks all! I actually decided to dig deeper into the jq docs to see if I could simply leverage it to do what I want.\r\n\r\n    after=`cat somefile.json | jq -c -r &#39;.after[] + &quot;; &quot;&#39;` | tr -d &#39;\\n&#39;\r\nThis ended up working very well. Thanks for the sed version though! Always good to see another working solution.",
                "title": "Convert quoted string list to specific format"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501659638,
                "creation_date": 1501659638,
                "answer_id": 45454474,
                "question_id": 20276744,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming `.after[]` returns the list of strings you describe, you can do this entirely with jq using **join** to format them as follows:\r\n\r\n    [ .after[] ] | join(&quot;; &quot;) + &quot;;&quot;\r\n",
                "title": "Convert quoted string list to specific format"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1501659638,
        "creation_date": 1385685717,
        "last_edit_date": 1403302385,
        "question_id": 20276744,
        "body_markdown": "I&#39;m using [jq][1] to read some data from a JSON file.\r\n\r\n    after=`cat somefile.json | jq &#39;.after[]&#39;`\r\n\r\nreturns something like this:\r\n\r\n    &quot;some value&quot; &quot;another value&quot; &quot;something else&quot;\r\nBasically a list of quoted strings. I now need to convert these strings into one string formatted like\r\n\r\n    &quot;some value; another value; something else;&quot;\r\nI&#39;ve tried a lot of combinations of for loops to try and get this working and nothing quite works.\r\n\r\nAnyone know how this can be done? Cheers!\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/20276744/convert-quoted-string-list-to-specific-format",
        "title": "Convert quoted string list to specific format"
    },
    {
        "tags": [
            "json",
            "shell",
            "diff",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1388453068,
                "creation_date": 1388453068,
                "answer_id": 20850306,
                "question_id": 20850289,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use diff. Like in\r\n\r\n    diff --unified file1.json file2.json\r\n\r\n",
                "title": "Comparing two json files : shell scripting"
            },
            {
                "up_vote_count": 30,
                "is_accepted": false,
                "score": 30,
                "last_activity_date": 1494283346,
                "creation_date": 1494283346,
                "answer_id": 43858340,
                "question_id": 20850289,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To compare json files you should convert them so they have same order of keys. Very good tool for this job is *jq* (https://stedolan.github.io/jq/) where you can do:\r\n\r\n    jq -S . fileA.json &gt; fileA_fmt.json\r\n    jq -S . fileB.json &gt; fileB_fmt.json\r\n    \r\nthen, you can use your favourite tool for text file comparison. I like *kdiff3* for GUI or just plain *diff* when in pure command-line e.g.:\r\n\r\n    diff fileA_fmt.json fileB_fmt.json\r\n\r\n\r\n\r\n ",
                "title": "Comparing two json files : shell scripting"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1620754920,
                "last_edit_date": 1620754920,
                "creation_date": 1606007973,
                "answer_id": 64949783,
                "question_id": 20850289,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just to update on the answer from bartolomeon_n, you can actually do this all on one line.\r\n\r\n\r\n    diff &lt;(jq -S . fileA.json) &lt;(jq -S . fileB.json)\r\n    # or, with nice columns and colours:\r\n    diff -y --left-column --color &lt;(jq -S . fileA.json) &lt;(jq -S . fileB.json)",
                "title": "Comparing two json files : shell scripting"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 15,
        "last_activity_date": 1620754920,
        "creation_date": 1388452950,
        "last_edit_date": 1615278881,
        "question_id": 20850289,
        "body_markdown": "I would like to compare two json files which look like the following: \r\n\r\n    [\r\n       {\r\n          &quot;type&quot; : 1,\r\n          &quot;children&quot; : {\r\n             &quot;nsubj&quot; : {\r\n                &quot;role&quot; : &quot;topic&quot;,\r\n                &quot;POS&quot; : [\r\n                   &quot;noun&quot;\r\n                ]\r\n             }\r\n          },\r\n          &quot;role&quot; : &quot;vehicle&quot;,\r\n          &quot;POS&quot; : [\r\n             &quot;noun&quot;\r\n          ]\r\n       },\r\n\r\nand the other is in the similar format, but there are some differences between the two because one json file is  made up of 3336 lines, while another is made up of 3724 lines. I would like to write a shell script which would compare the two line by line and whenever it finds a difference, output the line number where the difference occurred. ",
        "link": "https://stackoverflow.com/questions/20850289/comparing-two-json-files-shell-scripting",
        "title": "Comparing two json files : shell scripting"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1219964,
                    "reputation": 240371,
                    "user_id": 1903116,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/w6Ffg.jpg?s=256",
                    "display_name": "thefourtheye",
                    "link": "https://stackoverflow.com/users/1903116/thefourtheye"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1390571461,
                "post_id": 21334348,
                "comment_id": 32161072,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 423151,
                    "reputation": 43599,
                    "user_id": 802365,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/2fe665d956e0376411350d79379848c9?s=256&d=identicon&r=PG",
                    "display_name": "&#201;douard Lopez",
                    "link": "https://stackoverflow.com/users/802365/%c3%89douard-lopez"
                },
                "reply_to_user": {
                    "account_id": 1219964,
                    "reputation": 240371,
                    "user_id": 1903116,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/w6Ffg.jpg?s=256",
                    "display_name": "thefourtheye",
                    "link": "https://stackoverflow.com/users/1903116/thefourtheye"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1390571615,
                "post_id": 21334348,
                "comment_id": 32161170,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1219964,
                    "reputation": 240371,
                    "user_id": 1903116,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/w6Ffg.jpg?s=256",
                    "display_name": "thefourtheye",
                    "link": "https://stackoverflow.com/users/1903116/thefourtheye"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1390571709,
                "post_id": 21334348,
                "comment_id": 32161227,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 423151,
                    "reputation": 43599,
                    "user_id": 802365,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/2fe665d956e0376411350d79379848c9?s=256&d=identicon&r=PG",
                    "display_name": "&#201;douard Lopez",
                    "link": "https://stackoverflow.com/users/802365/%c3%89douard-lopez"
                },
                "reply_to_user": {
                    "account_id": 1219964,
                    "reputation": 240371,
                    "user_id": 1903116,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/w6Ffg.jpg?s=256",
                    "display_name": "thefourtheye",
                    "link": "https://stackoverflow.com/users/1903116/thefourtheye"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1390571981,
                "post_id": 21334348,
                "comment_id": 32161386,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1390574722,
                "creation_date": 1390574722,
                "answer_id": 21335518,
                "question_id": 21334348,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A simple solution is to install [`jshon`][1] library :\r\n\r\n    jshon -l &lt; /tmp/test.json\r\n    2\r\n\r\n  [1]: http://kmkeen.com/jshon/",
                "title": "How to count items in JSON object using command line?"
            },
            {
                "up_vote_count": 740,
                "is_accepted": true,
                "score": 740,
                "last_activity_date": 1537905550,
                "last_edit_date": 1537905550,
                "creation_date": 1390679426,
                "answer_id": 21355442,
                "question_id": 21334348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just throwing another solution in the mix...\r\n\r\nTry [`jq`][1], a lightweight and flexible command-line JSON processor:\r\n\r\n    jq length /tmp/test.json\r\n\r\nPrints the length of the array of objects.\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/\r\n",
                "title": "How to count items in JSON object using command line?"
            },
            {
                "up_vote_count": 96,
                "is_accepted": false,
                "score": 96,
                "last_activity_date": 1459423296,
                "last_edit_date": 1459423296,
                "creation_date": 1459419706,
                "answer_id": 36330650,
                "question_id": 21334348,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The shortest expression is \r\n\r\n    curl &#39;http://…&#39; | jq length",
                "title": "How to count items in JSON object using command line?"
            },
            {
                "up_vote_count": 127,
                "is_accepted": false,
                "score": 126,
                "last_activity_date": 1626457668,
                "last_edit_date": 1626457668,
                "creation_date": 1600716238,
                "answer_id": 63998729,
                "question_id": 21334348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use [jq](https://stedolan.github.io/jq/) to track down the array within the returned json and then pipe that in to a _second_ `jq` call to get its length. Suppose it was in a property called `records`, like `{&quot;records&quot;:[...]}`.\r\n\r\n```bash\r\n$ curl https://my-source-of-json.com/list | jq -r &#39;.records | length&#39;\r\n2\r\n$ \r\n```",
                "title": "How to count items in JSON object using command line?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1692223228,
                "last_edit_date": 1692223228,
                "creation_date": 1625618431,
                "answer_id": 68278776,
                "question_id": 21334348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "try qic.  it works like jq/jello.  qic support interactive mode as well.\r\n\r\n```bash\r\ncat test.json | qic &quot;len(_)&quot;\r\n```\r\n\r\nhttps://walkerever.github.io/qic/\r\n",
                "title": "How to count items in JSON object using command line?"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 31,
                "last_activity_date": 1629789054,
                "creation_date": 1629789054,
                "answer_id": 68903201,
                "question_id": 21334348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the `JSON` is being read from a file, try this -\r\n\r\n```\r\nnumber_of_objects=`jq &#39;. | length&#39; json_file_name.json`\r\necho $number_of_objects\r\n```\r\n\r\nIf the `JSON` array is inside a key in the `JSON` as shown below -\r\n\r\n```\r\n{\r\n  &quot;fruits&quot;: [\r\n    &quot;apples&quot;,\r\n    &quot;oranges&quot;,\r\n    &quot;pears&quot;\r\n  ]\r\n}\r\n```\r\ntry this -\r\n```\r\nnumber_of_objects=`jq &#39;.fruits | length&#39; json_file_name.json`\r\necho $number_of_objects\r\n```\r\n(You&#39;ll have to download [`jq`][1] for this solution to work)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
                "title": "How to count items in JSON object using command line?"
            },
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1677012165,
                "creation_date": 1677012165,
                "answer_id": 75525705,
                "question_id": 21334348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assume this structure:\r\n\r\n(stored in a variable named `json`)\r\n```\r\n{\r\n    &quot;results&quot;: [\r\n        { &quot;id&quot;: 1 }\r\n        { &quot;id&quot;: 2 }\r\n    ]\r\n\r\n}\r\n```\r\n\r\nIf you&#39;re looking to count how many are in the  `results` array, the command is:\r\n```\r\n$json | jq &#39;.results | length&#39;\r\n```",
                "title": "How to count items in JSON object using command line?"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 465,
        "last_activity_date": 1692223228,
        "creation_date": 1390571239,
        "last_edit_date": 1536498549,
        "question_id": 21334348,
        "body_markdown": "I&#39;m getting this kind of `JSON` reply from a `curl` command:\r\n\r\n    [\r\n      {\r\n        &quot;cid&quot;: 49,\r\n        &quot;pyn&quot;: &quot;yi4&quot;,\r\n        &quot;hans&quot;: &quot;亿&quot;,\r\n        &quot;hant&quot;: &quot;億&quot;,\r\n        &quot;tid&quot;: 68,\r\n        &quot;l10n&quot;: &quot;cent million&quot;,\r\n        &quot;pid&quot;: 1,\r\n        &quot;pos&quot;: &quot;num&quot;,\r\n        &quot;pos_txt&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;cid&quot;: 50,\r\n        &quot;pyn&quot;: &quot;yi4&quot;,\r\n        &quot;hans&quot;: &quot;亿&quot;,\r\n        &quot;hant&quot;: &quot;億&quot;,\r\n        &quot;tid&quot;: 69,\r\n        &quot;l10n&quot;: &quot;100 millions&quot;,\r\n        &quot;pid&quot;: 1,\r\n        &quot;pos&quot;: &quot;num&quot;,\r\n        &quot;pos_txt&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n\r\nHow can I count the number of items in the array (here `2`), using `Bash` or a command line (e.g. `underscore`) ?",
        "link": "https://stackoverflow.com/questions/21334348/how-to-count-items-in-json-object-using-command-line",
        "title": "How to count items in JSON object using command line?"
    },
    {
        "tags": [
            "json",
            "terminal",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1403679207,
                "creation_date": 1403679207,
                "answer_id": 24402050,
                "question_id": 21902275,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Regarding getting your expected result, the filter you want to use is:\r\n\r\n    .name\r\n\r\nNote the `.`.  You want to get the value of the `name` property.\r\n\r\n\r\nAs for the error, I don&#39;t know what your environment is but it seems to indicate that you&#39;ve installed the wrong version of jq that isn&#39;t compatible with your OS.  Look for a _good_ tutorial on how to get it installed on your machine.",
                "title": "Parse json in command line terminal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1403679207,
        "creation_date": 1392885348,
        "last_edit_date": 1403679017,
        "question_id": 21902275,
        "body_markdown": "I want to use `jq` for processing my `json` file in terminal. I am trying this command:\r\n\r\n    cat json.txt | jq &#39;name&#39;\r\nit&#39;s showing me\r\n\r\n    -bash: /usr/bin/jq: cannot execute binary file\r\n\r\nExpected result:\r\n\r\n    Google\r\n\r\nwhere `json.txt` is indeed a valid `json` file. I tried to check whether `jq` is installed correctly. Here&#39;s what I am getting:\r\n\r\n     brew install jq\r\nit&#39;s showing me:\r\n\r\n    Warning: jq-1.3 already installed\r\n\r\nI am using `mac`. Anybody has any idea? The `json.txt` file is:\r\n\r\n     {\r\n        &quot;name&quot;: &quot;Google&quot;,\r\n        &quot;location&quot;:\r\n                {\r\n                        &quot;street&quot;: &quot;1600 Amphitheatre Parkway&quot;,\r\n                        &quot;city&quot;: &quot;Mountain View&quot;,\r\n                        &quot;state&quot;: &quot;California&quot;,\r\n                        &quot;country&quot;: &quot;US&quot;\r\n                },\r\n        &quot;employees&quot;:\r\n                [\r\n                        {\r\n                                &quot;name&quot;: &quot;Michael&quot;,\r\n                                &quot;division&quot;: &quot;Engineering&quot;\r\n                        },\r\n                        {\r\n                                &quot;name&quot;: &quot;Laura&quot;,\r\n                                &quot;division&quot;: &quot;HR&quot;\r\n                        },\r\n                        {\r\n                                &quot;name&quot;: &quot;Elise&quot;,\r\n                                &quot;division&quot;: &quot;Marketing&quot;\r\n                        }\r\n                ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/21902275/parse-json-in-command-line-terminal",
        "title": "Parse json in command line terminal"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1394752513,
                "creation_date": 1394752513,
                "answer_id": 22393004,
                "question_id": 22392819,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think that your `json` is not valid. I removed edge double quotes and unescaped the rest of them, like:\r\n\r\n    { &quot;ratio&quot;: 32.56351, &quot;name&quot;: &quot;Classes&quot; } { &quot;ratio&quot;: 9.505888, &quot;name&quot;: &quot;Conditionals&quot; } { &quot;ratio&quot;: 36.30363, &quot;name&quot;: &quot;File&quot; } { &quot;ratio&quot;: 13.349417, &quot;name&quot;: &quot;Lines&quot; } { &quot;ratio&quot;: 19.908062, &quot;name&quot;: &quot;Methods&quot; } { &quot;ratio&quot;: 43.75, &quot;name&quot;: &quot;Packages&quot; }\r\n\r\nWith it, you can try with string interpolation, like:\r\n\r\n    jq -r &#39;&quot;\\(.name): \\(.ratio)&quot;&#39; infile\r\n\r\nThat yields:\r\n\r\n    Classes: 32.56351\r\n    Conditionals: 9.505888\r\n    File: 36.30363\r\n    Lines: 13.349417\r\n    Methods: 19.908062\r\n    Packages: 43.75",
                "title": "JQ - Parsing data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1403160956,
        "creation_date": 1394751661,
        "last_edit_date": 1403160956,
        "question_id": 22392819,
        "body_markdown": "I have something like this in my shell script : \r\n\r\n   \r\n\r\n     &quot;{ \\&quot;ratio\\&quot;: 32.56351, \\&quot;name\\&quot;: \\&quot;Classes\\&quot; } { \\&quot;ratio\\&quot;: 9.505888, \\&quot;name\\&quot;: \\&quot;Conditionals\\&quot; } { \\&quot;ratio\\&quot;: 36.30363, \\&quot;name\\&quot;: \\&quot;Files\\&quot; } { \\&quot;ratio\\&quot;: 13.349417, \\&quot;name\\&quot;: \\&quot;Lines\\&quot; } { \\&quot;ratio\\&quot;: 19.908062, \\&quot;name\\&quot;: \\&quot;Methods\\&quot; } { \\&quot;ratio\\&quot;: 43.75, \\&quot;name\\&quot;: \\&quot;Packages\\&quot; }&quot;\r\n\r\nI need to extract something like this out of it :\r\n\r\n    Classes : 32.56351\r\n    Conditionals : 9.505888\r\n\r\nand so on for all the other values and store it in some array or varaible. I am thinking of using the jq json parser : http://stedolan.github.io/jq/\r\n\r\n",
        "link": "https://stackoverflow.com/questions/22392819/jq-parsing-data",
        "title": "JQ - Parsing data"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1454955530,
                "last_edit_date": 1495540476,
                "creation_date": 1394961236,
                "answer_id": 22435023,
                "question_id": 22434290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` is doing exactly what you tell it to do. &lt;s&gt;`jq` is not a program for generating JSON, but a tool for querying it. What you are doing with the `-n` switch is just using it as a pretty printer.&lt;/s&gt; So if you want it to print an object with an array containing &quot;one&quot;, &quot;two&quot;, &quot;three&quot; then you have to generate it.\r\n\r\n    VAR=&quot;one two three&quot;\r\n    VAR=$(echo $VAR | sed -e &#39;s/\\(\\w*\\)/,&quot;\\1&quot;/g&#39; | cut -d , -f 2-)\r\n    echo &quot;{var: [$VAR]}&quot;\r\n\r\n**Update**\r\n\r\nAs [Bryan][1] and others mention below it is indeed possible to generate JSON with jq, and from version 1.4, it&#39;s even possible to do what the OP ask directly, see for example [Jeff&#39;s answer][2].  \r\n\r\n\r\n  [1]: https://stackoverflow.com/users/91365/bryan-larsen\r\n  [2]: https://stackoverflow.com/a/24300273/2195474",
                "title": "jq &amp; bash: make JSON array from variable"
            },
            {
                "up_vote_count": 33,
                "is_accepted": false,
                "score": 33,
                "last_activity_date": 1453257040,
                "last_edit_date": 1453257040,
                "creation_date": 1403160067,
                "answer_id": 24300273,
                "question_id": 22434290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In jq 1.3 and up you can use the `--arg VARIABLE VALUE` command-line option:\r\n\r\n    jq -n --arg v &quot;$VAR&quot; &#39;{&quot;foo&quot;: $v}&#39;\r\n\r\nI.e., `--arg` sets a variable to the given value so you can then use `$varname` in your jq program, and now you don&#39;t have to use shell variable interpolation into your jq program.\r\n\r\nEDIT: From jq 1.5 and up, you can use --argjson to pass in an array directly, e.g. \r\n\r\n    jq -n --argjson v &#39;[1,2,3]&#39; &#39;{&quot;foo&quot;: $v}&#39;",
                "title": "jq &amp; bash: make JSON array from variable"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1469299652,
                "last_edit_date": 1469299652,
                "creation_date": 1407174047,
                "answer_id": 25124477,
                "question_id": 22434290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Once you have your variable loaded, you should use the [`split`](http://stedolan.github.io/jq/manual/#split) filter to split that string into an array.\r\n\r\n    $ jq -n --arg inarr &quot;${ARR}&quot; &#39;{ arr: $inarr | split(&quot;\\n&quot;) }&#39;",
                "title": "jq &amp; bash: make JSON array from variable"
            },
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 12,
                "last_activity_date": 1453256563,
                "last_edit_date": 1453256563,
                "creation_date": 1417391477,
                "answer_id": 27219744,
                "question_id": 22434290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The original posting in this thread mentions VAR=&quot;one two three&quot;.  For such a variable, a very simple solution in jq 1.4 is as follows:\r\n\r\n    $ jq -n -c -M --arg s &quot;$VAR&quot; &#39;{var: ($s|split(&quot; &quot;))}&#39;\r\n    {&quot;var&quot;:[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]}\r\n\r\n(This assumes a Linux or Mac shell or similar, and works with jq 1.4.)\r\n\r\nIf the separator character is a newline, then consider this typescript:\r\n\r\n    $ s=$(printf &quot;a\\nb\\nc\\n&quot;)\r\n    $ jq -n -c -M --arg var &quot;$s&quot; &#39;{&quot;var&quot;: ($var|split(&quot;\\n&quot;))}&#39;\r\n    {&quot;var&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]}\r\n\r\n\r\nNotice that the JSON string for the newline character is `&quot;\\n&quot;` (not `&quot;\\\\n&quot;`).\r\n\r\nA third case of interest is when VAR is a bash array.  In this case, it may be acceptable to pass in the items using &quot;${VAR[@]}&quot;, but in general, it must be remembered that the &quot;--arg name value&quot; option is intended only for passing in strings.\r\n\r\nIn jq&gt;1.4, exported shell variables can be passed in using the &quot;env&quot; object, as documented in the online jq manual page.",
                "title": "jq &amp; bash: make JSON array from variable"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1478620934,
                "creation_date": 1478620934,
                "answer_id": 40491396,
                "question_id": 22434290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First you have to use `-R` to read the raw lines and next you have to slurp all values with `-s`:\r\n\r\n    $ echo -e &quot;one\\ntwo\\nthree&quot; | jq -R . | jq -s &#39;{&quot;arr&quot;: .}&#39;\r\n    {\r\n      &quot;arr&quot;: [\r\n        &quot;one&quot;,\r\n        &quot;two&quot;,\r\n        &quot;three&quot;\r\n      ]\r\n    }\r\n",
                "title": "jq &amp; bash: make JSON array from variable"
            },
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 12,
                "last_activity_date": 1549551370,
                "last_edit_date": 1549551370,
                "creation_date": 1549551048,
                "answer_id": 54576004,
                "question_id": 22434290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This worked for me in jq 1.6:\r\n\r\n    $ jq -nc &#39;$ARGS.positional&#39; --args 1 2 3\r\n    [&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]\r\n\r\nFor this specific use-case, you could use an array and write:\r\n\r\n    $ VAR=(one two three)\r\n    $ jq -nc &#39;{var: $ARGS.positional}&#39; --args ${VAR[@]}\r\n    {&quot;var&quot;:[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]}\r\n\r\nYou could also use a string like this:\r\n\r\n    $ VAR=&quot;one two three&quot;\r\n    $ jq -nc &#39;{var: ($ARGS.positional[0] | split(&quot; &quot;))}&#39; --args $VAR\r\n",
                "title": "jq &amp; bash: make JSON array from variable"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 31,
        "last_activity_date": 1549551370,
        "creation_date": 1394955729,
        "last_edit_date": 1417427106,
        "question_id": 22434290,
        "body_markdown": "I&#39;m using [jq][1] to form a JSON in bash from variable values.\r\n\r\nGot how to make plain variables\r\n\r\n    $ VAR=&quot;one two three&quot;\r\n    $ jq -n &quot;{var:\\&quot;$VAR\\&quot;}&quot;\r\n    {\r\n      &quot;var&quot;: &quot;one two three&quot;\r\n    }\r\n\r\nBut can&#39;t make arrays yet. I have\r\n\r\n    $ echo $ARR\r\n    one\r\n    two\r\n    three\r\n\r\nand want to get something like\r\n\r\n    {\r\n      &quot;arr&quot;: [&quot;one&quot;, &quot;two&quot;, &quot;three&quot;]\r\n    }\r\n\r\nI only manage to get garbled output like\r\n\r\n    $ jq -n &quot;{arr: [\\&quot;$ARR\\&quot;]}&quot;\r\n    {\r\n      &quot;arr&quot;: [\r\n        &quot;one\\ntwo\\nthree&quot;\r\n      ]\r\n    }\r\n\r\nHow to form JSON array in a correct way? Can `jq` ever do that?\r\n\r\n**EDIT**: Question was asked when there was only jq 1.3. Now, in jq 1.4, it is possible to do straightly what I asked for, like @JeffMercado and @peak suggested, upvote for them. Won&#39;t undo acceptance of @jbr &#39;s answer though.\r\n\r\n  [1]: http://stedolan.github.io/jq/ &quot;jq&quot;",
        "link": "https://stackoverflow.com/questions/22434290/jq-bash-make-json-array-from-variable",
        "title": "jq &amp; bash: make JSON array from variable"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 41,
                "is_accepted": true,
                "score": 40,
                "last_activity_date": 1395307513,
                "last_edit_date": 1395307513,
                "creation_date": 1395307099,
                "answer_id": 22528346,
                "question_id": 22528142,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With that line of code\r\n\r\n    value=($(jq -r &#39;.key1&#39; jsonFile))\r\n\r\nyou are assigning both values to an [array][1]. Note the outer parantheses `()` around the command.\r\nThus you can access the values individually or echo the content of the entire array.\r\n\r\n    $ echo &quot;${value[@]}&quot;\r\n    aaaa bbbb\r\n    \r\n    $ echo &quot;${value[0]}&quot;\r\n    aaaa\r\n    \r\n    $ echo &quot;${value[1]}&quot;\r\n    bbbb\r\n\r\nSince you echoed `$value` without specifying which value you want to get you only get the first value of the array.\r\n\r\n  [1]: http://wiki.bash-hackers.org/syntax/arrays",
                "title": "get field from json and assign to variable in bash script?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1599467861,
                "creation_date": 1599467861,
                "answer_id": 63774101,
                "question_id": 22528142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    local result=$(&lt;your_json_response&gt;)\r\n    local aws_access_key=$(jq -r &#39;.Credentials.AccessKeyId&#39; &lt;&lt;&lt; ${result})\r\n    local aws_secret_key=$(jq -r &#39;.Credentials.SecretAccessKey&#39; &lt;&lt;&lt; ${result})\r\n    local session_token=$(jq -r &#39;.Credentials.SessionToken&#39; &lt;&lt;&lt; ${result})\r\n\r\nAbove code is another way to get the values from json response.",
                "title": "get field from json and assign to variable in bash script?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 31,
        "last_activity_date": 1599467861,
        "creation_date": 1395306531,
        "last_edit_date": 1477942633,
        "question_id": 22528142,
        "body_markdown": "I have a json store in jsonFile\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;aaaa bbbbb&quot;,\r\n      &quot;key2&quot;: &quot;cccc ddddd&quot;\r\n    }\r\n\r\nI have code in `mycode.sh`:\r\n\r\n    #!/bin/bash\r\n    value=($(jq -r &#39;.key1&#39; jsonFile))\r\n    echo &quot;$value&quot;\r\n\r\nAfter I run `./mycode.sh` the result is `aaaa`\r\nbut if I just run `jq -r &#39;.key1&#39; jsonFile` the result is `aaaa bbbbb`\r\n\r\nCould anyone help me?",
        "link": "https://stackoverflow.com/questions/22528142/get-field-from-json-and-assign-to-variable-in-bash-script",
        "title": "get field from json and assign to variable in bash script?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "amazon-ec2",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1396235362,
                "last_edit_date": 1396235362,
                "creation_date": 1396172793,
                "answer_id": 22742518,
                "question_id": 22704831,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The main problem is that your query is missing a closing &#39;]&#39;, however I think it&#39;s a bit trickier to filter on EC2 instances that have those tags.\r\n\r\nThis might be a bit convoluted, but something like this works for me:\r\n\r\n    aws ec2 describe-instances | jq &#39;.Instances | map(select(has(&quot;Tags&quot;))) | map(select(.Tags[].Key==&quot;Name&quot; and .Tags[].Key==&quot;Owner&quot; and .Tags[].Key==&quot;Cost.centre&quot;)) | map(select(has(&quot;InstanceId&quot;))) | .[].InstanceId,.[].Tags&#39;",
                "title": "Using jq to parse json output of AWS CLI tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1442790371,
                "creation_date": 1442790371,
                "answer_id": 32685222,
                "question_id": 22704831,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    $ aws ec2 describe-instances --output json | jq &#39;.Reservations[].Instances[] | (.Tags | from_entries) as $tags | select($tags.Owner != null) | {InstanceID: .InstanceId, Name: $tags.Name, Owner: $tags.Owner, CostCenter: $tags.&quot;cost.center&quot;}&#39;\r\n\r\n... which returns:\r\n\r\n    {\r\n      &quot;InstanceID&quot;: &quot;i-734cbc51&quot;,\r\n      &quot;Name&quot;: &quot;someserver001&quot;,\r\n      &quot;Owner&quot;: &quot;john.smith@null&quot;,\r\n      &quot;CostCenter&quot;: &quot;ABC001&quot;\r\n    }\r\n",
                "title": "Using jq to parse json output of AWS CLI tools"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1442790371,
        "creation_date": 1395984242,
        "last_edit_date": 1403209055,
        "question_id": 22704831,
        "body_markdown": "I would like to use jq (http://stedolan.github.io/jq/) to parse the json output from aws ec2 describe-instances and return the Instance ID  and Tags only where Tags contains Name. owner, costcentre.\r\n\r\nHere is partial redacted json representing the source output:\r\n\r\n    {\r\n      &quot;OwnerId&quot;:&quot;121456789127&quot;,\r\n      &quot;ReservationId&quot;:&quot;r-48465168&quot;,\r\n      &quot;Groups&quot;:[\r\n    \r\n      ],\r\n      &quot;Instances&quot;:[\r\n        {\r\n          &quot;Monitoring&quot;:{\r\n            &quot;State&quot;:&quot;disabled&quot;\r\n          },\r\n          &quot;PublicDnsName&quot;:null,\r\n          &quot;RootDeviceType&quot;:&quot;ebs&quot;,\r\n          &quot;State&quot;:{\r\n            &quot;Code&quot;:16,\r\n            &quot;Name&quot;:&quot;running&quot;\r\n          },\r\n          &quot;EbsOptimized&quot;:false,\r\n          &quot;LaunchTime&quot;:&quot;2014-03-19T09:16:56.000Z&quot;,\r\n          &quot;PrivateIpAddress&quot;:&quot;10.250.171.248&quot;,\r\n          &quot;ProductCodes&quot;:[\r\n            {\r\n              &quot;ProductCodeId&quot;:&quot;aacglxeowvn5hy8sznltowyqe&quot;,\r\n              &quot;ProductCodeType&quot;:&quot;marketplace&quot;\r\n            }\r\n          ],\r\n          &quot;VpcId&quot;:&quot;vpc-86bab0e4&quot;,\r\n          &quot;StateTransitionReason&quot;:null,\r\n          &quot;InstanceId&quot;:&quot;i-1234576&quot;,\r\n          &quot;ImageId&quot;:&quot;ami-b7f6c5de&quot;,\r\n          &quot;PrivateDnsName&quot;:&quot;ip-10-120-134-248.ec2.internal&quot;,\r\n          &quot;KeyName&quot;:&quot;Test_Virginia&quot;,\r\n          &quot;SecurityGroups&quot;:[\r\n            {\r\n              &quot;GroupName&quot;:&quot;Test&quot;,\r\n              &quot;GroupId&quot;:&quot;sg-12345b&quot;\r\n            }\r\n          ],\r\n          &quot;ClientToken&quot;:&quot;VYeFw1395220615808&quot;,\r\n          &quot;SubnetId&quot;:&quot;subnet-12345314&quot;,\r\n          &quot;InstanceType&quot;:&quot;t1.micro&quot;,\r\n          &quot;NetworkInterfaces&quot;:[\r\n            {\r\n              &quot;Status&quot;:&quot;in-use&quot;,\r\n              &quot;SourceDestCheck&quot;:true,\r\n              &quot;VpcId&quot;:&quot;vpc-123456e4&quot;,\r\n              &quot;Description&quot;:&quot;Primary network interface&quot;,\r\n              &quot;NetworkInterfaceId&quot;:&quot;eni-3619f31d&quot;,\r\n              &quot;PrivateIpAddresses&quot;:[\r\n                {\r\n                  &quot;Primary&quot;:true,\r\n                  &quot;PrivateIpAddress&quot;:&quot;10.120.134.248&quot;\r\n                }\r\n              ],\r\n              &quot;Attachment&quot;:{\r\n                &quot;Status&quot;:&quot;attached&quot;,\r\n                &quot;DeviceIndex&quot;:0,\r\n                &quot;DeleteOnTermination&quot;:true,\r\n                &quot;AttachmentId&quot;:&quot;eni-attach-9210dee8&quot;,\r\n                &quot;AttachTime&quot;:&quot;2014-03-19T09:16:56.000Z&quot;\r\n              },\r\n              &quot;Groups&quot;:[\r\n                {\r\n                  &quot;GroupName&quot;:&quot;Test&quot;,\r\n                  &quot;GroupId&quot;:&quot;sg-123456cb&quot;\r\n                }\r\n              ],\r\n              &quot;SubnetId&quot;:&quot;subnet-31236514&quot;,\r\n              &quot;OwnerId&quot;:&quot;109030037527&quot;,\r\n              &quot;PrivateIpAddress&quot;:&quot;10.120.134.248&quot;\r\n            }\r\n          ],\r\n          &quot;SourceDestCheck&quot;:true,\r\n          &quot;Placement&quot;:{\r\n            &quot;Tenancy&quot;:&quot;default&quot;,\r\n            &quot;GroupName&quot;:null,\r\n            &quot;AvailabilityZone&quot;:&quot;us-east-1c&quot;\r\n          },\r\n          &quot;Hypervisor&quot;:&quot;xen&quot;,\r\n          &quot;BlockDeviceMappings&quot;:[\r\n            {\r\n              &quot;DeviceName&quot;:&quot;/dev/sda&quot;,\r\n              &quot;Ebs&quot;:{\r\n                &quot;Status&quot;:&quot;attached&quot;,\r\n                &quot;DeleteOnTermination&quot;:false,\r\n                &quot;VolumeId&quot;:&quot;vol-37ff097b&quot;,\r\n                &quot;AttachTime&quot;:&quot;2014-03-19T09:17:00.000Z&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;Architecture&quot;:&quot;x86_64&quot;,\r\n          &quot;KernelId&quot;:&quot;aki-88aa75e1&quot;,\r\n          &quot;RootDeviceName&quot;:&quot;/dev/sda1&quot;,\r\n          &quot;VirtualizationType&quot;:&quot;paravirtual&quot;,\r\n          &quot;Tags&quot;:[\r\n            {\r\n              &quot;Value&quot;:&quot;Server for testing RDS feature in us-east-1c AZ&quot;,\r\n              &quot;Key&quot;:&quot;Description&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;:&quot;RDS_Machine (us-east-1c)&quot;,\r\n              &quot;Key&quot;:&quot;Name&quot;\r\n            },\r\n              {\r\n              &quot;Value&quot;:&quot;1234&quot;,\r\n              &quot;Key&quot;:&quot;Cost.centre&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;:&quot;Jyoti Bhanot&quot;,\r\n              &quot;Key&quot;:&quot;Owner&quot;\r\n            }\r\n          ],\r\n          &quot;AmiLaunchIndex&quot;:0\r\n        }\r\n      ]\r\n    }\r\n\r\nI am using this command :\r\n\r\n\r\n     aws ec2 describe-instances | jq &#39;.Instances[] | select(.Tags==[&quot;Name&quot;,&quot;Owner&quot;,&quot;cost.centre&quot;) | .InstanceId, .Tags&#39;\r\n\r\n\r\n**But its giving me error :**\r\n\r\n   \r\n\r\n                                                               ^\r\n       error: Invalid character\r\n    .Reservations[].Instances | map(select(has(&quot;Tags&quot;))) |.Tags[].Key==&quot;cost.centre&quot;)) | map(select(has(&quot;InstanceId&quot;))) | .[].InstanceId,.[].Tags\r\n                                                                                    ^\r\n    error: Invalid character\r\n    .Reservations[].Instances | map(select(has(&quot;Tags&quot;))) |.Tags[].Key==&quot;cost.centre&quot;)) | map(select(has(&quot;InstanceId&quot;))) | .[].InstanceId,.[].Tags\r\n                                                                                     ^\r\n    2 compile errors\r\n    \r\n    [Errno 32] Broken pipe\r\n\r\nKindly help me resolve this error \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/22704831/using-jq-to-parse-json-output-of-aws-cli-tools",
        "title": "Using jq to parse json output of AWS CLI tools"
    },
    {
        "tags": [
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1445617,
                    "reputation": 11876,
                    "user_id": 1364218,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/70a22970d761969c48f4d5850767b523?s=256&d=identicon&r=PG",
                    "display_name": "Josh Jolly",
                    "link": "https://stackoverflow.com/users/1364218/josh-jolly"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1396538155,
                "post_id": 22841472,
                "comment_id": 34842604,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1504740792,
                "post_id": 22841472,
                "comment_id": 79133515,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1398247113,
                "creation_date": 1398247113,
                "answer_id": 23240917,
                "question_id": 22841472,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I believe the following will work:\r\n\r\n    cat myjson.json | jq &#39;reduce .[] as $item ({}; . + $item)&#39;\r\n\r\nIt takes each item in the array, and adds it to the sum of all the previous items.",
                "title": "Reducing JSON with jq"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1403135375,
                "creation_date": 1403135375,
                "answer_id": 24296736,
                "question_id": 22841472,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Note that jq has a builtin function called &#39;add&#39; that the same thing that the first answer suggests, so you ought to be able to write:\r\n\r\n    jq add myjson.json",
                "title": "Reducing JSON with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1429764715,
                "creation_date": 1429764715,
                "answer_id": 29813954,
                "question_id": 22841472,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To expand on the other two answers a bit, you can &quot;add&quot; two objects together like this:\r\n\r\n    .[0] + .[1]\r\n\r\n    =&gt; { &quot;key1&quot;: &quot;value&quot;, &quot;key2&quot;: &quot;value&quot; }\r\n\r\nYou can use the generic `reduce` function to repeatedly apply a function between the first two items of a list, then between that result and the next item, and so on:\r\n\r\n    reduce .[] as $item ({}; . + $item)\r\n\r\nWe start with `{}`, add `.[0]`, then add `.[1]` etc.\r\n\r\nFinally, as a convenience, jq has an `add` function which is essentially an alias for exactly this function, so you can write the whole thing as:\r\n\r\n    add\r\n\r\nOr, as a complete command line:\r\n\r\n    jq add myjson.json\r\n\r\n\r\n\r\n",
                "title": "Reducing JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1429764715,
        "creation_date": 1396537132,
        "last_edit_date": 1403302413,
        "question_id": 22841472,
        "body_markdown": "I have a JSON array of Objects:\r\n\r\n    [{key1: value},{key2:value}, ...]\r\n\r\nI would like to reduce these into the following structure:\r\n\r\n    {key1: value, key2: value, ...} \r\n\r\nIs this possible to do with [jq](http://stedolan.github.io/jq/)?\r\n\r\nI was trying:\r\n\r\n    cat myjson.json | jq &#39;.[] | {(.key): value}&#39;\r\n\r\nThis doesn&#39;t quite work as it iterates over each datum rather than reducing it to one Object.",
        "link": "https://stackoverflow.com/questions/22841472/reducing-json-with-jq",
        "title": "Reducing JSON with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 436,
                "is_accepted": true,
                "score": 435,
                "last_activity_date": 1675797392,
                "last_edit_date": 1675797392,
                "creation_date": 1397676971,
                "answer_id": 23118607,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the keys in the order they appear in the original JSON use:\r\n```sh\r\njq &#39;keys_unsorted&#39; file.json\r\n```\r\n\r\nIf you want the keys sorted alphanumerically, you can use:\r\n```sh\r\njq &#39;keys&#39; file.json\r\n```\r\n\r\nComplete example\r\n```sh\r\n$ cat file.json\r\n{ &quot;Created-By&quot; : &quot;Apache Maven&quot;, &quot;Build-Number&quot; : &quot;&quot;, &quot;Archiver-Version&quot; : &quot;Plexus Archiver&quot;, &quot;Build-Id&quot; : &quot;&quot;,  &quot;Build-Tag&quot; : &quot;&quot;, &quot;Built-By&quot; : &quot;cporter&quot;}\r\n\r\n$ jq &#39;keys_unsorted&#39; file.json                                         \r\n[\r\n  &quot;Created-By&quot;,\r\n  &quot;Build-Number&quot;,\r\n  &quot;Archiver-Version&quot;,\r\n  &quot;Build-Id&quot;,\r\n  &quot;Build-Tag&quot;,\r\n  &quot;Built-By&quot;\r\n]\r\n\r\n$ jq &#39;keys&#39; file.json\r\n[\r\n  &quot;Archiver-Version&quot;,\r\n  &quot;Build-Id&quot;,\r\n  &quot;Build-Number&quot;,\r\n  &quot;Build-Tag&quot;,\r\n  &quot;Built-By&quot;,\r\n  &quot;Created-By&quot;\r\n]\r\n```",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 22,
                "is_accepted": false,
                "score": 22,
                "last_activity_date": 1498710729,
                "last_edit_date": 1498710729,
                "creation_date": 1498632951,
                "answer_id": 44795551,
                "question_id": 23118341,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In combination with the above answer, you want to ask jq for raw output, so your last filter should be eg.:\r\n\r\n         cat input.json | jq -r &#39;keys&#39;\r\n\r\nFrom jq help:\r\n\r\n    \t -r\t\toutput raw strings, not JSON texts;\r\n\r\n",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 53,
                "is_accepted": false,
                "score": 53,
                "last_activity_date": 1511204729,
                "last_edit_date": 1511204729,
                "creation_date": 1499365260,
                "answer_id": 44956291,
                "question_id": 23118341,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to use `jq &#39;keys[]&#39;`. For example:\r\n\r\n    echo &#39;{&quot;example1&quot; : 1, &quot;example2&quot; : 2, &quot;example3&quot; : 3}&#39; | jq &#39;keys[]&#39;\r\n\r\nWill output a line separated list:\r\n    \r\n    &quot;example1&quot;\r\n    &quot;example2&quot;\r\n    &quot;example3&quot;\r\n\r\n",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1547235921,
                "creation_date": 1547235921,
                "answer_id": 54153126,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`echo &#39;{&quot;ab&quot;: 1, &quot;cd&quot;: 2}&#39; | jq -r &#39;keys[]&#39;` prints all keys one key per line without quotes.\r\n\r\n    ab\r\n    cd",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1547339951,
                "last_edit_date": 1547339951,
                "creation_date": 1547337698,
                "answer_id": 54164990,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To print keys on one line as csv:\r\n```\r\necho &#39;{&quot;b&quot;:&quot;2&quot;,&quot;a&quot;:&quot;1&quot;}&#39; | jq -r &#39;keys | [ .[] | tostring ] | @csv&#39;\r\n```\r\nOutput:\r\n```\r\n&quot;a&quot;,&quot;b&quot;\r\n```\r\n\r\nFor csv completeness ... to print values on one line as csv:\r\n```\r\necho &#39;{&quot;b&quot;:&quot;2&quot;,&quot;a&quot;:&quot;1&quot;}&#39; | jq -rS . | jq -r &#39;. | [ .[] | tostring ] | @csv&#39;\r\n```\r\nOutput:\r\n```\r\n&quot;1&quot;,&quot;2&quot;\r\n```",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1733526956,
                "last_edit_date": 1733526956,
                "creation_date": 1588006098,
                "answer_id": 61464000,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way of getting a Bash array with the example JSON given by [@anubhava in his answer](https://stackoverflow.com/a/23118607):\r\n\r\n```bash\r\narr=($(jq --raw-output &#39;keys_unsorted | @sh&#39; file.json))\r\n\r\necho ${arr[0]}    # &#39;Archiver-Version&#39;\r\necho ${arr[1]}    # &#39;Build-Id&#39;\r\necho ${arr[2]}    # &#39;Build-Jdk&#39;\r\n```\r\n",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 108,
                "is_accepted": false,
                "score": 108,
                "last_activity_date": 1616323763,
                "last_edit_date": 1616323763,
                "creation_date": 1590071924,
                "answer_id": 61937001,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the keys on a deeper node in a JSON:\r\n\r\n```\r\necho &#39;{&quot;data&quot;: &quot;1&quot;, &quot;user&quot;: { &quot;name&quot;: 2, &quot;phone&quot;: 3 } }&#39; | jq &#39;.user | keys[]&#39;\r\n&quot;name&quot;\r\n&quot;phone&quot;\r\n```",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1619333106,
                "creation_date": 1619333106,
                "answer_id": 67250524,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input is an array of objects,\r\n\r\n    [\r\n      { \r\n        &quot;a01&quot; : { &quot;name&quot; : &quot;A&quot;, &quot;user&quot; : &quot;B&quot; }\r\n      },\r\n      { \r\n        &quot;a02&quot; : { &quot;name&quot; : &quot;C&quot;, &quot;user&quot; : &quot;D&quot; }\r\n      }\r\n    ]\r\n\r\ntry with:\r\n\r\n    jq &#39;.[] | keys[]&#39;",
                "title": "How to get key names from JSON using jq"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1619710946,
                "creation_date": 1619710946,
                "answer_id": 67320733,
                "question_id": 23118341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Oddly enough, the accepted answer doesn’t actually answer the Q exactly, so for reference, here is a solution that does:\r\n\r\n    $ jq -r &#39;keys_unsorted[]&#39; file.json",
                "title": "How to get key names from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 309,
        "last_activity_date": 1733526956,
        "creation_date": 1397676083,
        "last_edit_date": 1692225214,
        "question_id": 23118341,
        "body_markdown": "`curl http://testhost.test.com:8080/application/app/version | jq &#39;.version&#39; | jq &#39;.[]&#39;`\r\n\r\n The above command outputs only the values as below:\r\n\r\n    &quot;madireddy@test.com&quot;\r\n    \r\n    &quot;2323&quot;\r\n    \r\n    &quot;test&quot;\r\n    \r\n    &quot;02-03-2014-13:41&quot;\r\n    \r\n    &quot;application&quot;\r\n    \r\n How can I get the key names instead like the below:\r\n\r\n&lt;!-- language: none --&gt;\r\n    email\r\n    \r\n    versionID\r\n    \r\n    context\r\n    \r\n    date\r\n    \r\n    versionName\r\n\r\n",
        "link": "https://stackoverflow.com/questions/23118341/how-to-get-key-names-from-json-using-jq",
        "title": "How to get key names from JSON using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "enumeration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1398227324,
                "creation_date": 1398227324,
                "answer_id": 23234757,
                "question_id": 23120359,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq has an option to sort the keys. See http://stedolan.github.io/jq/manual/#Invokingjq\r\n\r\n    --sort-keys / -S:\r\n    \r\n    Output the fields of each object with the keys in sorted order.\r\n\r\nHowever the current released version (1.3) of jq doesn&#39;t have this enhancement yet, you&#39;ll need to compile jq via latest code from it&#39;s master branch. See http://stedolan.github.io/jq/download/ , the &quot;From source on Linux or OS X&quot; section.\r\n\r\nFor a complete history and details of this feature, see issue #79 &quot;Option or function to sort object members by name&quot; https://github.com/stedolan/jq/issues/79",
                "title": "jq sorts KEY and VALUES in different way - how can I enumerate them in the same order?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1403208826,
                "creation_date": 1403208826,
                "answer_id": 24315502,
                "question_id": 23120359,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can also\r\n\r\n    $ echo &#39;{&quot;a&quot;:0, &quot;b&quot;:1}&#39; | jq -c &#39;to_entries|map([.key, .value])|map(.[])&#39;\r\n    [&quot;a&quot;,0,&quot;b&quot;,1]",
                "title": "jq sorts KEY and VALUES in different way - how can I enumerate them in the same order?"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1487634860,
                "last_edit_date": 1495541372,
                "creation_date": 1487487711,
                "answer_id": 42324565,
                "question_id": 23120359,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem stems from `jq`&#39;s possibly surprising **default behavior**:\r\n\r\n* `keys` enumerates the keys alphabetically *sorted*.\r\n* `.[]` enumerates the values based on the keys&#39; *input order*&lt;sup&gt;[1]&lt;/sup&gt;\r\n\r\nIn other words: If you use `keys` to extract an object&#39;s *keys* in one pass, and then `.[]` to extract its *values* in another, the corresponding output elements might not match.\r\n\r\n**`jq` v1.5** introduced the **`keys_unsorted/0`** function, which enables a simple solution:\r\n\r\n    # Sample input with unordered keys.\r\n    # Sorting the values results in the same order as sorting the keys,\r\n    # so the output order of values below implies the key enumeration order that was applied.\r\n    json=&#39;{ &quot;c&quot;:3, &quot;a&quot;:1, &quot;b&quot;:2 }&#39;\r\n\r\nPrint ***keys* in input order**, using `keys_unsorted/0`:\r\n\r\n    $ echo &quot;$json&quot; | jq -r &#39;keys_unsorted[]&#39;\r\n    c\r\n    a\r\n    b\r\n\r\n\r\n\r\nPrint ***values* in input order**, which `[]` invariably does:\r\n\r\n    $ echo &quot;$json&quot; | jq -r &#39;.[]&#39;\r\n    3\r\n    1\r\n    2\r\n\r\n**Caveat**: Up to version **v1.3**, using **`.[]`** resulted in **no guaranteed enumeration order** (the underlying hash table&#39;s key sorting was used, which is an implementation detail); if you still must use v1.3, you can use the `to_entries` approach shown below.\r\n\r\n----------\r\n\r\n**[v1.3+]** **`to_entries/0`**, as used in [user2259432&#39;s helpful answer](https://stackoverflow.com/a/24315502/45375), also enumerates the properties **in input order**:\r\n\r\n    # Extract keys\r\n    $ echo &quot;$json&quot; | jq -r &#39;to_entries | map(.key)[]&#39;\r\n    c\r\n    a\r\n    b\r\n\r\n&lt;!--  --&gt;\r\n\r\n    # Extract values\r\n    $ echo &quot;$json&quot; | jq -r &#39;to_entries | map(.value)[]&#39;\r\n    3\r\n    1\r\n    2\r\n\r\n**Caveat**: **Prior to v1.5, `to_entries/0`** output key-value pairs in **sorted-by-key order**.  \r\n\r\nHowever, since `to_entries/0` can be used to enumerate both keys and values, it is **still a viable solution for producing a stable enumeration order** in parallel key/value extractions, **even in pre-v1.5 versions**.\r\n\r\n----------\r\n\r\n**[v1.3+]** If, by contrast, you want to **enumerate in *sorted-by-key* order**:\r\n\r\nPrint ***keys* in alphabetically sorted order**, using `keys/0`:\r\n\r\n    $ echo &quot;$json&quot; | jq -r &#39;keys[]&#39;\r\n    a\r\n    b\r\n    c\r\n\r\nPrint ***values* by alphabetically sorted keys**:\r\n\r\n    $ echo &quot;$json&quot; | jq -r &#39;keys[] as $k | .[$k]&#39;\r\n    1\r\n    2\r\n    3\r\n\r\n----------\r\n\r\nA **caveat re `-S` / `--sort-keys`**: \r\n\r\nThis option **only applies to _whole objects_, on _output_:**\r\n\r\n    $ echo &quot;$json&quot; | jq -Sc &#39;.&#39;\r\n    {&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}  # Sorted by key\r\n\r\nIt **doesn&#39;t apply when you use an operator or function to access the internals of an object:**\r\n\r\n    $ echo &quot;$json&quot; | jq -S &#39;.[]&#39; # !! -S doesn&#39;t apply, because [] always uses input order\r\n    3\r\n    1\r\n    2\r\n\r\n----------\r\n\r\n&lt;sup&gt;[1] Prior to v1.5, _no particular order_ was guaranteed, resulting the same problem, however.&lt;/sup&gt;\r\n\r\n",
                "title": "jq sorts KEY and VALUES in different way - how can I enumerate them in the same order?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 12,
        "last_activity_date": 1487634860,
        "creation_date": 1397683175,
        "last_edit_date": 1487512463,
        "question_id": 23120359,
        "body_markdown": "I get REST output in JSON format using curl command as below\r\n\r\nGetting KEY names alone using:\r\n\r\n    curl http://test.te:8080/testApp/app/version | jq &#39;.version&#39; | jq &#39;. | keys&#39;\r\n\r\nOUTPUT:\r\n \r\n\r\n    &quot;Archiver-Version&quot;,\r\n    &quot;Build-Id&quot;,\r\n    &quot;Build-Jdk&quot;,\r\n    &quot;Build-Number&quot;,\r\n    &quot;Build-Tag&quot;,\r\n    &quot;Built-By&quot;\r\n\r\nGetting VALUES alone using:\r\n\r\n    curl http://test.te.com:8080/testApp/app/version | jq &#39;.version&#39; | jq &#39;.[]&#39;\r\n\r\nOUTPUT (Note how the order of values doesn&#39;t correspond to the order of key names; e.g., the first value, `&quot;user@test.com&quot;`, is the value for key `&quot;Built-By&quot;`, not, as I would expect, for the first key, `&quot;Archiver-Version&quot;`):\r\n\r\n    &quot;user@test.com&quot;\r\n    &quot;1634d38&quot;\r\n    &quot;sandbox&quot;\r\n    &quot;02-03-2014-13:41&quot;\r\n    &quot;testApp&quot;\r\n\r\nI am trying to assign the KEYS and VALUES to separate arrays, so that I can iterate over them and display them in table format.\r\n\r\nBut these two commands are sorted in different way, I cannot assign the values and keys directly. \r\n\r\nIs there anyway to change the sorting of KEYS and VALUES so that both are same? \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/23120359/jq-sorts-key-and-values-in-different-way-how-can-i-enumerate-them-in-the-same",
        "title": "jq sorts KEY and VALUES in different way - how can I enumerate them in the same order?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 33,
                "is_accepted": true,
                "score": 33,
                "last_activity_date": 1403160272,
                "creation_date": 1403160272,
                "answer_id": 24300334,
                "question_id": 23268506,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In 1.4 you can just:\r\n\r\n    jq &#39;..|.updateDate?&#39;\r\n\r\nIf you&#39;re stuck with 1.3 you can use a longer program like so:\r\n\r\n    jq &#39;recurse(if type == &quot;array&quot; or type = &quot;object&quot; then .[] else empty end) | if type == &quot;object&quot; then .updateDate else empty end&#39;",
                "title": "jq - select objects with given key name"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1403160283,
                "creation_date": 1403160283,
                "answer_id": 24300340,
                "question_id": 23268506,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Not tested: how about `jq &#39;recurse(.[]?) | objects | has(&quot;updateDate&quot;)&#39;` ?",
                "title": "jq - select objects with given key name"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1544212472,
                "creation_date": 1544212472,
                "answer_id": 53676048,
                "question_id": 23268506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The accepted answer also produces `null` for every object that **doesn&#39;t** have the key.\r\n\r\nWhat worked for me was:\r\n\r\n    jq &#39;..|objects|.updateDate//empty&#39;\r\n\r\nThe `.updateDate//empty` part means: if `.updateDate` is `null` (or `false`), skip it entirely.\r\n\r\nThis of course wouldn&#39;t work if you expect your key to have values of `false` or `null`. In that case, use this:\r\n\r\n\r\n    jq &#39;..|objects|select(has(&quot;updateDate&quot;))|.updateDate&#39;\r\n",
                "title": "jq - select objects with given key name"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 29,
        "last_activity_date": 1544212472,
        "creation_date": 1398341418,
        "last_edit_date": 1403160127,
        "question_id": 23268506,
        "body_markdown": "I&#39;ve got an arbitrary structure with many levels, etc. I need to select all objects that contain a key named `updateDate`. How do I do that with jq? I came up with one way but it also produces errors on invalid data types when it visits a leaf which I have to grep out:\r\n\r\n    jq &#39;recurse(.[]) | has(&quot;updateDate&quot;)&#39; | grep -Fv error\r\n\r\nI don&#39;t really understand how to also check for types or leaves and I suspect there is a simpler way to achieve what I want?",
        "link": "https://stackoverflow.com/questions/23268506/jq-select-objects-with-given-key-name",
        "title": "jq - select objects with given key name"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 151321,
                    "reputation": 27498,
                    "user_id": 365102,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/4cFxJ9Lj.jpg?s=256",
                    "display_name": "Mateen Ulhaq",
                    "link": "https://stackoverflow.com/users/365102/mateen-ulhaq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690980676,
                "post_id": 23575963,
                "comment_id": 135428176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1403208571,
                "creation_date": 1403208571,
                "answer_id": 24315440,
                "question_id": 23575963,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq parses numbers into C doubles.  It then formats them back as numbers.  This conversion is lossy in two ways: a) there are many ways to represent the same number, but jq uses only one and has no options to do otherwise, b) C doubles have finite precision.\r\n\r\nThere are issues open against jq about both problems.  The likely solution will be to adopt a bignum/bigfloat approach, and to keep the original number string for numbers passed through unmodified (as it were; jq treats all data as copy-on-write).  But that isn&#39;t implemented yet.",
                "title": "How to prevent jq from automatically converting double to int?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1403208571,
        "creation_date": 1399682126,
        "last_edit_date": 1403161381,
        "question_id": 23575963,
        "body_markdown": "I have `input_file`:\r\n\r\n    {&quot;hi&quot;:48.0, &quot;yep&quot;:48.123}\r\n\r\nI run this\r\n\r\n    jq . &lt; input_file &gt; output_file\r\n    cat output_file\r\n\r\nMy output:\r\n\r\n    {\r\n      &quot;yep&quot;: 48.123,\r\n      &quot;hi&quot;: 48\r\n    }\r\n\r\nI would like the output to be \r\n\r\n    {\r\n      &quot;yep&quot;: 48.123,\r\n      &quot;hi&quot;: 48.0\r\n    }\r\n\r\nHow do I prevent jq from automatically converting my double values to an int?",
        "link": "https://stackoverflow.com/questions/23575963/how-to-prevent-jq-from-automatically-converting-double-to-int",
        "title": "How to prevent jq from automatically converting double to int?"
    },
    {
        "tags": [
            "json",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1399895978,
                "post_id": 23598328,
                "comment_id": 36241283,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1399845809,
                "creation_date": 1399845809,
                "answer_id": 23598435,
                "question_id": 23598328,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ahh, looks like I assumed that launchd shared the same PATHs as my normal bash shell. Explicitly spelling out where JQ lives seemed to work:\r\n\r\nSo at the top of the file I added:\r\n\r\n    JQ=/usr/local/bin/jq\r\n\r\nand replaced all instances of &#39;jq&#39; with:\r\n\r\n    $JQ",
                "title": "Using jq to parse JSON in launchd"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1399896477,
                "creation_date": 1399896477,
                "answer_id": 23608611,
                "question_id": 23598328,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As the very first process that runs in Mac OS X, `launchd` has no environment (including a `PATH` parameter) except for what you specify in `/etc/launchd.conf`. You could create that file and add\r\n\r\n    setenv PATH &quot;/usr/local/bin&quot;\r\n\r\nIf you want the full environment associated with your regular shell sessions, you should execute your script explicitly as a login shell:\r\n\r\n    bash -l myscript.bash",
                "title": "Using jq to parse JSON in launchd"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1403161097,
        "creation_date": 1399844939,
        "last_edit_date": 1403161097,
        "question_id": 23598328,
        "body_markdown": "I have a shell script that evaluates a folder full of JSON files which runs fine when invoked directly but fails when run from launchd. Specifically, launchd fails on this line:\r\n\r\n    current_file_snapshots=$(cat $current_file | jq &#39;.snapshots | length&#39;)\r\n\r\nBecause:\r\n\r\n    jq: command not found\r\n\r\nI looked through the jq docs to figure this out, but there&#39;s no mention of this problem. I haven&#39;t been able to figure out how to get jq (or any similar third party tool) to work through launchd. \r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/23598328/using-jq-to-parse-json-in-launchd",
        "title": "Using jq to parse JSON in launchd"
    },
    {
        "tags": [
            "parsing",
            "substring",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1350411,
                    "reputation": 47394,
                    "user_id": 1290264,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Pie1F.jpg?s=256",
                    "display_name": "bcorso",
                    "link": "https://stackoverflow.com/users/1290264/bcorso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1400644125,
                "post_id": 23773463,
                "comment_id": 36559180,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1350411,
                    "reputation": 47394,
                    "user_id": 1290264,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Pie1F.jpg?s=256",
                    "display_name": "bcorso",
                    "link": "https://stackoverflow.com/users/1290264/bcorso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1400644418,
                "post_id": 23773463,
                "comment_id": 36559253,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1400646400,
                "last_edit_date": 1400646400,
                "creation_date": 1400646068,
                "answer_id": 23773905,
                "question_id": 23773463,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So, it turns out most of these filters are not yet in the released version. For reference see issue [#289][1]\r\n\r\nWhat you could do is download the latest development version and compile from source. See [download page][2] &gt; From source on Linux\r\n\r\nAfter that, if indexing still doesn&#39;t work for strings, you should, at least, be able to do explode, index, implode combination, which seems to have been your plan.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/289\r\n  [2]: http://stedolan.github.io/jq/download/",
                "title": "jq substring gives &quot;jq: error: Cannot index string with object&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504739501,
                "creation_date": 1504739501,
                "answer_id": 46085576,
                "question_id": 23773463,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Looking at the [jq-1.3 manual](https://stedolan.github.io/jq/manual/v1.3/) I suspect there isn&#39;t a solution using that version since it offers no primitives for extacting parts of a string.",
                "title": "jq substring gives &quot;jq: error: Cannot index string with object&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1504739501,
        "creation_date": 1400643047,
        "last_edit_date": 1403302620,
        "question_id": 23773463,
        "body_markdown": "## Problem ##\r\nI&#39;m trying to filter a [json JQ][1] result to only show a substring of the original string. For example if a JQ filter grabed the value\r\n\r\n    4ffceab674ea8bb5ec421c612536696839bbaccecf64e851dfc270d795ee55d1\r\n\r\nI want it to only return the first 10 characters `4ffceab674`.\r\n\r\n\r\n----------\r\n\r\nWhat I&#39;ve tried\r\n----------\r\n\r\n\r\nOn the [Official JQ website][2] you can find an example that should give me what I need:\r\n\r\n    Command:\tjq &#39;.[2:4]&#39;\r\n\r\n    Input:\t\t&quot;abcdefghi&quot;\r\n    Output:\t\t&quot;cd&quot;\r\n\r\nI&#39;ve tried to test this out with a simple example in the unix terminal:\r\n\r\n    # this works fine, =&gt; &quot;abcdefghi&quot;\r\n    echo &#39;&quot;abcdefghi&quot;&#39; | jq &#39;.&#39;\r\n\r\n    # this doesn&#39;t work =&gt; jq: error: Cannot index string with object\r\n    echo &#39;&quot;abcdefghi&quot;&#39; | jq &#39;.[2:4]&#39;\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/\r\n  [2]: http://stedolan.github.io/jq/manual/#example3",
        "link": "https://stackoverflow.com/questions/23773463/jq-substring-gives-jq-error-cannot-index-string-with-object",
        "title": "jq substring gives &quot;jq: error: Cannot index string with object&quot;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1403209703,
                "creation_date": 1403209703,
                "answer_id": 24315702,
                "question_id": 24067809,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since subjects and so on can have multiple values, how do you want them separated in the output so as not to be ambiguous?\r\n\r\n    jq &#39;.personal_name as $names | .authors as $authors| {title, name, author: $names[.key]}&#39;\r\n\r\nis the fixed version of the jq command you have in your question, but not using `$authors`.\r\n\r\nAnyways, if you clarify what you&#39;re after we can definitely do this!",
                "title": "JQ or any json parser to make a join over mutiple large JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1403209703,
        "creation_date": 1401993686,
        "last_edit_date": 1403209367,
        "question_id": 24067809,
        "body_markdown": "At this page - https://openlibrary.org/developers/dumps - there are JSON data dumps for &#39;editions&#39; and &#39;authors&#39; totalling about 7Gb of data when compressed (about 28Gb when uncompressed). \r\n\r\nThe editions files are structured like this (the information in each row varies):\r\n&lt;pre&gt;\r\n/type/edition\t/books/OL24712550M\t2\t2011-08-12T15:48:15.081632\t{&quot;subtitle&quot;: &quot;finding solace and strength from friends and strangers&quot;, &quot;series&quot;: [&quot;Thorndike Press large print biography&quot;, &quot;Thorndike large print biography series&quot;], &quot;covers&quot;: [6783622], &quot;lc_classifications&quot;: [&quot;E840.8.E29 E24 2007&quot;], &quot;latest_revision&quot;: 2, &quot;ocaid&quot;: &quot;savinggracesfind00edwa&quot;, &quot;source_records&quot;: [&quot;ia:savinggracesfind00edwa&quot;], &quot;title&quot;: &quot;Saving graces&quot;, &quot;languages&quot;: [{&quot;key&quot;: &quot;/languages/eng&quot;}], &quot;subjects&quot;: [&quot;Cancer&quot;, &quot;Family&quot;, &quot;Legislators&#39; spouses&quot;, &quot;Philosophy&quot;, &quot;Patients&quot;, &quot;Large type books&quot;, &quot;Lawyers&#39; spouses&quot;, &quot;Biography&quot;, &quot;Protected DAISY&quot;], &quot;subject_people&quot;: [&quot;Elizabeth Edwards (1949-)&quot;, &quot;John Edwards (1953 June 10-)&quot;], &quot;publish_country&quot;: &quot;meu&quot;, &quot;by_statement&quot;: &quot;Elizabeth Edwards&quot;, &quot;oclc_numbers&quot;: [&quot;71809986&quot;], &quot;type&quot;: {&quot;key&quot;: &quot;/type/edition&quot;}, &quot;revision&quot;: 2, &quot;publishers&quot;: [&quot;Thorndike Press&quot;], &quot;ia_box_id&quot;: [&quot;IA133215&quot;], &quot;full_title&quot;: &quot;Saving graces finding solace and strength from friends and strangers&quot;, &quot;last_modified&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2011-08-12T15:48:15.081632&quot;}, &quot;key&quot;: &quot;/books/OL24712550M&quot;, &quot;authors&quot;: [{&quot;key&quot;: &quot;/authors/OL6606949A&quot;}], &quot;publish_places&quot;: [&quot;Waterville, Me&quot;], &quot;pagination&quot;: &quot;613 p. (large print) ;&quot;, &quot;created&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2011-06-29T22:47:47.350358&quot;}, &quot;dewey_decimal_class&quot;: [&quot;973.931092&quot;, &quot;B&quot;], &quot;number_of_pages&quot;: 613, &quot;isbn_13&quot;: [&quot;9780786291670&quot;], &quot;lccn&quot;: [&quot;2006031151&quot;], &quot;subject_places&quot;: [&quot;United States&quot;, &quot;North Carolina&quot;], &quot;isbn_10&quot;: [&quot;0786291672&quot;], &quot;publish_date&quot;: &quot;2007&quot;, &quot;copyright_date&quot;: &quot;2006&quot;, &quot;works&quot;: [{&quot;key&quot;: &quot;/works/OL15801457W&quot;}]}\r\n/type/edition\t/books/OL11119269M\t5\t2010-04-24T18:14:28.389476\t{&quot;number_of_pages&quot;: 362, &quot;subtitle&quot;: &quot;Godparenthood and Adoption in the Early Middle Ages (The University of Delaware Press Series, the Family in Interdisciplinary Perspective)&quot;, &quot;weight&quot;: &quot;1.6 pounds&quot;, &quot;covers&quot;: [2673249], &quot;latest_revision&quot;: 5, &quot;edition_name&quot;: &quot;Rev Exp edition&quot;, &quot;title&quot;: &quot;Spiritual Kinship As Social Practice&quot;, &quot;languages&quot;: [{&quot;key&quot;: &quot;/languages/eng&quot;}], &quot;subjects&quot;: [&quot;Family &amp; Relationships&quot;, &quot;Genealogy, heraldry, names and honours&quot;, &quot;c 500 CE to c 1000 CE&quot;, &quot;Ancient Rome - History&quot;, &quot;Social Institutions&quot;, &quot;Sociology&quot;, &quot;Ancient Rome&quot;, &quot;Sociology - Marriage &amp; Family&quot;, &quot;Alternative Family&quot;, &quot;Ancient - Rome&quot;, &quot;Spirituality - General&quot;, &quot;Adoption&quot;, &quot;Europe&quot;, &quot;History&quot;, &quot;Medieval, 500-1500&quot;, &quot;Social history&quot;, &quot;Sponsors&quot;, &quot;To 1500&quot;], &quot;type&quot;: {&quot;key&quot;: &quot;/type/edition&quot;}, &quot;physical_dimensions&quot;: &quot;9.8 x 6.2 x 1 inches&quot;, &quot;revision&quot;: 5, &quot;publishers&quot;: [&quot;University of Delaware Press&quot;], &quot;physical_format&quot;: &quot;Hardcover&quot;, &quot;last_modified&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2010-04-24T18:14:28.389476&quot;}, &quot;key&quot;: &quot;/books/OL11119269M&quot;, &quot;authors&quot;: [{&quot;key&quot;: &quot;/authors/OL797447A&quot;}], &quot;identifiers&quot;: {&quot;goodreads&quot;: [&quot;2994735&quot;]}, &quot;isbn_13&quot;: [&quot;9780874136326&quot;], &quot;isbn_10&quot;: [&quot;0874136326&quot;], &quot;publish_date&quot;: &quot;June 2000&quot;, &quot;works&quot;: [{&quot;key&quot;: &quot;/works/OL4195029W&quot;}]}\r\n/type/edition\t/books/OL25407707M\t1\t2012-08-08T08:36:18.306844\t{&quot;series&quot;: [&quot;Then &amp; now&quot;], &quot;lc_classifications&quot;: [&quot;F459.E43 C375 2012&quot;], &quot;latest_revision&quot;: 1, &quot;source_records&quot;: [&quot;marc:marc_loc_updates/v40.i32.records.utf8:13804252:745&quot;], &quot;title&quot;: &quot;Elizabethtown&quot;, &quot;languages&quot;: [{&quot;key&quot;: &quot;/languages/eng&quot;}], &quot;subjects&quot;: [&quot;Buildings, structures&quot;, &quot;Pictorial works&quot;, &quot;Historic buildings&quot;], &quot;publish_country&quot;: &quot;scu&quot;, &quot;by_statement&quot;: &quot;Meranda L. Caswell&quot;, &quot;type&quot;: {&quot;key&quot;: &quot;/type/edition&quot;}, &quot;revision&quot;: 1, &quot;publishers&quot;: [&quot;Arcadia Pub.&quot;], &quot;full_title&quot;: &quot;Elizabethtown&quot;, &quot;last_modified&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2012-08-08T08:36:18.306844&quot;}, &quot;key&quot;: &quot;/books/OL25407707M&quot;, &quot;authors&quot;: [{&quot;key&quot;: &quot;/authors/OL1397347A&quot;}], &quot;publish_places&quot;: [&quot;Charleston, S.C&quot;], &quot;pagination&quot;: &quot;x, 95 p. :&quot;, &quot;created&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2012-08-08T08:36:18.306844&quot;}, &quot;lccn&quot;: [&quot;2012933881&quot;], &quot;number_of_pages&quot;: 95, &quot;isbn_13&quot;: [&quot;9780738591667&quot;], &quot;subject_places&quot;: [&quot;Elizabethtown (Ky.)&quot;, &quot;Elizabethtown&quot;, &quot;Kentucky&quot;], &quot;isbn_10&quot;: [&quot;0738591661&quot;], &quot;publish_date&quot;: &quot;2012&quot;, &quot;works&quot;: [{&quot;key&quot;: &quot;/works/OL16772737W&quot;}]}\r\n&lt;/pre&gt;\r\n\r\nThe author files are structured like this:\r\n\r\n&lt;pre&gt;\r\n/type/author\t/authors/OL100223A\t2\t2008-09-08T16:20:28.105165\t{&quot;name&quot;: &quot;Umu Hilmy&quot;, &quot;personal_name&quot;: &quot;Umu Hilmy&quot;, &quot;last_modified&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2008-09-08T16:20:28.105165&quot;}, &quot;key&quot;: &quot;/authors/OL100223A&quot;, &quot;type&quot;: {&quot;key&quot;: &quot;/type/author&quot;}, &quot;revision&quot;: 2}\r\n/type/author\t/authors/OL6606949A\t1\t2009-05-14T08:13:43.294872\t{&quot;name&quot;: &quot;Elizabeth Edwards&quot;, &quot;created&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2009-05-14T08:13:43.294872&quot;}, &quot;personal_name&quot;: &quot;Elizabeth Edwards&quot;, &quot;last_modified&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2009-05-14T08:13:43.294872&quot;}, &quot;latest_revision&quot;: 1, &quot;key&quot;: &quot;/authors/OL6606949A&quot;, &quot;birth_date&quot;: &quot;1949&quot;, &quot;type&quot;: {&quot;key&quot;: &quot;/type/author&quot;}, &quot;revision&quot;: 1}\r\n/type/author\t/authors/OL1003081A\t5\t2012-06-06T22:11:38.525232\t{&quot;name&quot;: &quot;William Pinder Eversley&quot;, &quot;created&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2008-04-01T03:28:50.625462&quot;}, &quot;death_date&quot;: &quot;1918&quot;, &quot;photos&quot;: [6897255, 6897254], &quot;last_modified&quot;: {&quot;type&quot;: &quot;/type/datetime&quot;, &quot;value&quot;: &quot;2012-06-06T22:11:38.525232&quot;}, &quot;latest_revision&quot;: 5, &quot;key&quot;: &quot;/authors/OL1003081A&quot;, &quot;birth_date&quot;: &quot;1850&quot;, &quot;personal_name&quot;: &quot;William Pinder Eversley&quot;, &quot;type&quot;: {&quot;key&quot;: &quot;/type/author&quot;}, &quot;revision&quot;: 5}\r\n\r\n&lt;/pre&gt;\r\nWhat I want to end up with is a tab-delimited file with only the following information:\r\n\r\n&gt;OL reference\ttitle\tname\tisbn_10\tisbn_13\tsubjects\tsubject_places\tsubject_people\r\n\r\nFor example:\r\n\r\n&gt;/books/OL24712550M\tSaving graces\tElizabeth Edwards\t0786291672\t9780786291670\t&quot;Cancer&quot;, &quot;Family&quot;, &quot;Legislators&#39; spouses&quot;, &quot;Philosophy&quot;, &quot;Patients&quot;, &quot;Large type books&quot;, &quot;Lawyers&#39; spouses&quot;, &quot;Biography&quot;, &quot;Protected DAISY&quot;\t&quot;United States&quot;, &quot;North Carolina&quot;\t&quot;Elizabeth Edwards (1949-)&quot;, &quot;John Edwards (1953 June 10-)&quot;\r\n\r\n(In some cases of course some of these fields will be empty.)\r\n\r\nSo all of the information I want is in the editions dump except for the &#39;name&#39; field which comes from the authors dump, looked up by the reference in the editions dump, eg /authors/OL6606949A.\r\n\r\nSo I was trying to use [JQ][1] with the following query (for testing only few columns):\r\n\r\n&gt;.personal_name as $names | .authors | {title , name, author: $names[.key]}\r\n\r\nBut it does not even execute as I am also having problem finding the notation for author key.\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/manual/#Invokingjq",
        "link": "https://stackoverflow.com/questions/24067809/jq-or-any-json-parser-to-make-a-join-over-mutiple-large-json-files",
        "title": "JQ or any json parser to make a join over mutiple large JSON files"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1404457862,
                "creation_date": 1404457862,
                "answer_id": 24568571,
                "question_id": 24528256,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s easier than you think.\r\n\r\n    to_entries | map({name:.value, index:.key})\r\n\r\n`to_entries` takes an object and returns an array of key/value pairs. In the case of arrays, it effectively makes index/value pairs.  You could map those pairs to the items you wanted.",
                "title": "How do i add an index in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1415124713,
                "creation_date": 1415124713,
                "answer_id": 26742074,
                "question_id": 24528256,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A more &quot;hands-on&quot; approach is to use `reduce`:\r\n```\r\n[&quot;a&quot;, &quot;b&quot;] | . as $in | reduce range(0;length) as $i ([]; . + [{&quot;name&quot;: $in[$i], &quot;index&quot;: $i}])\r\n```",
                "title": "How do i add an index in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505971586,
                "last_edit_date": 1505971586,
                "creation_date": 1503601396,
                "answer_id": 45869175,
                "question_id": 24528256,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are a few more ways. Assuming `input.json` contains your data\r\n\r\n    [&quot;a&quot;, &quot;b&quot;]\r\n\r\nand you invoke jq as\r\n\r\n    jq -M -c -f filter.jq input.json\r\n\r\nthen any of the following `filter.jq` filters will generate\r\n\r\n    {&quot;name&quot;:&quot;a&quot;,&quot;index&quot;:0}\r\n    {&quot;name&quot;:&quot;b&quot;,&quot;index&quot;:1}\r\n\r\n1) using **keys** and **foreach**\r\n\r\n       foreach keys[] as $k (.;.;[$k,.[$k]])\r\n     | {name:.[1], index:.[0]}\r\n\r\n\r\nEDIT: I now realize a filter of the form `foreach E as $X (.; .; R)` can almost always be rewritten as `E as $X | R` so the above is really just\r\n\r\n       keys[] as $k\r\n     | [$k, .[$k]]\r\n     | {name:.[1], index:.[0]}\r\n\r\nwhich can be simplified to\r\n\r\n       keys[] as $k\r\n     | {name:.[$k], index:$k}\r\n\r\n     \r\n2) using **keys** and **transpose**\r\n\r\n       [keys, .]\r\n     | transpose[]\r\n     | {name:.[1], index:.[0]}\r\n     \r\n3) using a function\r\n\r\n     def enumerate:\r\n        def _enum(i):\r\n          if   length&lt;1\r\n          then empty\r\n          else [i, .[0]], (.[1:] | _enum(i+1))\r\n          end\r\n        ;\r\n        _enum(0)\r\n      ;\r\n\r\n       enumerate\r\n     | {name:.[1], index:.[0]}",
                "title": "How do i add an index in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707344801,
                "creation_date": 1707344801,
                "answer_id": 77958267,
                "question_id": 24528256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should also do the trick:\r\n\r\n```jq\r\n[range(length) as $i | .[$i] | {name: ., index: $i}]\r\n```\r\n\r\njqplay [here](https://jqplay.org/s/sS8mfkWZiuO).\r\n",
                "title": "How do i add an index in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 17,
        "last_activity_date": 1707344801,
        "creation_date": 1404295308,
        "last_edit_date": 1404298379,
        "question_id": 24528256,
        "body_markdown": "I want to use jq map my input\r\n\r\n    [&quot;a&quot;, &quot;b&quot;]\r\n\r\nto output\r\n\r\n    [{name: &quot;a&quot;, index: 0}, {name: &quot;b&quot;, index: 1}]\r\n\r\nI got as far as \r\n\r\n    0 as $i | def incr: $i = $i + 1; [.[] | {name:., index:incr}]&#39;\r\n\r\nwhich outputs:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;a&quot;,\r\n        &quot;index&quot;: 1\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;b&quot;,\r\n        &quot;index&quot;: 1\r\n      }\r\n    ]\r\n\r\nBut I&#39;m missing something.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/24528256/how-do-i-add-an-index-in-jq",
        "title": "How do i add an index in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 902797,
                    "reputation": 1945,
                    "user_id": 938472,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/f5d2cdf3f9a3e571dbd2fbc39004f921?s=256&d=identicon&r=PG",
                    "display_name": "nik.shornikov",
                    "link": "https://stackoverflow.com/users/938472/nik-shornikov"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1491327386,
                "post_id": 24698188,
                "comment_id": 73499627,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 416988,
                    "reputation": 1885,
                    "user_id": 792725,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/8e503e33711abe55f76b9a3b79101eba?s=256&d=identicon&r=PG",
                    "display_name": "aRestless",
                    "link": "https://stackoverflow.com/users/792725/arestless"
                },
                "reply_to_user": {
                    "account_id": 902797,
                    "reputation": 1945,
                    "user_id": 938472,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/f5d2cdf3f9a3e571dbd2fbc39004f921?s=256&d=identicon&r=PG",
                    "display_name": "nik.shornikov",
                    "link": "https://stackoverflow.com/users/938472/nik-shornikov"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1561195878,
                "post_id": 24698188,
                "comment_id": 99990871,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 327040,
                    "reputation": 6201,
                    "user_id": 649167,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/e56e7f730847a9d1ebb6b7669a83e003?s=256&d=identicon&r=PG",
                    "display_name": "knite",
                    "link": "https://stackoverflow.com/users/649167/knite"
                },
                "reply_to_user": {
                    "account_id": 902797,
                    "reputation": 1945,
                    "user_id": 938472,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/f5d2cdf3f9a3e571dbd2fbc39004f921?s=256&d=identicon&r=PG",
                    "display_name": "nik.shornikov",
                    "link": "https://stackoverflow.com/users/938472/nik-shornikov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649955102,
                "post_id": 24698188,
                "comment_id": 127010586,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 51,
                "is_accepted": true,
                "score": 50,
                "last_activity_date": 1405237159,
                "last_edit_date": 1405237159,
                "creation_date": 1405146765,
                "answer_id": 24710337,
                "question_id": 24698188,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This one was a tricky one to craft.\r\n\r\n    map\r\n    (\r\n        with_entries(select(.key != &quot;fields&quot;))\r\n        +\r\n        (.fields | with_entries(.value = .value[0]))\r\n    )\r\n\r\nLet&#39;s break it down and explain the bits of it\r\n\r\n1. For every item in the array...\r\n\r\n        map(...)\r\n\r\n2. Create a new object containing the values for all except the `fields` property.\r\n\r\n        with_entries(select(.key != &quot;fields&quot;))\r\n\r\n3. Combine that with...\r\n\r\n        +\r\n\r\n4. Each of the `fields` projecting each of the values to the first item of each array\r\n\r\n        (.fields | with_entries(.value = .value[0]))",
                "title": "Flatten a JSON document using jq"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1668500012,
                "last_edit_date": 1668500012,
                "creation_date": 1409426257,
                "answer_id": 25585921,
                "question_id": 24698188,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this filter:\r\n\r\n    [.[] | {index: .index, type: .type, id: .id, deviceOs: .fields.deviceOs[],deviceID: .fields.deviceID[],country: .fields.country[]}]\r\n\r\nYou can test here [https://jqplay.org][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/UTm4HqX0b6k",
                "title": "Flatten a JSON document using jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1501693526,
                "creation_date": 1501693526,
                "answer_id": 45466966,
                "question_id": 24698188,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are some variations that start by merging .fields into the containing object with + and then flattening the array elements.  First we take care of .fields with\r\n\r\n      .[]\r\n    | . + .fields\r\n    | del(.fields)\r\n\r\nthat leaves us with objects which look like\r\n\r\n    {\r\n      &quot;index&quot;: &quot;index1&quot;,\r\n      &quot;type&quot;: [\r\n        &quot;type&quot;\r\n      ],\r\n      &quot;id&quot;: &quot;id1&quot;,\r\n      &quot;deviceOs&quot;: [\r\n        &quot;Android&quot;\r\n      ],\r\n      &quot;deviceID&quot;: [\r\n        &quot;deviceID1&quot;\r\n      ],\r\n      &quot;country&quot;: [\r\n        &quot;DE&quot;\r\n      ]\r\n    }\r\n\r\nthen we can flatten the keys multiple ways. \r\nOne way is to use **with_entries**\r\n\r\n    | with_entries( .value = if .value|type == &quot;array&quot; then .value[0] else .value end )\r\n    \r\nanother way is to use **reduce** and **setpath**\r\n\r\n    | . as $v\r\n    | reduce keys[] as $k (\r\n        {};\r\n        setpath([$k]; if $v[$k]|type != &quot;array&quot; then $v[$k] else $v[$k][0] end)\r\n      )\r\n    ",
                "title": "Flatten a JSON document using jq"
            },
            {
                "up_vote_count": 30,
                "is_accepted": false,
                "score": 30,
                "last_activity_date": 1741642819,
                "last_edit_date": 1741642819,
                "creation_date": 1549680332,
                "answer_id": 54602675,
                "question_id": 24698188,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a tool called [`gron`][1] and you can pipe that json in, to get something like this.\r\n\r\n```bash\r\n$ gron document.json\r\njson = [];\r\njson[0] = {};\r\njson[0].fields = {};\r\njson[0].fields.country = [];\r\njson[0].fields.country[0] = &quot;DE&quot;;\r\njson[0].fields.deviceID = [];\r\njson[0].fields.deviceID[0] = &quot;deviceID1&quot;;\r\njson[0].fields.deviceOs = [];\r\njson[0].fields.deviceOs[0] = &quot;Android&quot;;\r\njson[0].fields.type = [];\r\njson[0].fields.type[0] = &quot;type&quot;;\r\njson[0].id = &quot;id1&quot;;\r\njson[0].index = &quot;index1&quot;;\r\njson[0].type = &quot;type1&quot;;\r\njson[1] = {};\r\njson[1].fields = {};\r\njson[1].fields.country = [];\r\njson[1].fields.country[0] = &quot;US&quot;;\r\njson[1].fields.deviceID = [];\r\njson[1].fields.deviceID[0] = &quot;deviceID2&quot;;\r\njson[1].fields.deviceOs = [];\r\njson[1].fields.deviceOs[0] = &quot;Android&quot;;\r\njson[1].fields.type = [];\r\njson[1].fields.type[0] = &quot;type&quot;;\r\njson[1].id = &quot;id2&quot;;\r\njson[1].index = &quot;index2&quot;;\r\njson[1].type = &quot;type2&quot;;\r\n```\r\n\r\n\r\n  [1]: https://github.com/tomnomnom/gron",
                "title": "Flatten a JSON document using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1741642874,
                "last_edit_date": 1741642874,
                "creation_date": 1632237364,
                "answer_id": 69271466,
                "question_id": 24698188,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Similar to [the @jq170727 answer](https://stackoverflow.com/a/45466966): \r\n```jq\r\njq &#39;map(. + (.fields | with_entries(.value |= .[])) | del(.fields))&#39;\r\n```\r\n(assuming no field inside `.fields` is itself called `.fields`).  \r\n\r\nThe `|with_entries(.value|=.[])` part is to flatten the value arrays in `.fields` -- beware only the first item is preserved. `.value|=join(&quot;, &quot;)` could be used to join multiple string values into one.",
                "title": "Flatten a JSON document using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 38,
        "last_activity_date": 1741642874,
        "creation_date": 1405082997,
        "question_id": 24698188,
        "body_markdown": "I&#39;m considering the following array of JSON objects:\r\n\r\n    [\r\n      {\r\n        &quot;index&quot;: &quot;index1&quot;,\r\n        &quot;type&quot;: &quot;type1&quot;,\r\n        &quot;id&quot;: &quot;id1&quot;,\r\n        &quot;fields&quot;: {\r\n          &quot;deviceOs&quot;: [\r\n            &quot;Android&quot;\r\n          ],\r\n          &quot;deviceID&quot;: [\r\n            &quot;deviceID1&quot;\r\n          ],\r\n          &quot;type&quot;: [\r\n            &quot;type&quot;\r\n          ],\r\n          &quot;country&quot;: [\r\n            &quot;DE&quot;\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;index&quot;: &quot;index2&quot;,\r\n        &quot;type&quot;: &quot;type2&quot;,\r\n        &quot;id&quot;: &quot;id2&quot;,\r\n        &quot;fields&quot;: {\r\n          &quot;deviceOs&quot;: [\r\n            &quot;Android&quot;\r\n          ],\r\n          &quot;deviceID&quot;: [\r\n            &quot;deviceID2&quot;\r\n          ],\r\n          &quot;type&quot;: [\r\n            &quot;type&quot;\r\n          ],\r\n          &quot;country&quot;: [\r\n            &quot;US&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nand I would like to flatten it to get:\r\n\r\n    [\r\n      {\r\n        &quot;index&quot;: &quot;index1&quot;,\r\n        &quot;type&quot;: &quot;type&quot;,\r\n        &quot;id&quot;: &quot;id1&quot;,\r\n        &quot;deviceOs&quot;: &quot;Android&quot;,\r\n        &quot;deviceID&quot;: &quot;deviceID1&quot;,\r\n        &quot;country&quot;: &quot;DE&quot;\r\n      },\r\n      {\r\n        &quot;index&quot;: &quot;index2&quot;,\r\n        &quot;type&quot;: &quot;type&quot;,\r\n        &quot;id&quot;: &quot;id2&quot;,\r\n        &quot;deviceOs&quot;: &quot;Android&quot;,\r\n        &quot;deviceID&quot;: &quot;deviceID2&quot;,\r\n        &quot;country&quot;: &quot;US&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m trying to work with `jq` but I fail to flatten the `&quot;fields&quot;`. How should I do it? At the moment I&#39;m interested in command-line tools, but I&#39;m open to other suggestions as well.\r\n",
        "link": "https://stackoverflow.com/questions/24698188/flatten-a-json-document-using-jq",
        "title": "Flatten a JSON document using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1405666516,
                "creation_date": 1405666516,
                "answer_id": 24818914,
                "question_id": 24817244,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not sure there&#39;s enough data here to assess what the source of the problem is. I find it hard to believe that what you tried results in that. I&#39;m getting errors with that all the way.\r\n\r\nTry this filter instead:\r\n\r\n    .[0]\r\n        | to_entries\r\n        | group_by(.key[0:6])\r\n        | map({\r\n              key:   .[0].key[0:6],\r\n              value: map(.key=.key[6:8]) | from_entries\r\n          })\r\n        | from_entries\r\n\r\nGiven data that looks like this:\r\n\r\n    [{\r\n        &quot;91201544&quot;:&quot;INXX0019&quot;,\r\n        &quot;90429396&quot;:&quot;THXX0020&quot;,\r\n        &quot;20140367&quot;:&quot;ITXX0043&quot;,\r\n        &quot;00000023&quot;:&quot;INCD1234&quot;,\r\n        &quot;00000027&quot;:&quot;INCF1423&quot;,\r\n        &quot;90429300&quot;:&quot;THXX0020&quot;,\r\n        &quot;90429302&quot;:&quot;THXX0024&quot;,\r\n        &quot;90429305&quot;:&quot;THXY0013&quot;\r\n    }]\r\n\r\nResults in this:\r\n\r\n    {\r\n      &quot;000000&quot;: {\r\n        &quot;23&quot;: &quot;INCD1234&quot;,\r\n        &quot;27&quot;: &quot;INCF1423&quot;\r\n      },\r\n      &quot;201403&quot;: {\r\n        &quot;67&quot;: &quot;ITXX0043&quot;\r\n      },\r\n      &quot;904293&quot;: {\r\n        &quot;00&quot;: &quot;THXX0020&quot;,\r\n        &quot;02&quot;: &quot;THXX0024&quot;,\r\n        &quot;05&quot;: &quot;THXY0013&quot;,\r\n        &quot;96&quot;: &quot;THXX0020&quot;\r\n      },\r\n      &quot;912015&quot;: {\r\n        &quot;44&quot;: &quot;INXX0019&quot;\r\n      }\r\n    }",
                "title": "Using jq to extract common prefixes in a JSON data structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1405746408,
                "last_edit_date": 1405746408,
                "creation_date": 1405669307,
                "answer_id": 24819707,
                "question_id": 24817244,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I understand that this is not what you are asking for but, just for the reference, I think it will be MUCH more faster to do this with Redis&#39;s built-in Lua scripting.\r\n\r\nAnd it turns out that it is a bit more straightforward:\r\n\r\n    for _,key in pairs(redis.call(&#39;keys&#39;, &#39;*&#39;)) do\r\n      local val = redis.call(&#39;get&#39;, key)\r\n      local short_key = string.sub(key, 0, -2)\r\n      redis.call(&#39;hset&#39;, short_key, key, val)\r\n      redis.call(&#39;del&#39;, key)\r\n    end\r\n\r\nThis will be done in place without transferring from/to Redis and converting to/from JSON.\r\n\r\nRun it from console as:\r\n\r\n    $ redis-cli eval &quot;$(cat script.lua)&quot; 0\r\n",
                "title": "Using jq to extract common prefixes in a JSON data structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1450118631,
                "creation_date": 1450118631,
                "answer_id": 34274318,
                "question_id": 24817244,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For the record, jq&#39;s `group_by` relies on sorting, which of course will slow things down noticeably when the input is sufficiently large. The following is about 40% faster even when the input array has just 100,000 items:\r\n\r\n    def compress:\r\n      . as $in\r\n      | reduce keys[] as $key ({};\r\n          $key[0:6] as $k6\r\n          | $key[6:] as $k2\r\n          | .[$k6] += {($k2): $in[$key]} );\r\n\r\n    .[0] | compress\r\n\r\nGiven Jeff&#39;s input, the output is identical.",
                "title": "Using jq to extract common prefixes in a JSON data structure"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1450118631,
        "creation_date": 1405657750,
        "last_edit_date": 1405879831,
        "question_id": 24817244,
        "body_markdown": "I have a JSON data set with around 8.7 million key value pairs extracted from a Redis store, where each key is guaranteed to be an 8 digit number, and the key is an 8 alphanumeric character value i.e.\r\n\r\n    [{\r\n    &quot;91201544&quot;:&quot;INXX0019&quot;,\r\n    &quot;90429396&quot;:&quot;THXX0020&quot;,\r\n    &quot;20140367&quot;:&quot;ITXX0043&quot;,\r\n     ...\r\n    }]\r\n\r\nTo reduce Redis memory usage, I want to transform this into a hash of hashes, where the hash prefix key is the first 6 characters of the key (see [this link](http://redis.io/topics/memory-optimization)) and then store this back into Redis.\r\n\r\nSpecifically, I want my resulting JSON data structure (that I&#39;ll then write some code to parse this JSON structure and create a Redis command file consisting of HSET, etc) to look more like\r\n\r\n    [{\r\n     &quot;000000&quot;: { &quot;00000023&quot;: &quot;INCD1234&quot;,\r\n                 &quot;00000027&quot;: &quot;INCF1423&quot;,\r\n                  ....\r\n               },\r\n     ....\r\n     &quot;904293&quot;: { &quot;90429300&quot;: &quot;THXX0020&quot;,\r\n                 &quot;90429302&quot;: &quot;THXX0024&quot;,\r\n                 &quot;90429305&quot;: &quot;THXY0013&quot;}\r\n     }]\r\n\r\nSince I&#39;ve been impressed by [jq](http://stedolan.github.io/jq/manual/#Invokingjq) and I&#39;m trying to be more proficient at functional style programming, I wanted to use *jq* for this task.  So far I&#39;ve come up with the following:\r\n\r\n    % jq &#39;.[0] | to_entries | map({key: .key, pfx: .key[0:6], value: .value}) | group_by(.pfx)&#39;\r\n\r\nThis gives me something like\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;key&quot;: &quot;00000130&quot;,\r\n          &quot;pfx&quot;: &quot;000001&quot;,\r\n          &quot;value&quot;: &quot;CAXX3231&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;00000162&quot;,\r\n          &quot;pfx&quot;: &quot;000001&quot;,\r\n          &quot;value&quot;: &quot;CAXX4606&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;key&quot;: &quot;00000238&quot;,\r\n          &quot;pfx&quot;: &quot;000002&quot;,\r\n          &quot;value&quot;: &quot;CAXX1967&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;00000256&quot;,\r\n          &quot;pfx&quot;: &quot;000002&quot;,\r\n          &quot;value&quot;: &quot;CAXX0727&quot;\r\n        }\r\n      ],\r\n      ....\r\n    ]\r\n\r\nI&#39;ve tried the following:\r\n\r\n    % jq &#39;map(map({key: .pfx, value: {key, value}})) \r\n          | map(reduce .[] as $item ({}; {key: $item.key, value: [.value[], $item.value]} )) \r\n          | map( {key, value: .value | from_entries} ) \r\n          | from_entries&#39;\r\n\r\nwhich does give me the correct result, but also prints out an error for every reduce (I believe) of \r\n\r\n    jq: error: Cannot iterate over null\r\n\r\nThe end result is \r\n\r\n    {\r\n       &quot;000001&quot;: {\r\n         &quot;00000130&quot;: &quot;CAXX3231&quot;,\r\n         &quot;00000162&quot;: &quot;CAXX4606&quot;\r\n       },\r\n       &quot;000002&quot;: {\r\n         &quot;00000238&quot;: &quot;CAXX1967&quot;,\r\n         &quot;00000256&quot;: &quot;CAXX0727&quot;\r\n       },\r\n       ...\r\n    }\r\n\r\nwhich is correct, but how can I avoid getting this stderr warning thrown as well?",
        "link": "https://stackoverflow.com/questions/24817244/using-jq-to-extract-common-prefixes-in-a-json-data-structure",
        "title": "Using jq to extract common prefixes in a JSON data structure"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1405981904,
                "last_edit_date": 1405981904,
                "creation_date": 1405981453,
                "answer_id": 24875844,
                "question_id": 24875419,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this filter:\r\n\r\n    .students | map(\r\n        {\r\n            name,\r\n            age,\r\n            gpa: .cum_gpa,\r\n            CSC101: .semesters | map(.grades) | add | .CSC101\r\n        }\r\n        |\r\n        select(.CSC101 == &quot;A&quot;)\r\n    )\r\n\r\nThe idea is to merge all grades from all semesters for each student and grab the `CSC101` grade.  Then filter the students out that have an A grade.\r\n\r\nThis results in:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;age&quot;: &quot;19&quot;,\r\n        &quot;gpa&quot;: &quot;3.83&quot;,\r\n        &quot;CSC101&quot;: &quot;A&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Mary&quot;,\r\n        &quot;age&quot;: &quot;20&quot;,\r\n        &quot;gpa&quot;: &quot;3.50&quot;,\r\n        &quot;CSC101&quot;: &quot;A&quot;\r\n      }\r\n    ]",
                "title": "Complex jq Filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1405981904,
        "creation_date": 1405979302,
        "question_id": 24875419,
        "body_markdown": "***Disclaimer:  this is not homework, this is a sanitized version of something I&#39;m doing for work.***\r\n\r\nI&#39;m trying to filter some json data using jq and want to return an object for each matching record in my filter.  Here&#39;s a text description of what I&#39;m doing: &quot;Given a JSON object containing a list of students, some personal info, and their grades, return a list of the name, ages, and cumulative gpa for each student that received an A in CSC101.&quot;\r\n\r\nHere&#39;s the test JSON object (program input):\r\n\r\n    {\r\n        &quot;students&quot;: [\r\n            {&quot;name&quot;: &quot;John&quot;, &quot;age&quot;: &quot;19&quot;, &quot;gender&quot;: &quot;m&quot;, &quot;from&quot;: &quot;Tampa, FL&quot;, &quot;cum_gpa&quot;: &quot;3.83&quot;, &quot;semesters&quot;: [\r\n                {&quot;name&quot;: &quot;201302&quot;, &quot;gpa&quot;: &quot;3.67&quot;, &quot;grades&quot;: {&quot;CSC101&quot;: &quot;A&quot;, &quot;MAT101&quot;: &quot;A&quot;, &quot;PSY101&quot;: &quot;B&quot;}},\r\n                {&quot;name&quot;: &quot;201401&quot;, &quot;gpa&quot;: &quot;4.00&quot;, &quot;grades&quot;: {&quot;CSC201&quot;: &quot;A&quot;, &quot;MAT201&quot;: &quot;A&quot;, &quot;HIS101&quot;: &quot;A&quot;}}\r\n            ]},\r\n            {&quot;name&quot;: &quot;Mary&quot;, &quot;age&quot;: &quot;20&quot;, &quot;gender&quot;: &quot;f&quot;, &quot;from&quot;: &quot;Chicago, IL&quot;, &quot;cum_gpa&quot;: &quot;3.50&quot;, &quot;semesters&quot;: [\r\n                {&quot;name&quot;: &quot;201302&quot;, &quot;gpa&quot;: &quot;4.00&quot;, &quot;grades&quot;: {&quot;CSC101&quot;: &quot;A&quot;, &quot;MAT101&quot;: &quot;A&quot;, &quot;ECO101&quot;: &quot;A&quot;}},\r\n                {&quot;name&quot;: &quot;201401&quot;, &quot;gpa&quot;: &quot;3.00&quot;, &quot;grades&quot;: {&quot;CSC201&quot;: &quot;B&quot;, &quot;MAT201&quot;: &quot;B&quot;, &quot;HUM101&quot;: &quot;B&quot;}}\r\n            ]},\r\n            {&quot;name&quot;: &quot;Dan&quot;, &quot;age&quot;: &quot;20&quot;, &quot;gender&quot;: &quot;m&quot;, &quot;from&quot;: &quot;Seattle, WA&quot;, &quot;cum_gpa&quot;: &quot;3.33&quot;, &quot;semesters&quot;: [\r\n                {&quot;name&quot;: &quot;201302&quot;, &quot;gpa&quot;: &quot;3.33&quot;, &quot;grades&quot;: {&quot;CHE101&quot;: &quot;B&quot;, &quot;MAT101&quot;: &quot;A&quot;, &quot;PSY101&quot;: &quot;B&quot;}},\r\n                {&quot;name&quot;: &quot;201401&quot;, &quot;gpa&quot;: &quot;3.33&quot;, &quot;grades&quot;: {&quot;CHE201&quot;: &quot;A&quot;, &quot;MAT201&quot;: &quot;A&quot;, &quot;HUM101&quot;: &quot;C&quot;}}\r\n            ]}\r\n        ]\r\n    }\r\n\r\nHere&#39;s my current filter expression and the result:\r\n\r\n    cat test.json |jq -c &#39;.students[]|select(.semesters[].grades.CSC101 == &quot;A&quot;)|{name: .name, age: .age, gpa: .cum_gpa, CSC101: .semesters[].grades.CSC101}&#39; \r\n    {&quot;name&quot;:&quot;John&quot;,&quot;age&quot;:&quot;19&quot;,&quot;gpa&quot;:&quot;3.83&quot;,&quot;CSC101&quot;:&quot;A&quot;}\r\n    {&quot;name&quot;:&quot;John&quot;,&quot;age&quot;:&quot;19&quot;,&quot;gpa&quot;:&quot;3.83&quot;,&quot;CSC101&quot;:null}\r\n    {&quot;name&quot;:&quot;Mary&quot;,&quot;age&quot;:&quot;20&quot;,&quot;gpa&quot;:&quot;3.50&quot;,&quot;CSC101&quot;:&quot;A&quot;}\r\n    {&quot;name&quot;:&quot;Mary&quot;,&quot;age&quot;:&quot;20&quot;,&quot;gpa&quot;:&quot;3.50&quot;,&quot;CSC101&quot;:null}\r\n\r\n\r\nIt&#39;s sort-of working, but it generates extra output.  I only want it to yield the semesters that have an entry for CSC101, but instead it returns all semesters for any student that took CSC101. Any suggestions?",
        "link": "https://stackoverflow.com/questions/24875419/complex-jq-filter",
        "title": "Complex jq Filter"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "amazon-ec2",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1406219013,
                "post_id": 24938971,
                "comment_id": 38755844,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1406219372,
                "post_id": 24938971,
                "comment_id": 38756046,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2611264,
                    "reputation": 3354,
                    "user_id": 2261330,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/9d4f09a9a169d0d6dddd4d0980cc94be?s=256&d=identicon&r=PG",
                    "display_name": "Bas Peeters",
                    "link": "https://stackoverflow.com/users/2261330/bas-peeters"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1406219482,
                "post_id": 24938971,
                "comment_id": 38756125,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3881522,
                    "reputation": 15561,
                    "user_id": 3213868,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9036cfc255c306c089d214b61c3fd7b9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ooga",
                    "link": "https://stackoverflow.com/users/3213868/ooga"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1406219849,
                "post_id": 24938971,
                "comment_id": 38756345,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 40542,
                    "reputation": 71057,
                    "user_id": 117471,
                    "user_type": "registered",
                    "accept_rate": 31,
                    "profile_image": "https://www.gravatar.com/avatar/959ccd33301cb3c15953c1a632a36763?s=256&d=identicon&r=PG",
                    "display_name": "Bruno Bronosky",
                    "link": "https://stackoverflow.com/users/117471/bruno-bronosky"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516217523,
                "post_id": 24938971,
                "comment_id": 83602692,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1582089499,
                "last_edit_date": 1582089499,
                "creation_date": 1406220197,
                "answer_id": 24939494,
                "question_id": 24938971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The below command would list the IP addresses of all your running EC2 instances\r\n\r\n    aws ec2 describe-instances | grep PublicIpAddress | grep -o -P &quot;\\d+\\.\\d+\\.\\d+\\.\\d+&quot; | grep -v &#39;^10\\.&#39;\r\n\r\nHope that answers your query...\r\n\r\nBut this works without all the errors about access:\r\n\r\n    wget -qO- http://instance-data/latest/meta-data/public-ipv4/|grep .",
                "title": "List public IP addresses of EC2 instances"
            },
            {
                "up_vote_count": 122,
                "is_accepted": true,
                "score": 122,
                "last_activity_date": 1406221256,
                "creation_date": 1406221256,
                "answer_id": 24939787,
                "question_id": 24938971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Directly from the [aws cli][1]:\r\n\r\n    aws ec2 describe-instances \\\r\n      --query &quot;Reservations[*].Instances[*].PublicIpAddress&quot; \\\r\n      --output=text\r\n\r\n\r\n  [1]: http://aws.amazon.com/cli/",
                "title": "List public IP addresses of EC2 instances"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1483427737,
                "creation_date": 1483427737,
                "answer_id": 41438275,
                "question_id": 24938971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    aws ec2 describe-instances --query &quot;Reservations[].Instances[][PublicIpAddress]&quot;\r\n\r\nRefer:\r\nhttp://docs.aws.amazon.com/cli/latest/userguide/controlling-output.html\r\n",
                "title": "List public IP addresses of EC2 instances"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1505914923,
                "creation_date": 1505914923,
                "answer_id": 46323720,
                "question_id": 24938971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use [instance metadata](http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-metadata.html#instancedata-data-retrieval) so you can run the following command from the ec2 instance:\r\n\r\n    curl http://169.254.169.254/latest/meta-data/public-ipv4\r\n\r\nand it will give you the public IP of the instance. If you want the private IP, you will run\r\n\r\n    curl http://169.254.169.254/latest/meta-data/local-ipv4",
                "title": "List public IP addresses of EC2 instances"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1586283872,
                "last_edit_date": 1586283872,
                "creation_date": 1523365761,
                "answer_id": 49754566,
                "question_id": 24938971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "* Filter on running instances (you can drop that part if you don&#39;t need it) \r\n* Query for each PublicIPaddress and the Name Tag, handling when Name isn&#39;t set\r\n```\r\naws ec2 describe-instances \\\r\n  --filter &quot;Name=instance-state-name,Values=running&quot; \\\r\n  --query &quot;Reservations[*].Instances[*].[PublicIpAddress, Tags[?Key==&#39;Name&#39;].Value|[0]]&quot; \\\r\n  --output text\r\n```",
                "title": "List public IP addresses of EC2 instances"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 53,
        "last_activity_date": 1586283872,
        "creation_date": 1406218577,
        "last_edit_date": 1421311097,
        "question_id": 24938971,
        "body_markdown": "I want to list the public IP addresses of my EC2 instances using Bash, separated by a delimiter (space or a new-line).\r\n\r\nI tried to pipe the output to [jq][1] with `aws ec2 describe-instances | jq`, but can&#39;t seem to isolate just the IP addresses.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n\r\nCan this be done by `aws` alone, specifying arguments to `jq`, or something else entirely?",
        "link": "https://stackoverflow.com/questions/24938971/list-public-ip-addresses-of-ec2-instances",
        "title": "List public IP addresses of EC2 instances"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1406436554,
                "creation_date": 1406436554,
                "answer_id": 24978015,
                "question_id": 24977872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I ended up solving the problem using: `[POSSIBLY_MATCHED_EXPRESSION][0]`, in this case:\r\n\r\n\r\n     cat testdata | jq &#39;.[] | {id, name: ([select(.tags.key == &quot;name&quot;) | .tags.value][0])}&#39;",
                "title": "Interaction between {} and select"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1406480123,
                "last_edit_date": 1406480123,
                "creation_date": 1406439873,
                "answer_id": 24978262,
                "question_id": 24977872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I&#39;m understanding correctly, if you wanted to include a name only if it existed, I&#39;d do this:\r\n\r\n    map({id} + with_entries(select(.key == &quot;tags&quot;) | .value))\r\n\r\nOtherwise if you don&#39;t mind `null` names:\r\n\r\n    map({id, name: with_entries(select(.key == &quot;tags&quot;) | .value) | .name})\r\n\r\n&lt;hr&gt;\r\n\r\nHere&#39;s a more general solution if you have other &quot;tags&quot; so it&#39;s not hardcoded to only accept `name` values.\r\n\r\nThis assumes that any object value is actually a key/value pair.\r\n\r\n    map(with_entries(if .value | type == &quot;object&quot; then .value else . end))\r\n\r\nOr if `tags` is the only dynamic property:\r\n\r\n    map(with_entries(if .key == &quot;tags&quot; then .value else . end))",
                "title": "Interaction between {} and select"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1441592667,
                "creation_date": 1441592667,
                "answer_id": 32430311,
                "question_id": 24977872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the goal is to produce:\r\n\r\n    {&quot;id&quot;:&quot;id-1&quot;,&quot;name&quot;:&quot;name-1&quot;}\r\n    {&quot;id&quot;:&quot;id-2&quot;}\r\n\r\nthen the following three expressions are essentially equivalent solutions:\r\n\r\n    .[] | if .tags.key == &quot;name&quot; then {id, name: .tags.value} else {id} end\r\n\r\n    .[] | {id} + (if .tags.key == &quot;name&quot; then {name: .tags.value} else {} end)\r\n\r\n    .[] | (select(.tags.key  == &quot;name&quot;) | {id, name: .tags.value}) // {id}\r\n",
                "title": "Interaction between {} and select"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1684823382,
                "last_edit_date": 1684823382,
                "creation_date": 1501694465,
                "answer_id": 45467262,
                "question_id": 24977872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just add a conditional removal using [`if .. then .. else .. end`][1]:\r\n\r\n    | if .name == null then del(.name) else . end\r\n\r\nto the end of your filter to get rid of the .name key when its value is `null`.\r\nWith your test data, the following\r\n\r\n      .[]\r\n    | {id, name:.tags.value }\r\n    | if .name == null then del(.name) else . end\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;id&quot;: &quot;id-1&quot;,\r\n      &quot;name&quot;: &quot;name-1&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;id-2&quot;\r\n    }\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#if-then-else",
                "title": "Interaction between {} and select"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684821133,
                "last_edit_date": 1684821133,
                "creation_date": 1684782437,
                "answer_id": 76309229,
                "question_id": 24977872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two additional possible solutions to the problem:\r\n\r\n* `.[] | { id, name: .tags | select(.key == &quot;name&quot;).value } // { id }`\r\n* `.[] | { id } + ({ name: .tags | select(.key == &quot;name&quot;).value } // {})`\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;id-1&quot;,\r\n  &quot;name&quot;: &quot;name-1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;id-2&quot;\r\n}\r\n```\r\n\r\nOr to generate output with `name: null`:\r\n\r\n* `.[] | { id, name: (.tags | select(.key == &quot;name&quot;).value // null) }`\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;id-1&quot;,\r\n  &quot;name&quot;: &quot;name-1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;id-2&quot;,\r\n  &quot;name&quot;: null\r\n}\r\n```",
                "title": "Interaction between {} and select"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1684823382,
        "creation_date": 1406434690,
        "last_edit_date": 1406475648,
        "question_id": 24977872,
        "body_markdown": "Here&#39;s my test data:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;id-1&quot;,\r\n        &quot;tags&quot;: {\r\n          &quot;key&quot;: &quot;name&quot;,\r\n          &quot;value&quot;: &quot;name-1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;id-2&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m trying to simplify the output, to show the &#39;name&#39; field if present, and always show the id. For example, this script almost works:\r\n\r\n    ~ $ cat testdata | jq &#39;.[] | {id, name: .tags.value}&#39;\r\n\r\n    {\r\n      &quot;id&quot;: &quot;id-1&quot;,\r\n      &quot;name&quot;: &quot;name-1&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;id-2&quot;,\r\n      &quot;name&quot;: null\r\n    }\r\n\r\nWhen I try to add in a guard against .keys not existing and filter for the section of &#39;keys&#39; I care about, here&#39;s what happens:\r\n\r\n    ~ $ cat testdata | jq &#39;.[] | {id, name: (select(.tags.key == &quot;name&quot;) | .tags.value)}&#39;\r\n\r\n    {\r\n      &quot;id&quot;: &quot;id-1&quot;,\r\n      &quot;name&quot;: &quot;name-1&quot;\r\n    }\r\n\r\nI assume {} is somehow ending up with a zero-length array instead of &#39;null&#39;. What should I be using instead of |? What am I misunderstanding?",
        "link": "https://stackoverflow.com/questions/24977872/interaction-between-and-select",
        "title": "Interaction between {} and select"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1406571015,
                "creation_date": 1406571015,
                "answer_id": 25001531,
                "question_id": 25001349,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    .Tags[] | select(.Key == &quot;Type&quot;) | .Value",
                "title": "Conditionally print value based on the value of another key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1504600151,
        "creation_date": 1406570404,
        "last_edit_date": 1504600151,
        "question_id": 25001349,
        "body_markdown": "Here&#39;s some example JSON:\r\n\r\n    {\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Type&quot;,\r\n          &quot;Value&quot;: &quot;C&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to print the value of &quot;Value&quot; only when &quot;Key&quot; is &quot;Type&quot;. So it should print out &quot;C&quot;. This is what I have so far. \r\n\r\n    echo $MY_TAGS | jq &#39;if .Tags[].Key == &quot;Type&quot; then .Tags[].Value else empty end&#39;\r\n\r\nBut it prints out:\r\n\r\n&quot;foo&quot;  \r\n&quot;C&quot;  \r\n\r\nIs there a way to do this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/25001349/conditionally-print-value-based-on-the-value-of-another-key",
        "title": "Conditionally print value based on the value of another key"
    },
    {
        "tags": [
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 199734,
                    "reputation": 76108,
                    "user_id": 445221,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6bcf75dbf1e66fc9cf453393db706d2d?s=256&d=identicon&r=PG",
                    "display_name": "konsolebox",
                    "link": "https://stackoverflow.com/users/445221/konsolebox"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1407218038,
                "post_id": 25131293,
                "comment_id": 39117881,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3052093,
                    "reputation": 31,
                    "user_id": 2586428,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XMbS4.jpg?s=256",
                    "display_name": "Yury Oparin",
                    "link": "https://stackoverflow.com/users/2586428/yury-oparin"
                },
                "reply_to_user": {
                    "account_id": 199734,
                    "reputation": 76108,
                    "user_id": 445221,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6bcf75dbf1e66fc9cf453393db706d2d?s=256&d=identicon&r=PG",
                    "display_name": "konsolebox",
                    "link": "https://stackoverflow.com/users/445221/konsolebox"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1407227845,
                "post_id": 25131293,
                "comment_id": 39122250,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1407242515,
                "creation_date": 1407242515,
                "answer_id": 25139108,
                "question_id": 25131293,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq &#39;map(select(has(&quot;folder&quot;) or (.[&quot;title&quot;] | startswith(&quot;item&quot;))) | del(.id))&#39; sample_file\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;item&quot;,\r\n        &quot;title&quot;: &quot;item-1&quot;,\r\n        &quot;folder&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;item&quot;,\r\n        &quot;title&quot;: &quot;item-2&quot;,\r\n        &quot;folder&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;item&quot;,\r\n        &quot;title&quot;: &quot;item-3&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Analogue for sql join in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1428510065,
                "last_edit_date": 1428510065,
                "creation_date": 1407266295,
                "answer_id": 25146665,
                "question_id": 25131293,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this filter:\r\n\r\n    map(\r\n        (select(.type==&quot;item&quot;) | { key: .folder, value: { type, title } }),\r\n        (select(.type==&quot;folder&quot;) | { key: .id, value: { folder: .title } })\r\n    )\r\n    | group_by(.key)\r\n    | map(\r\n        (map(select(.key != null) | .value) | add)\r\n        // map(.value)[]\r\n    )\r\n\r\nYou&#39;ll have to break this out into steps.\r\n\r\n1. Get the items and folders and for each, take the values you&#39;re interested in and assign it a key to associate with.\r\n\r\n        map(\r\n            (select(.type==&quot;item&quot;) | { key: .folder, value: { type, title } }),\r\n            (select(.type==&quot;folder&quot;) | { key: .id, value: { folder: .title } })\r\n        )\r\n\r\n2. Group all by the key\r\n\r\n        | group_by(.key)\r\n\r\n3. Then combine the values that have keys (folders) and the value otherwise\r\n\r\n        | map(\r\n            (map(select(.key != null) | .value) | add)\r\n            // map(.value)[]\r\n        )\r\n",
                "title": "Analogue for sql join in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503674486,
                "last_edit_date": 1503674486,
                "creation_date": 1503673828,
                "answer_id": 45884463,
                "question_id": 25131293,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which works by separating the data into two objects `$folders` and `$items` and then constructing the desired result.\r\n\r\n      (\r\n        reduce map(select(.type == &quot;folder&quot;))[] as $f (\r\n          {}\r\n        ; .[$f.id] = $f\r\n        )\r\n      ) as $folders\r\n\r\n    | (\r\n        reduce map(select(.type == &quot;item&quot;))[] as $i (\r\n          {}\r\n        ; .[$i.id] = $i\r\n        ) \r\n      ) as $items\r\n\r\n    | [\r\n          $items[]\r\n        | {type, title, folder}\r\n        | if .folder == null then del(.folder) else .folder = $folders[.folder].title end\r\n      ]\r\n\r\nIf your version of jq has [INDEX/2](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L294-L299)\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n    \r\nthis can be simplified to\r\n\r\n      INDEX(.[] | select(.type == &quot;folder&quot;); .id) as $folders\r\n    | INDEX(.[] | select(.type == &quot;item&quot;); .id) as $items\r\n    | [\r\n          $items[]\r\n        | {type, title, folder}\r\n        | if .folder == null then del(.folder) else .folder = $folders[.folder].title end\r\n      ]",
                "title": "Analogue for sql join in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1503674486,
        "creation_date": 1407213462,
        "last_edit_date": 1407227741,
        "question_id": 25131293,
        "body_markdown": "I have the following json:\r\n\r\n    [\r\n      {&quot;id&quot;: &quot;1&quot;, &quot;type&quot;: &quot;folder&quot;, &quot;title&quot;: &quot;folder-1&quot;},\r\n      {&quot;id&quot;: &quot;2&quot;, &quot;type&quot;: &quot;folder&quot;, &quot;title&quot;: &quot;folder-2&quot;},\r\n      {&quot;id&quot;: &quot;3&quot;, &quot;type&quot;: &quot;item&quot;, &quot;title&quot;: &quot;item-1&quot;, &quot;folder&quot;: &quot;1&quot;},\r\n      {&quot;id&quot;: &quot;4&quot;, &quot;type&quot;: &quot;item&quot;, &quot;title&quot;: &quot;item-2&quot;, &quot;folder&quot;: &quot;2&quot;},\r\n      {&quot;id&quot;: &quot;5&quot;, &quot;type&quot;: &quot;item&quot;, &quot;title&quot;: &quot;item-3&quot;}\r\n    ]\r\n\r\nBasically, I need to produce this output using jq, which is similar to the result of sql join:\r\n\r\n    [\r\n      {&quot;type&quot;: &quot;item&quot;, &quot;title&quot;: &quot;item-1&quot;, &quot;folder&quot;: &quot;folder-1&quot;},\r\n      {&quot;type&quot;: &quot;item&quot;, &quot;title&quot;: &quot;item-2&quot;, &quot;folder&quot;: &quot;folder-2&quot;},\r\n      {&quot;type&quot;: &quot;item&quot;, &quot;title&quot;: &quot;item-3&quot;}\r\n    ]\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/25131293/analogue-for-sql-join-in-jq",
        "title": "Analogue for sql join in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 128,
                "is_accepted": true,
                "score": 128,
                "last_activity_date": 1558534291,
                "last_edit_date": 1558534291,
                "creation_date": 1408434550,
                "answer_id": 25378171,
                "question_id": 25378013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could try:\r\n\r\n    jq -r &#39;to_entries|map(&quot;\\(.key)=\\(.value|tostring)&quot;)|.[]&#39; test.json\r\n\r\nHere&#39;s a demo:\r\n\r\n    $ cat test.json\r\n    {\r\n        &quot;var&quot;: 1,\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;x&quot;: &quot;test&quot;\r\n    }\r\n    $ jq -r &#39;to_entries|map(&quot;\\(.key)=\\(.value|tostring)&quot;)|.[]&#39; test.json\r\n    foo=bar\r\n    var=1\r\n    x=test\r\n",
                "title": "How to convert a JSON object to key=value format in jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1445476984,
                "last_edit_date": 1445476984,
                "creation_date": 1431845452,
                "answer_id": 30284185,
                "question_id": 25378013,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; Is there any way i can do this recursively? \r\n\r\nHere is a function which might do what you want:\r\n\r\n    # Denote the input of recursively_reduce(f) by $in.\r\n    # Let f be a filter such that for any object o, (o|f) is an array.\r\n    # If $in is an object, then return $in|f;\r\n    # if $in is a scalar, then return [];\r\n    # otherwise, collect the results of applying recursively_reduce(f)\r\n    # to each item in $in.\r\n    def recursively_reduce(f):\r\n      if type == &quot;object&quot; then f\r\n      elif type == &quot;array&quot; then map( recursively_reduce(f) ) | add\r\n      else []\r\n      end;\r\n\r\nExample: emit key=value pairs\r\n\r\n    def kv: to_entries | map(&quot;\\(.key)=\\(.value)&quot;);\r\n\r\n\r\n    [ {&quot;a&quot;:1}, [[{&quot;b&quot;:2, &quot;c&quot;: 3}]] ] | recursively_reduce(kv)\r\n    #=&gt; [&quot;a=1&quot;,&quot;b=2&quot;,&quot;c=3&quot;]\r\n\r\nUPDATE: After the release of jq 1.5, walk/1 was added as a jq-defined built-in.  It can be used with the above-defined kv, e.g. as follows:\r\n\r\n     walk(if type == &quot;object&quot; then kv else . end) \r\n\r\nWith the above input, the result would be:\r\n\r\n   [[&quot;a=1&quot;],[[[&quot;b=2&quot;,&quot;c=3&quot;]]]]\r\n\r\nTo &quot;flatten&quot; the output, flatten/0 can be used.  Here is a complete example:\r\n\r\n    jq -cr &#39;def kv: to_entries | map(&quot;\\(.key)=\\(.value)&quot;);\r\n            walk(if type == &quot;object&quot; then kv else . end) | flatten[]&#39;\r\n\r\nInput:\r\n\r\n    [ {&quot;a&quot;:1}, [[{&quot;b&quot;:2, &quot;c&quot;: 3}]] ]\r\n\r\nOutput:\r\n\r\n    a=1\r\n    b=2\r\n    c=3\r\n\r\n\r\n",
                "title": "How to convert a JSON object to key=value format in jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1567140715,
                "creation_date": 1567140715,
                "answer_id": 57720670,
                "question_id": 25378013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Incidentally, building off of @aioobe&#39;s excellent answer. If you need the keys to be all upper case you can use `ascii_upcase` to do this by modifying his example:\r\n\r\n```\r\njq -r &#39;to_entries|map(&quot;\\(.key|ascii_upcase)=\\(.value|tostring)&quot;)|.[]&#39;\r\n```\r\n\r\n### Example\r\nI had a scenario similar to yours but wanted to uppercase all the keys when creating environment variables for accessing AWS.\r\n\r\n```\r\n$ okta-credential_process arn:aws:iam::1234567890123:role/myRole | \\\r\n     jq -r &#39;to_entries|map(&quot;\\(.key|ascii_upcase)=\\(.value|tostring)&quot;)|.[]&#39;\r\nEXPIRATION=2019-08-30T16:46:55.307014Z\r\nVERSION=1\r\nSESSIONTOKEN=ABcdEFghIJ....\r\nACCESSKEYID=ABCDEFGHIJ.....\r\nSECRETACCESSKEY=AbCdEfGhI.....\r\n```\r\n\r\n### References\r\n- https://github.com/oktadeveloper/okta-aws-cli-assume-role\r\n- https://github.com/stedolan/jq/issues/492",
                "title": "How to convert a JSON object to key=value format in jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1581191171,
                "creation_date": 1581191171,
                "answer_id": 60130545,
                "question_id": 25378013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "without `jq`, I was able to export every item in json using `grep` and `sed` but this will work for simple cases only where we have key/value pairs \r\n\r\n\r\n    for keyval in $(grep -E &#39;&quot;: [^\\{]&#39; fileName.json | sed -e &#39;s/: /=/&#39; -e &quot;s/\\(\\,\\)$//&quot;); do\r\n        echo &quot;$keyval&quot;\r\n    done\r\n\r\nhere&#39;s a sample response: \r\n\r\n    ❯ for keyval in $(grep -E &#39;&quot;: [^\\{]&#39; config.dev.json | sed -e &#39;s/: /=/&#39; -e &quot;s/\\(\\,\\)$//&quot;); do\r\n        echo &quot;$keyval&quot;       \r\n    done\r\n    &quot;env&quot;=&quot;dev&quot;\r\n    &quot;memory&quot;=128\r\n    &quot;role&quot;=&quot;&quot;\r\n    &quot;region&quot;=&quot;us-east-1&quot;",
                "title": "How to convert a JSON object to key=value format in jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1689203325,
                "creation_date": 1689203325,
                "answer_id": 76674955,
                "question_id": 25378013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a compact solution: `to_entries[]|join(&quot;=&quot;)`\r\n\r\n```shell\r\n$ echo &#39;{&quot;var&quot;: 1, &quot;foo&quot;: &quot;bar&quot;, &quot;x&quot;: &quot;test&quot;}&#39; | \\\r\njq -r &#39;to_entries[]|join(&quot;=&quot;)&#39;\r\nvar=1\r\nfoo=bar\r\nx=test\r\n```",
                "title": "How to convert a JSON object to key=value format in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689815622,
                "creation_date": 1689815622,
                "answer_id": 76726084,
                "question_id": 25378013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add on top of [aaiobe’s answer](https://stackoverflow.com/a/25378171/2171120), here’s a few things to make it safer / more flexible to use:\r\n\r\n- question mark for `null` safety\r\n- support for one level of nested arrays\r\n- `jsn_` pr&#230;fix for namespacing the resulting variables to avoid them overwriting your normal variables\r\n\r\n```\r\n$ cat nil.jsn\r\nnull\r\n$ jq -r &#39;to_entries? | map(&quot;set -A jsn_\\(.key|@sh) -- \\(.value|@sh)&quot;) | .[]&#39; &lt;nil.jsn\r\n$ cat test.jsn\r\n{\r\n  &quot;var&quot;: 1,\r\n  &quot;foo&quot;: [\r\n    &quot;bar&quot;,\r\n    &quot;baz&quot;,\r\n    &quot;space test&quot;\r\n  ],\r\n  &quot;x&quot;: &quot;test&quot;\r\n}\r\n$ jq -r &#39;to_entries? | map(&quot;set -A jsn_\\(.key|@sh) -- \\(.value|@sh)&quot;) | .[]&#39; &lt;nil.jsn\r\n$ jq -r &#39;to_entries? | map(&quot;set -A jsn_\\(.key|@sh) -- \\(.value|@sh)&quot;) | .[]&#39; &lt;test.jsn\r\nset -A jsn_&#39;var&#39; -- 1\r\nset -A jsn_&#39;foo&#39; -- &#39;bar&#39; &#39;baz&#39; &#39;space test&#39;\r\nset -A jsn_&#39;x&#39; -- &#39;test&#39;\r\n```\r\n\r\nThe above outputs Korn Shell arrays (for `mksh` and AT&amp;T `ksh`). If you prefer/need GNU bash-style arrays (also supported by many other recent shell releases) use:\r\n\r\n```\r\n$ jq -r &#39;to_entries? | map(&quot;jsn_\\(.key | @sh)=(\\(.value | @sh))&quot;) | .[]&#39; &lt;nil.jsn\r\n$ jq -r &#39;to_entries? | map(&quot;jsn_\\(.key | @sh)=(\\(.value | @sh))&quot;) | .[]&#39; &lt;test.jsn\r\njsn_&#39;var&#39;=(1)\r\njsn_&#39;foo&#39;=(&#39;bar&#39; &#39;baz&#39; &#39;space test&#39;)\r\njsn_&#39;x&#39;=(&#39;test&#39;)\r\n```\r\n\r\nIn all subsequent examples I will be using the Korn Shell variant, but applying the difference between the above two variants will work for them.\r\n\r\nIn both cases, you get arrays, but dereferencing the array itself is the same as dereferencing its element #0 so this is safe even for single values:\r\n\r\n```\r\n$ eval &quot;$(jq -r &#39;to_entries? | map(&quot;set -A jsn_\\(.key|@sh) -- \\(.value|@sh)&quot;) | .[]&#39; &lt;test.jsn)&quot;\r\n$ echo $jsn_x\r\ntest\r\n$ echo $jsn_foo = ${jsn_foo[0]} but not ${jsn_foo[1]}\r\nbar = bar but not baz\r\n```\r\n\r\nThere is a downside though: scripts written for just `sh` do not have arrays, so you need to either target `bash`, `ksh88`, `ksh93`, `mksh`, `zsh`, (possibly others), or their common subset (all of these support `[[ … ]]`; all but `ksh88` should support GNU bash-style arrays).\r\n\r\n----\r\n\r\nTwo further improvements:\r\n\r\n- manual `null` handling (see below)\r\n- filter the top-level keys from a whitelist\r\n\r\n```\r\n$ jq -r &#39;if . == null then\r\n&gt;         null\r\n&gt; else\r\n&gt;         to_entries | map(\r\n&gt;                 select(IN(.key;\r\n&gt;                         &quot;foo&quot;, &quot;val&quot;, &quot;var&quot;\r\n&gt;                 )) | &quot;set -A jsn_\\(.key | @sh) -- \\(.value | @sh)&quot;\r\n&gt;         ) | .[]\r\n&gt; end&#39; &lt;nil.jsn\r\nnull\r\n$ jq -r &#39;if . == null then\r\n&gt;         null\r\n&gt; else\r\n&gt;         to_entries | map(\r\n&gt;                 select(IN(.key;\r\n&gt;                         &quot;foo&quot;, &quot;val&quot;, &quot;var&quot;\r\n&gt;                 )) | &quot;set -A jsn_\\(.key | @sh) -- \\(.value | @sh)&quot;\r\n&gt;         ) | .[]\r\n&gt; end&#39; &lt;test.jsn\r\nset -A jsn_&#39;var&#39; -- 1\r\nset -A jsn_&#39;foo&#39; -- &#39;bar&#39; &#39;baz&#39; &#39;space test&#39;\r\n```\r\n\r\nIn this example, only the keys `foo`, `val` (not existent here) and `var` are permitted. This can be used e.g. to filter out keys whose values are something other than simple values or one-dimensional JSONArrays of simple values, so the result is safe&#185;.\r\n\r\nYou would use this e.g. as follows in a shell snippet:\r\n\r\n```ksh\r\nset -o pipefail\r\nif ! vars=$(curl &quot;${curlopts[@]}&quot; &quot;$url&quot; | jq -r &#39;\r\n        if . == null then\r\n                null\r\n        else\r\n                to_entries | map(\r\n                        select(IN(.key;\r\n                                &quot;foo&quot;, &quot;val&quot;, &quot;var&quot;\r\n                        )) | &quot;set -A jsn_\\(.key | @sh) -- \\(.value | @sh)&quot;\r\n                ) | .[]\r\n        end\r\n    &#39;); then\r\n        echo &gt;&amp;2 &quot;E: no API response&quot;\r\n        exit 1\r\nfi\r\nif [[ $vars = null ]]; then\r\n        echo &gt;&amp;2 &quot;E: empty API response&quot;\r\n        exit 1\r\nfi\r\neval &quot;$vars&quot;\r\necho &quot;I: API response: var=$jsn_var&quot;\r\nfor x in &quot;${jsn_foo[@]}&quot;; do\r\n        echo &quot;N: got foo &#39;$x&#39;&quot;\r\ndone\r\n```\r\n\r\n----\r\n\r\n① While `jq` throws an error unless the question mark is used, the failure mode is not so nice if there _are_ indeed multi-dimensional arrays or other shenanigans:\r\n\r\n```\r\n$ cat test.jsn \r\n{\r\n  &quot;foo&quot;: [\r\n    [\r\n      &quot;bar&quot;,\r\n      &quot;baz&quot;\r\n    ],\r\n    &quot;space test&quot;\r\n  ],\r\n  &quot;var&quot;: 1,\r\n  &quot;x&quot;: &quot;test&quot;\r\n}\r\n$ jq -r &#39;to_entries? | map(&quot;set -A jsn_\\(.key|@sh) -- \\(.value|@sh)&quot;) | .[]&#39; &lt;test.jsn\r\n$ echo $?\r\n0\r\n$ jq -r &#39;to_entries | map(&quot;set -A jsn_\\(.key|@sh) -- \\(.value|@sh)&quot;) | .[]&#39; &lt;test.jsn \r\njq: error (at &lt;stdin&gt;:11): array ([&quot;bar&quot;,&quot;baz&quot;]) can not be escaped for shell\r\n$ echo $?\r\n5\r\n$ jq -r &#39;if . == null then\r\n&gt;         null\r\n&gt; else\r\n&gt;         to_entries | map(\r\n&gt;                 select(IN(.key;\r\n&gt;                         &quot;foo&quot;, &quot;val&quot;, &quot;var&quot;\r\n&gt;                 )) | &quot;set -A jsn_\\(.key | @sh) -- \\(.value | @sh)&quot;\r\n&gt;         ) | .[]\r\n&gt; end&#39; &lt;test.jsn\r\njq: error (at &lt;stdin&gt;:11): array ([&quot;bar&quot;,&quot;baz&quot;]) can not be escaped for shell\r\n$ echo $?\r\n5\r\n```\r\n\r\nMake sure to test for that if you don’t know your JSON will be fine. Heck, test for that, always; catch `jq` error exit codes. Note how the `set -o pipefail` in the above example, if supported by the shell (most recent ones do), makes the whole command substitution fail if _either_ cURL or `jq` fail (or both, of course); otherwise you’d have to redirect cURL output to a temporary file, check `curl`’s errorlevel, then run jq on the temporary file in a command substitution and check its exit status (you’ll still have to do precisely that if you wish to distinguish between them in error messages).",
                "title": "How to convert a JSON object to key=value format in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 74,
        "last_activity_date": 1689815622,
        "creation_date": 1408433948,
        "last_edit_date": 1478796011,
        "question_id": 25378013,
        "body_markdown": "In jq, how can I convert a JSON to a string with `key=value`?\r\n\r\nFrom:\r\n\r\n    {\r\n        &quot;var&quot;: 1,\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;x&quot;: &quot;test&quot;\r\n    }\r\n\r\nTo:\r\n\r\n    var=1\r\n    foo=bar\r\n    x=test",
        "link": "https://stackoverflow.com/questions/25378013/how-to-convert-a-json-object-to-key-value-format-in-jq",
        "title": "How to convert a JSON object to key=value format in jq?"
    },
    {
        "tags": [
            "bash",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1408571125,
                "post_id": 25414854,
                "comment_id": 39645540,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1408573049,
                "post_id": 25414854,
                "comment_id": 39646265,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2184628,
                    "reputation": 373,
                    "user_id": 1933311,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/979fdcb4e0e25f7e6d209a961dbe2bae?s=256&d=identicon&r=PG",
                    "display_name": "Layfon Weller",
                    "link": "https://stackoverflow.com/users/1933311/layfon-weller"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1408576626,
                "post_id": 25414854,
                "comment_id": 39647304,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 18,
                "last_activity_date": 1408652910,
                "last_edit_date": 1408652910,
                "creation_date": 1408595580,
                "answer_id": 25418274,
                "question_id": 25414854,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So, I&#39;m taking a stab in the dark here (to mix metaphors), but this gives what seems to be the results you want:\r\n\r\n    cat test.json | jq &#39;.Project[0].projectName.tag[0].tagName |= .+ [&quot;path2&quot;] | .Project[0].projectName.branch[0].branchName |= .+ [&quot;path2&quot;]&#39;\r\n\r\nThe `|= .+ [...]` essentially appends a new array item. You can use the array specs for good effect for all array elements by omitting the `0` from, e.g., `tag[0]`.\r\n\r\nThis produces:\r\n\r\n    {\r\n      &quot;Project&quot;: [\r\n        {\r\n          &quot;projectName&quot;: {\r\n            &quot;tag&quot;: [\r\n              {\r\n                &quot;tagName&quot;: [\r\n                  &quot;path&quot;,\r\n                  &quot;path2&quot;\r\n                ]\r\n              }\r\n            ],\r\n            &quot;branch&quot;: [\r\n              {\r\n                &quot;branchName&quot;: [\r\n                  &quot;path&quot;,\r\n                  &quot;path2&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nEdit -- if I understand the new method now (but I could be missing something), we start with:\r\n\r\n    {\r\n      &quot;Project&quot;: {\r\n        &quot;projectName&quot;: {\r\n          &quot;tag&quot;: {\r\n            &quot;tagName&quot;: [\r\n              &quot;path&quot;,\r\n            ]\r\n          },\r\n          &quot;branch&quot;: {\r\n            &quot;branchName&quot;: [\r\n              &quot;path&quot;,\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nThen set some variables and apply this transform:\r\n\r\n    Project=projectName ProjectNumber=path2 Branch=branchName Tag=tagName\r\n    jq &quot;.Project.${Project}.tag.${Tag} |= .+ [\\&quot;${ProjectNumber}\\&quot;] | .Project.${Project}.branch.${Branch} |= .+ [\\&quot;${ProjectNumber}\\&quot;]&quot;\r\n\r\nAnd we get:\r\n\r\n    {\r\n      &quot;Project&quot;: {\r\n        &quot;projectName&quot;: {\r\n          &quot;tag&quot;: {\r\n            &quot;tagName&quot;: [\r\n              &quot;path&quot;,\r\n              &quot;path2&quot;\r\n            ]\r\n          },\r\n          &quot;branch&quot;: {\r\n            &quot;branchName&quot;: [\r\n              &quot;path&quot;,\r\n              &quot;path2&quot;\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "Add json array element with jq (cmdline)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 13,
        "last_activity_date": 1498708569,
        "creation_date": 1408570650,
        "last_edit_date": 1498708569,
        "question_id": 25414854,
        "body_markdown": "I&#39;m trying to generate a json file within bash. I installed jq, hoping that it would help me generate and append json.\r\n\r\nFor example, I want to generate a json in this format:\r\n\r\n    {\r\n      &quot;Project&quot;: [\r\n        {\r\n          &quot;projectName&quot;: {\r\n            &quot;branch&quot;: [\r\n              {\r\n                &quot;branchName&quot;: [\r\n                  &quot;path&quot;\r\n                ]\r\n              }\r\n            ],\r\n            &quot;tag&quot;: [\r\n              {\r\n                &quot;tagName&quot;: [\r\n                  &quot;path&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nWhile a can to something like that, with the following filter \r\n\r\n     .Project=.Project+.Project+\r\n      [{&quot;projectName&quot; : {&quot;branch&quot; : (.branch+[{&quot;branchName&quot;:(.tagName+[&quot;path&quot;])}]),\r\n\t\t         &quot;tag&quot;: (.tag+[{&quot;tagName&quot;:(.tagName+[&quot;path&quot;])}]) }}]\r\n\r\nwhen I want to create another entry in the same project and name, it creates a whole new entry, has if it was a new project,\r\nresulting in this:\r\n\r\n        {\r\n          &quot;Project&quot;: [\r\n            {\r\n              &quot;projectName&quot;: {\r\n                &quot;branch&quot;: [\r\n                  {\r\n                    &quot;branchName&quot;: [\r\n                      &quot;path&quot;\r\n                    ]\r\n                  }\r\n                ],\r\n                &quot;tag&quot;: [\r\n                  {\r\n                    &quot;tagName&quot;: [\r\n                      &quot;path&quot;\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;projectName&quot;: {\r\n                &quot;branch&quot;: [\r\n                  {\r\n                    &quot;branchName&quot;: [\r\n                      &quot;path&quot;\r\n                    ]\r\n                  }\r\n                ],\r\n                &quot;tag&quot;: [\r\n                  {\r\n                    &quot;tagName&quot;: [\r\n                      &quot;path&quot;\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;projectName&quot;: {\r\n                &quot;branch&quot;: [\r\n                  {\r\n                    &quot;branchName&quot;: [\r\n                      &quot;path2&quot;\r\n                    ]\r\n                  }\r\n                ],\r\n                &quot;tag&quot;: [\r\n                  {\r\n                    &quot;tagName&quot;: [\r\n                      &quot;path2&quot;\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        }\r\nBut I would like to have\r\n\r\n    {\r\n      &quot;Project&quot;: [\r\n        {\r\n          &quot;projectName&quot;: {\r\n            &quot;branch&quot;: [\r\n              {\r\n                &quot;branchName&quot;: [\r\n                  &quot;path&quot;,\r\n                  &quot;path2&quot;\r\n                ]\r\n              }\r\n            ],\r\n            &quot;tag&quot;: [\r\n              {\r\n                &quot;tagName&quot;: [\r\n                  &quot;path&quot;,\r\n                  &quot;path2&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\nIs there a way with jq/bash?",
        "link": "https://stackoverflow.com/questions/25414854/add-json-array-element-with-jq-cmdline",
        "title": "Add json array element with jq (cmdline)"
    },
    {
        "tags": [
            "regex",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1408836080,
                "post_id": 25463196,
                "comment_id": 39742357,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1408815605,
                "creation_date": 1408815605,
                "answer_id": 25464642,
                "question_id": 25463196,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s what worked for my, by our old good friend, Grep(and egrep)\r\n\r\n    $&lt;sample.dat  jq -c &#39;{appid:.appid,app_name:.app_name}&#39;  | egrep -i &quot;camfrog|draw something&quot;\r\n    {&quot;appid&quot;:&quot;f8022204aaa7478a88fca1a417ddb125&quot;,&quot;app_name&quot;:&quot;Camfrog Android Smartphone&quot;}\r\n    {&quot;appid&quot;:&quot;f8022204aaa7478a88fca1a417ddb125&quot;,&quot;app_name&quot;:&quot;Camfrog Android Smartphone&quot;}\r\n    {&quot;appid&quot;:&quot;agltb3B1Yi1pbmNyDAsSA0FwcBim6MAVDA&quot;,&quot;app_name&quot;:&quot;Draw Something Android&quot;}\r\n\r\n",
                "title": "FIltering by value in jq while building regex patterns"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664040868,
                "creation_date": 1664040868,
                "answer_id": 73839304,
                "question_id": 25463196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you&#39;re looking for a combination of `select` `ascii_downcase` and `test`, like so:\r\n\r\n```bash\r\n$ echo &#39;[{&quot;thing&quot;: &quot;foo&quot;}, {&quot;thing&quot;:&quot;Foo&quot;}, {&quot;thing&quot;:&quot;fOo&quot;}, {&quot;thing&quot;:&quot;Bar&quot;}]&#39; \\\r\n    | jq &#39;.[] | select(.thing | ascii_downcase | test(&quot;foo&quot;))&#39;\r\n\r\n    {\r\n      &quot;thing&quot;: &quot;foo&quot;\r\n    }\r\n    {\r\n       &quot;thing&quot;: &quot;Foo&quot;\r\n    }\r\n    {\r\n      &quot;thing&quot;: &quot;fOo&quot; \r\n    }\r\n```\r\n\r\n`select` takes a list and returns only certain elements from it\r\n\r\n`ascii_downcase` converts everything to lowercase\r\n\r\n`test` uses a regular expression to see if `select` should include the item or not",
                "title": "FIltering by value in jq while building regex patterns"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664040868,
        "creation_date": 1408805682,
        "last_edit_date": 1408810268,
        "question_id": 25463196,
        "body_markdown": "While trying to create a version of input to feed into my actual code, I need to create a file that enable to get &quot;contains&quot; a string with case sensitive version of string, in a value for a key. \r\ni.e **building a regex to implement &quot;contains&quot;** &quot;camfrog or tubemate, or soundclould&quot; .\r\n\r\n\r\nSample JSON input :\r\n\r\n    {&quot;appid&quot;:&quot;537c6d4a9c4846b8bc44ebdf78ab8e2d&quot;,&quot;app_name&quot;:&quot;TubeMate\r\n    YouTube Downloader&quot;,&quot;publisher_id&quot;:&quot;1690d6387fcc441091a2f2d73f89709d&quot;}\r\n    {&quot;appid&quot;:&quot;f8022204aaa7478a88fca1a417ddb125&quot;,&quot;app_name&quot;:&quot;Camfrog\r\n    Android Smartphone&quot;,&quot;publisher_id&quot;:&quot;085d0268a9674ce885a2f185ec895246&quot;}\r\n    {&quot;appid&quot;:&quot;agltb3B1Yi1pbmNyDAsSA0FwcBih9tMUDA&quot;,&quot;app_name&quot;:&quot;TuneIn Radio\r\n    - iPad&quot;,&quot;publisher_id&quot;:&quot;agltb3B1Yi1pbmNyEAsSB0FjY291bnQYsv-PFAw&quot;} {&quot;appid&quot;:&quot;537c6d4a9c4846b8bc44ebdf78ab8e2d&quot;,&quot;app_name&quot;:&quot;TubeMate\r\n    YouTube Downloader&quot;,&quot;publisher_id&quot;:&quot;1690d6387fcc441091a2f2d73f89709d&quot;}\r\n    {&quot;appid&quot;:&quot;f8022204aaa7478a88fca1a417ddb125&quot;,&quot;app_name&quot;:&quot;Camfrog\r\n    Android Smartphone&quot;,&quot;publisher_id&quot;:&quot;085d0268a9674ce885a2f185ec895246&quot;}\r\n     {&quot;appid&quot;:&quot;92255b8b662148e59973b8eca128adde&quot;,&quot;app_name&quot;:&quot;SubwaySimulator3D&quot;,&quot;publisher_id&quot;:&quot;0d78f4d244ec4309b4aa06cdfb871341&quot;}\r\n    {&quot;appid&quot;:&quot;agltb3B1Yi1pbmNyDAsSA0FwcBjq_6EUDA&quot;,&quot;app_name&quot;:&quot;TuneIn\r\n    Radio&quot;,&quot;publisher_id&quot;:&quot;agltb3B1Yi1pbmNyEAsSB0FjY291bnQYsv-PFAw&quot;}\r\n    {&quot;appid&quot;:&quot;f7cc119ca9e1426c8d162d2d37c8558f&quot;,&quot;app_name&quot;:&quot;Android Skout\r\n    New&quot;,&quot;publisher_id&quot;:&quot;agltb3B1Yi1pbmNyEAsSB0FjY291bnQY7cCnEgw&quot;}\r\n    {&quot;appid&quot;:&quot;agltb3B1Yi1pbmNyDAsSA0FwcBim6MAVDA&quot;,&quot;app_name&quot;:&quot;Draw\r\n    Something\r\n    Android&quot;,&quot;publisher_id&quot;:&quot;agltb3B1Yi1pbmNyEAsSB0FjY291bnQYgYC-FQw&quot;}\r\n\r\n\r\nFrom this Json input I need to filter apps that have names &quot;like&quot; Camfrog (It can be CAMFROG, camfrog .. etc, so the regex has to be case insensitive.along with this, I need to output a series of app_names like, say &quot;Camfrog&quot;, &quot;Tubemate&quot;, &quot;soundcloud&quot; etc. \r\nI looked up the jq manual here, http://stedolan.github.io/jq/manual/, but couldn&#39;t build the expression. \r\n\r\nHere&#39;s what I tried -:\r\n\r\n     &lt;/home/ekta/Prototype1/sample.dat jq -c &#39;{app_name:.app_name} |\r\n     match([&quot;Camfrog&quot;, &quot;ig&quot;])&#39;  \r\n     map(select(.app.name like &quot;%Camfrog%&quot; ))\r\n\r\nBut I get match is not defined &amp; a compile error thereof. How can I do this within Jq.\r\n\r\nfallback -:\r\nI could load this as a dataframe in pandas, and do the regex there,but since my file has a tons of things I dont really need, I would like to filter quickly in Jq. \r\n\r\nsample output after filtering for the apps ( I need all the key,values as in orignal output-:\r\n\r\n    {&quot;appid&quot;:&quot;537c6d4a9c4846b8bc44ebdf78ab8e2d&quot;,&quot;app_name&quot;:&quot;TubeMate\r\n    YouTube Downloader&quot;,&quot;publisher_id&quot;:&quot;1690d6387fcc441091a2f2d73f89709d&quot;}\r\n    {&quot;appid&quot;:&quot;f8022204aaa7478a88fca1a417ddb125&quot;,&quot;app_name&quot;:&quot;Camfrog\r\n    Android Smartphone&quot;,&quot;publisher_id&quot;:&quot;085d0268a9674ce885a2f185ec895246&quot;}\r\n    {&quot;appid&quot;:&quot;537c6d4a9c4846b8bc44ebdf78ab8e2d&quot;,&quot;app_name&quot;:&quot;TubeMate\r\n    YouTube Downloader&quot;,&quot;publisher_id&quot;:&quot;1690d6387fcc441091a2f2d73f89709d&quot;}\r\n    {&quot;appid&quot;:&quot;f8022204aaa7478a88fca1a417ddb125&quot;,&quot;app_name&quot;:&quot;Camfrog\r\n    Android Smartphone&quot;,&quot;publisher_id&quot;:&quot;085d0268a9674ce885a2f185ec895246&quot;}\r\n\r\n\r\n\r\n**PPS :** Will appreciate if you could &quot;Teach me to fish&quot;, instead of just building the regex that should be matched. \r\n\r\n**Follow up Question-:**\r\n\r\nAlso, when I try to test the sample examples, in the jq manual , like -:\r\n\r\n&gt; echo [{&quot;foo&quot;: 1, &quot;bar&quot;: 2}, {&quot;foo&quot;: 1, &quot;bar&quot;: 3}, {&quot;foo&quot;: 4, &quot;bar&quot;:\r\n&gt; 5}] | jq &#39;unique(.foo)\r\n\r\nI get , error: too many arguments to unique (expected 0 but got 1) unique(.foo)1 compile error\t\r\n\r\nWhile the jq manual reads, a sample example as below -:\r\n\r\n&gt;     jq &#39;unique(.foo)&#39;\r\n&gt;     Input\t[{&quot;foo&quot;: 1, &quot;bar&quot;: 2}, {&quot;foo&quot;: 1, &quot;bar&quot;: 3}, {&quot;foo&quot;: 4, &quot;bar&quot;: 5}]\r\n&gt;     Output \t[{&quot;foo&quot;: 1, &quot;bar&quot;: 2}, {&quot;foo&quot;: 4, &quot;bar&quot;: 5}]\r\n\r\n**How else should I try out the input here ?** \r\n\r\nThe way I am building my dictionary really is , `&lt;/home/ekta/SamplePrototype.dat jq -c &#39;{appid:.app.id,,app_name:.app.name,publisher_id:.app.publisher_id}&#39;` , but I would like to test things as in jq manual. Could you give me pointers about what am I doing wrong here ?\r\n",
        "link": "https://stackoverflow.com/questions/25463196/filtering-by-value-in-jq-while-building-regex-patterns",
        "title": "FIltering by value in jq while building regex patterns"
    },
    {
        "tags": [
            "json",
            "perl",
            "shell",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1409267114,
                "creation_date": 1409267114,
                "answer_id": 25559344,
                "question_id": 25558456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using Perl and its JSON module:\r\n\r\n    #!/usr/bin/perl\r\n    use warnings;\r\n    use strict;\r\n    use feature qw{ say };\r\n    \r\n    use JSON;\r\n    \r\n    my $input = &lt;&lt; &#39;__JSON__&#39;;\r\n    {&quot;id&quot;:&quot;111&quot;,&quot;case&quot;:&quot;Y&quot;,&quot;custom&quot;:{&quot;speech invoked&quot;:&quot;no&quot;,&quot;input method&quot;:&quot;hard&quot;,&quot;session ID&quot;:&quot;420&quot;}}\r\n    __JSON__\r\n    \r\n    my $struct = decode_json($input);\r\n    \r\n    my @header = grep ! ref $struct-&gt;{$_}, keys %$struct;\r\n    push @header, map keys %{ $struct-&gt;{$_} },\r\n                  grep ref $struct-&gt;{$_},\r\n                  keys %$struct;\r\n    \r\n    my @row = grep ! ref, values %$struct;\r\n    push @row, map values %$_, grep ref, values %$struct;\r\n    \r\n    say join &#39;,&#39;, @header;\r\n    say join &#39;,&#39;, @row;\r\n\r\n",
                "title": "How can I convert my JSON to CSV using jq?"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1415395788,
                "creation_date": 1415395788,
                "answer_id": 26810388,
                "question_id": 25558456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using perl wasn&#39;t a good solution for me but after a bit of trial and error I figured out you can do it with just `jq` using the `join()` operator. \r\n\r\nFirst make an array of the output you need, then join the array elements using commas. \r\n\r\n    jq -r &#39;[.case, .custom.&quot;speech invoked&quot;, .custom.&quot;input method&quot;] | join(&quot;, &quot;)&#39;\r\n\r\nEnjoy. :)",
                "title": "How can I convert my JSON to CSV using jq?"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 12,
                "last_activity_date": 1416934750,
                "creation_date": 1416934750,
                "answer_id": 27132468,
                "question_id": 25558456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using jq, you can use this filter:\r\n\r\n    with_entries(select(.key != &quot;custom&quot;)) + .custom\r\n        | to_entries\r\n        | map(.key), map(.value)\r\n        | @csv\r\n\r\nJust note that written this way, the &quot;custom&quot; properties will always be written in the end, no matter what order the properties are in.",
                "title": "How can I convert my JSON to CSV using jq?"
            },
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 22,
                "last_activity_date": 1435830107,
                "creation_date": 1435830107,
                "answer_id": 31181094,
                "question_id": 25558456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Building upon Joe Harris&#39; answer, you can use the @csv filter so that strings are properly quoted and escaped when necessary :\r\n\r\n    jq -r &#39;[.case, .custom.&quot;speech invoked&quot;, .custom.&quot;input method&quot;] | @csv&#39;",
                "title": "How can I convert my JSON to CSV using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504304508,
                "last_edit_date": 1504304508,
                "creation_date": 1504302811,
                "answer_id": 46008401,
                "question_id": 25558456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution.  If `data.json` contains the sample data then\r\n\r\n    jq -M -s -r &#39;map(.+.custom|del(.custom)) | (.[0]|keys_unsorted), (.[]|[.[]]) | join(&quot;,&quot;)&#39; data.json\r\n\r\nwill produce\r\n\r\n    id,case,speech invoked,input method,session ID\r\n    111,Y,no,hard,420\r\n",
                "title": "How can I convert my JSON to CSV using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 18,
        "last_activity_date": 1504304508,
        "creation_date": 1409261911,
        "last_edit_date": 1409265067,
        "question_id": 25558456,
        "body_markdown": "I have the following JSON data:\r\n \r\n    {&quot;id&quot;:&quot;111&quot;,&quot;case&quot;:&quot;Y&quot;,&quot;custom&quot;:{&quot;speech invoked&quot;:&quot;no&quot;,&quot;input method&quot;:&quot;hard&quot;,&quot;session ID&quot;:&quot;420&quot;}}\r\n\r\nHow can I convert it to CSV format using [jq](http://stedolan.github.io/jq/) so my result looks like this?\r\n\r\n    id,case,session Id,speech invoked,input method\r\n\r\n    111,Y,420,no,hard\r\n\r\n\r\nI tried the following, but it didn&#39;t work:\r\n\r\n    {(.id),(.case),(.custom.&quot;session Id&quot;),(.custom.&quot;speech invoked&quot;),(.custom.&quot;input method&quot;)}\r\n\r\n\r\nIf not possible any perl or shell solution is appreciated.",
        "link": "https://stackoverflow.com/questions/25558456/how-can-i-convert-my-json-to-csv-using-jq",
        "title": "How can I convert my JSON to CSV using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1409765861,
                "creation_date": 1409765861,
                "answer_id": 25650468,
                "question_id": 25649960,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Found out the answer\r\n\r\n    jq &#39;select(.items | index(&quot;blue&quot;))&#39;",
                "title": "How to select items in JQ based on value in array"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1436422311,
                "last_edit_date": 1436422311,
                "creation_date": 1409795670,
                "answer_id": 25656183,
                "question_id": 25649960,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&lt;strike&gt;\r\nWhile what you have certainly works, it would be more correct to use `contains`.  I would avoid that use since it can lead to confusion.  `index(&quot;blue&quot;)` is `0` and one wouldn&#39;t consider that a truthy value and might expect it to be excluded from the results.\r\n\r\nConsider using this filter instead:\r\n\r\n    select(.items | contains([&quot;blue&quot;]))\r\n\r\nThis has the added benefit that it would work if you wanted items with more than one match by simply adding more to the array.\r\n&lt;/strike&gt;\r\n\r\nAs Will pointed out in the comments, this isn&#39;t quite correct. Strings are compared using substring matching (`contains` is used recursively) here.\r\n\r\nIn retrospect, `contains` didn&#39;t work out as I thought it would.  Using `index` works, but personally I wouldn&#39;t use it. There&#39;s something about figuring out if an item is in a collection by looking for it&#39;s index that feels wrong to me.  Using `contains` makes more sense to me, but in light of this information, it wouldn&#39;t be ideal in this case.\r\n\r\n&lt;hr&gt;\r\n\r\nHere&#39;s an alternative that should work correctly:\r\n\r\n    select([.items[] == &quot;blue&quot;] | any)\r\n\r\nOr for a more scalable way if you wanted to be able to match more values:\r\n\r\n    select(.items as $values | [&quot;blue&quot;, &quot;yellow&quot;] | map([$values[] == .] | any) | all)",
                "title": "How to select items in JQ based on value in array"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1579102117,
                "last_edit_date": 1579102117,
                "creation_date": 1498965901,
                "answer_id": 44867184,
                "question_id": 25649960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On Jan 30, 2017, a builtin named `IN` was added for efficiently testing whether a JSON entity is contained in a stream. It can also be used for efficiently testing membership in an array. In the present case, the relevant usage would be:\r\n\r\n    select( .items as $items | &quot;blue&quot; | IN($items[]) )\r\n\r\nIf your jq does not have `IN/1`, then so long as your jq has `first/1`, you can use this equivalent definition:\r\n\r\n    def IN(s): . as $in | first(if (s == $in) then true else empty end) // false;\r\n\r\n## any/0\r\n\r\nUsing `any/0` here is relatively inefficient, e.g. compared to using `any/1`:\r\n\r\n    select( any( .items[]; . == &quot;blue&quot; ))\r\n\r\n     \r\n\r\n(In practice, `index/1` is usually fast enough, but its implementation currently (jq 1.5 and versions through at least July 2017) is suboptimal.)",
                "title": "How to select items in JQ based on value in array"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1545216087,
                "creation_date": 1545216087,
                "answer_id": 53849486,
                "question_id": 25649960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have needed to use &#39;regex&#39; for the same situation of the objects. (In another context, of course). I write the code because I did not find a solution for my need in these pages. This can be useful for someone.\r\n\r\nFor example, to match the blue color using a regular expression:\r\n\r\n    jq &#39;select(.items[]|test(&quot;bl.*&quot;))&#39; yourfile.json\r\n\r\n[jqPlay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/5JHn1CIjBj",
                "title": "How to select items in JQ based on value in array"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 31,
        "last_activity_date": 1579102117,
        "creation_date": 1409763920,
        "last_edit_date": 1409765099,
        "question_id": 25649960,
        "body_markdown": "I have a file with lines like this:\r\n\r\n    {&quot;items&quot;:[&quot;blue&quot;,&quot;green&quot;]}\r\n    {&quot;items&quot;:[&quot;yellow&quot;,&quot;green&quot;]}\r\n    {&quot;items&quot;:[&quot;blue&quot;,&quot;pink&quot;]}\r\n\r\nHow can I use [jq][1] to select and show only the JSON values that have &quot;blue&quot; in their &quot;items&quot; array?\r\n\r\nSo the output would be:\r\n\r\n    {&quot;items&quot;:[&quot;blue&quot;,&quot;green&quot;]}\r\n    {&quot;items&quot;:[&quot;blue&quot;,&quot;pink&quot;]}\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/25649960/how-to-select-items-in-jq-based-on-value-in-array",
        "title": "How to select items in JQ based on value in array"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1410210756,
                "post_id": 25729683,
                "comment_id": 40232951,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1410201254,
                "creation_date": 1410201254,
                "answer_id": 25730853,
                "question_id": 25729683,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Never mind - after some more head-cracking, I think I got it:\r\n\r\n    cat veggies.json | jq &#39;.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values |= . + [{ &quot;type&quot;: &quot;root&quot;, &quot;tuber&quot;: &quot;yam&quot; }]&#39;\r\n\r\nThis seems to do what I want:\r\n\r\n    {\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;stem&quot;,\r\n          &quot;tuber&quot;: &quot;potato&quot;\r\n        },\r\n        {\r\n          &quot;tuber&quot;: &quot;yam&quot;,\r\n          &quot;type&quot;: &quot;root&quot;\r\n        }\r\n      ],\r\n      &quot;section&quot;: &quot;TUBERS&quot;\r\n    }\r\n\r\nIf somebody can optimize this even further, I&#39;d be very eager to learn that as well.",
                "title": "Add JSON value in correct section"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1410203301,
                "last_edit_date": 1410203301,
                "creation_date": 1410202550,
                "answer_id": 25731205,
                "question_id": 25729683,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this instead:\r\n\r\n    jq &#39;(.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values) |= . + [{&quot;type&quot;: &quot;root&quot;, &quot;tuber&quot;: &quot;yam&quot;}]&#39; veggies.json\r\n\r\nThis runs a sub-filter: selecting the elements of the veggies array, finding the element with a matching section and yielding the values varray.  Then it appends the object to the values array.\r\n\r\nThis is essentially the same as the filters in your own answer with one key difference: because you don&#39;t actually filter anything out of the main input data, it will print out the entire JSON document (not just the modified portion).  I&#39;m not sure if that&#39;s a benefit to you or not, but it makes it really easy to modify the document as a whole in a script.\r\n\r\n(tested on jq 1.3)",
                "title": "Add JSON value in correct section"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1410203301,
        "creation_date": 1410196769,
        "last_edit_date": 1410202231,
        "question_id": 25729683,
        "body_markdown": "My json file &#39;veggies.json&#39; as follows:\r\n\r\n    {&quot;plants&quot;:\r\n      {&quot;veggies&quot;:\r\n        [\r\n          {&quot;section&quot;:&quot;TUBERS&quot;,\r\n            &quot;values&quot;:\r\n              [\r\n                {&quot;tuber&quot;:&quot;potato&quot;,&quot;type&quot;:&quot;stem&quot;}\r\n              ]\r\n          },\r\n          {&quot;section&quot;:&quot;LEGUMES&quot;,\r\n            &quot;values&quot;:\r\n              [\r\n                {&quot;legume&quot;:&quot;beans&quot;},\r\n                {&quot;legume&quot;:&quot;peanuts&quot;}\r\n              ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to add another tuber &quot;yam&quot;, which is of type &quot;root&quot; - this has to go under the section TUBERS.\r\n\r\nI&#39;ve just started off with JSON, and I have been breaking my head with all sorts of jq commands, but to not much avail.\r\n\r\nI tried to read the value at values[0] with the following command, but I don&#39;t seem to be able to list anything:\r\n\r\n    jq -r &quot;[.[] | select(.plants.veggies.section == \\&quot;TUBERS\\&quot;) | .plants.veggies.values.tuber]&quot; veggies.json\r\n\r\nEssentially, I am trying to achieve this - if plants section is TUBERS, add tuber &quot;yam&quot; which is of type &quot;root&quot;\r\n\r\nCan anybody please help me out?\r\n\r\nOh, and I am stuck with jq version 1.2, if that matters (backward compatibility and all that stuff).\r\n\r\nMuch thanks in advance.",
        "link": "https://stackoverflow.com/questions/25729683/add-json-value-in-correct-section",
        "title": "Add JSON value in correct section"
    },
    {
        "tags": [
            "jq",
            "json-path-expression"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1410419346,
                "creation_date": 1410419346,
                "answer_id": 25781241,
                "question_id": 25780807,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "That&#39;s what the `..` filter was meant to represent.  The use would look like this:\r\n\r\n    .level1 | .. | .level3? .element\r\n\r\nNote: you must use the `?` otherwise you&#39;ll get errors as it recurses down objects that do not have the corresponding property.",
                "title": "How can I use a relative Path or a Wildcard in JQ"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1451460922,
                "last_edit_date": 1451460922,
                "creation_date": 1451458552,
                "answer_id": 34524501,
                "question_id": 25780807,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Two additional points relative to Jeff&#39;s answer:\r\n\r\n(1) An alternative to using `?` is to use `objects`, e.g.\r\n\r\n    .level1 | .. | objects | .level3.element\r\n\r\n(2) Typically one will want to eliminate the nulls corresponding to paths that do NOT match the specified trailing keys.  To eliminate ALL nulls, one option is to tack on the filter: select(. != null). \r\n\r\nOn the other hand, if one wants to retain nulls that do appear as values, then one possibility is to use `paths` as follows:\r\n\r\n\r\n    .level1\r\n    | (paths | select( .[-2:] == [&quot;level3&quot;, &quot;element&quot;])) as $path\r\n    | getpath($path)\r\n\r\n(Since `paths` produces a stream of arrays of strings, the above expression produces a stream of the values corresponding to paths ending in .level3.element)\r\n\r\nEquivalently but as a one-liner:\r\n\r\n    .level1 | getpath(paths | select(.[-2:] == [&quot;level3&quot;,&quot;element&quot;]))",
                "title": "How can I use a relative Path or a Wildcard in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1624194644,
        "creation_date": 1410417842,
        "last_edit_date": 1624194644,
        "question_id": 25780807,
        "body_markdown": "Is it possible to use a relative path or name in JQ like the XPath // ?\r\n\r\nOr is it possible to use an wildcard in JQ like .level1.*.level3.element ?",
        "link": "https://stackoverflow.com/questions/25780807/how-can-i-use-a-relative-path-or-a-wildcard-in-jq",
        "title": "How can I use a relative Path or a Wildcard in JQ"
    },
    {
        "tags": [
            "json",
            "shell",
            "elasticsearch",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1410833240,
                "creation_date": 1410833240,
                "answer_id": 25859644,
                "question_id": 25859100,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can try find/replace using regexp:\r\n\r\n 1. Find what: &quot;^\\s{2,}&quot; replace to &quot;&quot;\r\n 2. Find what &quot;\\n&quot; replace &quot;&quot; \r\n\r\nSee this: https://github.com/dzhibas/SublimePrettyJson/issues/17",
                "title": "How to do an unpretty print on pretty JSON file in shell &gt;&gt; serial string JSON &gt;&gt; ES _bulk?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1638049278,
                "last_edit_date": 1638049278,
                "creation_date": 1410851968,
                "answer_id": 25862791,
                "question_id": 25859100,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer from D_S_toowhite was not a direct answer but it set me thinking in the right way i.e., the problem is to remove all the white space. I found a very simple way to remove all white space using command line tool tr:\r\n\r\n\r\n    tr -d [:space:] inputfile\r\n\r\nThe :space: tag removes all white space, tabs, spaces, vertical tabs etc. So a pretty JSON input like this:-\r\n\r\n    {\r\n        &quot;version&quot; : &quot;4.0&quot;,\r\n        &quot;success&quot; : true,\r\n        &quot;result&quot; :\r\n        {\r\n                &quot;Focus&quot; : 0.000590008,\r\n                &quot;Arc&quot; : 12\r\n        }\r\n    }\r\n\r\nbecomes this JSON serial string:\r\n\r\n    {&quot;version&quot;:&quot;4.0&quot;,&quot;success&quot;:true,&quot;result&quot;:{&quot;Focus&quot;:0.000590008,&quot;Arc&quot;:12}}\r\n\r\nI still have to solve the \\n terminator but I think that is trivial now at least in my special case, just append after closing bracket pair using sed.\r\n\r\n\r\n",
                "title": "How to do an unpretty print on pretty JSON file in shell &gt;&gt; serial string JSON &gt;&gt; ES _bulk?"
            },
            {
                "up_vote_count": 77,
                "is_accepted": false,
                "score": 77,
                "last_activity_date": 1445041889,
                "creation_date": 1445041889,
                "answer_id": 33181419,
                "question_id": 25859100,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can try the great [jq][1] tool for parsing JSON in the shell. To de-pretty print with jq, you can use either method below:\r\n\r\n    cat pretty-printed.json | jq -c .\r\n    jq -c . pretty-printed.json\r\n\r\nthe -c (or --compact-output) tells it to not pretty print (which is the default). The &quot;.&quot; tells it to return the JSON content &quot;as is&quot; unmodified other than the reformatting. It gets dumped back to stdout, so you can redirect output or pipe it to something else.\r\n\r\nP.S. I was looking to address the same problem and came to this option.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
                "title": "How to do an unpretty print on pretty JSON file in shell &gt;&gt; serial string JSON &gt;&gt; ES _bulk?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1447435615,
                "creation_date": 1447435615,
                "answer_id": 33698500,
                "question_id": 25859100,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[jsonlint][1] is easy to get up and running in the command line with the help of npm, and a simple way to print out &#39;no fluff&#39; JSON is to give it an indentation character of &quot;&quot;.\r\n\r\n    jsonlint -t &quot;&quot;\r\n\r\nAs a bonus for command line users, I use this all the time to take paste buffers (on a Mac) and convert them into something else, for instance:\r\n\r\nSwap buffer contents for a JSON linted &#39;compressed&#39; format:\r\n\r\n    pbpaste | jsonlint -t &quot;&quot; | pbcopy\r\n\r\nSwap buffer contents for a pretty printed JSON linted format:\r\n\r\n    pbpaste | jsonlint | pbcopy\r\n\r\nYou could also pipe file contents to an ugly (and JSON linted) version of the file:\r\n\r\n    cat data-pretty.json | jsonlint -t &quot;&quot; &gt; data-ugly.json\r\n\r\n  [1]: https://github.com/zaach/jsonlint\r\n",
                "title": "How to do an unpretty print on pretty JSON file in shell &gt;&gt; serial string JSON &gt;&gt; ES _bulk?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 48,
        "last_activity_date": 1638049278,
        "creation_date": 1410828702,
        "last_edit_date": 1614038321,
        "question_id": 25859100,
        "body_markdown": "In working with Elasticsearch on AWS EC2, I just hit an issue with bulk indexing.  The ES _bulk endpoint requires the files to be basically JSON serial strings with \\n terminators on each string; and what I have built using various web APIs and file pre/processing is pretty JSON ie., easily human readable.\r\n\r\n**Is there a simple shell script method to get all the pretty JSON simply concatenated into strings**, without loading up some Java libraries or whatever? I can add tokens to the basic file during pre-processing to tag the desired \\n breaks if that helps parsing, but if anyone has a tip on the toolset I would be grateful. I have a feeling there are scripts out there and I know there are some libraries, but I have not found any simple command line tools to do the unpretty printing so far.",
        "link": "https://stackoverflow.com/questions/25859100/how-to-do-an-unpretty-print-on-pretty-json-file-in-shell-serial-string-json",
        "title": "How to do an unpretty print on pretty JSON file in shell &gt;&gt; serial string JSON &gt;&gt; ES _bulk?"
    },
    {
        "tags": [
            "bash",
            "if-statement",
            "for-loop",
            "while-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1410856893,
                "post_id": 25864097,
                "comment_id": 40472276,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1410857038,
                "post_id": 25864097,
                "comment_id": 40472367,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5006260,
                    "reputation": 87,
                    "user_id": 4023849,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/f3d6408dbfdf3311409accf3f6c191ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BashNewbie",
                    "link": "https://stackoverflow.com/users/4023849/bashnewbie"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1410858477,
                "post_id": 25864097,
                "comment_id": 40473177,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5006260,
                    "reputation": 87,
                    "user_id": 4023849,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/f3d6408dbfdf3311409accf3f6c191ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BashNewbie",
                    "link": "https://stackoverflow.com/users/4023849/bashnewbie"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1410858673,
                "post_id": 25864097,
                "comment_id": 40473281,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1410858868,
                "post_id": 25864097,
                "comment_id": 40473388,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1410858984,
                "post_id": 25864097,
                "comment_id": 40473460,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5006260,
                    "reputation": 87,
                    "user_id": 4023849,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/f3d6408dbfdf3311409accf3f6c191ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BashNewbie",
                    "link": "https://stackoverflow.com/users/4023849/bashnewbie"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1410859058,
                "post_id": 25864097,
                "comment_id": 40473502,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1410867000,
                "post_id": 25864097,
                "comment_id": 40478067,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1410938767,
                "last_edit_date": 1410938767,
                "creation_date": 1410938281,
                "answer_id": 25884566,
                "question_id": 25864097,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I know it might seem arrogant to answer my own question, but for all those out there who has struggled like me, I wanted to add a fix. Before I get any slams for the code maybe being clumsy and &quot;too much&quot;, just remember, I just started coding in bash, and this is working. Others might find this and with their experience be able to clean it up. For me though, this is what worked, so I stuck with it.\r\n\r\nThanks to Mark Setchell, I went back to the drawing board to figure out why the while loop was giving me a hard time. I figured out that some of the json return I got had more objects in it than others, so the jq command had to be adjusted to fit each command. I am only posting the relevant code for extracting the data I was looking for in my OP.\r\n\r\n    if grep -q -e &#39;Cleaning up&quot;&#39; $LINE-curl-final.txt; then\r\n    \r\n          \r\n    \r\nBecause some media packages fail on first processing, then gets &quot;picked up&quot; to be re-processed, they have more than one workflow object. This if-statement searches for the succeeded one between them,and extracts the data with the adjusted jq query\r\n    \r\n    \r\n\r\n    get_count=$( jq -r &#39;.[] | .totalCount&#39; &lt; $LINE-curl-final.txt )                \r\n        if  [[ &quot;$get_count&quot; -gt 1 ]]; then\r\n            \r\n           state=$( jq -r &#39;.workflows.workflow[] | select(.state == &quot;SUCCEEDED&quot; ) | .operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .state&#39; &lt; $LINE-curl-final.txt )\r\n          \r\n           if [ &quot;$state&quot; = &quot;SUCCEEDED&quot; ];then\r\n            \r\n               end_time=$( jq &#39;.workflows.workflow[] | select(.state == &quot;SUCCEEDED&quot; ) | .operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .completed&#39; &lt; $LINE-curl-final.txt )\r\n               ingest_time=$( jq &#39;.workflows.workflow [] | .operations.operation[] | select(.description == &quot;Ingest&quot;) | .completed&#39; &lt; $LINE-curl-final.txt )\r\n           \r\n           fi\r\n    \r\n       else\r\n           state=$(  jq -r &#39;.workflows.workflow.operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .state&#39; &lt; $LINE-curl-final.txt )\r\n           if [ &quot;$state&quot; = &quot;SUCCEEDED&quot; ];then\r\n        \r\n               end_time=$( jq &#39;.workflows.workflow.operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .completed&#39; &lt; $LINE-curl-final.txt )\r\n               ingest_time=$( jq &#39;.workflows.workflow.operations.operation[] | select(.description == &quot;Ingest&quot;) | .completed&#39; &lt; $LINE-curl-final.txt )\r\n                \r\n           fi\r\n    \r\n        fi\r\n\r\nNote the difference between \r\n\r\n    jq &#39;.workflows.workflow.operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .completed&#39;\r\n\r\nand\r\n\r\n    jq &#39;.workflows.workflow[] | select(.state == &quot;SUCCEEDED&quot; ) | .operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .completed&#39;\r\n\r\nI hope that this idea might help anybody else struggling with the same problem.\r\n\r\n",
                "title": "Bash with while, for and if works, until I add a second value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1410938767,
        "creation_date": 1410856451,
        "question_id": 25864097,
        "body_markdown": "I have a script where I extract values from curl statements using jq. This script works well whenever the if-statement receives one true value, however, it breaks as soon as a second media package is found and has to be processed. \r\n\r\nThe code:\r\n\r\n    #!/bin/bash\r\n    \r\n    source mh_auth.sh\r\n    \r\n    rm -f times.txt\r\n    touch times.txt\r\n    \r\n    #Read lines from file with mediapackage-id&#39;s that are on schedule.\r\n    while read LINE; do\r\n    \r\n           \r\n            curl --silent --digest -u $mh_username:$mh_password -H &quot;X-Requested-Auth: Digest&quot; -H &quot;X-Opencast-Matterhorn-Authorization: true&quot; &quot;$mh_server/workflow/instances.json?mp=$LINE&quot; &gt;  $LINE-curl.txt\r\n    \r\n            #Format the file to make it more readable if you need to troubleshoot\r\n            /usr/bin/python -m json.tool $LINE-curl.txt &gt; $LINE-curl-final.txt\r\n    \r\n            #Test to see if this mediapackage has been published yet, and if it has, extract the necessary values for calculation\r\n            \r\n            if grep -q -e &#39;Cleaning up&quot;&#39; $LINE-curl-final.txt; then\r\n    \r\n                    echo &quot;Media Package found&quot;\r\n                    workflows=$( jq &#39;.workflows.workflow[]&#39; &lt; $LINE-curl-final.txt )\r\n    \r\n                    for i in &quot;${workflows}&quot;\r\n                    do\r\n                            echo &quot;Getting the end_time variable&quot;\r\n                            end_time=`echo ${i} | jq &#39;.operations.operation[] | select(.description == &quot;Cleaning up&quot;) | .completed&#39;`\r\n                            echo &quot;Done getting end time variable&quot;\r\n                            echo &quot;Getting ingest time variable&quot;\r\n                            ingest_time=`echo ${i} | jq &#39;.operations.operation[] | select(.description == &quot;Ingest&quot;) | .completed&#39;`\r\n                            echo &quot;Done getting ingest time variable&quot;\r\n                            \r\n                            echo $ingest_time  $end_time  &gt;&gt; times.txt\r\n                            echo last &gt;&gt; times.txt\r\n    \r\n                    done\r\n    \r\n            else\r\n                    echo &quot;Media Package not published yet&quot;\r\n            fi\r\n    \r\n            rm -f $LINE-curl.txt\r\n            rm -f $LINE-curl-final.txt\r\n    \r\n    done &lt; scheduled-mediapackages.txt\r\n\r\nA successful run yields the following:\r\n\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package found\r\n    Getting the end_time variable\r\n    Done getting end time variable\r\n    Getting ingest time variable\r\n    Done getting ingest time variable\r\n\r\nWhenever I add a second published media package containing exactly the same json as the first to my list, I get the following:\r\n\r\n    Media Package not published yet\r\n    Media Package not published yet\r\n    Media Package found\r\n    Getting the end_time variable\r\n    Done getting end time variable\r\n    Getting ingest time variable\r\n    Done getting ingest time variable\r\n    Media Package found\r\n    Getting the end_time variable\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    Done getting end time variable\r\n    Getting ingest time variable\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot index string with string\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    Done getting ingest time variable\r\n\r\nAny ideas how to fix this? I have been going around in circles and cannot get it to work?\r\n",
        "link": "https://stackoverflow.com/questions/25864097/bash-with-while-for-and-if-works-until-i-add-a-second-value",
        "title": "Bash with while, for and if works, until I add a second value"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1410882163,
                "creation_date": 1410882163,
                "answer_id": 25873084,
                "question_id": 25870599,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This looks like it *should* work, but it doesn&#39;t -- if there&#39;s no &quot;yam&quot;, then the output is empty.\r\n\r\n    jq &#39;\r\n      if (.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values)[] | select(.tuber == &quot;yam&quot;)\r\n      then . \r\n      else (.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values) += [{&quot;tuber&quot;:&quot;yam&quot;, &quot;cookstyle&quot;:&quot;mashed&quot;}]    \r\n      end\r\n    &#39; veggies.json \r\n\r\n",
                "title": "Add JSON value uniquely in correct section using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1411028182,
                "last_edit_date": 1411028182,
                "creation_date": 1411024972,
                "answer_id": 25906604,
                "question_id": 25870599,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ok - turns out that I was overthinking this entire thing - maybe it is possible as a one-liner with jq itself, but since I have the liberty of working with shell, I simply just checked for whether &quot;yam&quot; is present, if not, add it, and if it does, edit it - like so:\r\n\r\n    IS_YAM_PRESENT=`jq &#39;(.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values[] | select(.tuber == &quot;yam&quot;) | .cookstyle)&#39; veggies.json`\r\n    if [ -z ${IS_YAM_PRESENT} ]\r\n    then\r\n        jq &#39;(.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values) |= . + [{ &quot;tuber&quot;: &quot;yam&quot;, &quot;cookstyle&quot;: &quot;boiled&quot; }]&#39; veggies.json\r\n    else\r\n        jq &#39;(.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values[] | select(.tuber == &quot;yam&quot;)) |= { &quot;tuber&quot;: &quot;yam&quot;, &quot;cookstyle&quot;: &quot;boiled&quot; }&#39; veggies.json\r\n    fi\r\n\r\nAs always, if anybody has a better more &quot;refined&quot; and &quot;tighter&quot; solution to this, I would be most happy to see it.\r\n\r\nCheers! :)",
                "title": "Add JSON value uniquely in correct section using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1502856122,
                "creation_date": 1502856122,
                "answer_id": 45704929,
                "question_id": 25870599,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think [Lakshminarayanan](https://stackoverflow.com/users/3759959/lakshminarayanan-k)&#39;s solution is very close.  If you don&#39;t want the duplicate yam if it&#39;s already in the array you can remove it with **unique**. E.g.\r\n\r\n       (\r\n           .plants.veggies[]\r\n         | select(.section == &quot;TUBERS&quot;)\r\n         | .values\r\n\r\n       ) |= (\r\n              . + [ {&quot;cookstyle&quot;: &quot;boil&quot;, &quot;tuber&quot;: &quot;yam&quot;} ]\r\n              | unique\r\n            )\r\n\r\nOr perhaps consider putting the logic in a separate function so that it can be more easily managed if it gets complex. E.g.\r\n\r\n    def addyam:\r\n         . + [ {&quot;cookstyle&quot;: &quot;boil&quot;, &quot;tuber&quot;: &quot;yam&quot;} ]\r\n       | unique\r\n    ;\r\n\r\n       (\r\n           .plants.veggies[]\r\n         | select(.section == &quot;TUBERS&quot;)\r\n         | .values\r\n\r\n       ) |= addyam",
                "title": "Add JSON value uniquely in correct section using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1502866819,
        "creation_date": 1410875366,
        "last_edit_date": 1502866819,
        "question_id": 25870599,
        "body_markdown": "This question is an extension to an earlier question I had asked earlier: [Add JSON value in correct section][1]\r\n\r\nEssentially, I have a json file &#39;veggies.json&#39; as follows:\r\n\r\n    {&quot;plants&quot;:\r\n      {&quot;veggies&quot;:\r\n        [\r\n          {&quot;section&quot;:&quot;TUBERS&quot;,\r\n            &quot;values&quot;:\r\n              [\r\n                {&quot;tuber&quot;:&quot;potato&quot;,&quot;cookstyle&quot;:&quot;fry&quot;}\r\n              ]\r\n          },\r\n          {&quot;section&quot;:&quot;LEGUMES&quot;,\r\n            &quot;values&quot;:\r\n              [\r\n                {&quot;legume&quot;:&quot;beans&quot;,&quot;cookstyle&quot;:&quot;boil&quot;},\r\n                {&quot;legume&quot;:&quot;peanuts&quot;,&quot;cookstyle&quot;:&quot;salted&quot;}\r\n              ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to add another tuber &quot;yam&quot;, which can have cookstyle &quot;boil&quot; - this has to go under the section TUBERS, but uniquely. Meaning, I want to add this tuber only if it is not already there - if it already there, I just want to replace it with whatever &quot;cookstyle&quot; I am passing - it could be cookstyle:&quot;mashed&quot; as well.\r\n\r\nFrom my [earlier question][1], I already have this code using the &#39;jq&#39; tool:\r\n\r\n    jq &#39;(.plants.veggies[] | select(.section == &quot;TUBERS&quot;) | .values) |= . + [{&quot;cookstyle&quot;: &quot;boil&quot;, &quot;tuber&quot;: &quot;yam&quot;}]&#39; veggies.json\r\n\r\nHowever, this line of code keeps adding the same line multiple times under the TUBERS section - is there any way I can add it uniquely (hash like behaviour)\r\n\r\nMuch thanks in advance.\r\n\r\n  [1]: https://stackoverflow.com/questions/25729683/add-json-value-in-correct-section/25730853#25730853",
        "link": "https://stackoverflow.com/questions/25870599/add-json-value-uniquely-in-correct-section-using-jq",
        "title": "Add JSON value uniquely in correct section using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1412178620,
                "last_edit_date": 1412178620,
                "creation_date": 1412109161,
                "answer_id": 26129572,
                "question_id": 26128753,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**Edit**: new &quot;[flatten][2]&quot; function not needed (thanks\r\n @JeffMercado)\r\n\r\nI can run\r\n\r\n    jq -s &#39;group_by(.foo) | map({foo: .[0].foo, bar: map(.bar) | unique, baz: map(.baz) | add | unique})\r\n\r\nwhich produces:\r\n\r\n    [\r\n      {&quot;foo&quot;:&quot;one&quot;,&quot;bar&quot;:[2,3],&quot;baz&quot;:[0,2,3,4]},\r\n      {&quot;foo&quot;:&quot;two&quot;,&quot;bar&quot;:[3],&quot;baz&quot;:[1]}\r\n    ]\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq\r\n  [2]: http://stedolan.github.io/jq/manual/#flattenflattendepth",
                "title": "How do I collect unique elements of an array-valued field across multiple objects in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 20,
        "last_activity_date": 1412178620,
        "creation_date": 1412105952,
        "question_id": 26128753,
        "body_markdown": "I have json data that looks like:\r\n\r\n    {&quot;foo&quot;:&quot;one&quot;, &quot;bar&quot;:2, &quot;baz&quot;:[0]}\r\n    {&quot;foo&quot;:&quot;two&quot;, &quot;bar&quot;:3, &quot;baz&quot;:[1]}\r\n    {&quot;foo&quot;:&quot;one&quot;, &quot;bar&quot;:3, &quot;baz&quot;:[2,3]}\r\n    {&quot;foo&quot;:&quot;one&quot;, &quot;bar&quot;:2, &quot;baz&quot;:[2,4]}\r\n\r\nI want to group everything with the same &quot;foo&quot; and collect the unique values of bar, and then collect the unique values inside of the &quot;baz&quot; arrays:\r\n\r\n    [\r\n      {&quot;foo&quot;:&quot;one&quot;, &quot;bar&quot;:[2, 3], &quot;baz&quot;:[0,2,3,4]},\r\n      {&quot;foo&quot;:&quot;two&quot;, &quot;bar&quot;:[3], &quot;baz&quot;:[1]}\r\n    ]\r\n\r\n(I don&#39;t care if the result is in an array or just a raw sequence of whitespace separated JSON objects, and I don&#39;t care about the order of the items in the &quot;baz&quot; array)\r\n\r\nI&#39;ve got jq version 1.4 installed from source.  I can properly group by &quot;foo&quot; and collect unique values of &quot;bar&quot; with:\r\n\r\n    jq -s &#39;group_by(.foo) | map({foo: .[0].foo, bar: map(.bar) | unique})&#39;\r\n\r\nyielding:\r\n\r\n    [\r\n      {&quot;foo&quot;:&quot;one&quot;,&quot;bar&quot;:[2,3]},\r\n      {&quot;foo&quot;:&quot;two&quot;,&quot;bar&quot;:[3]}\r\n    ]\r\n\r\nbut I can&#39;t figure out how to do the collection of unique values of &quot;baz&quot;.\r\n\r\n\r\nWhat am I missing?  ",
        "link": "https://stackoverflow.com/questions/26128753/how-do-i-collect-unique-elements-of-an-array-valued-field-across-multiple-object",
        "title": "How do I collect unique elements of an array-valued field across multiple objects in jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 68,
                "is_accepted": true,
                "score": 68,
                "last_activity_date": 1412452951,
                "creation_date": 1412452951,
                "answer_id": 26196653,
                "question_id": 26195214,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the `select` filter where length &gt; 0.\r\n\r\n    select(length &gt; 0)",
                "title": "How to nicely remove empty array in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 38,
        "last_activity_date": 1657011495,
        "creation_date": 1412443233,
        "question_id": 26195214,
        "body_markdown": "I am reading O&#39;Reilly&#39;s new &quot;Data Science at the Command Line&quot; and running into trouble using jq. I have some JSON (returned from the NYTimes Articles API) I am parsing with jq like so:\r\n\r\n    jq -c \\\r\n    &#39;[.response.docs[] | {date: .pub_date, type: .document_type, title: .headline.main }]&#39; \\\r\n    &lt; myjsonfile.json\r\n\r\nSo, I am looking for &quot;response&quot;:&quot;docs&quot; (which is an array) and then matching every item in that array with &quot;pub_type&quot; etc., renaming it, and so on. This works great, but it adds an empty array at the end:\r\n\r\n    [{&quot;date&quot;:&quot;2009-01-02T00:00:00Z&quot;,&quot;type&quot;:&quot;article&quot;,&quot;title&quot;:&quot;SPARE TIMES: AROUND TOWN&quot;},  \r\n    {&quot;date&quot;:&quot;2009-01-02T00:00:00Z&quot;,&quot;type&quot;:&quot;article&quot;,&quot;title&quot;:&quot;Catskill Home Prices: How Low Will They Go?&quot;},\r\n    {&quot;date&quot;:&quot;2009-01-01T00:00:00Z&quot;,&quot;type&quot;:&quot;article&quot;,&quot;title&quot;:&quot;Ominous Cutbacks At Chanel&quot;}]\r\n    [] \r\n\r\nHow do I get rid of the empty array? My solution right now is to pipe the output back into jq, but that feels really suboptimal. So this works:\r\n\r\n    jq -c \\\r\n    &#39;[.response.docs[] | {date: .pub_date, type: .document_type, title: .headline.main }]&#39; | \\\r\n    &lt; myjsonfile.json | \r\n    jq &#39;if length &gt; 0 then . else empty end&#39;\r\n\r\nBut that feels ugly. Is there a nicer way of doing this?",
        "link": "https://stackoverflow.com/questions/26195214/how-to-nicely-remove-empty-array-in-jq",
        "title": "How to nicely remove empty array in jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1412891601,
                "post_id": 26287130,
                "comment_id": 41248451,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 400321,
                    "reputation": 4900,
                    "user_id": 766233,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/6b427ecaae0d8045fc140ca8997590bd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jcalfee314",
                    "link": "https://stackoverflow.com/users/766233/jcalfee314"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1412898128,
                "post_id": 26287130,
                "comment_id": 41250441,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 55,
                "is_accepted": true,
                "score": 54,
                "last_activity_date": 1421612203,
                "last_edit_date": 1421612203,
                "creation_date": 1421544073,
                "answer_id": 28006220,
                "question_id": 26287130,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I was also trying to convert a bunch of lines into a JSON array, and was at a standstill until I realized that `-s` was the only way I could handle more than one line at a time in the `jq` expression, even if that meant I&#39;d have to parse the newlines manually.\r\n\r\n    jq -R -s -c &#39;split(&quot;\\n&quot;)&#39; &lt; just_lines.txt\r\n\r\n* `-R` to read raw input\r\n* `-s` to read all input as a single string\r\n* `-c` to not pretty print the output\r\n\r\nEasy peasy.\r\n\r\nEdit: I&#39;m on `jq` ≥ 1.4, which is apparently when the `split` built-in was introduced.",
                "title": "converting lines to json in bash"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1451829674,
                "last_edit_date": 1451829674,
                "creation_date": 1451827164,
                "answer_id": 34576956,
                "question_id": 26287130,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&lt;!-- language-all: none --&gt;\r\n\r\nYou can also use `jq -R .` to format each line as a JSON string and then `jq -s` (`--slurp`) to create an array for the input lines after parsing them as JSON:\r\n\r\n    $ printf %s\\\\n aa bb|jq -R .|jq -s .\r\n    [\r\n      &quot;aa&quot;,\r\n      &quot;bb&quot;\r\n    ]\r\n\r\nThe method in chbrown&#39;s answer adds an empty element to the end if the input ends with a linefeed, but you can use `printf %s &quot;$(cat)&quot;` to remove trailing linefeeds:\r\n\r\n    $ printf %s\\\\n aa bb|jq -R -s &#39;split(&quot;\\n&quot;)&#39;\r\n    [\r\n      &quot;aa&quot;,\r\n      &quot;bb&quot;,\r\n      &quot;&quot;\r\n    ]\r\n    $ printf %s\\\\n aa bb|printf %s &quot;$(cat)&quot;|jq -R -s &#39;split(&quot;\\n&quot;)&#39;\r\n    [\r\n      &quot;aa&quot;,\r\n      &quot;bb&quot;\r\n    ]\r\n\r\nIf the input lines don&#39;t contain ASCII control characters (which have to be escaped in strings in valid JSON), you can use `sed`:\r\n\r\n    $ printf %s\\\\n aa bb|sed &#39;s/[&quot;\\]/\\\\&amp;/g;s/.*/&quot;&amp;&quot;/;1s/^/[/;$s/$/]/;$!s/$/,/&#39;\r\n    [&quot;aa&quot;,\r\n    &quot;bb&quot;]\r\n",
                "title": "converting lines to json in bash"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1497392030,
                "last_edit_date": 1497392030,
                "creation_date": 1497045778,
                "answer_id": 44467288,
                "question_id": 26287130,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I found in the man page for jq and through experimentation what seems to me to be a simpler answer.\r\n\r\n    $ cat test_file.txt | jq -Rsc &#39;. / &quot;\\n&quot; - [&quot;&quot;]&#39;\r\n    [&quot;aa&quot;,&quot;bb&quot;]\r\n\r\nThe -R is to read without trying to parse json, the -s says to read all of the input as one string, and the -c is for one-line output - not necessary, but it&#39;s what I was looking for.\r\n\r\nThen in the string I pass to jq, the &#39;.&#39; says take the input as it is. The &#39;/ \\n&#39; says to divide the string (split it) on newlines. The &#39;- [&quot;&quot;]&#39; says to remove from the resulting array any empty strings (resulting from an extra newline at the end).\r\n\r\nIt&#39;s one line and without any complicated constructs, using just simple built in jq features.",
                "title": "converting lines to json in bash"
            },
            {
                "up_vote_count": 33,
                "is_accepted": false,
                "score": 33,
                "last_activity_date": 1537304030,
                "last_edit_date": 1537304030,
                "creation_date": 1502330343,
                "answer_id": 45603242,
                "question_id": 26287130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## --raw-input, then --slurp\n\nJust summarizing what the others have said in a hopefully quicker to understand form:\r\n\r\n    cat /etc/hosts  | jq  --raw-input .  | jq --slurp .\r\n\r\nwill return you:\r\n\r\n    [\r\n      &quot;fe00::0 ip6-localnet&quot;,\r\n      &quot;ff00::0 ip6-mcastprefix&quot;,\r\n      &quot;ff02::1 ip6-allnodes&quot;,\r\n      &quot;ff02::2 ip6-allrouters&quot;\r\n    ]\r\n\r\n**Explanation**\r\n\r\n     --raw-input/-R:\r\n\r\n           Don&#180;t parse the input as JSON. Instead, each line of text is passed\r\n           to  the  filter  as  a  string.  If combined with --slurp, then the\r\n           entire input is passed to the filter as a single long string.\r\n\r\n     --slurp/-s:\r\n\r\n           Instead of running the filter for each JSON object  in  the  input,\r\n           read  the entire input stream into a large array and run the filter\r\n           just once.",
                "title": "converting lines to json in bash"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1578024591,
                "last_edit_date": 1578024591,
                "creation_date": 1536853526,
                "answer_id": 52317320,
                "question_id": 26287130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update: If your jq has `inputs` you can simply write:\r\n\r\n    jq -nR [inputs] /etc/hosts \r\n\r\nto produce a JSON array of strings.  This avoids having to read the text file as a whole.",
                "title": "converting lines to json in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 41,
        "last_activity_date": 1578024591,
        "creation_date": 1412885405,
        "question_id": 26287130,
        "body_markdown": "I would like to convert a list into JSON array.  I&#39;m looking at `jq` for this but the examples are mostly about parsing JSON (not creating it).  It would be nice to know proper escaping will occur.  My list is single line elements so the new line will probably be the best delimiter.\r\n",
        "link": "https://stackoverflow.com/questions/26287130/converting-lines-to-json-in-bash",
        "title": "converting lines to json in bash"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1412933654,
                "last_edit_date": 1412933654,
                "creation_date": 1412933164,
                "answer_id": 26296095,
                "question_id": 26295285,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your json file is not valid at: `.dependencies.pkgMeta.version`.\r\n\r\nAfter fixing your json file, try this command:\r\n\r\n    jq &#39;\r\n      .dependencies |\r\n        to_entries |\r\n          map(.value |\r\n            {\r\n              name: .main.name,\r\n              c_version: .pkgMeta.version,\r\n              n_version: .update.latest\r\n            }\r\n          )&#39; input.json\r\n\r\n\r\n----------\r\n\r\nThe result is:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;plugin1name&quot;,\r\n        &quot;c_version&quot;: &quot;0.0.1&quot;,\r\n        &quot;n_version&quot;: &quot;0.0.5&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;plugin2name&quot;,\r\n        &quot;c_version&quot;: &quot;0.1.1&quot;,\r\n        &quot;n_version&quot;: &quot;0.1.5&quot;\r\n      }\r\n    ]",
                "title": "Get formatted data in shell script which is read from file containing JSON data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1412937438,
        "creation_date": 1412930537,
        "last_edit_date": 1412937438,
        "question_id": 26295285,
        "body_markdown": "Writting one shell script to automatically get list of name, current and latest available version from raw json data.\r\n\r\nI am trying to format JSON data stored in file using shell script. I tried using [JQ][1] command line JSON parser.\r\n\r\nI want to get formatted JSON data in script. Their is advanced option provided in JQ for same scenario. I am not able to use it properly.\r\n\r\nExample: File containing Following JSON\r\n\r\n\t{\r\n\t  &quot;endpoint&quot;: {\r\n\t\t&quot;name&quot;: &quot;test-plugin&quot;,\r\n\t\t&quot;version&quot;: &quot;0.0.1&quot;\r\n\t  },\r\n\t  &quot;dependencies&quot;: {\r\n\t\t&quot;plugin1&quot;: {\r\n\t\t  &quot;main&quot;: {\r\n\t\t    &quot;name&quot;: &quot;plugin1name&quot;,\r\n\t\t    &quot;description&quot;: &quot;Dummy text&quot;\r\n\t\t  },\r\n\t\t  &quot;pkgMeta&quot;: {\r\n\t\t    &quot;name&quot;: &quot;plugin1name&quot;,\r\n\t\t    &quot;version&quot;: &quot;0.0.1&quot;\r\n\t\t  },\r\n\t\t  &quot;dependencies&quot;: {},\r\n\t\t  &quot;versions&quot;: [\r\n\t\t    &quot;0.0.5&quot;,\r\n\t\t    &quot;0.0.4&quot;,\r\n\t\t    &quot;0.0.3&quot;,\r\n\t\t    &quot;0.0.2&quot;,\r\n\t\t    &quot;0.0.1&quot;\r\n\t\t  ],\r\n\t\t  &quot;update&quot;: {\r\n\t\t    &quot;latest&quot;: &quot;0.0.5&quot;\r\n\t\t  }\r\n\t\t},\r\n\t\t&quot;plugin2&quot;: {\r\n\t\t  &quot;main&quot;: {\r\n\t\t    &quot;name&quot;: &quot;plugin2name&quot;,\r\n\t\t    &quot;description&quot;: &quot;Dummy text&quot;\r\n\t\t  },\r\n\t\t  &quot;pkgMeta&quot;: {\r\n\t\t    &quot;name&quot;: &quot;plugin2name&quot;,\r\n\t\t    &quot;version&quot;: &quot;0.1.1&quot;\r\n\t\t  },\r\n\t\t  &quot;dependencies&quot;: {},\r\n\t\t  &quot;versions&quot;: [\r\n\t\t    &quot;0.1.5&quot;,\r\n\t\t    &quot;0.1.4&quot;,\r\n\t\t    &quot;0.1.3&quot;,\r\n\t\t    &quot;0.1.2&quot;,\r\n\t\t    &quot;0.1.1&quot;\r\n\t\t  ],\r\n\t\t  &quot;update&quot;: {\r\n\t\t    &quot;latest&quot;: &quot;0.1.5&quot;\r\n\t\t  }\r\n\t\t}\r\n\t\r\n\t   }\r\n\t}\r\n\r\nTrying to get result in format\r\n\r\n    [{name: &quot;plugin1name&quot;, \r\n        c_version: &quot;0.0.1&quot;, \r\n        n_version: &quot;0.0.5&quot;\r\n     },\r\n     {name: &quot;plugin2name&quot;, \r\n        c_version: &quot;0.1.1&quot;, \r\n        n_version: &quot;0.1.5&quot;}]\r\n\r\nCan someone suggest anything ?\r\n\r\n  [1]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/26295285/get-formatted-data-in-shell-script-which-is-read-from-file-containing-json-data",
        "title": "Get formatted data in shell script which is read from file containing JSON data"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 60064,
                    "reputation": 12969,
                    "user_id": 179529,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/yGraC.jpg?s=256",
                    "display_name": "Guy",
                    "link": "https://stackoverflow.com/users/179529/guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1413527055,
                "post_id": 26417153,
                "comment_id": 41484672,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5101772,
                    "reputation": 43,
                    "user_id": 4152101,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/T7Ej7.jpg?s=256",
                    "display_name": "hydrajump",
                    "link": "https://stackoverflow.com/users/4152101/hydrajump"
                },
                "reply_to_user": {
                    "account_id": 60064,
                    "reputation": 12969,
                    "user_id": 179529,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/yGraC.jpg?s=256",
                    "display_name": "Guy",
                    "link": "https://stackoverflow.com/users/179529/guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1413559467,
                "post_id": 26417153,
                "comment_id": 41501566,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 60064,
                    "reputation": 12969,
                    "user_id": 179529,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/yGraC.jpg?s=256",
                    "display_name": "Guy",
                    "link": "https://stackoverflow.com/users/179529/guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1413629928,
                "post_id": 26417153,
                "comment_id": 41521893,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1413605056,
                "last_edit_date": 1413605056,
                "creation_date": 1413525081,
                "answer_id": 26418643,
                "question_id": 26417153,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you&#39;re using the latest version where the `test` filter is implemented, you could do this:\r\n\r\n    .. | select(.DeviceName? | test(&quot;/dev/sd[bcd]&quot;)) | .Ebs.VolumeId\r\n\r\nOtherwise, you&#39;ll have to make some adjustments:\r\n\r\n    .. | select(.DeviceName? == (&quot;/dev/sdb&quot;,&quot;/dev/sdc&quot;,&quot;/dev/sdd&quot;)) | .Ebs.VolumeId",
                "title": "How to parse AWS CLI json output using jq to get array of volume-ids?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1413605056,
        "creation_date": 1413514377,
        "last_edit_date": 1592644375,
        "question_id": 26417153,
        "body_markdown": "I&#39;m using the AWS CLI to get the `BlockDeviceMappings` array for a specific instance like this,\n\n## awscli query\n\n    aws ec2 describe-instances --filters &quot;Name=tag:Name,Values=mongodb-*&quot; &quot;Name=private-ip-address,Values=$MEMBER_IP&quot; \\\n        --output json --query &quot;Reservations[*].Instances[*].BlockDeviceMappings[*]   \n\n**output**\n\n    [\n        [\n            [\n                {\n                    &quot;DeviceName&quot;: &quot;/dev/xvda&quot;, \n                    &quot;Ebs&quot;: {\n                        &quot;Status&quot;: &quot;attached&quot;, \n                        &quot;DeleteOnTermination&quot;: true, \n                        &quot;VolumeId&quot;: &quot;vol-xvda-xxx&quot;, \n                        &quot;AttachTime&quot;: &quot;2014-10-13T14:40:13.000Z&quot;\n                    }\n                }, \n                {\n                    &quot;DeviceName&quot;: &quot;/dev/sdb&quot;, \n                    &quot;Ebs&quot;: {\n                        &quot;Status&quot;: &quot;attached&quot;, \n                        &quot;DeleteOnTermination&quot;: false, \n                        &quot;VolumeId&quot;: &quot;vol-sdb-xxxx&quot;, \n                        &quot;AttachTime&quot;: &quot;2014-10-13T14:40:13.000Z&quot;\n                    }\n                }, \n                {\n                    &quot;DeviceName&quot;: &quot;/dev/sdc&quot;, \n                    &quot;Ebs&quot;: {\n                        &quot;Status&quot;: &quot;attached&quot;, \n                        &quot;DeleteOnTermination&quot;: false, \n                        &quot;VolumeId&quot;: &quot;vol-sdc-xxx&quot;, \n                        &quot;AttachTime&quot;: &quot;2014-10-13T14:40:13.000Z&quot;\n                    }\n                }, \n                {\n                    &quot;DeviceName&quot;: &quot;/dev/sdd&quot;, \n                    &quot;Ebs&quot;: {\n                        &quot;Status&quot;: &quot;attached&quot;, \n                        &quot;DeleteOnTermination&quot;: false, \n                        &quot;VolumeId&quot;: &quot;vol-sdd-xxx&quot;, \n                        &quot;AttachTime&quot;: &quot;2014-10-13T14:40:13.000Z&quot;\n                    }\n                }\n            ]\n        ]\n    ]\n\n**desired output**\n\nI want a list of the volume-ids for `/dev/sdb`, `/dev/sdc` and `/dev/sdd`, respectively.\n\n`vol-sdb-xxxxx, vol-sdc-xxxx, vol-sdd-xxxxx`\n\nI&#39;ve attempted to use `jq` to do the parsing by piping the aws-cli output to `jq`, but I keep getting &quot;jq: error: Cannot index array with string&quot;.\n\nAlso, it&#39;s possible that the `DeviceName` might not always come in the order that I can assume that the 2nd,3rd and 4th elements in the array are in the right order, so I&#39;d like to make sure that the desired output of volume-ids is always in the form: sdb, sdc, sdd if possible.\n\n## update 1\n\nAfter trying both of Jeff&#39;s suggestions:\n\n**suggestion 1**\n\n    aws ec2 describe-instances --filters &quot;Name=tag:Name,Values=mongodb-*&quot; &quot;Name=private-ip-address,Values=$MEMBER_IP&quot; --output json --query &quot;Reservations[*].Instances[*].BlockDeviceMappings[*]&quot; | jq &#39;select(.DeviceName? | test(&quot;/dev/sd[bcd]&quot;)) | .Ebs.VolumeId&#39;\n    error: test is not defined\n    select(.DeviceName? | test(&quot;/dev/sd[bcd]&quot;)) | .Ebs.VolumeId                      1 compile error\n    \n    [Errno 32] Broken pipe\n\n**suggestion 2**\n\n    aws ec2 describe-instances --filters &quot;Name=tag:Name,Values=mongodb-*&quot; &quot;Name=private-ip-address,Values=$MEMBER_IP&quot; --output json --query &quot;Reservations[*].Instances[*].BlockDeviceMappings[*]&quot; | jq &#39;select(  \n             .DeviceName? as $dn\n                 | [&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]\n                 | map($dn == &quot;/dev/sd\\(.)&quot;)\n                 | any\n         )\n       | .Ebs.VolumeId&#39;\n\nNo output\n\nI&#39;m using jq-1.4 which I believe is the latest.\n\n## update 2\n\nThe following works with jq-1.4,\n\n    aws ec2 describe-instances --filters &quot;Name=tag:Name,Values=mongodb-*&quot; &quot;Name=private-ip-address,Values=$MEMBER_IP&quot; --output json --query &quot;Reservations[*].Instances[*].BlockDeviceMappings[*]&quot; | jq &#39;.. | select(.DeviceName? as $dn | [&quot;b&quot;,&quot;c&quot;,&quot;d&quot;] | map($dn == &quot;/dev/sd\\(.)&quot;) | any) | .Ebs.VolumeId&#39;",
        "link": "https://stackoverflow.com/questions/26417153/how-to-parse-aws-cli-json-output-using-jq-to-get-array-of-volume-ids",
        "title": "How to parse AWS CLI json output using jq to get array of volume-ids?"
    },
    {
        "tags": [
            "json",
            "csv",
            "format",
            "extract",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1414122022,
                "creation_date": 1414122022,
                "answer_id": 26541109,
                "question_id": 26535102,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Sure it is:\r\n\r\n    .data | sort_by(.rank) | map(.displayName), map(.value) | @csv",
                "title": "Using jq to extract values and format in CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1414122022,
        "creation_date": 1414089809,
        "last_edit_date": 1414091871,
        "question_id": 26535102,
        "body_markdown": "I have the below json file:\r\n\r\n    {\r\n    &quot;data&quot;: [\r\n        {\r\n            &quot;displayName&quot;: &quot;First Name&quot;,\r\n            &quot;rank&quot;: 1,\r\n            &quot;value&quot;: &quot;VALUE&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;Last Name&quot;,\r\n            &quot;rank&quot;: 2,\r\n            &quot;value&quot;: &quot;VALUE&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;Position&quot;,\r\n            &quot;rank&quot;: 3,\r\n            &quot;value&quot;: &quot;VALUE&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;Company Name&quot;,\r\n            &quot;rank&quot;: 4,\r\n            &quot;value&quot;: &quot;VALUE&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;Country&quot;,\r\n            &quot;rank&quot;: 5,\r\n            &quot;value&quot;: &quot;VALUE&quot;\r\n        },\r\n    ]\r\n    }\r\n\r\nI would like to have a CSV file in this format:\r\n\r\n`First Name, Last Name, Position, Company Name, Country`\r\n\r\n`VALUE, VALUE, VALUE, VALUE, VALUE, VALUE`\r\n\r\nIs this possible by using only jq? I don&#39;t have any programming and/or great command-line skills.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/26535102/using-jq-to-extract-values-and-format-in-csv",
        "title": "Using jq to extract values and format in CSV"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5179771,
                    "reputation": 47,
                    "user_id": 4145807,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/462ecd7f893df6454ffab2f88c479554?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Marco Giusti",
                    "link": "https://stackoverflow.com/users/4145807/marco-giusti"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1414137132,
                "post_id": 26543318,
                "comment_id": 41710973,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1414680838,
                "creation_date": 1414680838,
                "answer_id": 26656259,
                "question_id": 26543318,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Resolved with PERL:\r\n\r\n\r\n    use JSON qw( decode_json );\r\n\r\n    sub creatab{\r\n    my $json = $dump; #dump from the AWS CLI\r\n    my $decoded = decode_json($json);\r\n    \r\n    my @secgrp = @{ $decoded-&gt;{&#39;SecurityGroups&#39;} };\r\n    foreach my $f ( @secgrp ) {\r\n     $description=$f-&gt;{&quot;Description&quot;};\r\n     $groupname=$f-&gt;{&quot;GroupName&quot;};\r\n     $vpcid=$f-&gt;{&quot;VpcId&quot;}; if ($vpcid eq &quot;&quot;) {$vpcid = &quot;EC2&quot;}\r\n     $groupid=$f-&gt;{&quot;GroupId&quot;};\r\n    \r\n    #------INBOUND RULES------------------------\r\n     my @ipperm = @{ $f-&gt;{&#39;IpPermissions&#39;} };\r\n     foreach my $g ( @ipperm ) {\r\n      $toport=$g-&gt;{&#39;ToPort&#39;};\r\n      $fromport=$g-&gt;{&#39;FromPort&#39;};\r\n      $proto=$g-&gt;{&#39;IpProtocol&#39;};\r\n    \r\n      my @cidr = @{ $g-&gt;{&#39;IpRanges&#39;} };\r\n      foreach my $h ( @cidr ) {\r\n       $cidr=$h-&gt;{&#39;CidrIp&#39;};\r\n        if ($proto==-1) {$fromport=&quot;ALLPORTS&quot;; $toport=&quot;ALLPORTS&quot;; $proto=&quot;ALLPROTO&quot;;}\r\n        $tabella .= &quot;$groupid|$groupname|$description|$vpcid|INBOUND|$cidr|$fromport|$toport|$proto\\n&quot;;\r\n      }\r\n    \r\n      my @useridgrouppairs = @{ $g-&gt;{&#39;UserIdGroupPairs&#39;} };\r\n      foreach my $h ( @useridgrouppairs ) {\r\n       $useridgrouppairs=$h-&gt;{&#39;GroupId&#39;};\r\n        if ($proto==-1) {$fromport=&quot;ALLPORTS&quot;; $toport=&quot;ALLPORTS&quot;; $proto=&quot;ALLPROTO&quot;;}\r\n        $tabella .= &quot;$groupid|$groupname|$description|$vpcid|INBOUND|$useridgrouppairs|$fromport|$toport|$proto\\n&quot;;\r\n      }\r\n     }\r\n    #-------------------------------------------\r\n    #-------------OUTBOUND RULES----------------\r\n     my @ipperm = @{ $f-&gt;{&#39;IpPermissionsEgress&#39;} };\r\n     foreach my $g ( @ipperm ) {\r\n      $toport=$g-&gt;{&#39;ToPort&#39;};\r\n      $fromport=$g-&gt;{&#39;FromPort&#39;};\r\n      $proto=$g-&gt;{&#39;IpProtocol&#39;};\r\n    \r\n      my @cidr = @{ $g-&gt;{&#39;IpRanges&#39;} };\r\n      foreach my $h ( @cidr ) {\r\n       $cidr=$h-&gt;{&#39;CidrIp&#39;};\r\n        if ($proto==-1) {$fromport=&quot;ALLPORTS&quot;; $toport=&quot;ALLPORTS&quot;; $proto=&quot;ALLPROTO&quot;;}\r\n        $tabella .= &quot;$groupid|$groupname|$description|$vpcid|OUTBOUND|$cidr|$fromport|$toport|$proto\\n&quot;;\r\n      }\r\n    \r\n      my @useridgrouppairs = @{ $g-&gt;{&#39;UserIdGroupPairs&#39;} };\r\n      foreach my $h ( @useridgrouppairs ) {\r\n       $useridgrouppairs=$h-&gt;{&#39;GroupId&#39;};\r\n        if ($proto==-1) {$fromport=&quot;ALLPORTS&quot;; $toport=&quot;ALLPORTS&quot;; $proto=&quot;ALLPROTO&quot;;}\r\n        $tabella .= &quot;$groupid|$groupname|$description|$vpcid|OUTBOUND|$useridgrouppairs|$fromport|$toport|$proto\\n&quot;;\r\n      }\r\n     }\r\n    #------------------------------------------\r\n    }\r\n    return $tabella;\r\n    }\r\n\r\n",
                "title": "Parse aws cli output security groups with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502853927,
                "creation_date": 1502853927,
                "answer_id": 45704642,
                "question_id": 26543318,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq solution\r\n\r\n    def ports:\r\n       if .IpProtocol == &quot;-1&quot;\r\n       then {FromPort:&quot;ALLPORTS&quot;, ToPort:&quot;ALLPORTS&quot;, IpProtocol:&quot;ALLPROTO&quot;}\r\n       else {FromPort, ToPort, IpProtocol}\r\n       end\r\n    ;\r\n\r\n    def tabella($g; $p; $dir; $ip):\r\n        [ $g.GroupId, $g.GroupName, $g.Description, $g.VpcId, $dir, $ip,\r\n          $p.FromPort, $p.ToPort, $p.IpProtocol ]\r\n    ;\r\n\r\n    def creatab:\r\n          .SecurityGroups[]\r\n        | { GroupId, GroupName, Description, VpcId } as $g\r\n        | (\r\n              .IpPermissions[]\r\n            | ports as $p\r\n            | ( .IpRanges[]         | tabella($g; $p; &quot;INBOUND&quot;; .CidrIp) ),\r\n              ( .UserIdGroupPairs[] | tabella($g; $p; &quot;INBOUND&quot;; .GroupId) )\r\n          ),\r\n          (\r\n              .IpPermissionsEgress[]\r\n            | ports as $p\r\n            | ( .IpRanges[]         | tabella($g; $p; &quot;OUTBOUND&quot;; .CidrIp) ),\r\n              ( .UserIdGroupPairs[] | tabella($g; $p; &quot;OUTBOUND&quot;; .GroupId) )\r\n          )\r\n    ;\r\n\r\n      creatab\r\n    | map(tostring)\r\n    | join(&quot;|&quot;)\r\n\r\nwhen run as \r\n\r\n    jq -M -r -f filter.jq data.json\r\n    \r\nit will produce the same output as [Marco&#39;s perl solution](https://stackoverflow.com/a/26656259/8379597)\r\n    \r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|10.12.0.0/16|3389|3389|tcp\r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|192.168.10.10/32|3389|3389|tcp\r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|192.168.10.10/32|5666|5666|tcp\r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|sg-00000001|ALLPORTS|ALLPORTS|ALLPROTO\r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|sg-000000001|ALLPORTS|ALLPORTS|ALLPROTO\r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|10.12.0.0/16|-1|-1|icmp\r\n    sg-000000001|server-db|server-db|vpc-0000001|INBOUND|192.168.10.10/32|-1|-1|icmp\r\n    sg-000000001|server-db|server-db|vpc-0000001|OUTBOUND|0.0.0.0/0|ALLPORTS|ALLPORTS|ALLPROTO\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|sg-00000001|ALLPORTS|ALLPORTS|ALLPROTO\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|10.12.0.0/16|22|22|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.10.10/32|22|22|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|10.12.0.0/16|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.60.10/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.160.10/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.130.10/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.130.50/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.130.150/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.10.10/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.80.150/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.80.152/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.80.155/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.80.158/32|443|443|tcp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|sg-00000002|ALLPORTS|ALLPORTS|ALLPROTO\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|10.12.0.0/16|-1|-1|icmp\r\n    sg-00000001|server-as|server-as|vpc-00000001|INBOUND|192.168.10.10/32|-1|-1|icmp\r\n    sg-00000001|server-as|server-as|vpc-00000001|OUTBOUND|0.0.0.0/0|ALLPORTS|ALLPORTS|ALLPROTO\r\n",
                "title": "Parse aws cli output security groups with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1502853927,
        "creation_date": 1414135620,
        "question_id": 26543318,
        "body_markdown": "IM gettin&#39; crazy using &quot;JQ&quot; for parse a json output from the AWS CLI.\r\n\r\nMaybe i have not yet understand how to use JQ properly, but id like to parse 2 (or more) security groups having one string formatted for every rule, both inbound and outbound\r\n\r\nThe command AWS CLI is about this:&lt;br&gt;\r\n\r\n    aws ec2 describe-security-groups --group-ids sg-0000001 sg-0000002\r\n\r\nAnd the output json is about this (i have random edited some infos for privacy):\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;IpPermissionsEgress&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ],\r\n                &quot;Description&quot;: &quot;server-db&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;server-db&quot;,\r\n                        &quot;Key&quot;: &quot;Client&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;server-db&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;ToPort&quot;: 3389,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.12.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.10.10/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;FromPort&quot;: 3389\r\n                    },\r\n                    {\r\n                        &quot;ToPort&quot;: 5666,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.10.10/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;FromPort&quot;: 5666\r\n                    },\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: [\r\n                            {\r\n                                &quot;UserId&quot;: &quot;121211212121&quot;,\r\n                                &quot;GroupId&quot;: &quot;sg-00000001&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: [\r\n                            {\r\n                                &quot;UserId&quot;: &quot;121211212121&quot;,\r\n                                &quot;GroupId&quot;: &quot;sg-000000001&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;ToPort&quot;: -1,\r\n                        &quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.12.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.10.10/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;FromPort&quot;: -1\r\n                    }\r\n                ],\r\n                &quot;GroupName&quot;: &quot;server-db&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-0000001&quot;,\r\n                &quot;OwnerId&quot;: &quot;121211212121&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-000000001&quot;\r\n            },\r\n            {\r\n                &quot;IpPermissionsEgress&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ],\r\n                &quot;Description&quot;: &quot;server-as&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;server-as&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;server&quot;,\r\n                        &quot;Key&quot;: &quot;Client&quot;\r\n                    }\r\n                ],\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: [\r\n                            {\r\n                                &quot;UserId&quot;: &quot;121211212121&quot;,\r\n                                &quot;GroupId&quot;: &quot;sg-00000001&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;ToPort&quot;: 22,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.12.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.10.10/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;FromPort&quot;: 22\r\n                    },\r\n                    {\r\n                        &quot;ToPort&quot;: 443,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.12.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.60.10/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.160.10/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.130.10/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.130.50/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.130.150/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.10.10/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.80.150/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.80.152/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.80.155/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.80.158/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;FromPort&quot;: 443\r\n                    },\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: [\r\n                            {\r\n                                &quot;UserId&quot;: &quot;121211212121&quot;,\r\n                                &quot;GroupId&quot;: &quot;sg-00000002&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;ToPort&quot;: -1,\r\n                        &quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.12.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;192.168.10.10/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;FromPort&quot;: -1\r\n                    }\r\n                ],\r\n                &quot;GroupName&quot;: &quot;server-as&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-00000001&quot;,\r\n                &quot;OwnerId&quot;: &quot;121211212121&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-00000001&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nThe format that id like to have could be something as:\r\n\r\n    SecurityGroupId - GroupName - InBound/OutBound - IpProtocol - Port - SourceRanges/DestinationRanges\r\n\r\nAnyOne could help me?\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/26543318/parse-aws-cli-output-security-groups-with-jq",
        "title": "Parse aws cli output security groups with JQ"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 246521,
                    "reputation": 931,
                    "user_id": 520720,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/9IX0J.jpg?s=256",
                    "display_name": "theGrayFox",
                    "link": "https://stackoverflow.com/users/520720/thegrayfox"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1414630567,
                "post_id": 26642231,
                "comment_id": 41893059,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1414631001,
                "post_id": 26642231,
                "comment_id": 41893163,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 501236,
                    "reputation": 1,
                    "user_id": 1002260,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://www.gravatar.com/avatar/5ec9c21c8d54825b04def7a41998d18d?s=256&d=identicon&r=PG",
                    "display_name": "Zombo",
                    "link": "https://stackoverflow.com/users/1002260/zombo"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1414631423,
                "post_id": 26642231,
                "comment_id": 41893251,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1414631508,
                "post_id": 26642231,
                "comment_id": 41893275,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1414629660,
                "last_edit_date": 1414629660,
                "creation_date": 1414628758,
                "answer_id": 26643026,
                "question_id": 26642231,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have not escaped the `$v`, so Bash thinks it is a Bash variable, probably an empty one.\r\nTry this\r\n\r\n    &quot;.[\\&quot;\\\\(\\$v)\\&quot;]&quot;\r\n    #       ^\r\n    #       |\r\n    #       --- notice\r\n\r\nIn my opinion, it is better in this situation to use use `--arg` with single quotes. `--arg` was implemented similar to awk `-v`, to fix exactly this type of situation with quoting headaches.",
                "title": "Interpolating Strings Using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1414631681,
                "creation_date": 1414631681,
                "answer_id": 26643436,
                "question_id": 26642231,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt;  I noticed that this works, but I&#39;m skeptical about how it&#39;s interpolating $v within the single quotes.\r\n\r\nSingle quotes **don&#39;t** interpolate variables or evaluate anything else.\r\n\r\n**Nothing** is magical within single quotes. You can&#39;t even escape single quotes within single quotes.\r\n\r\nThe quoting/escaping problem you are having exists only because you are attempting to use double quotes instead of single quotes here.",
                "title": "Interpolating Strings Using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1414631681,
        "creation_date": 1414624139,
        "last_edit_date": 1414627677,
        "question_id": 26642231,
        "body_markdown": "I&#39;m using jq to parse JSON data and pull out a value based on a dynamic key value given as a command line argument. I noticed that this works, but I&#39;m skeptical about how it&#39;s interpolating ```$v``` within the single quotes. Is it possible to rewrite the expression ```&#39;.[&quot;\\($v)&quot;]&#39;``` within double quotes? What am I doing wrong?\r\n\r\n\r\nTrying the following doesn&#39;t work for whatever reason:\r\n\r\n```recipe_url=$(cat ./*.json | jq -r --arg v &quot;$recipe_key&quot; &quot;.[\\&quot;\\\\($v)\\&quot;]&quot;)```\r\n\r\n\r\nHowever, this does:\r\n\r\n\r\n    recipe_key=&#39;Wilted Greens&#39; # example key to interpolate\r\n\r\n    recipe_url=$(cat ./*.json | jq -r --arg v &quot;$recipe_key&quot; &#39;.[&quot;\\($v)&quot;]&#39;) # works!\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/26642231/interpolating-strings-using-jq",
        "title": "Interpolating Strings Using jq"
    },
    {
        "tags": [
            "jq",
            "songkick"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1414979926,
                "last_edit_date": 1414979926,
                "creation_date": 1414722503,
                "answer_id": 26666655,
                "question_id": 26666120,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This filter should work:\r\n\r\n    .resultsPage.results.event | map(\r\n        {\r\n            venue_name: .venue.displayName,\r\n            start_date: .start.date\r\n        }\r\n        +\r\n        (.performance[].artist | {\r\n            artist_mbid: .identifier[].mbid,\r\n            artist_name: .displayName\r\n        })\r\n    )\r\n\r\nThough the fields aren&#39;t in the same order, but you could always reorder if needed:\r\n\r\n    [\r\n      {\r\n        &quot;venue_name&quot;: &quot;Live At The Star&quot;,\r\n        &quot;start_date&quot;: &quot;2014-10-28&quot;,\r\n        &quot;artist_mbid&quot;: &quot;08e5954e-efc0-4a95-95ac-d74cca5b79ff&quot;,\r\n        &quot;artist_name&quot;: &quot;James Keelaghan&quot;\r\n      },\r\n      {\r\n        &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n        &quot;start_date&quot;: &quot;2014-10-28&quot;,\r\n        &quot;artist_mbid&quot;: &quot;2df30b6c-997d-4c3f-abb5-5e0d6317ea57&quot;,\r\n        &quot;artist_name&quot;: &quot;Katy B&quot;\r\n      },\r\n      {\r\n        &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n        &quot;start_date&quot;: &quot;2014-10-28&quot;,\r\n        &quot;artist_mbid&quot;: &quot;27bc6f5b-4585-49ab-8d7d-c62b59f5f010&quot;,\r\n        &quot;artist_name&quot;: &quot;Becky Hill&quot;\r\n      }\r\n    ]\r\n\r\nYou&#39;re trying to create an object for every corresponding `performance` so you&#39;ll have to flatten it down a bit before you start collecting results.",
                "title": "How can I flatten this object stream without creating duplicate objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1414979926,
        "creation_date": 1414718379,
        "question_id": 26666120,
        "body_markdown": "I want to use a relational database to analyze information from Songkick&#39;s [JSON API for local events](http://www.songkick.com/developer/upcoming-events-for-metro-area).\r\n\r\nThe event objects in are complex and deeply nested, so I want to filter and flatten the event objects and convert them to CSV so I can load them with standard tools.\r\n\r\nCan I use jq to filter and flatten the events?\r\n\r\nA typical response from the API is too large to show here. I will show a simplified version with the same relative structure.\r\n\r\nApplying the filter `.resultsPage.results.event[]` to the response produces a stream of event objects like this.\r\n\r\n    {\r\n      &quot;start&quot;: {\r\n        &quot;date&quot;: &quot;2014-10-28&quot;\r\n      },\r\n      &quot;performance&quot;: [\r\n        {\r\n          &quot;artist&quot;: {\r\n            &quot;displayName&quot;: &quot;James Keelaghan&quot;,\r\n            &quot;identifier&quot;: [\r\n              {\r\n                &quot;mbid&quot;: &quot;08e5954e-efc0-4a95-95ac-d74cca5b79ff&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ],\r\n      &quot;venue&quot;: {\r\n        &quot;displayName&quot;: &quot;Live At The Star&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;start&quot;: {\r\n        &quot;date&quot;: &quot;2014-10-28&quot;\r\n      },\r\n      &quot;performance&quot;: [\r\n        {\r\n          &quot;artist&quot;: {\r\n            &quot;displayName&quot;: &quot;Katy B&quot;,\r\n            &quot;identifier&quot;: [\r\n              {\r\n                &quot;mbid&quot;: &quot;2df30b6c-997d-4c3f-abb5-5e0d6317ea57&quot;\r\n              }\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;artist&quot;: {\r\n            &quot;displayName&quot;: &quot;Becky Hill&quot;,\r\n            &quot;identifier&quot;: [\r\n              {\r\n                &quot;mbid&quot;: &quot;27bc6f5b-4585-49ab-8d7d-c62b59f5f010&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ],\r\n      &quot;venue&quot;: {\r\n        &quot;displayName&quot;: &quot;O2 ABC&quot;\r\n        }\r\n    }\r\n\r\nNext I want to produce one output object for each object in the performance list. These new objects should have attributes from the containing event object, such as date and venue.\r\n\r\nThe correct output for the example would look like this.\r\n\r\n    {\r\n      &quot;venue_name&quot;: &quot;Live At The Star&quot;,\r\n      &quot;artist_mbid&quot;: &quot;08e5954e-efc0-4a95-95ac-d74cca5b79ff&quot;,\r\n      &quot;artist_name&quot;: &quot;James Keelaghan&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_mbid&quot;: &quot;2df30b6c-997d-4c3f-abb5-5e0d6317ea57&quot;,\r\n      &quot;artist_name&quot;: &quot;Katy B&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_mbid&quot;: &quot;2df30b6c-997d-4c3f-abb5-5e0d6317ea57&quot;,\r\n      &quot;artist_name&quot;: &quot;Becky Hill&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n\r\nIf I ignore the mbid, this jq filter gives me what I want.\r\n\r\n    {\r\n      start_date: .start.date,\r\n      artist_name: .performance[].artist.displayName,\r\n      venue_name: .venue.displayName\r\n    }\r\n\r\nThe result looks like this.\r\n\r\n    {\r\n      &quot;venue_name&quot;: &quot;Live At The Star&quot;,\r\n      &quot;artist_name&quot;: &quot;James Keelaghan&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_name&quot;: &quot;Katy B&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_name&quot;: &quot;Becky Hill&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n\r\nI tried this filter to get the mbid as well.\r\n\r\n    {\r\n      start_date: .start.date,\r\n      artist_name: .performance[].artist.displayName,\r\n      artist_mbid: .performance[].artist.identifier[].mbid,\r\n      venue_name: .venue.displayName\r\n    }\r\n\r\nThe result looks like this.\r\n\r\n    {\r\n      &quot;venue_name&quot;: &quot;Live At The Star&quot;,\r\n      &quot;artist_mbid&quot;: &quot;08e5954e-efc0-4a95-95ac-d74cca5b79ff&quot;,\r\n      &quot;artist_name&quot;: &quot;James Keelaghan&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_mbid&quot;: &quot;2df30b6c-997d-4c3f-abb5-5e0d6317ea57&quot;,\r\n      &quot;artist_name&quot;: &quot;Katy B&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_mbid&quot;: &quot;27bc6f5b-4585-49ab-8d7d-c62b59f5f010&quot;,\r\n      &quot;artist_name&quot;: &quot;Katy B&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_mbid&quot;: &quot;2df30b6c-997d-4c3f-abb5-5e0d6317ea57&quot;,\r\n      &quot;artist_name&quot;: &quot;Becky Hill&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n    {\r\n      &quot;venue_name&quot;: &quot;O2 ABC&quot;,\r\n      &quot;artist_mbid&quot;: &quot;27bc6f5b-4585-49ab-8d7d-c62b59f5f010&quot;,\r\n      &quot;artist_name&quot;: &quot;Becky Hill&quot;,\r\n      &quot;start_date&quot;: &quot;2014-10-28&quot;\r\n    }\r\n\r\nEach object looks right, but there are too many of them! The &quot;Katy B&quot;\r\nand &quot;Becky Hill&quot; objects are duplicated.\r\n\r\nWhat is the correct way to do this in jq?\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/26666120/how-can-i-flatten-this-object-stream-without-creating-duplicate-objects",
        "title": "How can I flatten this object stream without creating duplicate objects?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq",
            "negation"
        ],
        "answers": [
            {
                "up_vote_count": 745,
                "is_accepted": true,
                "score": 745,
                "last_activity_date": 1473244191,
                "last_edit_date": 1495540976,
                "creation_date": 1414947091,
                "answer_id": 26701851,
                "question_id": 26701538,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Very close! In your `select` expression, you have to use a pipe (`|`) before `contains`.\r\n\r\nThis filter produces the expected output.\r\n\r\n    . - map(select(.Names[] | contains (&quot;data&quot;))) | .[] .Id\r\n\r\nThe [jq Cookbook](https://github.com/stedolan/jq/wiki/Cookbook#filter-objects-based-on-the-contents-of-a-key) has an example of the syntax.\r\n\r\n&gt; # Filter objects based on the contents of a key\r\n&gt; \r\n&gt; E.g., I only want objects whose genre key contains &quot;house&quot;.\r\n&gt; \r\n&gt;     $ json=&#39;[{&quot;genre&quot;:&quot;deep house&quot;}, {&quot;genre&quot;: &quot;progressive house&quot;}, {&quot;genre&quot;: &quot;dubstep&quot;}]&#39;\r\n&gt;     $ echo &quot;$json&quot; | jq -c &#39;.[] | select(.genre | contains(&quot;house&quot;))&#39;\r\n&gt;     {&quot;genre&quot;:&quot;deep house&quot;}\r\n&gt;     {&quot;genre&quot;:&quot;progressive house&quot;}\r\n\r\n[Colin D](https://stackoverflow.com/questions/26701538/how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array-with-jq/26701851?noredirect=1#comment65634694_26701851) asks how to preserve the JSON structure of the array, so that the final output is a single JSON array rather than a stream of JSON objects.\r\n\r\nThe simplest way is to wrap the whole expression in an array constructor:\r\n\r\n    $ echo &quot;$json&quot; | jq -c &#39;[ .[] | select( .genre | contains(&quot;house&quot;)) ]&#39;\r\n    [{&quot;genre&quot;:&quot;deep house&quot;},{&quot;genre&quot;:&quot;progressive house&quot;}]\r\n\r\nYou can also use the map function:\r\n\r\n    $ echo &quot;$json&quot; | jq -c &#39;map(select(.genre | contains(&quot;house&quot;)))&#39;\r\n    [{&quot;genre&quot;:&quot;deep house&quot;},{&quot;genre&quot;:&quot;progressive house&quot;}]\r\n\r\nmap unpacks the input array, applies the filter to every element, and creates a new array. In other words, `map(f)` is equivalent to `[.[]|f]`.\r\n",
                "title": "jq: how to filter an array of objects based on values in an inner array?"
            },
            {
                "up_vote_count": 39,
                "is_accepted": false,
                "score": 39,
                "last_activity_date": 1616841513,
                "last_edit_date": 1616841513,
                "creation_date": 1504140804,
                "answer_id": 45971669,
                "question_id": 26701538,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is another solution which uses [any/2](https://stedolan.github.io/jq/manual/#any,any\\(condition\\),any\\(generator;condition\\))\r\n\r\n    map(select(any(.Names[]; contains(&quot;data&quot;))|not)|.Id)[]\r\n\r\nwith the sample data and the `-r` option it produces:\r\n\r\n    cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b\r\n    a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19\r\n",
                "title": "jq: how to filter an array of objects based on values in an inner array?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1683643888,
                "creation_date": 1683643888,
                "answer_id": 76210639,
                "question_id": 26701538,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following jq map select expression produces the intended outcome:\r\n\r\n    aws ecr describe-images \\\r\n      --registry-id &lt;aws_account_id&gt; \\\r\n      --repository-name &lt;ecr_repository_name&gt; \\\r\n      --region &lt;aws_region&gt; \\\r\n      --no-cli-pager \\\r\n      --filter tagStatus=TAGGED \\\r\n    | jq &#39;.imageDetails | map(select(.imageTags[] | contains (&quot;version_tag&quot;)))&#39; ",
                "title": "jq: how to filter an array of objects based on values in an inner array?"
            },
            {
                "up_vote_count": 17,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1694769871,
                "creation_date": 1694769871,
                "answer_id": 77111184,
                "question_id": 26701538,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter ([demo][1]):\r\n\r\n```jq\r\n.[] | select( [ .Names[] | contains(&quot;data&quot;) ] | any) | .Id\r\n```\r\n\r\nExplanation:\r\n\r\n- `.[]` unpacks the array so that we iterate over each element in the array\r\n- `select(&lt;condition&gt;)` keeps only those elements where the condition is satisfied. The condition is that at least one name in the `.Names` array of that element has the word `data` in it.\r\n  - `.Names[] | contains (&quot;data&quot;)` unpacks the `.Names` array of each element and checks whether each name contains the text `data`. At this point, we have an array of bools of the same length as a `.Names` array of that element.\r\n  -  ` [.Names[] | contains (&quot;data&quot;) ] | any` takes that array of bools and collapses it into a single boolean because the `any` function checks that at least one element in that array is `true`. The `select` uses this value as the condition effectively.\r\n- `.Id` plucks the `Id` attribute of the elements that came through.\r\n\r\n\r\n  [1]: https://jqplay.org/s/yp_Qy0X_5Xe",
                "title": "jq: how to filter an array of objects based on values in an inner array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -8,
                "last_activity_date": 1718382051,
                "creation_date": 1718382051,
                "answer_id": 78624045,
                "question_id": 26701538,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why complicate the things?\r\n\r\n```sh\r\n| jq | grep -E &#39;{|property_a|property_b|property_c|}&#39;\r\n```",
                "title": "jq: how to filter an array of objects based on values in an inner array?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 513,
        "last_activity_date": 1718382051,
        "creation_date": 1414945412,
        "last_edit_date": 1704381304,
        "question_id": 26701538,
        "body_markdown": "Given this input:\r\n\r\n    [\r\n      {\r\n        &quot;Id&quot;: &quot;cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b&quot;,\r\n        &quot;Names&quot;: [\r\n          &quot;condescending_jones&quot;,\r\n          &quot;loving_hoover&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;186db739b7509eb0114a09e14bcd16bf637019860d23c4fc20e98cbe068b55aa&quot;,\r\n        &quot;Names&quot;: [\r\n          &quot;foo_data&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19&quot;,\r\n        &quot;Names&quot;: [\r\n          &quot;jovial_wozniak&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;76b71c496556912012c20dc3cbd37a54a1f05bffad3d5e92466900a003fbb623&quot;,\r\n        &quot;Names&quot;: [\r\n          &quot;bar_data&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;m trying to construct a filter with [jq](http://stedolan.github.io/jq/) that returns all objects with `Id`s that **do not** contain &quot;data&quot; in the inner `Names` array, with the output being newline-separated.  For the above data, the output I&#39;d like is:\r\n\r\n    cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b\r\n    a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19\r\n\r\nI think I&#39;m somewhat close with this:\r\n\r\n    (. - select(.Names[] contains(&quot;data&quot;))) | .[] .Id\r\n\r\nbut the `select` filter is not correct and it doesn&#39;t compile (get `error: syntax error, unexpected IDENT`).",
        "link": "https://stackoverflow.com/questions/26701538/jq-how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array",
        "title": "jq: how to filter an array of objects based on values in an inner array?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5242725,
                    "reputation": 409,
                    "user_id": 4189331,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9c1d7ec3809cb0fb914b53233db60687?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Evgenii",
                    "link": "https://stackoverflow.com/users/4189331/evgenii"
                },
                "reply_to_user": {
                    "account_id": 121840,
                    "reputation": 37173,
                    "user_id": 315228,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/g17T4.jpg?s=256",
                    "display_name": "SMA",
                    "link": "https://stackoverflow.com/users/315228/sma"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1415028347,
                "post_id": 26717277,
                "comment_id": 42024694,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 88014,
                    "reputation": 62614,
                    "user_id": 1178669,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/ef6112195affeb9801ef720a29b035e5?s=256&d=identicon&r=PG",
                    "display_name": "helpermethod",
                    "link": "https://stackoverflow.com/users/1178669/helpermethod"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1415028425,
                "post_id": 26717277,
                "comment_id": 42024746,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 37,
                "is_accepted": true,
                "score": 37,
                "last_activity_date": 1567577490,
                "last_edit_date": 1567577490,
                "creation_date": 1415028533,
                "answer_id": 26717401,
                "question_id": 26717277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want key and value, and based on [How do i convert a json object to key=value format in JQ](https://stackoverflow.com/a/25378171/1983854), you can do:\r\n\r\n    $ jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; file\r\n    SALUTATION=Hello world\r\n    SOMETHING=bla bla bla Mr. Freeman\r\n\r\nIn a more general way, you can store the values into an array `myarray[key] = value` like this, just by providing `jq` to the `while` with the `while ... do; ... done &lt; &lt;(command)` syntax:\r\n\r\n    declare -A myarray\r\n    while IFS=&quot;=&quot; read -r key value\r\n    do\r\n        myarray[$key]=&quot;$value&quot;\r\n    done &lt; &lt;(jq -r &#39;to_entries|map(&quot;(.key)=(.value)&quot;)|.[]&#39; file)\r\n\r\nAnd then you can loop through the values like this:\r\n\r\n    for key in &quot;${!myarray[@]}&quot;\r\n    do\r\n        echo &quot;$key = ${myarray[$key]}&quot;\r\n    done\r\n\r\nFor this given input, it returns:\r\n\r\n    SALUTATION = Hello world\r\n    SOMETHING = bla bla bla Mr. Freeman\r\n",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1530023853,
                "last_edit_date": 1530023853,
                "creation_date": 1479148978,
                "answer_id": 40595625,
                "question_id": 26717277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**&lt;I&gt;&lt;sub&gt;Context: This answer was written to be responsive to a question title which no longer exists.&lt;/sub&gt;&lt;/I&gt;**.\r\n\r\n---\r\n\r\nThe OP&#39;s question actually describes objects, vs arrays.\r\n\r\nTo be sure that we help other people coming in who are *actually* looking for help with JSON arrays, though, it&#39;s worth covering them explicitly.\r\n\r\n---\r\n\r\nFor the safe-ish case where strings can&#39;t contain newlines (and when bash 4.0 or newer is in use), this works:\r\n\r\n    str=&#39;[&quot;Hello world&quot;, &quot;bla bla bla Mr. Freeman&quot;]&#39;\r\n    readarray -t array &lt;&lt;&lt;&quot;$(jq -r &#39;.[]&#39; &lt;&lt;&lt;&quot;$str&quot;)&quot;\r\n\r\nTo support older versions of bash, and strings with newlines, we get a bit fancier, using a NUL-delimited stream to read from `jq`:\r\n\r\n    str=&#39;[&quot;Hello world&quot;, &quot;bla bla bla Mr. Freeman&quot;, &quot;this is\\ntwo lines&quot;]&#39;\r\n    array=( )\r\n    while IFS= read -r -d &#39;&#39; line; do\r\n      array+=( &quot;$line&quot; )\r\n    done &lt; &lt;(jq -j &#39;.[] | (. + &quot;\\u0000&quot;)&#39;)",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1509666567,
                "last_edit_date": 1509666567,
                "creation_date": 1509413027,
                "answer_id": 47026579,
                "question_id": 26717277,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is how can it be done recursively:\r\n\r\n    #!/bin/bash\r\n\r\n    SOURCE=&quot;$PWD&quot;\r\n    SETTINGS_FILE=&quot;$SOURCE/settings.json&quot;\r\n    SETTINGS_JSON=`cat &quot;$SETTINGS_FILE&quot;`\r\n\r\n    declare -A SETTINGS\r\n\r\n    function get_settings() {\r\n        local PARAMS=&quot;$#&quot;\r\n        local JSON=`jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; &lt;&lt;&lt; &quot;$1&quot;`\r\n        local KEYS=&#39;&#39;\r\n    \r\n        if [ $# -gt 1 ]; then\r\n            KEYS=&quot;$2&quot;\r\n        fi\r\n    \r\n        while read -r PAIR; do\r\n    \t\tlocal KEY=&#39;&#39;\r\n    \t\r\n            if [ -z &quot;$PAIR&quot; ]; then\r\n                break\r\n            fi\r\n    \r\n            IFS== read PAIR_KEY PAIR_VALUE &lt;&lt;&lt; &quot;$PAIR&quot;\r\n    \r\n            if [ -z &quot;$KEYS&quot; ]; then\r\n                KEY=&quot;$PAIR_KEY&quot;\r\n            else\r\n                KEY=&quot;$KEYS:$PAIR_KEY&quot;\r\n            fi\r\n    \r\n            if jq -e . &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt; &quot;$PAIR_VALUE&quot;; then\r\n                get_settings &quot;$PAIR_VALUE&quot; &quot;$KEY&quot;\r\n            else\r\n                SETTINGS[&quot;$KEY&quot;]=&quot;$PAIR_VALUE&quot;\r\n            fi\r\n        done &lt;&lt;&lt; &quot;$JSON&quot;\r\n    }\r\n\r\nTo call it:\r\n\r\n    get_settings &quot;$SETTINGS_JSON&quot;\r\n\r\nThe array will be accessed like so:\r\n\r\n    ${SETTINGS[grandparent:parent:child]}",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1525513145,
                "last_edit_date": 1525513145,
                "creation_date": 1525511922,
                "answer_id": 50187777,
                "question_id": 26717277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To load JSON object into a bash associative array efficiently (without using loops in bash), one can use tool &#39;jq&#39;, as follows. \r\n\r\n    # first, load the json text into a variable:\r\n    json=&#39;{&quot;SALUTATION&quot;: &quot;Hello world&quot;, &quot;SOMETHING&quot;: &quot;bla bla bla Mr. Freeman&quot;}&#39;\r\n\r\n    # then, prepare associative array, I use &#39;aa&#39;:\r\n\tunset aa\r\n\tdeclare -A aa\r\n\r\n\t# use jq to produce text defining name:value pairs in the bash format\r\n    # using @sh to properly escape the values\r\n\taacontent=$(jq -r &#39;. | to_entries | .[] | &quot;[\\&quot;&quot; + .key + &quot;\\&quot;]=&quot; + (.value | @sh)&#39; &lt;&lt;&lt; &quot;$json&quot;)\r\n\r\n\t# string containing whole definition of aa in bash\r\n\taadef=&quot;aa=($aacontent)&quot;\r\n\r\n\t# load the definition (because values may contain LF characters, aadef must be in double quotes)\r\n\teval &quot;$aadef&quot;\r\n\r\n    # now we can access the values like this: echo &quot;${aa[SOMETHING]}&quot;\r\n\r\n*Warning:* this uses eval, which is dangerous if the json input is from unknown source (may contain malicious shell commands that eval may execute).",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1666159037,
                "last_edit_date": 1666159037,
                "creation_date": 1533434444,
                "answer_id": 51690860,
                "question_id": 26717277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although this question is answered, I wasn&#39;t able to fully satiate my\r\nrequirements from the posted answer. Here is a little write up that&#39;ll help any\r\nbash-newcomers.\r\n\r\n# Foreknowledge\r\n\r\nA basic associative array declaration\r\n\r\n    #!/bin/bash\r\n\r\n    declare -A associativeArray=([key1]=val1 [key2]=val2)\r\n\r\nYou can also use quotes (`&#39;`, `&quot;`) around the `declaration`, its `keys`, and\r\n  `values`.\r\n\r\n    #!/bin/bash\r\n\r\n    declare -A &#39;associativeArray=([key1]=val1 [key2]=val2)&#39;\r\n\r\nAnd you can delimit each `[key]=value` pair via space or newline.\r\n\r\n    #!/bin/bash\r\n\r\n    declare -A associativeArray([key1]=value1\r\n      [&#39;key2&#39;]=value2 [key3]=&#39;value3&#39;\r\n      [&#39;key4&#39;]=&#39;value2&#39;               [&quot;key5&quot;]=&quot;value3&quot;\r\n\r\n\r\n      [&quot;key6&quot;]=&#39;value4&#39;\r\n      [&#39;key7&#39;]=&quot;value5&quot;\r\n    )\r\n\r\nDepending on your quote variation, you may need to escape your string.\r\n\r\n**Using Indirection to access both key and value in an associative array**\r\n\r\n    example () {\r\n      local -A associativeArray=([key1]=val1 [key2]=val2)\r\n\r\n      # print associative array\r\n      local key value\r\n      for key in &quot;${!associativeArray[@]}&quot;; do\r\n        value=&quot;${associativeArray[&quot;$key&quot;]}&quot;\r\n        printf &#39;%s = %s&#39; &quot;$key&quot; &quot;$value&quot;\r\n      done\r\n    }\r\n\r\nRunning the example function\r\n\r\n    $ example\r\n    key2 = val2\r\n    key1 = val1\r\n\r\nKnowing the aforementioned tidbits allows you to derive the following snippets:\r\n\r\n----------\r\n\r\nThe following examples will all have the result as the example above\r\n\r\n## String evaluation\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    example () {\r\n      local arrayAsString=&#39;associativeArray=([key1]=val1 [key2]=val2)&#39;\r\n      local -A &quot;$arrayAsString&quot;\r\n\r\n      # print associative array\r\n    }\r\n\r\n## Piping your JSON into JQ\r\n\r\n    #!/usr/bin/env bash\r\n    # Note: usage of single quotes instead of double quotes for the jq\r\n    #       filter. The former is preferred to avoid issues with shell \r\n    #       substitution of quoted strings.\r\n    example () {\r\n      # Given the following JSON\r\n      local json=&#39;{ &quot;key1&quot;: &quot;val1&quot;, &quot;key2&quot;: &quot;val2&quot; }&#39;\r\n\r\n      # filter using `map` &amp;&amp; `reduce`\r\n      local filter=&#39;to_entries | map(&quot;[\\(.key)]=\\(.value)&quot;) |\r\n        reduce .[] as $item (&quot;associativeArray=(&quot;; . + ($item|@sh) + &quot; &quot;) + &quot;)&quot;&#39;\r\n\r\n      # Declare and assign separately to avoid masking return values.\r\n      local arrayAsString;\r\n      # Note: no encompassing quotation (&quot;)\r\n      arrayAsString=$(jq --raw-output &quot;${filter}&quot; &lt;&lt;&lt; &quot;$json&quot;)\r\n      local -A &quot;$arrayAsString&quot;\r\n\r\n      # print associative array\r\n    }\r\n\r\n## jq -n / --null-input option + --argfile &amp;&amp; redirection\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    example () {\r\n      # /path/to/file.json contains the same json as the first two examples\r\n      local filter filename=&#39;/path/to/file.json&#39;\r\n\r\n      # including bash variable name in reduction\r\n      filter=&#39;to_entries | map(&quot;[\\(.key | @sh)]=\\(.value | @sh) &quot;)\r\n        | &quot;associativeArray=(&quot; + add + &quot;)&quot;&#39;\r\n\r\n      # using --argfile &amp;&amp; --null-input\r\n      local -A &quot;$(jq --raw-output --null-input --argfile file &quot;$filename&quot; \\\r\n        &quot;\\$filename | ${filter}&quot;)&quot;\r\n\r\n      # or for a more traceable declaration (using shellcheck or other) this\r\n      # variation moves the variable name outside of the string\r\n\r\n      # map definition &amp;&amp; reduce replacement\r\n      filter=&#39;[to_entries[]|&quot;[&quot;+(.key|@sh)+&quot;]=&quot;+(.value|@sh)]|&quot;(&quot;+join(&quot; &quot;)+&quot;)&quot;&#39;\r\n      \r\n      # input redirection &amp;&amp; --join-output\r\n      local -A associativeArray=$(jq --join-output &quot;${filter}&quot; &lt; &quot;${filename}&quot;)\r\n      \r\n      # print associative array\r\n    }\r\n\r\n----------\r\n\r\n## Reviewing previous answers\r\n\r\n**@J&#225;n Lalinsk&#253;**\r\n\r\n&gt; To load JSON object into a bash associative array efficiently\r\n  (without using loops in bash), one can use tool &#39;jq&#39;, as follows.\r\n&gt;\r\n&gt;     # first, load the json text into a variable:\r\n&gt;     json=&#39;{&quot;SALUTATION&quot;: &quot;Hello world&quot;, &quot;SOMETHING&quot;: &quot;bla bla bla Mr. Freeman&quot;}&#39;\r\n&gt;\r\n&gt;     # then, prepare associative array, I use &#39;aa&#39;:\r\n&gt;     unset aa\r\n&gt;     declare -A aa\r\n&gt;\r\n&gt;     # use jq to produce text defining name:value pairs in the bash format\r\n&gt;     # using @sh to properly escape the values\r\n&gt;     aacontent=$(jq -r &#39;. | to_entries | .[] | &quot;[\\&quot;&quot; + .key + &quot;\\&quot;]=&quot; + (.value | @sh)&#39; &lt;&lt;&lt; &quot;$json&quot;)\r\n&gt;\r\n&gt;     # string containing whole definition of aa in bash\r\n&gt;     aadef=&quot;aa=($aacontent)&quot;\r\n&gt;\r\n&gt;     # load the definition (because values may contain LF characters, aadef must be in double quotes)\r\n&gt;     eval &quot;$aadef&quot;\r\n&gt;\r\n&gt;     # now we can access the values like this: echo &quot;${aa[SOMETHING]}&quot;\r\n&gt;\r\n&gt; *Warning:* this uses eval, which is dangerous if the json input is from unknown source (may contain malicious shell commands that eval may execute).\r\n\r\nThis could be reduced to the following\r\n\r\n    example () {\r\n      local json=&#39;{ &quot;key1&quot;: &quot;val1&quot;, &quot;key2&quot;: &quot;val2&quot; }&#39;\r\n      local -A associativeArray=&quot;($(jq -r &#39;. | to_entries | .[] |\r\n        &quot;[\\&quot;&quot; + .key + &quot;\\&quot;]=&quot; + (.value | @sh)&#39; &lt;&lt;&lt; &quot;$json&quot;))&quot;\r\n\r\n      # print associative array\r\n    }\r\n\r\n**@fedorqui**\r\n\r\n&gt; If you want key and value, and based on [How do i convert a json object to key=value format in JQ](https://stackoverflow.com/a/25378171/1983854), you can do:\r\n&gt;\r\n&gt;     $ jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; file\r\n&gt;     SALUTATION=Hello world\r\n&gt;     SOMETHING=bla bla bla Mr. Freeman\r\n&gt;\r\n&gt; In a more general way, you can store the values into an array `myarray[key] = value` like this, just by providing `jq` to the `while` with the `while ... do; ... done &lt; &lt;(command)` syntax:\r\n&gt;\r\n&gt;     declare -A myarray\r\n&gt;     while IFS=&quot;=&quot; read -r key value\r\n&gt;     do\r\n&gt;         myarray[$key]=&quot;$value&quot;\r\n&gt;     done &lt; &lt;(jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value)\\&quot;)|.[]&quot; file)\r\n&gt;\r\n&gt; And then you can loop through the values like this:\r\n&gt;\r\n&gt;     for key in &quot;${!myarray[@]}&quot;\r\n&gt;     do\r\n&gt;         echo &quot;$key = ${myarray[$key]}&quot;\r\n&gt;     done\r\n&gt;\r\n&gt; For this given input, it returns:\r\n&gt;\r\n&gt;     SALUTATION = Hello world\r\n&gt;     SOMETHING = bla bla bla Mr. Freeman\r\n\r\nThe main difference between this solution and my own is looping through the\r\narray in bash or in jq.\r\n\r\nEach solution is valid and depending on your use case, one may be more useful\r\nthen the other.\r\n",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1606903609,
                "creation_date": 1606903609,
                "answer_id": 65105935,
                "question_id": 26717277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n**Solution**: use `jq`( it&#39;s a lightweight and flexible command-line JSON processor.).\r\n\r\nIn bash I&#39;d rather assign JSONs object to a variable and use `jq`  in order to access and parse the right result from it. It&#39;s more convenient than parse this structure with arrays and it comes out of the box with multiple functionalities and features such as accessing nested and complex objects, select methods, builtin operators and functions, regex support ,comparisons etc...\r\n\r\n**example**:\r\n\r\n    example=&#39;{&quot;SALUTATION&quot;: &quot;Hello world&quot;,&quot;SOMETHING&quot;: &quot;bla bla bla Mr. Freeman&quot;}&#39;\r\n    echo $example | jq .SOMETHING\r\n    \r\n    # output:\r\n    &quot;bla bla bla Mr. Freeman&quot;\r\n",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1627217712,
                "creation_date": 1627217712,
                "answer_id": 68518734,
                "question_id": 26717277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on @HelpNeeder&#39;s [solution][1] (nice one btw)\r\n\r\nHis solution wasn&#39;t really working with integers, so i made some additions. Extended amount of condition checks, so it&#39;s fair to say some performance is sacrificed. \r\n\r\nThis version works with integers and also floating point values. \r\n\r\n```\r\nSOURCE=&quot;$PWD&quot;\r\nSETTINGS_FILE=&quot;./test2.json&quot;\r\nSETTINGS_JSON=`cat &quot;$SETTINGS_FILE&quot;`\r\ndeclare -A SETTINGS\r\n\r\nget_settings() {\r\n    local PARAMS=&quot;$#&quot;\r\n  \r\n    local JSON=`jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; &lt;&lt;&lt; &quot;$1&quot;`\r\n    local KEYS=&#39;&#39;\r\n\r\n    if [ $# -gt 1 ]; then\r\n  \r\n        KEYS=&quot;$2&quot;\r\n    fi\r\n\r\n    while read -r PAIR; do\r\n        local KEY=&#39;&#39;\r\n\r\n        if [ -z &quot;$PAIR&quot; ]; then\r\n            break\r\n        fi\r\n\r\n        IFS== read PAIR_KEY PAIR_VALUE &lt;&lt;&lt; &quot;$PAIR&quot;\r\n\r\n        if [ -z &quot;$KEYS&quot; ]; then\r\n            KEY=&quot;$PAIR_KEY&quot;\r\n        else\r\n            KEY=&quot;$KEYS:$PAIR_KEY&quot;\r\n        fi\r\n                \r\n              \r\n                res=$(jq -e . 2&gt;/dev/null &lt;&lt;&lt; &quot;$PAIR_VALUE&quot;)\r\n                \r\n                exitCode=$?\r\n                check=`echo &quot;$PAIR_VALUE&quot; | grep -E ^\\-?[0-9]*\\.?[0-9]+$`\r\n          # if [ &quot;${res}&quot; ] &amp;&amp; [ $exitCode -eq &quot;0&quot; ] &amp;&amp; [[ ! &quot;${PAIR_VALUE}&quot; == ?(-)+([0-9]) ]]  ALTERNATIVE, works only for integer (not floating point)\r\n          if [ &quot;${res}&quot; ] &amp;&amp; [ $exitCode -eq &quot;0&quot; ] &amp;&amp; [[ &quot;$check&quot; == &#39;&#39; ]]\r\n            then\r\n                get_settings &quot;$PAIR_VALUE&quot; &quot;$KEY&quot;\r\n               else\r\n            SETTINGS[&quot;$KEY&quot;]=&quot;$PAIR_VALUE&quot;\r\n        fi\r\n           \r\n       \r\n\r\n    done &lt;&lt;&lt; &quot;$JSON&quot;\r\n}\r\nget_settings &quot;$SETTINGS_JSON&quot;\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/47026579/7204671",
                "title": "Accessing a JSON object in Bash - associative array / list / another model"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 33,
        "last_activity_date": 1666159037,
        "creation_date": 1415028072,
        "last_edit_date": 1606909991,
        "question_id": 26717277,
        "body_markdown": "I have a Bash script which gets data in JSON, I want to be able to **convert the JSON into an accessible structure** - array / list / or other model which would be easy to parse the nested data.\r\n\r\n**Example**:\r\n\r\n    {\r\n      &quot;SALUTATION&quot;: &quot;Hello world&quot;,\r\n      &quot;SOMETHING&quot;: &quot;bla bla bla Mr. Freeman&quot;\r\n    }\r\n\r\nI want to get the value like the following: `echo ${arr[SOMETHING]}`\r\n\r\n[ Different approach is optional as well. ] ",
        "link": "https://stackoverflow.com/questions/26717277/accessing-a-json-object-in-bash-associative-array-list-another-model",
        "title": "Accessing a JSON object in Bash - associative array / list / another model"
    },
    {
        "tags": [
            "javascript",
            "json",
            "filter",
            "geojson",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1415173116,
                "last_edit_date": 1415173116,
                "creation_date": 1415123804,
                "answer_id": 26741801,
                "question_id": 26741075,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq &#39; .. | select( has(&quot;properties&quot;) )? | select( .properties.MODE == &quot;D&quot;)&#39;`\r\n\r\nThe question mark tells jq to ignore errors. The .. is to recurse into the object\r\n\r\n\r\n\r\n`jq &#39;.features[] | select(.properties.MODE == &quot;D&quot;)&#39;`\r\n\r\nWill get you the results you are after without recursion just to note the differences in the methods\r\n\r\nfor reference: https://github.com/stedolan/jq/issues/610",
                "title": "Filtering GeoJSON with JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1415123812,
                "creation_date": 1415123812,
                "answer_id": 26741807,
                "question_id": 26741075,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re missing quite a lot.  You used `.[]` but what is that supposed to accomplish?  The `MODE` is a property of the `properties` object of a feature.\r\n\r\n    .features | map(select(.properties.MODE == &quot;D&quot;))",
                "title": "Filtering GeoJSON with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1415173116,
        "creation_date": 1415121235,
        "question_id": 26741075,
        "body_markdown": "Given this JSON\r\n\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;MODE&quot;: &quot;A&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -69.23583984375,\r\n              45.460130637921004\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;MODE&quot;: &quot;D&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -69.23651039600372,\r\n              45.46053888199693\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like to use [jq](https://stedolan.github.io/jq/) to filter through and select the `features` that possess the `MODE: D` property.  As far as I can tell, the query `jq .[] | select(.MODE == &quot;D&quot;)` should work, but it doesn&#39;t!\r\n\r\nWhat am I missing?\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/26741075/filtering-geojson-with-jq",
        "title": "Filtering GeoJSON with JQ"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "amazon-ec2",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1415311580,
                "post_id": 26789915,
                "comment_id": 42156602,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1415315346,
                "last_edit_date": 1415315346,
                "creation_date": 1415312532,
                "answer_id": 26790515,
                "question_id": 26789915,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I don&#39;t use AWS so I don&#39;t have much to go on but based off of the [`describe-instances`](http://docs.aws.amazon.com/cli/latest/reference/ec2/describe-instances.html) reference, I think this filter should work.\r\n\r\n    .Reservations[].Instances |\r\n        map(select(.Platform != &quot;Windows&quot;) | .NetworkInterfaces[].PrivateIpAddress)",
                "title": "aws ec2 cli + jq exclude results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1415315346,
        "creation_date": 1415310064,
        "question_id": 26789915,
        "body_markdown": "I&#39;m writing a bash script that needs to get the private ips of all instances where describe-instances does not return platform=&gt;windows, and store them in an array $ips\r\n\r\nThis script works so far (just getting the private ips)\r\n\r\n     ips=$(aws ec2 describe-instances --region $r --filters &quot;Name=tag:Name,Values=*$c*&quot; | jq &#39;.Reservations[].Instances[].NetworkInterfaces[].PrivateIpAddress&#39;)\r\n\r\nbut what I can&#39;t figure out is how to exclude windows servers (or, conversely, only include non-windows servers)\r\n\r\nHere&#39;s what I&#39;ve tried\r\n\r\n    --filters &quot;Name=tag:Name,Values=*$c*&quot; &quot;Name=platform,Values=&quot;\r\n    --filters &quot;Name=tag:Name,Values=*$c*&quot; &quot;Name=platform,Values=null&quot;\r\n    --filters &quot;Name=tag:Name,Values=*$c*&quot; &quot;Name=platform,Values=NULL&quot;\r\n\r\nI&#39;ve also tried doing it on the jq side of the pipe, but my attempts were ridiculous and I will not publish them here. I did find out you cannot do more than two filters on that side (unless I messed that up too)\r\n\r\nAny ideas?\r\n",
        "link": "https://stackoverflow.com/questions/26789915/aws-ec2-cli-jq-exclude-results",
        "title": "aws ec2 cli + jq exclude results"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1415390237,
                "creation_date": 1415390237,
                "answer_id": 26809124,
                "question_id": 26808855,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use:\r\n\r\n    X=(&quot;hello world&quot; &quot;goodnight moon&quot;)\r\n    sed &#39;s/^/[/; s/,$/]/&#39; &lt;(printf &#39;&quot;%s&quot;,&#39; &quot;${X[@]}&quot;) | jq -s &#39;.&#39;\r\n    [\r\n      [\r\n        &quot;hello world&quot;,\r\n        &quot;goodnight moon&quot;\r\n      ]\r\n    ]",
                "title": "How to format a bash array as a JSON array"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1415390843,
                "creation_date": 1415390843,
                "answer_id": 26809278,
                "question_id": 26808855,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This ...\r\n\r\n    X=(&quot;hello world&quot; &quot;goodnight moon&quot; &#39;say &quot;boo&quot;&#39; &#39;foo\\bar&#39;)\r\n\r\n    json_array() {\r\n      echo -n &#39;[&#39;\r\n      while [ $# -gt 0 ]; do\r\n        x=${1//\\\\/\\\\\\\\}\r\n        echo -n \\&quot;${x//\\&quot;/\\\\\\&quot;}\\&quot;\r\n        [ $# -gt 1 ] &amp;&amp; echo -n &#39;, &#39;\r\n        shift\r\n      done\r\n      echo &#39;]&#39;\r\n    }\r\n    \r\n    json_array &quot;${X[@]}&quot;\r\n\r\n... yields:\r\n\r\n    [&quot;hello world&quot;, &quot;goodnight moon&quot;, &quot;say \\&quot;boo\\&quot;&quot;, &quot;foo\\\\bar&quot;]\r\n\r\nIf you are planning to do a lot of this (as your reluctance to use a subshell suggests) then something such as this that does not rely on *any* subprocess is likely to your advantage.\r\n",
                "title": "How to format a bash array as a JSON array"
            },
            {
                "up_vote_count": 54,
                "is_accepted": false,
                "score": 54,
                "last_activity_date": 1415391419,
                "last_edit_date": 1415391419,
                "creation_date": 1415391020,
                "answer_id": 26809318,
                "question_id": 26808855,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can do this:\r\n\r\n    X=(&quot;hello world&quot; &quot;goodnight moon&quot;)\r\n    printf &#39;%s\\n&#39; &quot;${X[@]}&quot; | jq -R . | jq -s .\r\n    \r\n### output\r\n    [\r\n      &quot;hello world&quot;,\r\n      &quot;goodnight moon&quot;\r\n    ]",
                "title": "How to format a bash array as a JSON array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1451833540,
                "creation_date": 1451833540,
                "answer_id": 34577949,
                "question_id": 26808855,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&lt;!-- language-all: none --&gt;\r\n\r\nIf the values do not contain ASCII control characters, which have to be escaped in strings in valid JSON, you can also use `sed`:\r\n\r\n    $ X=(&quot;hello world&quot; &quot;goodnight moon&quot;)\r\n    $ printf %s\\\\n &quot;${X[@]}&quot;|sed &#39;s/[&quot;\\]/\\\\&amp;/g;s/.*/&quot;&amp;&quot;/;1s/^/[/;$s/$/]/;$!s/$/,/&#39;\r\n    [&quot;hello world&quot;,\r\n    &quot;goodnight moon&quot;]\r\n\r\nIf the values contain ASCII control characters, you can do something like this:\r\n\r\n    X=($&#39;a\\ta&#39; $&#39;a\\n\\\\\\&quot;&#39;)\r\n    for((i=0;i&lt;${#X[@]};i++));do\r\n      [ $i = 0 ]&amp;&amp;printf \\[\r\n      printf \\&quot;\r\n      e=${X[i]}\r\n      e=${e//\\\\/\\\\\\\\}\r\n      e=${e//\\&quot;/\\\\\\&quot;}\r\n      for((j=0;j&lt;${#e};j++));do\r\n        c=${e:j:1}\r\n        if [[ $c = [[:cntrl:]] ]];then\r\n          printf &#39;\\\\u%04x&#39; &quot;&#39;$c&quot;\r\n        else\r\n          printf %s &quot;$c&quot;\r\n        fi\r\n      done\r\n      printf \\&quot;\r\n      if((i&lt;=${#X[@]}-2));then\r\n        printf ,\r\n      else\r\n        printf \\]\r\n      fi\r\n    done\r\n",
                "title": "How to format a bash array as a JSON array"
            },
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1651149806,
                "last_edit_date": 1651149806,
                "creation_date": 1620744955,
                "answer_id": 67489301,
                "question_id": 26808855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since jq 1.6 you can do this:\r\n\r\n```bash\r\njq --compact-output --null-input &#39;$ARGS.positional&#39; --args -- &quot;${X[@]}&quot;\r\n```\r\ngiving:\r\n```\r\n[&quot;hello world&quot;,&quot;goodnight moon&quot;]\r\n```\r\n\r\nThis has the benefit that no escaping is required at all. It handles strings containing newlines, tabs, double quotes, backslashes and other control characters. (Well, it doesn&#39;t handle NUL characters but you can&#39;t have them in a bash array in the first place.)",
                "title": "How to format a bash array as a JSON array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634306600,
                "last_edit_date": 1634306600,
                "creation_date": 1634298862,
                "answer_id": 69584344,
                "question_id": 26808855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As improve of [answer][1]\r\n\r\n&gt; https://stackoverflow.com/a/26809278/16566807\r\n\r\nScript produce few formats which could be usefull when include. Script meets BASH spec, checked with shellcheck.\r\n\r\n    #!/bin/bash\r\n    #\r\n    #\r\n            X=(&quot;hello world&quot; &quot;goodnight moon&quot; &#39;say &quot;boo&quot;&#39; &#39;foo\\bar&#39;)\r\n    #\r\n    #       set parameter to define purpose: return_format\r\n    #               php5    -&gt; for 5.x\r\n    #               -&gt; https://stackoverflow.com/questions/7073672/how-to-load-return-array-from-a-php-file/7073686\r\n    #               php     -&gt; for 7.x and greater\r\n    #               json    -&gt; for $array=@file_get_contents($f); json_decode($array, true);\r\n    #               /none/  -&gt; for JS to JSON.Parse(myJSON);\r\n    #       function call with array as parameter: return_array &quot;${array[@]}&quot;\r\n            return_array() {\r\n                    rf=&quot;${return_format}&quot;\r\n                    if [[ $rf = &quot;php5&quot; ]]; then\r\n                            q=(&quot;&lt;?php return array(&quot; &quot;);&quot;)\r\n                    elif [[ $rf = &quot;php&quot; ]];then\r\n                            q=(&quot;&lt;?php return [&quot; &quot;];&quot;)\r\n                    elif [[ $rf = &quot;json&quot; ]];then\r\n                            q=(&quot;{&quot; &quot;}&quot;)\r\n                    else\r\n                            q=(&quot;[&quot; &quot;]&quot;)\r\n                    fi\r\n                    echo -n &quot;${q[0]}&quot;\r\n                    while [[ $# -gt 0 ]]; do\r\n                            x=${1//\\\\/\\\\\\\\}\r\n                            echo -n &quot;\\&quot;${x//\\&quot;/\\\\\\&quot;}\\&quot;&quot;\r\n                            [[ $# -gt 1 ]] &amp;&amp; echo -n &#39;, &#39;\r\n                            shift\r\n                    done\r\n                    echo &quot;${q[1]}&quot;\r\n            }\r\n    \r\n    echo &quot;PHP 5.x&quot;\r\n    return_format=&quot;php5&quot;\r\n    return_array &quot;${X[@]}&quot;\r\n    echo &quot;PHP 7.x&quot;\r\n    return_format=&quot;php&quot;\r\n    return_array &quot;${X[@]}&quot;\r\n    echo &quot;JSON for PHP&quot;\r\n    return_format=&quot;json&quot;\r\n    return_array &quot;${X[@]}&quot;\r\n    echo &quot;JSON for JS&quot;\r\n    return_format=\r\n    return_array &quot;${X[@]}&quot;\r\n\r\nwill produce output:\r\n\r\n    PHP 5.x\r\n    &lt;?php return array(&quot;hello world&quot;, &quot;goodnight moon&quot;, &quot;say \\&quot;boo\\&quot;&quot;, &quot;foo\\\\bar&quot;);\r\n    PHP 7.x\r\n    &lt;?php return [&quot;hello world&quot;, &quot;goodnight moon&quot;, &quot;say \\&quot;boo\\&quot;&quot;, &quot;foo\\\\bar&quot;];\r\n    JSON for PHP\r\n    {&quot;hello world&quot;, &quot;goodnight moon&quot;, &quot;say \\&quot;boo\\&quot;&quot;, &quot;foo\\\\bar&quot;}\r\n    JSON for JS\r\n    [&quot;hello world&quot;, &quot;goodnight moon&quot;, &quot;say \\&quot;boo\\&quot;&quot;, &quot;foo\\\\bar&quot;]\r\n\r\n  [1]: https://stackoverflow.com/a/26809278/16566807",
                "title": "How to format a bash array as a JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 34,
        "last_activity_date": 1651149806,
        "creation_date": 1415389305,
        "last_edit_date": 1415397525,
        "question_id": 26808855,
        "body_markdown": "I have a bash array\r\n\r\n    X=(&quot;hello world&quot; &quot;goodnight moon&quot;)\r\n\r\nThat I want to turn into a json array\r\n\r\n    [&quot;hello world&quot;, &quot;goodnight moon&quot;]\r\n\r\nIs there a good way for me to turn this into a json array of strings without looping over the keys in a subshell?\r\n\r\n    (for x in &quot;${X[@]}&quot;; do; echo $x | sed &#39;s|.*|&quot;&amp;&quot;|&#39;; done) | jq -s &#39;.&#39;\r\n\r\nThis clearly doesn&#39;t work\r\n\r\n    echo &quot;${X[@]}&quot; | jq -s -R &#39;.&#39;",
        "link": "https://stackoverflow.com/questions/26808855/how-to-format-a-bash-array-as-a-json-array",
        "title": "How to format a bash array as a JSON array"
    },
    {
        "tags": [
            "json",
            "google-maps",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1416834672,
                "last_edit_date": 1495540254,
                "creation_date": 1416834672,
                "answer_id": 27105684,
                "question_id": 27103393,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I wrote a function to do this.\r\n\r\n    /**\r\n    *   geocodeResponse is an object full of address data.  \r\n    *   This function will &quot;fish&quot; for the right value\r\n    *   \r\n    *   example: type = &#39;postal_code&#39; =&gt; \r\n    *   geocodeResponse.address_components[5].types[1] = &#39;postal_code&#39;\r\n    *   geocodeResponse.address_components[5].long_name = &#39;1000&#39;\r\n    * \r\n    *   type = &#39;route&#39; =&gt; \r\n    *   geocodeResponse.address_components[1].types[1] = &#39;route&#39;\r\n    *   geocodeResponse.address_components[1].long_name = &#39;Wetstraat&#39;\r\n    */\r\n    function addresComponent(type, geocodeResponse, shortName) {\r\n      for(var i=0; i &lt; geocodeResponse.address_components.length; i++) {\r\n        for (var j=0; j &lt; geocodeResponse.address_components[i].types.length; j++) {\r\n          if (geocodeResponse.address_components[i].types[j] == type) {\r\n            if (shortName) {\r\n              return geocodeResponse.address_components[i].short_name;\r\n            }\r\n            else {\r\n              return geocodeResponse.address_components[i].long_name;\r\n            }\r\n          }\r\n        }\r\n      }\r\n      return &#39;&#39;;\r\n    }\r\n\r\n\r\nThe way to use it; an example:\r\n\r\n    ...\r\n    myGeocoder.geocode({&#39;latLng&#39;: marker.getPosition()}, function(results, status) {\r\n      if (status == google.maps.GeocoderStatus.OK &amp;&amp; results[1]) {\r\n        var country     = addresComponent(&#39;country&#39;, results[1], true);\r\n        var postal_code = addresComponent(&#39;postal_code&#39;, results[1], true);\r\n        ...\r\n      }\r\n    });\r\n    ...\r\n\r\n\r\nI used it here: https://stackoverflow.com/questions/26484126/saving-marker-data-into-db/26487615#26487615\r\n",
                "title": "Parsing Google Maps JSON data for Geocoding in JQ (Not JQuery)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1416836947,
                "creation_date": 1416836947,
                "answer_id": 27106402,
                "question_id": 27103393,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assign the json to results variable, var results = {your json}.\r\n Then try this :\r\n\r\n    for( var idx in results.results)\r\n    {\r\n        var address = results.results[idx].address_components;\r\n        for(var elmIdx in address)\r\n        {\r\n            if(address[elmIdx].types.indexOf(&quot;country&quot;) &gt; -1 &amp;&amp;\r\n               address[elmIdx].types.indexOf(&quot;political&quot;) &gt; -1)\r\n            {\r\n               address[elmIdx].short_name //this is the country name\r\n               address[elmIdx].long_name  //this is the country name\r\n    \t\t   \r\n            }\r\n        }\r\n    }    ",
                "title": "Parsing Google Maps JSON data for Geocoding in JQ (Not JQuery)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1416975252,
                "creation_date": 1416975252,
                "answer_id": 27141218,
                "question_id": 27103393,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s unclear to me what exactly you&#39;re looking for.  Each result has a set of types, each address component also has a set of types.  Which one did you want?  We can write a filter that will match what you attempted but considering the data, it will be completely useless to you.  The only item that contains the types you listed is just a country name.\r\n\r\nAnyway, assuming you wanted to get a result object that had the types `&quot;country&quot;` and `&quot;political&quot;`, use the `contains()` filter.\r\n\r\n    .results | map(\r\n        select(\r\n            .types | contains([&quot;country&quot;,&quot;political&quot;])\r\n        )\r\n    )\r\n\r\nOtherwise you&#39;ll need to clarify what exactly you wanted from this data set.  An example of the expected results...",
                "title": "Parsing Google Maps JSON data for Geocoding in JQ (Not JQuery)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1416975252,
        "creation_date": 1416827220,
        "last_edit_date": 1416842429,
        "question_id": 27103393,
        "body_markdown": "I am trying to get the Country and City names from Lat and Long values with JQ.\r\n\r\nHere is the full example JSON\r\nhttps://maps.googleapis.com/maps/api/geocode/json?latlng=55.397563,10.39870099999996&amp;sensor=false\r\n\r\nI pasted returned JSON in [jqplay][1],\r\n\r\nTried to select Country and City names, but the closest I get is \r\n\r\n    .results[0].address_components[].short_name\r\n\r\nHow can I specify just bring the nodes where `&quot;types&quot; : [ &quot;country&quot;, &quot;political&quot; ]` ?\r\n\r\nThanks\r\n\r\n  [1]: https://jqplay.org/",
        "link": "https://stackoverflow.com/questions/27103393/parsing-google-maps-json-data-for-geocoding-in-jq-not-jquery",
        "title": "Parsing Google Maps JSON data for Geocoding in JQ (Not JQuery)"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 8,
                "creation_date": 1416920021,
                "post_id": 27127091,
                "comment_id": 42753947,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1416921317,
                "post_id": 27127091,
                "comment_id": 42754746,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 301110,
                    "reputation": 103185,
                    "user_id": 608639,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/aPIhh.jpg?s=256",
                    "display_name": "jww",
                    "link": "https://stackoverflow.com/users/608639/jww"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1562616660,
                "post_id": 27127091,
                "comment_id": 100423886,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1417240607,
                "last_edit_date": 1417240607,
                "creation_date": 1416920881,
                "answer_id": 27127626,
                "question_id": 27127091,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The [tag:shell] itself can&#39;t store complicated Data Structures, but like most of the time in shell, you can use external tools, I demonstrate here 6 different solutions, all in Unix* like shells:\r\n\r\n\r\nFirst, your `JSON` is broken, this is a valid version in `file.js` :\r\n\r\n    {\r\n       &quot;italian&quot; : {\r\n          &quot;name&quot; : [\r\n             &quot;gatto&quot;,\r\n             &quot;cane&quot;,\r\n             &quot;pasta&quot;,\r\n             &quot;telefono&quot;,\r\n             &quot;libro&quot;\r\n          ],\r\n          &quot;adjective&quot; : [\r\n             &quot;pesante&quot;,\r\n             &quot;sottile&quot;,\r\n             &quot;giallo&quot;,\r\n             &quot;stretto&quot;\r\n          ]\r\n       },\r\n       &quot;english&quot; : {\r\n          &quot;name&quot; : [\r\n             &quot;fish&quot;,\r\n             &quot;book&quot;,\r\n             &quot;guitar&quot;,\r\n             &quot;piano&quot;\r\n          ],\r\n          &quot;adjective&quot; : [\r\n             &quot;dirty&quot;,\r\n             &quot;good&quot;,\r\n             &quot;ugly&quot;,\r\n             &quot;great&quot;\r\n          ]\r\n       }\r\n    }\r\n\r\n\r\n&lt;h2&gt;Using [tag:jq]&lt;/h2&gt;\r\n\r\n    $ jq &#39;.english.adjective[1]&#39; file.js\r\n\r\nOutput:\r\n \r\n    good\r\n\r\nPlaying with `jq` and `RANDOM` shell variable :\r\n\r\n    $ echo $(\r\n        jq &quot;.english.adjective[$((RANDOM%4))], .english.name[$((RANDOM%4))]&quot; file.js\r\n    )\r\n    &quot;great&quot; &quot;piano&quot;\r\n\r\n[jq][1], see the [tutorial][2].\r\n\r\n&lt;h2&gt;Using [tag:rhino]&lt;/h2&gt;\r\n\r\n    $ rhino&lt;&lt;EOF 2&gt;/dev/null\r\n    hash = $(&lt;file.js)\r\n    print(hash.english.adjective[1])\r\n    EOF\r\n\r\nOutput:\r\n\r\n    ...\r\n    good\r\n\r\n&lt;h2&gt;Using [tag:node.js]&lt;/h2&gt;\r\n\r\n    $ node&lt;&lt;EOF\r\n    hash = $(&lt;file.js)\r\n    console.log(hash.english.adjective[1])\r\n    EOF\r\n\r\nOutput :\r\n\r\n    good\r\n\r\n&lt;h2&gt;Using [tag:perl]&lt;/h2&gt;\r\n\r\n\r\nLet&#39;s parse the DS in a perl command line :\r\n\r\n    $ perl -MJSON -0lnE &#39;\r\n        $words = decode_json $_;\r\n        say $words-&gt;{english}-&gt;{adjective}-&gt;[1]\r\n    &#39; file.js\r\n\r\nOutput:\r\n \r\n    good\r\n\r\n&lt;h2&gt;Using [tag:python]&lt;/h2&gt;\r\n\r\n    $ python&lt;&lt;EOF\r\n    import json\r\n    json_data = open(&#39;file.js&#39;)\r\n    data = json.load(json_data)\r\n    json_data.close()\r\n    print(data[&#39;english&#39;][&#39;adjective&#39;][1])\r\n    EOF\r\n\r\nOutput:\r\n\r\n    good\r\n\r\n&lt;h2&gt;Using [tag:ruby]&lt;/h2&gt;\r\n\r\n    $ ruby&lt;&lt;EOF\r\n    require &#39;json&#39;\r\n    file = File.read(&#39;file.js&#39;)\r\n    data = JSON.parse(file)\r\n    print(data[&#39;english&#39;][&#39;adjective&#39;][1])\r\n    EOF\r\n\r\nOutput:\r\n\r\n    good\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/\r\n  [2]: http://stedolan.github.io/jq/tutorial/\r\n",
                "title": "Parse JSON in shell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1681701518,
                "creation_date": 1681701518,
                "answer_id": 76031502,
                "question_id": 27127091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n&lt;h2&gt;Using pure [tag:Bash] 3.2+ without dependencies (such as jq, python, grep, etc.):&lt;/h2&gt;\r\n\r\n    source &lt;(curl -s -L -o- https://github.com/lirik90/bashJsonParser/raw/master/jsonParser.sh)\r\n    JSON=$(minifyJson &quot;$JSON&quot;)\r\n    echo &quot;Result is: $(parseJson &quot;$JSON&quot; english adjective 1)&quot;\r\n\r\nOutput:\r\n\r\n    Result is: good\r\n\r\n\r\n[Try it][1].\r\n\r\n\r\n  [1]: https://replit.com/@lirik90/bashJsonParser-27127091",
                "title": "Parse JSON in shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1681701518,
        "creation_date": 1416919371,
        "last_edit_date": 1521562572,
        "question_id": 27127091,
        "body_markdown": "How can i do dictionary structure in shell? My aim is to generate random words. Ex. dirty fish, good book, ugly piano or pesante pasta, giallo cane... Its js code look like this\r\n\r\n        words ={\r\n\r\n\t&quot;italian&quot; :\r\n\t{\r\n\t\t&quot;name&quot; :\r\n\t\t\t\t[\r\n\t\t\t\t &quot;gatto&quot;, \r\n\t\t\t\t &quot;cane&quot;, \r\n\t\t\t\t &quot;pasta&quot;, \r\n\t\t\t\t &quot;telefono&quot;, \r\n\t\t\t\t &quot;libro&quot;\r\n\t\t\t\t ],\r\n\t\t \r\n\t\t&quot;adjective&quot; : \r\n\t\t\t\t[\r\n\t\t\t\t &quot;pesante&quot;, \r\n\t\t\t\t &quot;sottile&quot;, \r\n\t\t\t\t &quot;giallo&quot;, \r\n\t\t\t\t &quot;stretto&quot;, \t \r\n\t\t\t\t ]\r\n\t},\r\n\t&quot;english&quot; :\r\n\t{\r\n\t\t&quot;name&quot; : \r\n\t\t\t\t[\r\n\t\t\t\t &quot;fish&quot;, \r\n                 &quot;book&quot;,\r\n                 &quot;guitar&quot;,\r\n                 &quot;piano&quot;,\r\n\t\t\t\t ],\t\t\r\n\t\t&quot;adjective&quot; :\r\n\t\t\t\t[\r\n\t\t\t\t  &quot;dirty&quot;,\r\n\t\t\t\t  &quot;good&quot;,\r\n\t\t\t\t  &quot;ugly&quot;,\r\n\t\t\t\t  &quot;great&quot;,\t \r\n\t\t\t\t ]\r\n\t}}\r\n\r\nI want this:\r\n\r\n    words[english][adjective][1]\r\n    &gt;&gt; good",
        "link": "https://stackoverflow.com/questions/27127091/parse-json-in-shell",
        "title": "Parse JSON in shell"
    },
    {
        "tags": [
            "decimal",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417367151,
                "post_id": 27211870,
                "comment_id": 42911496,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2678242,
                    "reputation": 183,
                    "user_id": 2314105,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/6373dc8cfbe58f6247e19ae9f7be4d85?s=256&d=identicon&r=PG",
                    "display_name": "user2314105",
                    "link": "https://stackoverflow.com/users/2314105/user2314105"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417384439,
                "post_id": 27211870,
                "comment_id": 42916650,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2678242,
                    "reputation": 183,
                    "user_id": 2314105,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/6373dc8cfbe58f6247e19ae9f7be4d85?s=256&d=identicon&r=PG",
                    "display_name": "user2314105",
                    "link": "https://stackoverflow.com/users/2314105/user2314105"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417385074,
                "post_id": 27211870,
                "comment_id": 42916831,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 261553,
                    "reputation": 685,
                    "user_id": 545798,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/55274f3b3dc7fb6094c38c8aec8dd8a6?s=256&d=identicon&r=PG",
                    "display_name": "MiroJanosik",
                    "link": "https://stackoverflow.com/users/545798/mirojanosik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675201809,
                "post_id": 27211870,
                "comment_id": 132877113,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1429092850,
                "last_edit_date": 1495540263,
                "creation_date": 1429030605,
                "answer_id": 29633176,
                "question_id": 27211870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Javascript does not support such big numbers and so does `jq`. The integer size is `2^53`. Check [this][1]\r\n\r\nTo make it work, you&#39;ll need to treat them as strings:\r\n\r\n    echo &#39;&quot;18302628978110292481&quot;&#39; | jq .\r\n    # Prints &quot;18302628978110292481&quot;\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/307200/171318",
                "title": "How can I avoid jq truncating long decimal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1429092850,
        "creation_date": 1417340126,
        "last_edit_date": 1417345046,
        "question_id": 27211870,
        "body_markdown": "How can I prevent jq from truncating long decimal values?\r\n\r\nFor example:\r\n\r\n    echo &#39;18302628978110292481&#39; | jq .\r\n\r\nresult: 18302628978110292000",
        "link": "https://stackoverflow.com/questions/27211870/how-can-i-avoid-jq-truncating-long-decimal",
        "title": "How can I avoid jq truncating long decimal"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 165169,
                    "reputation": 57580,
                    "user_id": 388389,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://i.sstatic.net/GWm7u.jpg?s=256",
                    "display_name": "npocmaka",
                    "link": "https://stackoverflow.com/users/388389/npocmaka"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417566587,
                "post_id": 27261547,
                "comment_id": 42996085,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 46322,
                    "reputation": 3261,
                    "user_id": 136785,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f1ee3b5f25f8c3551a8e98239a57beee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "J23",
                    "link": "https://stackoverflow.com/users/136785/j23"
                },
                "reply_to_user": {
                    "account_id": 165169,
                    "reputation": 57580,
                    "user_id": 388389,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://i.sstatic.net/GWm7u.jpg?s=256",
                    "display_name": "npocmaka",
                    "link": "https://stackoverflow.com/users/388389/npocmaka"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417569344,
                "post_id": 27261547,
                "comment_id": 42996801,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5198511,
                    "reputation": 14472,
                    "user_id": 4158862,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fKDhB.png?s=256",
                    "display_name": "SomethingDark",
                    "link": "https://stackoverflow.com/users/4158862/somethingdark"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417574489,
                "post_id": 27261547,
                "comment_id": 42997990,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417574609,
                "post_id": 27261547,
                "comment_id": 42998025,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 46322,
                    "reputation": 3261,
                    "user_id": 136785,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f1ee3b5f25f8c3551a8e98239a57beee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "J23",
                    "link": "https://stackoverflow.com/users/136785/j23"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1417578496,
                "post_id": 27261547,
                "comment_id": 42998906,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 35,
                "is_accepted": true,
                "score": 35,
                "last_activity_date": 1417590904,
                "creation_date": 1417590904,
                "answer_id": 27265780,
                "question_id": 27261547,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    curl --silent\r\n\r\n&lt;pre&gt;\r\n-s, --silent\r\n  Silent or quiet mode. Do not show progress meter or error messages. Makes Curl\r\n  mute.\r\n&lt;/pre&gt;\r\n\r\n- [Example][1]\r\n- [explainshell.com - curl --silent][2]\r\n\r\n[1]:http://github.com/svnpenn/a/blob/4e0992f8c1d6ed7571c0f27be1a/ff-song.sh#L100\r\n[2]:http://explainshell.com/explain?cmd=curl+--silent",
                "title": "Hide status output from jq in dos/windows"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589457865,
                "last_edit_date": 1589457865,
                "creation_date": 1589380991,
                "answer_id": 61777587,
                "question_id": 27261547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Solution**: In order to remove the progress bar on curl restful api response ,Use the `--silent` flag (in short `-s`) or use `--no-progress-meter`. I suggest using the latter because you&#39;d like to get warnings and informational messages on bad responses.\r\n\r\n**examples**:\r\n\r\n1.\r\n`curl -s &lt;Web-Address&gt;` OR `curl --silent &lt;Web-Address&gt;`\r\n\r\n2.\r\n `curl --no-progress-meter &lt;Web-Address&gt;`\r\n\r\nFor more [**Curl Documentation**][1]\r\n   \r\n\r\n    -s, --silent\r\n        \r\n    Silent or quiet mode. Don&#39;t show progress meter or error messages. \r\n    Makes Curl mute. \r\n    It will still output the data you ask for, potentially even to the terminal/stdout unless you redirect it.\r\n        \r\n    Use -S, --show-error in addition to this option to disable progress meter but still show error messages.\r\n\r\n    --no-progress-meter\r\n    \r\n    Option to switch off the progress meter output without muting or otherwise affecting warning and informational messages like -s, --silent does.\r\n    \r\n    Note that this is the negated option name documented. You can thus use --progress-meter to enable the progress meter again.\r\n\r\n\r\n  [1]: https://curl.haxx.se/docs/manpage.html#-s",
                "title": "Hide status output from jq in dos/windows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 20,
        "last_activity_date": 1589457865,
        "creation_date": 1417566366,
        "question_id": 27261547,
        "body_markdown": "I&#39;m using curl for windows (http://www.confusedbycode.com/curl/) in conjunction with jq (http://stedolan.github.io/jq/) to interact with a web api via a batch file.  The seemingly simple problem I&#39;m having is that no matter what I do, I cannot seem to suppress JQ&#39;s &quot;status&quot; output.  In particular, it always outputs &quot;progress status,&quot; like:\r\n\r\n    % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                   Dload  Upload   Total   Spent    Left  Speed\r\n    100   116  100    99  100    17    908    155 --:--:-- --:--:-- --:--:--   908\r\n\r\nA simplified example batch file would be:\r\n\r\n    @echo off\r\n    @curl.exe -H &quot;Content-Type: application/json&quot; -d &#39;{\\&quot;cmd\\&quot;:\\&quot;login\\&quot;}&#39; http://localhost:80/json | jq -r .session &gt; sess.txt\r\n\r\nNote that jq does operate as expected - I simply need to get it to operate *silently*.  It seems to ignore @echo off, and I couldn&#39;t find any switches in the manual to disable this output.\r\n\r\nAny ideas...?\r\n\r\nThanks much in advance :)",
        "link": "https://stackoverflow.com/questions/27261547/hide-status-output-from-jq-in-dos-windows",
        "title": "Hide status output from jq in dos/windows"
    },
    {
        "tags": [
            "bash",
            "jira",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418393846,
                "post_id": 27444164,
                "comment_id": 43329995,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1418390642,
                "last_edit_date": 1418390642,
                "creation_date": 1418390255,
                "answer_id": 27444530,
                "question_id": 27444164,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I suppose you just need to quote the double quotes (so that they are left alone by the shell as literal characters). The shell will normally substitute variables within backticks, and I suppose you just want to have the double quotes around the expanded JIRA_FIXVERSION, so that a command like the example you gave is produced (which contains `&quot;Version-...&quot;`).\r\n\r\nExample:\r\n\r\n    $ XX=bla; echo `echo kklkj | sed s/kk/\\&quot;$XX\\&quot;/g`\r\n    &quot;bla&quot;lkj\r\n\r\nor, indeed, simpler:\r\n\r\n    XX=bla; echo `echo \\&quot;$XX\\&quot;`\r\n-&gt; &quot;bla&quot;\r\n\r\n",
                "title": "Passing a bash script variable to a quoted value in backticks"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1418485664,
                "creation_date": 1418485664,
                "answer_id": 27460648,
                "question_id": 27444164,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ok, \r\n\r\nI got it in the end. So\r\n\r\n1. I have an alias which points to the bash file. The file receives a variable which must be passed in quotes:\r\n\r\n`$jiraReleases &quot;Version1.2.3&quot;`\r\n\r\n2. The file takes the variable:\r\n\r\n`JIRA_FIXVERSION=$1`\r\n\r\n3. Wthin jq the quotes are escaped, and additional quotes and apostrophes are added. Note that the below line is also surrounded by single quotes and backticks. \r\n\r\n\r\n`.[] | {id,name} | select(.name==&#39;\\&quot;&quot;${JIRA_FIXVERSION}&quot;\\&quot;&#39;) `",
                "title": "Passing a bash script variable to a quoted value in backticks"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1418485664,
        "creation_date": 1418389024,
        "question_id": 27444164,
        "body_markdown": "Unrelated: This has been doing my head in. \r\n\r\nBelow is a curl function that works as below (I&#39;ve put it on multiple lines for readability):\r\n\r\n    fixVersionQuery=&#39;https://thejirainstall.com/jira/rest/api/2/project/ON/versions?&#39;;\r\n\r\n    myJSONResponse=`curl -u username:password -X GET -H &quot;Content-Type: application/json&quot; \\\r\n    --insecure --silent $fixVersionQuery |jq &#39;.[] | {id,name} |  \\       \r\n    select(.name==&quot;Version-1.2.3&quot;) | .[&quot;id&quot;]&#39;`; \r\n\r\nThe above works. However, I want to be querying a version whose name I&#39;m passing to the function. So `&quot;Version-1.2.3&quot;` might be a variable such as `&quot;${JIRA_FIXVERSION}&quot;`. The problem is that within the line above, I can&#39;t figure out what combination of apostrophes` back ticks or quotes to use. Although I know that the general structure of the function will be...\r\n\r\n    JIRA_FIXVERSION;\r\n    fixVersionQuery=&#39;https://thejirainstall.com/jira/rest/api/2/project/ON/versions?&#39;;\r\n\r\n    myJSONResponse=`curl -u username:password -X GET -H &quot;Content-Type: application/json&quot; \\\r\n    --insecure --silent $fixVersionQuery |jq &#39;.[] | {id,name} |  \\       \r\n    select(.name==&quot;&#39;$JIRA_FIXVERSION&#39;&quot;) | .[&quot;id&quot;]&#39;`; \r\n\r\nThe above exits with a compile error on `&quot;&#39;$JIRA_FIXVERSION&#39;&quot;` or ${JIRA_FIXVERSION} if I use that.",
        "link": "https://stackoverflow.com/questions/27444164/passing-a-bash-script-variable-to-a-quoted-value-in-backticks",
        "title": "Passing a bash script variable to a quoted value in backticks"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418740938,
                "post_id": 27506416,
                "comment_id": 43444450,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418741774,
                "post_id": 27506416,
                "comment_id": 43444983,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418741826,
                "post_id": 27506416,
                "comment_id": 43445017,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418747553,
                "post_id": 27506416,
                "comment_id": 43448761,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1418750545,
                "post_id": 27506416,
                "comment_id": 43450791,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "reply_to_user": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418750552,
                "post_id": 27506416,
                "comment_id": 43450793,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "reply_to_user": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1418750834,
                "post_id": 27506416,
                "comment_id": 43450970,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1418750946,
                "creation_date": 1418750946,
                "answer_id": 27510459,
                "question_id": 27506416,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you need the &quot;map&quot; command in that too, in which the select command should be enclosed:\r\n\r\n    cat FullClosedIssueList.json | jq &#39;.[] | map(select(.typeid==&quot;1&quot;))&#39; ",
                "title": "Filter json file objects into a separate json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1418750946,
        "creation_date": 1418738556,
        "last_edit_date": 1418748330,
        "question_id": 27506416,
        "body_markdown": "At the moment I&#39;m successfully exporting curl output with JQ into a file with valid json. \r\n\r\nThe comment is as below:\r\n\r\njsonValues=` &lt;curl command&gt; | jq &#39;.[&quot;issues&quot;] | map({key: .key, type: .fields.issuetype.name, typeid: .fields.issuetype.id, status: .fields.status.name, summary: .fields.summary})&#39; &gt; FullClosedIssueList.json`; `\r\n\r\nYou can see that I&#39;m doing two things with this one command:\r\n\r\n* Putting all the results into `jsonValues`.\r\n* Exporting to `FullClosedIssueList.json`. \r\n\r\nI find that the `jsonValues` objects are formatted missing `[`, `]` and `,`. \r\n\r\n    {\r\n      &quot;key&quot;: &quot;ON-12345&quot;,\r\n      &quot;type&quot;: &quot;Bug&quot;,\r\n      &quot;typeid&quot;: &quot;1&quot;,\r\n      &quot;status&quot;: &quot;Closed&quot;,\r\n      &quot;summary&quot;: &quot;Some Bug Title&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;ON-12346&quot;,\r\n      &quot;type&quot;: &quot;Bug&quot;,\r\n      &quot;typeid&quot;: &quot;1&quot;,\r\n      &quot;status&quot;: &quot;Closed&quot;,\r\n      &quot;summary&quot;: &quot;Some Other Bug Title&quot;\r\n    }\r\n\r\nWhereas the file output is valid json.\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;ON-12345&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Some Bug Title&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;ON-12346&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Some Other Bug Title&quot;\r\n      }\r\n    ]\r\n\r\nWhat command do I need to add to JQ such that the objects passed to the bash variable are valid json?\r\n\r\n**EDIT:** This is the same problem as described [here](https://github.com/stedolan/jq/issues/189)",
        "link": "https://stackoverflow.com/questions/27506416/filter-json-file-objects-into-a-separate-json-file-with-jq",
        "title": "Filter json file objects into a separate json file with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1418980852,
                "creation_date": 1418980852,
                "answer_id": 27562901,
                "question_id": 27562424,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I managed to figure it out.\r\n\r\n    $ jq &#39;.[] | { id, &quot;info-spec&quot;: .stuff[&quot;info-spec&quot;] }&#39; xample.json\r\n    {\r\n      &quot;info-spec&quot;: 12,\r\n      &quot;id&quot;: 12345678\r\n    }\r\n    {\r\n      &quot;info-spec&quot;: 23,\r\n      &quot;id&quot;: 12345679\r\n    }\r\n\r\nThe key here seems to be to use the `newkey: .complex[&quot;key&quot;]` notation for lifting.",
                "title": "jq: nested object, extract top-level id and lift a value from internal object"
            },
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1418983853,
                "creation_date": 1418983853,
                "answer_id": 27563734,
                "question_id": 27562424,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "interesting, the issue is indeed the &quot;-&quot; character and this works for me:\r\n\r\n    jq &#39;.[] | { id, &quot;info-spec&quot;: .stuff.&quot;info-spec&quot; }&#39; xample.json\r\n    {\r\n      &quot;id&quot;: 12345678,\r\n      &quot;info-spec&quot;: 12\r\n    }\r\n    {\r\n      &quot;id&quot;: 12345679,\r\n      &quot;info-spec&quot;: 23\r\n    }\r\n\r\nyet your `jq` does not seem to like that syntax as it broke on the following and mine does not:\r\n\r\n    jq &#39;.[] | .stuff.&quot;info-spec&quot;&#39; xample.json\r\n    12\r\n    23\r\n\r\nI use:\r\n\r\n    jq --version\r\n    jq-1.4\r\n\r\nedit: looks like a version issue with &lt;1.4 indeed:\r\nhttps://github.com/stedolan/jq/issues/38\r\n",
                "title": "jq: nested object, extract top-level id and lift a value from internal object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 42,
        "last_activity_date": 1621838075,
        "creation_date": 1418978800,
        "last_edit_date": 1621838075,
        "question_id": 27562424,
        "body_markdown": "Given the following `xample.json`;\r\n\r\n    [\r\n     {\r\n      &quot;id&quot;: 12345678,\r\n      &quot;stuff&quot;: { &quot;book&quot;: &quot;shelf&quot;, &quot;hook&quot;: &quot;line&quot;, &quot;took&quot;: &quot;off&quot;, &quot;info-spec&quot;: 12 },\r\n      &quot;votes&quot;: 23\r\n     },\r\n     {\r\n      &quot;id&quot;: 12345679,\r\n      &quot;stuff&quot;: { &quot;book&quot;: &quot;maker&quot;, &quot;hook&quot;: &quot;sinker&quot;, &quot;took&quot;: &quot;pisin&quot;, &quot;info-spec&quot;: 23 },\r\n      &quot;votes&quot;: 1\r\n     }\r\n    ]\r\n\r\nI can extract the `id` and `votes` easily:\r\n\r\n    $ jq &#39;.[] | { id, votes }&#39; xample.json\r\n    {\r\n      &quot;votes&quot;: 23,\r\n      &quot;id&quot;: 12345678\r\n    }\r\n    {\r\n      &quot;votes&quot;: 1,\r\n      &quot;id&quot;: 12345679\r\n    }\r\n\r\nBut what would the query look like to extract `id` and `stuff.info-spec`?  The obvious (to me) syntax doesn&#39;t work at all:\r\n\r\n    $ jq &#39;.[] | { id, stuff.info-spec }&#39; xample.json\r\n    error: syntax error, unexpected &#39;.&#39;, expecting &#39;}&#39;\r\n    .[] | { id, stuff.info-spec }\r\n                     ^\r\n    1 compile error\r\n\r\nI tried `stuff[info-spec]` and `stuff[&quot;info-spec&quot;]` as well but, well, I just don&#39;t seem to have any idea how this should be done.\r\n\r\nThe dash in the key name seems to complicate matters even further, but my limited understanding is that I can work around that with double quotes.\r\n\r\n    $ sed &#39;s/votes/vo-tes/g&#39; xample.json | jq &#39;.[] | { id, &quot;vo-tes&quot; }&#39;\r\n\r\ngives the expected output (i.e. similar to above without the dash in &quot;vo-tes&quot;).\r\n\r\nI can extract `book`:\r\n\r\n    $ jq &#39;.[] | .stuff.book&#39; xample.json\r\n\r\nbut again cannot figure out the syntax for `id` and `book`; but also, I cannot extract `info-spec` with the same syntax:\r\n\r\n    $ jq &#39;.[] | .stuff.&quot;info-spec&quot;&#39; xample.json\r\n    error: syntax error, unexpected QQSTRING_START, expecting IDENT\r\n    .[] | .stuff.&quot;info-spec&quot;\r\n                 ^\r\n    1 compile error\r\n\r\nIf I take out the quotes, the error message is (predictably) different:\r\n\r\n    $ jq &#39;.[] | .stuff.info-spec&#39; xample.json\r\n    error: spec is not defined\r\n    .[] | .stuff.info-spec\r\n                      ^^^^\r\n    1 compile error\r\n\r\nBut hey, this works:\r\n\r\n    $ jq &#39;.[] | .stuff[&quot;info-spec&quot;] &#39; xample.json\r\n    12\r\n    23\r\n\r\nMy desired output for this example, then, is\r\n\r\n    {\r\n      &quot;info-spec&quot;: 12,\r\n      &quot;id&quot;: 12345678\r\n    }\r\n    {\r\n      &quot;info-spec&quot;: 23,\r\n      &quot;id&quot;: 12345679\r\n    }\r\n\r\nI&#39;ve looked at the [FAQ](https://github.com/stedolan/jq/wiki/FAQ) and the [`jq` Cookbook](https://github.com/stedolan/jq/wiki/jq-Cookbook) but I can&#39;t seem to find anything about a syntax for &quot;lifting&quot; an item from within an object inside another object.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/27562424/jq-nested-object-extract-top-level-id-and-lift-a-value-from-internal-object",
        "title": "jq: nested object, extract top-level id and lift a value from internal object"
    },
    {
        "tags": [
            "javascript",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1419377466,
                "post_id": 27629419,
                "comment_id": 43679612,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1419377173,
                "creation_date": 1419377173,
                "answer_id": 27629476,
                "question_id": 27629419,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Loop through the results and add it up...\r\n\r\n\r\n    var data = JSON.parse(&#39;[[&quot;Graz&quot;, 5.0],[&quot;Rio de Janeiro&quot;, 3.0],[&quot;Br&#228;cke&quot;, 2.0],[&quot;Campinas&quot;, 2.0],[&quot;Colchester&quot;, 2.0],[&quot;Cunewalde&quot;, 2.0],[&quot;Lille&quot;, 2.0],[&quot;London&quot;, 2.0],[&quot;Charleroi&quot;, 1.0],[&quot;Caracas&quot;, 1.0],[&quot;Butte&quot;, 1.0],[&quot;Buenos Aires&quot;, 1.0]]&#39;);\r\n    \r\n    var total = 0;\r\n    for (var i = 0; i &lt; data.length; i++) {\r\n      total += data[i][1];\r\n    }",
                "title": "Get total of JSON values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1419377343,
                "creation_date": 1419377343,
                "answer_id": 27629497,
                "question_id": 27629419,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is hardly a sexy answer, but it works.  Note, since it uses .length, it will only work on an array:\r\n\r\n    var\r\n      jsonArr = [[&quot;Graz&quot;, 5.0],[&quot;Rio de Janeiro&quot;, 3.0],[&quot;Br&#228;cke&quot;,2.0],[&quot;Campinas&quot;, 2.0],\r\n        [&quot;Colchester&quot;, 2.0],[&quot;Cunewalde&quot;, 2.0],[&quot;Lille&quot;, 2.0],[&quot;London&quot;, 2.0],\r\n        [&quot;Charleroi&quot;, 1.0],[&quot;Caracas&quot;, 1.0],[&quot;Butte&quot;, 1.0],[&quot;Buenos Aires&quot;, 1.0]],   \r\n      total = 0;\r\n     \r\n    for (var i in jsonArr) {\r\n      total += jsonArr[i].length; \r\n    }\r\n    console.log(total); // 24",
                "title": "Get total of JSON values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1419377890,
                "creation_date": 1419377890,
                "answer_id": 27629589,
                "question_id": 27629419,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just to complete Jake&#39;s excellent answer, I would like to point out that, since the question is tagged with the `jquery` tag, another approach could be the use of `$.each`:\r\nDemo:\r\n-----\r\n\r\n&lt;!-- begin snippet: js hide: true --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    function sumJSON(str) {\r\n      var data = JSON.parse(str),\r\n        total = 0;\r\n      $.each(data, function(index, value) {\r\n        total += value[1];\r\n      });\r\n      return total;\r\n    }\r\n    $(document).ready(function() {\r\n      var string = &#39;[[&quot;Graz&quot;, 5.0],[&quot;Rio de Janeiro&quot;, 3.0],[&quot;Br&#228;cke&quot;, 2.0],[&quot;Campinas&quot;, 2.0],[&quot;Colchester&quot;, 2.0],[&quot;Cunewalde&quot;, 2.0],[&quot;Lille&quot;, 2.0],[&quot;London&quot;, 2.0],[&quot;Charleroi&quot;, 1.0],[&quot;Caracas&quot;, 1.0],[&quot;Butte&quot;, 1.0],[&quot;Buenos Aires&quot;, 1.0]]&#39;;\r\n      $(&quot;.count&quot;).text( sumJSON(string) );\r\n    });\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;script src=&quot;https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js&quot;&gt;&lt;/script&gt;\r\n    &lt;p&gt;Total: &lt;span class=&quot;count&quot;&gt;&lt;/span&gt;\r\n    &lt;/p&gt;\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "Get total of JSON values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1419378021,
                "creation_date": 1419378021,
                "answer_id": 27629608,
                "question_id": 27629419,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Although it looks that you already got a response, I would suggest a general solution for all possible formats, not only this one that has one-level array nesting, and doesn&#39;t even consider objects or whatever. The following code will recursively iterate objects and arrays looking for values:\r\n\r\n    function isArray(obj) {\r\n      return !!(obj.length) &amp;&amp; ((obj + &quot;&quot;) !== obj);\r\n    }\r\n\r\n    function isObject(obj) {\r\n      return obj.toString() === &quot;[object Object]&quot;;\r\n    }\r\n\r\n    function getKeys(obj) {\r\n      var keys;\r\n      if (isArray(obj)) {\r\n        keys = [];\r\n        for (var i = 0; i &lt; obj.length; i++) {\r\n          keys.push(i);\r\n        }\r\n      } else {\r\n        keys = Object.keys(obj)\r\n      }\r\n      return keys;\r\n    }\r\n\r\n    function deepLength(arr) {\r\n      var totalValues = 0;\r\n      var keys = getKeys(arr);\r\n  \r\n      for (var i = 0; i &lt; keys.length; i++) {\r\n        if (isArray(arr[keys[i]]) || isObject(arr[keys[i]])) {\r\n          totalValues += deepLength(arr[keys[i]])\r\n        } else {\r\n          totalValues++;\r\n        }\r\n      }\r\n      return totalValues;\r\n    }\r\n \r\n\r\nI just didn&#39;t invest too much time with the isArray and isObject functions and I would recommend you using maybe those from lodash or underscore, or whatever but definitely not these.",
                "title": "Get total of JSON values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1419383393,
                "creation_date": 1419383393,
                "answer_id": 27630211,
                "question_id": 27629419,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "since the question has got a `jq` tag, here it goes...:\r\n\r\n    echo &quot;[[\\&quot;Graz\\&quot;,5],[\\&quot;Rio de Janeiro\\&quot;,3],[\\&quot;Br&#228;cke\\&quot;,2],[\\&quot;Campinas\\&quot;,2],[\\&quot;Colchester\\&quot;,2],[\\&quot;Cunewalde\\&quot;,2],[\\&quot;Lille\\&quot;,2],[\\&quot;London\\&quot;,2],[\\&quot;Charleroi\\&quot;,1],[\\&quot;Caracas\\&quot;,1],[\\&quot;Butte\\&quot;,1],[\\&quot;Buenos Aires\\&quot;,1]]&quot; | jq &#39;[.[][1]] | add&#39;",
                "title": "Get total of JSON values"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1419383393,
        "creation_date": 1419376722,
        "last_edit_date": 1419377446,
        "question_id": 27629419,
        "body_markdown": "I return the following JSON to populate a highchart http://www.highcharts.com/\r\n\r\n    [[&quot;Graz&quot;, 5.0],[&quot;Rio de Janeiro&quot;, 3.0],[&quot;Br&#228;cke&quot;, 2.0],[&quot;Campinas&quot;, 2.0],[&quot;Colchester&quot;, 2.0],[&quot;Cunewalde&quot;, 2.0],[&quot;Lille&quot;, 2.0],[&quot;London&quot;, 2.0],[&quot;Charleroi&quot;, 1.0],[&quot;Caracas&quot;, 1.0],[&quot;Butte&quot;, 1.0],[&quot;Buenos Aires&quot;, 1.0]] \r\n\r\nrather than requery the database again. How would I get the total of the values returned? ie in this case 24.\r\nI am still getting used to JSON, so would appreciate any help anyone can give...thanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/27629419/get-total-of-json-values",
        "title": "Get total of JSON values"
    },
    {
        "tags": [
            "json",
            "loops",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1420561615,
                "post_id": 27800718,
                "comment_id": 44014580,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5582814,
                    "reputation": 71,
                    "user_id": 4424212,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/225ea853d27e83c67548ad814980782d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shailendra Sadh",
                    "link": "https://stackoverflow.com/users/4424212/shailendra-sadh"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1420610476,
                "post_id": 27800718,
                "comment_id": 44033697,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1420631889,
                "creation_date": 1420631889,
                "answer_id": 27819020,
                "question_id": 27800718,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ok I got the answer for this.\r\n\r\nWe can use the below syntax to make is work in the for loop.\r\n\r\n \r\n\r\n    id=$(cat red | jq &#39;.content[&#39;${i}&#39;].id&#39;)",
                "title": "Not able to Iterate through JSON response object with JQ in Unix shell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1420631889,
        "creation_date": 1420554303,
        "last_edit_date": 1420610435,
        "question_id": 27800718,
        "body_markdown": "I am trying to iterate through a JSON object in UNIX, where the idea is to pickup different values and append it to a string and forward it as a syslog. Below is the code.\r\n\r\n    //picking up the length of Object\r\n    count=$(jq &#39;.content | length&#39; red)\r\n    #echo $count\r\n    \r\n        enter code here\r\n    \r\n    for((i=0;i&lt;$count;i++))\r\n    do\r\n            echo &quot;MY VALUE OF I&quot;\r\n            echo $i\r\n            //THE BELOW LINE GIVES ERROR UPON USAGE of $i\r\n            id=&quot;$(cat red | jq &#39;.content[$i].id&#39;)&quot;\r\n            source=$(cat red | jq &#39;.content[$i].entitySummary.source&#39;)\r\n            .\r\n            .\r\n    \r\n            #syslogString=&quot;ID=$id SOURCE=$source SUMMARY=$summaryText TITLE=$title DESCRIPTION=$description SEVERITY=$severity MITIGATION=$mitigation IMPACT=$impactDescrip$\r\n    \r\n            echo $id\r\n            echo &quot;value of ID ($id)&quot;\r\n\r\nI am receiving compilation error with content[$i] and cant get a workaround the same. \r\n\r\nThe response class looks like this:\r\n\r\n    Page {\r\n        content ( array[ ClientIncident ] )\r\n    \t\tThe list of results that make up the page. The number of elements should be less than or equal to the currentPage size.\r\n        currentPage ( Pagination )\r\n    \t\tSize and offset information about the current page.\r\n        total ( integer )\r\n    \t\tThe total number of results found. If there are a large number of results, this may be an estimate. Accuracy should improve as the page approaches the end of the resultset.\r\n    } \r\nunder content the JSON response looks as below:\r\n\r\n    {\r\n      &quot;content&quot;: [\r\n        {\r\n          &quot;id&quot;: 951653,\r\n          &quot;version&quot;: 12,\r\n          &quot;score&quot;: 100,\r\n          &quot;entitySummary&quot;: {\r\n            &quot;source&quot;: &quot;somewebsite&quot;,\r\n            &quot;summaryText&quot;: &quot;someTEXT here&quot;,\r\n            &quot;domain&quot;: &quot;www.domian.com&quot;,\r\n            &quot;sourceDate&quot;: &quot;2014-12-19T17:00:00.000Z&quot;,\r\n            &quot;type&quot;: &quot;WEB_PAGE&quot;\r\n          },\r\n          &quot;type&quot;: &quot;SomeTYPE&quot;,\r\n          &quot;title&quot;: &quot;some Title&quot;,\r\n          &quot;description&quot;: &quot;some description &quot;,\r\n          &quot;occurred&quot;: &quot;2014-12-19T17:00:00.000Z&quot;,\r\n          &quot;verified&quot;: &quot;2014-12-19T17:17:22.326Z&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;id&quot;: 424,\r\n              &quot;name&quot;: &quot;Data Breach or Compromise&quot;,\r\n              &quot;type&quot;: &quot;IMPACT_EFFECTS&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 1064,\r\n              &quot;name&quot;: &quot;United States&quot;,\r\n              &quot;type&quot;: &quot;TARGET_GEOGRAPHY&quot;\r\n            },\r\n           ],\r\n          &quot;severity&quot;: &quot;MEDIUM&quot;,\r\n          &quot;clientId&quot;: &quot;NET&quot;,\r\n          &quot;alerted&quot;: &quot;2014-12-19T17:39:55.500Z&quot;,\r\n          &quot;mitigation&quot;: &quot;MititgationINFO&quot;,\r\n          &quot;impactDescription&quot;: &quot;IMpact description&quot;: 0\r\n        },\r\n        {\r\n          &quot;id&quot;: 951174,\r\n          &quot;version&quot;: 8,\r\n          &quot;score&quot;: 100,\r\n          &quot;entitySummary&quot;: {",
        "link": "https://stackoverflow.com/questions/27800718/not-able-to-iterate-through-json-response-object-with-jq-in-unix-shell",
        "title": "Not able to Iterate through JSON response object with JQ in Unix shell"
    },
    {
        "tags": [
            "json",
            "key",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 36,
                "is_accepted": true,
                "score": 36,
                "last_activity_date": 1485271270,
                "last_edit_date": 1495542380,
                "creation_date": 1420715956,
                "answer_id": 27838881,
                "question_id": 27838154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `map()` function to filter any key:\r\n\r\n    jq &#39;map({name: .name})&#39;\r\n\r\n###Update\r\nSuggested by [`@WilfredHughes`][1]: The above filter can be abbreviated as follows:\r\n\r\n    jq &#39;map({name})&#39;\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/509706/wilfred-hughes",
                "title": "How do I remove all keys except one with jq?"
            },
            {
                "up_vote_count": 26,
                "is_accepted": false,
                "score": 25,
                "last_activity_date": 1420716236,
                "creation_date": 1420716236,
                "answer_id": 27838968,
                "question_id": 27838154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you can use `map` with `del` if you know the keys you don&#39;t want:\r\n\r\n    jq &#39;map(del (.group) | del (.created))&#39;",
                "title": "How do I remove all keys except one with jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1465573074,
                "creation_date": 1465573074,
                "answer_id": 37752134,
                "question_id": 27838154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another solution without the `map` function:\r\n\r\n    jq &#39;[.[] | {name: .name}]&#39;",
                "title": "How do I remove all keys except one with jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1485699022,
                "creation_date": 1485699022,
                "answer_id": 41921795,
                "question_id": 27838154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The accepted answer (with `map`) and the equivalent answer by @mauricio-tranjano will, in effect, add the specified key to objects that don&#39;t already have it.  If that&#39;s not the behavior you want, then consider using `has(_)`, e.g.:\r\n\r\n    $ jq -c &#39;map( if has(&quot;a&quot;) then {a} else {} end )&#39;\r\n\r\nInput:\r\n\r\n    [{id:1,a:1}, {id:2}]\r\n\r\nOutput:\r\n\r\n    [{&quot;a&quot;:1},{}]",
                "title": "How do I remove all keys except one with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643310624,
                "creation_date": 1643310624,
                "answer_id": 70884388,
                "question_id": 27838154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would allow keeping a set of fields (matched by regex).\r\n\r\n```\r\nmap(\r\n  to_entries\r\n  |map(select(.key|test(&quot;^(name)$&quot;)))\r\n  |from_entries\r\n)\r\n```",
                "title": "How do I remove all keys except one with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1700478234,
                "creation_date": 1700478234,
                "answer_id": 77515353,
                "question_id": 27838154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**8 years later...**\r\n\r\nAs of [`jq` version 1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), [`pick`](https://jqlang.github.io/jq/manual/#pick) can be used:\r\n\r\n```bash\r\njq &#39;pick(.[].name)&#39;\r\n```",
                "title": "How do I remove all keys except one with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 32,
        "last_activity_date": 1700478234,
        "creation_date": 1420713705,
        "last_edit_date": 1485702627,
        "question_id": 27838154,
        "body_markdown": "Given a list of objects, with many keys I don&#39;t want:\r\n\r\n    [{\r\n        &quot;name&quot;: &quot;Alice&quot;,\r\n        &quot;group&quot;: &quot;Admins&quot;,\r\n        &quot;created&quot;: &quot;2014&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Bob&quot;,\r\n        &quot;group&quot;: &quot;Users&quot;,\r\n        &quot;created&quot;: &quot;2014&quot;\r\n    }]\r\n\r\n\r\nHow do I filter these objects to only include keys I want?\r\n\r\n    [{\r\n        &quot;name&quot;: &quot;Alice&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Bob&quot;\r\n    }]\r\n\r\n\r\nI&#39;ve tried `jq &#39;.[].name&#39;` but that extracts the values, rather than preserving the objects.",
        "link": "https://stackoverflow.com/questions/27838154/how-do-i-remove-all-keys-except-one-with-jq",
        "title": "How do I remove all keys except one with jq?"
    },
    {
        "tags": [
            "curl",
            "jira",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1420731549,
                "post_id": 27841690,
                "comment_id": 44091410,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1420732401,
                "post_id": 27841690,
                "comment_id": 44092041,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1420733406,
                "post_id": 27841690,
                "comment_id": 44092803,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1420733628,
                "creation_date": 1420733628,
                "answer_id": 27844609,
                "question_id": 27841690,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I found the answer, \r\n\r\nThe original and incorrect attempt looks like this:\r\n\r\n    curl to jira | jq &#39;.[&quot;issues&quot;] | \r\n       map({\r\n        key: .key, \r\n        type: .fields.issuetype.name, \r\n        typeid: .fields.issuetype.id, \r\n        status: .fields.status.name, \r\n        summary: .fields.summary, \r\n        closedDate: .fields.resolutiondate, \r\n        flag: .fields.customfield_10170[&quot;value&quot;]})&#39;\r\n        &gt;  output/json/FullIssueList.json\r\n\r\n\r\nI wasn&#39;t treating the entry for `flag` as a separate array. So that single line should have been:\r\n\r\n`flag: .fields.customfield_10170[0].value`\r\n\r\nThis takes the first element in the array, `[0]` and then requests the `value` field. \r\n",
                "title": "Mapping values at the top level and a single value from a nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1420733628,
        "creation_date": 1420725016,
        "last_edit_date": 1495542034,
        "question_id": 27841690,
        "body_markdown": "I&#39;m attempting to do this with a jira issue and a custom field and it&#39;s proving to be quite difficult.\r\n\r\nFor conciseness lets say that the below is what I&#39;ve received:\r\n\r\n    &quot;expand&quot;: &quot;editmeta,renderedFields,transitions,changelog,operations&quot;,\r\n    &quot;id&quot;: &quot;59378&quot;,\r\n    &quot;self&quot;: &quot;https://myjirainstance.com/jira/rest/api/2/issue/59378&quot;,\r\n    &quot;key&quot;: &quot;AB-12345&quot;,\r\n    &quot;fields&quot;:\r\n      {\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;19&quot;,\r\n        &quot;status&quot;: &quot;Backlog&quot;,\r\n        &quot;summary&quot;: &quot;I&#39;m a big bad bug&quot;,\r\n        &quot;closedDate&quot;: null,\r\n        &quot;customfield_10170&quot;:[{&quot;self&quot;:&quot;http://address/1938&quot;,&quot;value&quot;:&quot;Critical&quot;,&quot;id&quot;:&quot;10404&quot;}]\r\n      },\r\n\r\nI&#39;ve previously mapped all the other fields like so\r\n\r\n    curl to jira | jq &#39;.[&quot;issues&quot;] | \r\n       map({\r\n        key: .key, \r\n        type: .fields.issuetype.name, \r\n        typeid: .fields.issuetype.id, \r\n        status: .fields.status.name, \r\n        summary: .fields.summary, \r\n        closedDate: .fields.resolutiondate, \r\n        flag: .fields.customfield_10170[&quot;value&quot;]})&#39;\r\n        &gt;  output/json/FullIssueList.json\r\n\r\nBut adding that last line in order to get `value` as [suggested here](https://stackoverflow.com/questions/27562424/jq-nested-object-extract-top-level-id-and-lift-a-value-from-internal-object) results in the entire object being excluded from the output file. \r\n\r\nany ideas?",
        "link": "https://stackoverflow.com/questions/27841690/mapping-values-at-the-top-level-and-a-single-value-from-a-nested-object",
        "title": "Mapping values at the top level and a single value from a nested object"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1420751823,
                "creation_date": 1420751823,
                "answer_id": 27849664,
                "question_id": 27848887,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Map each entry to the `closedDate` filtering out non-values, then get the minimum value.\r\n\r\n    map(.closedDate | values) | min",
                "title": "Returning a single minimum date value from a key across multiple objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1420751823,
        "creation_date": 1420748594,
        "question_id": 27848887,
        "body_markdown": "I&#39;ve got a set of objects as below, and I&#39;m trying to obtain just a single date value from across all of them. \r\n\r\nThe desired output is:\r\n\r\n`&quot;2014-12-16T08:59:08.000+0100&quot;`\r\n\r\nThe data set is:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;AB-12345&quot;,\r\n        &quot;type&quot;: &quot;Fault&quot;,\r\n        &quot;typeid&quot;: &quot;19&quot;,\r\n        &quot;status&quot;: &quot;Open&quot;,\r\n        &quot;summary&quot;: &quot;I&#39;m a big bad fault&quot;,\r\n        &quot;closedDate&quot;: null,\r\n        &quot;flag&quot;: null\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;AB-12346&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;19&quot;,\r\n        &quot;status&quot;: &quot;Open&quot;,\r\n        &quot;summary&quot;: &quot;I&#39;m a big bad bug&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-12-16T08:59:08.000+0100&quot;,\r\n        &quot;flag&quot;: null\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;AB-12347&quot;,\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;typeid&quot;: &quot;19&quot;,\r\n        &quot;status&quot;: &quot;Open&quot;,\r\n        &quot;summary&quot;: &quot;I&#39;m a big bad feature&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-12-17T08:27:07.000+0100&quot;,\r\n        &quot;flag&quot;: null\r\n      }\r\n     ]\r\n\r\nI&#39;ve managed to get as far as using:\r\n\r\n`.[] | {&quot;closedDate&quot;: .closedDate} | select(.closedDate &gt; 0)`\r\n\r\nWhich will get me:\r\n\r\n    {\r\n      &quot;closedDate&quot;: &quot;2014-12-16T08:59:08.000+0100&quot;\r\n    }\r\n    {\r\n      &quot;closedDate&quot;: &quot;2014-12-17T08:27:07.000+0100&quot;\r\n    }\r\n\r\n\r\nbut I can&#39;t figure out a way of using `select`, `max_by` or `min_by` to achieve this. \r\n\r\nI&#39;m on jq 1.4",
        "link": "https://stackoverflow.com/questions/27848887/returning-a-single-minimum-date-value-from-a-key-across-multiple-objects-with-jq",
        "title": "Returning a single minimum date value from a key across multiple objects with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1420996812,
                "creation_date": 1420996812,
                "answer_id": 27889871,
                "question_id": 27889137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You misunderstand the point of the `@` filters.  These are string formatting filters, they yield strings.  So `@csv` returns a string representation of the array as a csv row.  That&#39;s precisely what it&#39;s supposed to.  It would be wrong for it to return the &quot;unstringified&quot; version because it would not be possible to process any further.\r\n\r\nIf you want the raw &quot;unstringified&quot; output, use the `-r` raw output option.\r\n\r\n    $ echo &#39;[&quot;a&quot;,1,true,&quot;comment&quot;]&#39; | jq -r &#39;@csv&#39;\r\n    &quot;a&quot;,1,true,&quot;comment&quot;",
                "title": "Conversion of json array to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1420996812,
        "creation_date": 1420992359,
        "question_id": 27889137,
        "body_markdown": "Using `jq` to convert a json array to csv results in this:\r\n\r\n    $ echo &#39;[&quot;a&quot;,1,true,&quot;comment&quot;]&#39; | jq &#39;.|@csv&#39;\r\n    &quot;\\&quot;a\\&quot;,1,true,\\&quot;comment\\&quot;&quot;\r\n\r\nI am surprised that the entire array becomes one string rather than a list of values. What can I do to get \r\n\r\n    &quot;a&quot;,1,true,&quot;comment&quot;\r\n\r\ninstead?",
        "link": "https://stackoverflow.com/questions/27889137/conversion-of-json-array-to-csv-using-jq",
        "title": "Conversion of json array to csv using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3518150,
                    "reputation": 315,
                    "user_id": 2941084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7772e6b2cc1c6f1257fca9bfb8991245?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shane",
                    "link": "https://stackoverflow.com/users/2941084/shane"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459243218,
                "post_id": 27993448,
                "comment_id": 60186559,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 3518150,
                    "reputation": 315,
                    "user_id": 2941084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7772e6b2cc1c6f1257fca9bfb8991245?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shane",
                    "link": "https://stackoverflow.com/users/2941084/shane"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1461797252,
                "post_id": 27993448,
                "comment_id": 61368612,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1421449076,
                "last_edit_date": 1421449076,
                "creation_date": 1421445697,
                "answer_id": 27993498,
                "question_id": 27993448,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Variables aren&#39;t interpolated inside single quotes. Use double quotes instead, and remove the existing quotes.\r\n\r\n    v1=($(cat $INPUT | jq &quot;.config[$i].var1[]&quot;))\r\n\r\nOr use the `--arg` option and then you can stick with single quotes.\r\n\r\n    v1=($(cat $INPUT | jq --arg i &quot;$i&quot; &#39;.config[$i].var1[]&#39;))\r\n\r\nYou could also fix the useless use of cat:\r\n\r\n    v1=($(jq &quot;.config[$i].var1[]&quot; &quot;$INPUT&quot;))\r\n\r\nAlso, see @CharlesDuffy&#39;s answer for a great, detailed explanation of why assigning to array like this is unsafe.",
                "title": "bash: Iterating over members of a JSON array selected by index"
            },
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1421460529,
                "last_edit_date": 1421460529,
                "creation_date": 1421447420,
                "answer_id": 27993824,
                "question_id": 27993448,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s a fair bit of room for improvement. Let&#39;s start here:\r\n\r\n    v1=($(cat $INPUT | jq &#39;.&quot;config&quot;[$i].&quot;var1&quot;[]&#39;))\r\n\r\n...first, you don&#39;t actually need to use `cat`; it&#39;s slowing your performance, because it forces `jq` to read from a pipe rather than from your input file directly. Just running `jq &lt;&quot;$INPUT&quot;` would be more robust (or, better, `&lt;&quot;$input&quot;`, to avoid using all-uppercase names, which are reserved by convention for shell builtins and environment variables).\r\n\r\nSecond, you need to quote all variable expansions, including the expansion of the input file&#39;s name -- otherwise, you&#39;ll get bugs whenever your filename contains spaces.\r\n\r\nThird, `array=( $(stuff) )` splits the output of `stuff` on *all characters in IFS*, and expands the results of that splitting as a series of glob expressions (so if the output contains `*.txt`, and you&#39;re running this script in a directory that contains text files, you get the names of those files in your result array). Splitting on newlines only would mean you could correctly parse multi-word strings, and disabling glob expansion is necessary before you can use this technique reliably in the presence of glob characters. One way to do this is to set `IFS=$&#39;\\n&#39;` and run `set -h` before running this command; another is to redirect the output of your command into a `while read` loop (shown below).\r\n\r\nFourth, string substitution into code is bad practice in any language -- that way lies (local equivalents to) &lt;A HREF=&quot;http://xkcd.com/327/&quot;&gt;Bobby Tables&lt;/A&gt;, allowing someone who&#39;s supposed to be able to only change the data passed into your process to provide content which is processed as executable code (albeit, in this case, as a `jq` script, which is less dangerous than arbitrary code execution in a more full-featured language; still, this can allow extra data to be added to the output).\r\n\r\nNext, once you&#39;re getting `jq` to emit newline-separated content, you don&#39;t need to read it into an array at all: You can iterate over the content as it&#39;s written from `jq` and read into your shell, thus preventing the shell from needing to allocate memory to buffer that content:\r\n\r\n    while IFS= read -r; do\r\n      echo &quot;read content from jq: $REPLY&quot;\r\n    done &lt; &lt;(jq -r --arg i &quot;$i&quot; &#39;.config[$i | tonumber].var1[]&#39; &lt;&quot;$input&quot;)\r\n\r\nFinally -- let&#39;s say you _do_ want to work with an array. There are two ways to do this that avoid pitfalls. One is to set `IFS` explicitly and disable glob expansion before the assignment:\r\n\r\n    IFS=$&#39;\\n&#39; # split only on newlines\r\n    set -f\r\n    result=( $(jq -r ... &lt;&quot;$input&quot;) )\r\n\r\nThe other is to assign to your array with a loop:\r\n\r\n    result=( )\r\n    while IFS= read -r; do\r\n      result+=( &quot;$REPLY&quot; )\r\n    done &lt; &lt;(jq -r ... &lt;&quot;$input&quot;)\r\n\r\n...or, as suggested by @JohnKugelman, to use `read -a` to read the whole array in one operation:\r\n\r\n    IFS=$&#39;\\n&#39; read -r -d &#39;&#39; -a result &lt; &lt;(jq -r ... &lt;&quot;$input&quot;)",
                "title": "bash: Iterating over members of a JSON array selected by index"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1448345559,
                "creation_date": 1448345559,
                "answer_id": 33886618,
                "question_id": 27993448,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` is capable of extracting the structure in one go, so the entire loop is superfluous.  If the input JSON contains more records than you have values in `nvars`, use the index to chop.\r\n\r\n    jq -r &#39;.&quot;config-vars&quot;[].&quot;var1&quot;&#39; &quot;$INPUT&quot; |\r\n    head -n &quot;${#nvars[@]}&quot;  # If you need just the #nvars first values",
                "title": "bash: Iterating over members of a JSON array selected by index"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1641219620,
                "last_edit_date": 1641219620,
                "creation_date": 1498066295,
                "answer_id": 44682640,
                "question_id": 27993448,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have already stored the result of some JSON into a variable called $MY_VAR:\r\n\r\n    while IFS= read -r; do\r\n      echo &quot;$REPLY&quot;\r\n    done &lt; &lt;(echo &quot;$MY_VAR&quot; | jq -r &#39;.[]&#39;)",
                "title": "bash: Iterating over members of a JSON array selected by index"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 6,
        "last_activity_date": 1641219620,
        "creation_date": 1421445484,
        "last_edit_date": 1475080833,
        "question_id": 27993448,
        "body_markdown": "I&#39;m using `jq` to parse a JSON file, extracting each JSON array in a series into a shell array.\r\n\r\nMy current code looks like the following:\r\n\r\n    for ((i = 0; i &lt; ${#nvars[@]}; i++)); do\r\n        v1=($(cat $INPUT | jq &#39;.&quot;config&quot;[i].&quot;var1&quot;[]&#39;))\r\n        echo $v1\r\n    done\r\n\r\nerror message:\r\n\r\n    error: i is not defined\r\n\r\nI also replaced\r\n\r\n    v1=($(cat $INPUT | jq &#39;.&quot;config&quot;[i].&quot;var1&quot;[]&#39;))\r\n\r\nwith\r\n\r\n    v1=($(cat $INPUT | jq &#39;.&quot;config&quot;[$i].&quot;var1&quot;[]&#39;))\r\n\r\nstill not working. Any idea? Any help is appreciated! \r\n\r\n\r\n-------\r\nEdit: Sample Input Data\r\n\r\n    {\r\n        &quot;config-vars&quot;:[\r\n\t        {\r\n\t\t\t\t&quot;var1&quot;:[&quot;v1&quot;,&quot;v2&quot;],\r\n\t\t\t\t&quot;var2&quot;:&quot;&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n                &quot;var1&quot;:[&quot;v3&quot;,&quot;&quot;],\r\n\t\t\t\t&quot;var2&quot;:&quot;v4&quot;\r\n\t\t\t}\r\n\t\t]\r\n    }",
        "link": "https://stackoverflow.com/questions/27993448/bash-iterating-over-members-of-a-json-array-selected-by-index",
        "title": "bash: Iterating over members of a JSON array selected by index"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "transpose",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1489787612,
                "last_edit_date": 1489787612,
                "creation_date": 1421994248,
                "answer_id": 28104166,
                "question_id": 28103489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Scratch this, it doesn&#39;t actually work for any array greater than size 2.\r\n\r\n`[map(.[0]) , map(.[1])] | map({(.[0]):.[1]}) | add`\r\n\r\nWelp, I thought this would be easy, having a little prolog experience... oh man. I ended up banging my head against a wall too. Don&#39;t think I&#39;ll ever use jq ever again.",
                "title": "Create object from array of keys and values"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1449785856,
                "last_edit_date": 1449785856,
                "creation_date": 1422027173,
                "answer_id": 28113274,
                "question_id": 28103489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The current version of jq has a `transpose` filter that can be used to pair up the keys and values.  You could use it to build out the result object rather easily.\r\n\r\n    transpose | reduce .[] as $pair ({}; .[$pair[0]] = $pair[1])",
                "title": "Create object from array of keys and values"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1422043408,
                "creation_date": 1422043408,
                "answer_id": 28117842,
                "question_id": 28103489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Resolved this on [github][1]:\r\n\r\n    .[0] as $keys |\r\n    .[1] as $values |\r\n    reduce range(0; $keys|length) as $i  ( {}; . + { ($keys[$i]): $values[$i] })\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/675",
                "title": "Create object from array of keys and values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1441473972,
                "creation_date": 1441473972,
                "answer_id": 32415821,
                "question_id": 28103489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just to be clear:\r\n\r\n(0) Abdullah Jibaly&#39;s solution is simple, direct, efficient and generic, and should work in all versions of jq;\r\n\r\n(1) transpose/0 is a builtin in jq 1.5 and has been available in pre-releases since Oct 2014;\r\n\r\n(2) using transpose/0 (or zip/0 as defined above), an even shorter but still simple, fast, and generic solution to the problem is:\r\n\r\n    transpose | map( {(.[0]): .[1]} ) | add\r\n\r\n\r\nExample:\r\n\r\n    $ jq &#39;transpose | map( {(.[0]): .[1]} ) | add&#39;\r\n\r\nInput:\r\n\r\n    [[&quot;k1&quot;,&quot;k2&quot;,&quot;k3&quot;], [1,2,3] ]\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;k1&quot;: 1,\r\n      &quot;k2&quot;: 2,\r\n      &quot;k3&quot;: 3\r\n    }\r\n",
                "title": "Create object from array of keys and values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501780260,
                "creation_date": 1501780260,
                "answer_id": 45490649,
                "question_id": 28103489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **reduce** with a state object holding an iteration index and a result object.  It iterates over the keys in `.[0]` setting corresponding values in the result from `.[1]` \r\n\r\n      .[1] as $v\r\n    | reduce .[0][] as $k (\r\n       {idx:0, result:{}}; .result[$k] = $v[.idx] | .idx += 1\r\n      )\r\n    | .result\r\n",
                "title": "Create object from array of keys and values"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 9,
        "last_activity_date": 1501780260,
        "creation_date": 1421990326,
        "last_edit_date": 1489896008,
        "question_id": 28103489,
        "body_markdown": "I&#39;ve been banging my head against the wall for several hours on this and just can&#39;t seem to find a way to do this. I have an array of keys and an array of values, how can I generate an object? Input:\r\n\r\n    [[&quot;key1&quot;, &quot;key2&quot;], [&quot;val1&quot;, &quot;val2&quot;]]\r\n\r\nOutput:\r\n\r\n    {&quot;key1&quot;: &quot;val1&quot;, &quot;key2&quot;: &quot;val2&quot;}",
        "link": "https://stackoverflow.com/questions/28103489/create-object-from-array-of-keys-and-values",
        "title": "Create object from array of keys and values"
    },
    {
        "tags": [
            "sed",
            "grep",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3057,
                    "reputation": 250951,
                    "user_id": 4323,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/qqgFU.png?s=256",
                    "display_name": "John Zwinck",
                    "link": "https://stackoverflow.com/users/4323/john-zwinck"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1422334095,
                "post_id": 28163355,
                "comment_id": 44697778,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1422335386,
                "creation_date": 1422335386,
                "answer_id": 28163624,
                "question_id": 28163355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "sed isn&#39;t very good for multiline matches.  \r\n\r\nYou&#39;ll want to use [jq][1] instead... it&#39;s, &quot;like sed for JSON data&quot;. \r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
                "title": "Removing lines from list of files in terminal"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1422499063,
                "creation_date": 1422499063,
                "answer_id": 28206124,
                "question_id": 28163355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Well, in the end I still couldn&#39;t figure out using `jq` and instead upon finding some sources, I used a script to execute and perform the deletion\r\n\r\n    import sys\r\n    import json\r\n    \r\n    inputfile = sys.argv[1]\r\n    with open(inputfile,&#39;r&#39;) as myfile:\r\n        obj = json.loads(myfile.read().replace(&#39;True&#39;,&#39;true&#39;))\r\n        if &quot;unitmap&quot; in obj:\r\n            del obj[&quot;unitmap&quot;]\r\n    with open(inputfile,&#39;w&#39;) as myfile:\r\n        json.dump(obj,myfile,indent=4,separators=(&#39;,&#39;,&#39;: &#39;))\r\n\r\nSeems to work thus far but do comment in if there is a better way :)",
                "title": "Removing lines from list of files in terminal"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503602399,
                "creation_date": 1503602399,
                "answer_id": 45869404,
                "question_id": 28163355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **del**. If `input.json` contains\r\n\r\n    {\r\n        &quot;tags&quot;: {}, \r\n        &quot;map&quot;: {\r\n            &quot;KPA&quot;: {\r\n                &quot;State&quot;: true, \r\n                &quot;namespace&quot;: &quot;KPA01&quot;\r\n            }\r\n        }\r\n    }\r\n    {\r\n        &quot;tags&quot;: {\r\n            &quot;type&quot;: [\r\n                &quot;char&quot;\r\n            ], \r\n            &quot;dynamic&quot;: true\r\n        }, \r\n        &quot;unitmap&quot;: {\r\n            &quot;KPA01&quot;: {\r\n                &quot;State&quot;: true, \r\n                &quot;namespace&quot;: &quot;KPA01&quot;\r\n            }\r\n        }\r\n    }\r\n\r\ninvoking jq as\r\n\r\n    jq -M -c &#39;del(.map, .unitmap)&#39; input.json\r\n\r\nwill produce the output\r\n\r\n    {&quot;tags&quot;:{}}\r\n    {&quot;tags&quot;:{&quot;type&quot;:[&quot;char&quot;],&quot;dynamic&quot;:true}}\r\n",
                "title": "Removing lines from list of files in terminal"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1503602399,
        "creation_date": 1422333473,
        "last_edit_date": 1422348912,
        "question_id": 28163355,
        "body_markdown": "I am trying to write up a command line interfaces that will removes a particular section / lines of codes within a list of json files. By the way, the json file are located within the sub-folders of the main directory\r\n\r\nThis is the code that I can come up with - `find -name &quot;*.json&quot; | xargs sed -i &quot;map&quot;` but some of the json files I had, its format is slightly different\r\n\r\nSo far I am seeing the following 2 formats within my list:\r\n\r\n    {\r\n        &quot;tags&quot;: {}, \r\n        &quot;map&quot;: {\r\n            &quot;KPA&quot;: {\r\n                &quot;State&quot;: True, \r\n                &quot;namespace&quot;: &quot;KPA01&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nor \r\n\r\n    {\r\n        &quot;tags&quot;: {\r\n            &quot;type&quot;: [\r\n                &quot;char&quot;\r\n            ], \r\n            &quot;dynamic&quot;: true\r\n        }, \r\n        &quot;unitmap&quot;: {\r\n            &quot;KPA01&quot;: {\r\n               &quot;State&quot;: True, \r\n                &quot;namespace&quot;: &quot;KPA01&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nand basically, I am trying to omit out the `map` section that it has, so that it will only display the `tags` section but the presence of commas and [] / {} are making it hard for me.\r\n\r\nWill this be possible to do so in a command line interface?",
        "link": "https://stackoverflow.com/questions/28163355/removing-lines-from-list-of-files-in-terminal",
        "title": "Removing lines from list of files in terminal"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 753,
                "is_accepted": false,
                "score": 751,
                "last_activity_date": 1642751498,
                "last_edit_date": 1642751498,
                "creation_date": 1436911471,
                "answer_id": 31418194,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I recommend using String Interpolation:\r\n\r\n    jq &#39;.users[] | &quot;\\(.first) \\(.last)&quot;&#39;\r\n\r\nWe are piping down the result of `.users[]` to generate the string &quot;.first .last&quot; using string interpolation. `\\(foo)` syntax is used for string interpolation in `jq`. So, for the above example, it becomes &quot;Stevie Wonder&quot; (`&quot;.users[].first .users[].second&quot;` working elementwise) and &quot;Michael Jackson&quot;.\r\n\r\njq reference: [String interpolation][1]\r\n\r\n  [1]: http://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 397,
                "is_accepted": false,
                "score": 396,
                "last_activity_date": 1590566992,
                "last_edit_date": 1590566992,
                "creation_date": 1438616485,
                "answer_id": 31791436,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [addition][1] to concatenate strings.\r\n\r\n&gt; **Strings** are added by being joined into a larger string.\r\n\r\n    jq &#39;.users[] | .first + &quot; &quot; + .last&#39;\r\n\r\nThe above works when both `first` and `last` are string. If you are extracting different datatypes(number and string), then we need to convert to equivalent types. Referring to [solution on this question][2]. For example.\r\n\r\n    jq &#39;.users[] | .first + &quot; &quot; + (.number|tostring)&#39;\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Addition\r\n  [2]: https://stackoverflow.com/a/46674867/979772",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1494863667,
                "last_edit_date": 1494863667,
                "creation_date": 1462135158,
                "answer_id": 36971694,
                "question_id": 28164849,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "While both of the above answers work well if key,value are strings, I had a situation to append a string and integer (jq errors using the above expressions) \r\n\r\nRequirement: To construct a url out below json\r\n\r\n    pradeep@seleniumframework&gt;curl http://192.168.99.103:8500/v1/catalog/service/apache-443 | jq .[0]\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100   251  100   251    0     0   155k      0 --:--:-- --:--:-- --:--:--  245k\r\n    {\r\n      &quot;Node&quot;: &quot;myconsul&quot;,\r\n      &quot;Address&quot;: &quot;192.168.99.103&quot;,\r\n      &quot;ServiceID&quot;: &quot;4ce41e90ede4:compassionate_wozniak:443&quot;,\r\n      &quot;ServiceName&quot;: &quot;apache-443&quot;,\r\n      &quot;ServiceTags&quot;: [],\r\n      &quot;ServiceAddress&quot;: &quot;&quot;,\r\n      &quot;ServicePort&quot;: 1443,\r\n      &quot;ServiceEnableTagOverride&quot;: false,\r\n      &quot;CreateIndex&quot;: 45,\r\n      &quot;ModifyIndex&quot;: 45\r\n    }\r\n\r\nSolution:\r\n\r\n    curl http://192.168.99.103:8500/v1/catalog/service/apache-443 |\r\n    jq &#39;.[0] | &quot;http://&quot; + .Address + &quot;:&quot; + &quot;\\(.ServicePort)&quot;&#39;\r\n",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1500672676,
                "creation_date": 1500672676,
                "answer_id": 45246993,
                "question_id": 28164849,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I got pretty close to what I wanted by doing something like this\r\n\r\n    cat my.json | jq &#39;.my.prefix[] | .primary_key + &quot;:&quot;, (.sub.prefix[] | &quot;    - &quot; + .sub_key)&#39; | tr -d &#39;&quot;&#39; \r\n\r\nThe output of which is close enough to yaml for me to usually import it into other tools without much problem. (I am still looking for a way to basicallt export a subset of the input json)",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1559850994,
                "creation_date": 1559850994,
                "answer_id": 56484285,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will produce an array of names\r\n\r\n```\r\n&gt; jq &#39;[ .users[] | (.first + &quot; &quot; + .last) ]&#39; ~/test.json\r\n\r\n[\r\n  &quot;Stevie Wonder&quot;,\r\n  &quot;Michael Jackson&quot;\r\n]\r\n```",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 86,
                "is_accepted": false,
                "score": 86,
                "last_activity_date": 1749584221,
                "last_edit_date": 1749584221,
                "creation_date": 1561692300,
                "answer_id": 56800543,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.users[]|.first,.last&#39; | paste - -\r\n```\r\n\r\n**N** fields per `jq` record == **N** dashes in `paste`.",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 22,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1584464606,
                "creation_date": 1584464606,
                "answer_id": 60726989,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "my approach will be (your json example is not well formed.. guess thats only a sample)\r\n\r\n\r\n    jq &#39;.Front[] | [.Name,.Out,.In,.Groups] | join(&quot;|&quot;)&#39;  front.json  &gt; output.txt\r\n\r\nreturns something like this \r\n\r\n    &quot;new.domain.com-80|8.8.8.8|192.168.2.2:80|192.168.3.29:80 192.168.3.30:80&quot;\r\n    &quot;new.domain.com -443|8.8.8.8|192.168.2.2:443|192.168.3.29:443 192.168.3.30:443&quot;\r\n\r\nand grep the output with regular expression. \r\n\r\n\r\n",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 93,
                "is_accepted": false,
                "score": 93,
                "last_activity_date": 1628157543,
                "creation_date": 1628157543,
                "answer_id": 68664471,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In addition to what others have suggested, I think that two options are worth mentioning.\r\n\r\n### Print as CSV/TSV\r\n\r\n```bash\r\n$ cat file.json | jq -r &#39;.users[] | [.first, .last] | @tsv&#39;\r\nStevie  Wonder\r\nMichael Jackson\r\n```\r\n\r\n```bash\r\ncat file.json | jq -r &#39;.users[] | [.first, .last] | @csv&#39;\r\n&quot;Stevie&quot;,&quot;Wonder&quot;\r\n&quot;Michael&quot;,&quot;Jackson&quot;\r\n```\r\n\r\nThe first expression, `.users[]`, unnests the objects from the outer-most array as in the code given in the question. The next expression, `[.first, .last]`, creates a new array of the values for each input object, and the final expression uses the built-in functions `@tsv` and `@csv` to print all input arrays as tab-separated and comma-seperated values, respectively.\r\n\r\n### Print as JSON values\r\n\r\nSimilarly, it is possible to construct JSON values again, which is interesting if you just want to keep a subset of the fields:\r\n\r\n```bash\r\n$ cat file.json | jq -c &#39;.users[] | {first}&#39;\r\n{&quot;first&quot;:&quot;Stevie&quot;}\r\n{&quot;first&quot;:&quot;Michael&quot;}\r\n```",
                "title": "Using jq to parse and display multiple fields in a json serially"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1715772232,
                "last_edit_date": 1715772232,
                "creation_date": 1715771392,
                "answer_id": 78483503,
                "question_id": 28164849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A little bit more steps but I noticed no one here mentions `join()`. `join()` only works for array so you need to construct one. To eliminate double quotes, use  `-r`:\r\n\r\n    echo $JSON | jq -r &#39;.users[] | [.first,.last] | join(&quot; &quot;)&#39;\r\n\r\n`,` means applying filter to the previous step&#39;s output with such order, so you `.first` then you get `.last` and create an array. \r\n\r\nA small test does not show any performance degrading. ",
                "title": "Using jq to parse and display multiple fields in a json serially"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 542,
        "last_activity_date": 1749584221,
        "creation_date": 1422341673,
        "last_edit_date": 1616840951,
        "question_id": 28164849,
        "body_markdown": "I have this Json\r\n\r\n    {\r\n        &quot;users&quot;: [\r\n            {\r\n                &quot;first&quot;: &quot;Stevie&quot;,\r\n                &quot;last&quot;: &quot;Wonder&quot;\r\n            },\r\n            {\r\n                &quot;first&quot;: &quot;Michael&quot;,\r\n                &quot;last&quot;: &quot;Jackson&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nUsing jq I&#39;d like to display first and last name serially. Like so - \r\n\r\n    Stevie Wonder\r\n    Michael Jackson\r\n\r\nThis is how far I have gotten - \r\n\r\n    jq &#39;.users[].first, .users[].last&#39;\r\n\r\nBut it displays\r\n\r\n    &quot;Stevie&quot;\r\n    &quot;Michael&quot;\r\n    &quot;Wonder&quot;\r\n    &quot;Jackson&quot;\r\n\r\nNotice the following:\r\n\r\n1. The double quotes that I do not want.\r\n2. The carriage return that I do not want.\r\n3. It&#39;s jumbled up. My query displays all the first names first, and then all the last names. However, I want first-last, first-last pair.",
        "link": "https://stackoverflow.com/questions/28164849/using-jq-to-parse-and-display-multiple-fields-in-a-json-serially",
        "title": "Using jq to parse and display multiple fields in a json serially"
    },
    {
        "tags": [
            "amazon-web-services",
            "docker",
            "amazon-elastic-beanstalk",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 37,
                "is_accepted": false,
                "score": 37,
                "last_activity_date": 1422976102,
                "creation_date": 1422976102,
                "answer_id": 28302180,
                "question_id": 28213232,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem is that your Dockerrun.aws.json file is missing the `Volumes` property.\r\n\r\nThe 04pre.sh script uses the [jq](https://stedolan.github.io/jq/) tool in order to query the JSON file.\r\n\r\nSpecifically, it runs the following command on your file, which yields to an error:\r\n\r\n    $ jq -c &#39;.Volumes[] | [.HostDirectory, .ContainerDirectory]&#39; &lt; Dockerrun.aws.json\r\n    jq: error: Cannot iterate over null\r\n\r\nSpecifying an empty &quot;Volumes&quot; array should resolve the error.",
                "title": "Docker Error - &quot;jq: error: Cannot iterate over null&quot;"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1457521791,
                "creation_date": 1457521791,
                "answer_id": 35889903,
                "question_id": 28213232,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Note that an Elastic Beanstalk deployment to the Docker platform can fail with the &quot;jq: error ... Cannot iterate over null...&quot; error message in various phases of an Elastic Beanstalk deployment, for various different reasons. This can include your application (Docker container) quitting or erroring on startup. \r\n\r\nAlthough this particular reported occurrence of the problem may have been specific to a missing &quot;Volumes&quot; property in Dockerrun.aws.json, your problem may not be. If you get this error, then the best way to go about diagnosing the problem is to download your full EB logs and check the diagnostics in the following log file /var/log/eb-activity.log.\r\n\r\nIf the problem was caused by your application failing to startup then you&#39;ll find the error in /var/log/eb-docker/containers/eb-current-app/unexpected-quit.log.",
                "title": "Docker Error - &quot;jq: error: Cannot iterate over null&quot;"
            },
            {
                "up_vote_count": 82,
                "is_accepted": false,
                "score": 81,
                "last_activity_date": 1460057142,
                "creation_date": 1460057142,
                "answer_id": 36485400,
                "question_id": 28213232,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&lt;!-- language-all: none --&gt;\r\nIf others are looking for how to avoid the `Cannot iterate over null` error in their own `jq` commands, add a question mark after `[]`. For example\r\n\r\n    echo &#39;{\r\n      &quot;AWSEBDockerrunVersion&quot;: &quot;1&quot;,\r\n      &quot;Image&quot;: {\r\n        &quot;Name&quot;: &quot;blah&quot;,\r\n        &quot;Update&quot;: &quot;false&quot;\r\n      },\r\n      &quot;Ports&quot;: [\r\n        {\r\n          &quot;ContainerPort&quot;: &quot;8080&quot;\r\n        }\r\n      ]\r\n    }&#39;|jq -c &#39;.Volumes[]?|[.HostDirectory,.ContainerDirectory]&#39;\r\n\r\nwhere `[]` was replaced with `[]?` does not display the error.\r\n\r\nFrom the manual:\r\n\r\n    .[]?\r\n        Like .[], but no errors will be output if . is not an array or object.\r\n",
                "title": "Docker Error - &quot;jq: error: Cannot iterate over null&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505121466,
                "creation_date": 1505121466,
                "answer_id": 46152133,
                "question_id": 28213232,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In my case issue was caused by `ADD` in Dockerfile instead of `COPY` instruction. Changing it fixed the issue.",
                "title": "Docker Error - &quot;jq: error: Cannot iterate over null&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698757003,
                "creation_date": 1698757003,
                "answer_id": 77396090,
                "question_id": 28213232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For me I was already checking if the result was empty or not after running my `jq` command so I simply added `try` to the beginning of my query:\r\n\r\n**Before**\r\n```\r\n$myJson | jq -r &#39;.data[0].tags.version[] | select(startswith(&quot;&quot;chart-&quot;&quot;)) | sub(&quot;&quot;chart-&quot;&quot;;&quot;&quot;&quot;&quot;)&#39;\r\n```\r\n\r\n**After**\r\n```\r\n$myJson | jq -r &#39;try .data[0].tags.version[] | select(startswith(&quot;&quot;chart-&quot;&quot;)) | sub(&quot;&quot;chart-&quot;&quot;;&quot;&quot;&quot;&quot;)&#39;\r\n```\r\n\r\nThen if the result is empty I act accordingly.",
                "title": "Docker Error - &quot;jq: error: Cannot iterate over null&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 46,
        "last_activity_date": 1698757003,
        "creation_date": 1422529849,
        "last_edit_date": 1519656850,
        "question_id": 28213232,
        "body_markdown": "So I&#39;m trying to deploy a dockerfile on Elastic Beanstalk, but I can&#39;t get past this error - &quot;jq: error: Cannot iterate over null&quot;. \r\n\r\n\r\n    Successfully built [myContainerId]\r\n    Successfully built aws_beanstalk/staging-app\r\n    [2015-01-29T10:35:59.494Z] INFO  [16343] - [CMD-AppDeploy/AppDeployStage0/AppDeployPreHook/04run.sh] : Starting activity...\r\n    [2015-01-29T10:36:05.507Z] INFO  [16343] - [CMD-AppDeploy/AppDeployStage0/AppDeployPreHook/04run.sh] : Activity execution failed, because: command failed with error code 1: /opt/elasticbeanstalk/hooks/appdeploy/pre/04run.sh\r\n    jq: error: Cannot iterate over null\r\n    Docker container quit unexpectedly after launch: Docker container quit unexpectedly on Thu Jan 29 10:36:05 UTC 2015:. Check snapshot logs for details. (Executor::NonZeroExitStatus)\r\n\tat /opt/elasticbeanstalk/lib/ruby/lib/ruby/gems/2.1.0/gems/executor-1.0/lib/executor/exec.rb:81:in `sh&#39;\r\n\tfrom /opt/elasticbeanstalk/lib/ruby/lib/ruby/gems/2.1.0/gems/executor-1.0/lib/executor.rb:15:in `sh&#39;\r\n\tfrom /opt/elasticbeanstalk/lib/ruby/lib/ruby/gems/2.1.0/gems/beanstalk-core-1.1/lib/elasticbeanstalk/executable.rb:63:in `execute!&#39;\r\n\tfrom /opt/elasticbeanstalk/lib/ruby/lib/ruby/gems/2.1.0/gems/beanstalk-core-1.1/lib/elasticbeanstalk/hook-directory-executor.rb:29:in `block (2 levels) in run!&#39;\r\n\tfrom /opt/elasticbeanstalk/lib/ruby/lib/ruby/gems/2.1.0/gems/beanstalk-core-1.1/lib/elasticbeanstalk/activity.rb:169:in `call&#39;\r\n\tfrom /opt/elasticbeanstalk/lib/ruby/lib/ruby/gems/2.1.0/gems/beanstalk-core-1.1/lib/elasticbeanstalk/activity.rb:169:in `exec&#39;\r\n\r\n\r\n\r\nThere aren&#39;t any other errors in the logs. My Docker container is successfully built, so it seems unlikely the error is coming from there. \r\n\r\nMy Dockerrun.aws.json looks like : \r\n\r\n \r\n\r\n       {\r\n      &quot;AWSEBDockerrunVersion&quot;: &quot;1&quot;,\r\n      &quot;Image&quot;: {\r\n        &quot;Name&quot;: &quot;blah&quot;,\r\n        &quot;Update&quot;: &quot;false&quot;\r\n      },\r\n      &quot;Ports&quot;: [\r\n        {\r\n          &quot;ContainerPort&quot;: &quot;8080&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI&#39;m banging my head against a wall with this one, nothing I change seems to affect it and googling hasn&#39;t been of any help. \r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/28213232/docker-error-jq-error-cannot-iterate-over-null",
        "title": "Docker Error - &quot;jq: error: Cannot iterate over null&quot;"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "parameters",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1623138,
                    "reputation": 17456,
                    "user_id": 1499296,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/0bda7604e94b30bfb1bc2a4357a09305?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AKS",
                    "link": "https://stackoverflow.com/users/1499296/aks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1422562839,
                "post_id": 28223432,
                "comment_id": 44810670,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1307523,
                    "reputation": 77,
                    "user_id": 1256188,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/2a31d2e646963e3ac623c22d213c83c8?s=256&d=identicon&r=PG",
                    "display_name": "honestemu3",
                    "link": "https://stackoverflow.com/users/1256188/honestemu3"
                },
                "reply_to_user": {
                    "account_id": 1623138,
                    "reputation": 17456,
                    "user_id": 1499296,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/0bda7604e94b30bfb1bc2a4357a09305?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AKS",
                    "link": "https://stackoverflow.com/users/1499296/aks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1422563768,
                "post_id": 28223432,
                "comment_id": 44811244,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1422565668,
                "last_edit_date": 1422565668,
                "creation_date": 1422562628,
                "answer_id": 28223807,
                "question_id": 28223432,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In **BASH 4.3+** you can just pass an array by named reference. So your function can be simplified to:\r\n\r\n    fillarray() {\r\n       # tempArray is a reference to array name in $1\r\n       local -n tempArray=&quot;$1&quot;\r\n       while IFS= read -r entry; do\r\n          tempArray+=(&quot;$entry&quot;)\r\n       done &lt; &lt;(jq -r &#39;.data | .[].name&#39; &quot;$2&quot;)\r\n    }\r\n\r\nThen call it as:\r\n\r\n    buckets=()\r\n    fillarray buckets file.json\r\n\r\nAnd test it as:\r\n\r\n    declare -p buckets\r\n\r\n---\r\n\r\n**EDIT:** To make it work on **BASH 3.2** use below snippet:\r\n\r\n    fillarray() {\r\n       # $2 is current length of the array\r\n       i=$2\r\n       while IFS= read -r entry; do\r\n          read ${1}&quot;[$i]&quot; &lt;&lt;&lt; &quot;$entry&quot;\r\n          ((i++))\r\n       done &lt; &lt;(jq -r &#39;.data | .[].name&#39; &quot;$3&quot;)\r\n    }\r\n\r\nThen call it as:\r\n\r\n    buckets=()\r\n    fillarray buckets ${#buckets[@]} file.json\r\n",
                "title": "Modify an Array Function Parameter Bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1422572635,
                "creation_date": 1422572635,
                "answer_id": 28226350,
                "question_id": 28223432,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another way via `eval`,\r\n\r\n    fillarray () {\r\n     local tempArray;\r\n\r\n     while IFS= read -r entry; do\r\n        tempArray[${#tempArray[@]}]=&quot;$entry&quot;;\r\n     done &lt; &lt;(jq -r &#39;.data | .[].name&#39; $2);\r\n\r\n     eval $1=\\(&#39;&quot;${tempArray[@]}&quot;&#39;\\);\r\n    }\r\n",
                "title": "Modify an Array Function Parameter Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1422572635,
        "creation_date": 1422561299,
        "question_id": 28223432,
        "body_markdown": "I am trying modify an array that I have passed as a parameter to a function. So far, I have an empty array outside of the function:\r\n\r\n    buckets=()\r\n\r\nThen I have the function which takes in 2 arguments. The first argument is the empty array that I want to fill. The second argument is the name of the file that contains the data I want to use to fill the array.\r\n\r\nSo far, what I have done is create a temporary array. Then fill the temporary array with the contents of the file. This is how I do that:\r\n\r\n    fillarray ()\r\n    {\r\n    # Declare the paramater as a temporary array\r\n    declare -a tempArray=(&quot;${!1}&quot;)\r\n\r\n    # Fill it up\r\n    while IFS= read -r entry; do\r\n      tempArray+=(&quot;$entry&quot;)\r\n    done &lt; &lt;(jq -r &#39;.data | .[].name&#39; $2)\r\n\r\nThe final step is to set the parameter array(aka buckets) to be the contents of the temporary array which we just filled up. Any suggestions on how to go about doing this?",
        "link": "https://stackoverflow.com/questions/28223432/modify-an-array-function-parameter-bash",
        "title": "Modify an Array Function Parameter Bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4537281,
                    "reputation": 468,
                    "user_id": 3686125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d0b7e7e5c3a1f11d8f8544ae93c1650a?s=256&d=identicon&r=PG",
                    "display_name": "ChrisPrime",
                    "link": "https://stackoverflow.com/users/3686125/chrisprime"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547778876,
                "post_id": 28458046,
                "comment_id": 95318372,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1423677776,
                "creation_date": 1423677776,
                "answer_id": 28461226,
                "question_id": 28458046,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When you use the filter `.[]`, you are actually breaking the array result into separate results for each of the items. What you&#39;re seeing in the end is each of the individual results, one after the other.\r\n\r\nTo ensure they are kept as an array, you can put the results back into an array by wrapping your filter with square brackets:\r\n\r\n    [\r\n        .[] |\r\n        select(.Selected != null) |\r\n        {\r\n            &quot;Head Of House Name&quot;,\r\n            &quot;Head Of House Phone&quot;,\r\n            &quot;Head Of House Email&quot;,\r\n            &quot;Family Phone&quot;,\r\n            &quot;Family Email&quot;\r\n        }\r\n    ]\r\n\r\nOr keep it as an array by using the `map()` filter, you could then remove the `.[]` part:\r\n\r\n    map(\r\n        select(.Selected != null) |\r\n        {\r\n            &quot;Head Of House Name&quot;,\r\n            &quot;Head Of House Phone&quot;,\r\n            &quot;Head Of House Email&quot;,\r\n            &quot;Family Phone&quot;,\r\n            &quot;Family Email&quot;\r\n        }\r\n    )\r\n\r\nIf you asked me, you should stick with `map()`.",
                "title": "How can I filter an array of json objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1423677776,
        "creation_date": 1423668364,
        "question_id": 28458046,
        "body_markdown": "I have been able to get this far.\r\n\r\njson input, &#39;data.json&#39;:\r\n\r\n    [\r\n      {\r\n        &quot;Selected&quot;: null,\r\n        &quot;Family Name&quot;: &quot;Jones&quot;,\r\n        &quot;Couple Name&quot;: &quot;Jones, Adam &amp; Rachael Margaret&quot;,\r\n        &quot;Family Phone&quot;: &quot;404-4477&quot;,\r\n        &quot;Family Email&quot;: &quot;email@sbcglobal.net&quot;,\r\n        &quot;Family Address&quot;: &quot;777 Aggies Court Kindly, California 95388 &quot;,\r\n        &quot;Head Of House Name&quot;: &quot;Jones, Adam&quot;,\r\n        &quot;Head Of House Phone&quot;: &quot;(583) 404-2488&quot;,\r\n        &quot;Head Of House Email&quot;: &quot;email@sbcglobal.net&quot;,\r\n        &quot;Spouse Name&quot;: &quot;Jones, Rachael Margaret&quot;,\r\n        &quot;Spouse Phone&quot;: null,\r\n        &quot;Spouse Email&quot;: null,\r\n        &quot;Child Name&quot;: null,\r\n        &quot;Child Phone&quot;: null,\r\n        &quot;Child Email&quot;: null\r\n      },\r\n      {\r\n        &quot;Selected&quot;: &quot;x&quot;,\r\n        &quot;Family Name&quot;: &quot;Xiong&quot;,\r\n        &quot;Couple Name&quot;: &quot;Xiong, Arlene Frances&quot;,\r\n        &quot;Family Phone&quot;: null,\r\n        &quot;Family Email&quot;: null,\r\n        &quot;Family Address&quot;: &quot;888 Walnut Ave. Blatant, California 95388 &quot;,\r\n        &quot;Head Of House Name&quot;: &quot;Xiong, Arlene Frances&quot;,\r\n        &quot;Head Of House Phone&quot;: &quot;583-500-7917&quot;,\r\n        &quot;Head Of House Email&quot;: &quot;email@junk.net&quot;,\r\n        &quot;Spouse Name&quot;: null,\r\n        &quot;Spouse Phone&quot;: null,\r\n        &quot;Spouse Email&quot;: null,\r\n        &quot;Child Name&quot;: null,\r\n        &quot;Child Phone&quot;: null,\r\n        &quot;Child Email&quot;: null\r\n      },\r\n      {\r\n        &quot;Selected&quot;: &quot;x&quot;,\r\n        &quot;Family Name&quot;: &quot;Blair&quot;,\r\n        &quot;Couple Name&quot;: &quot;Blair, Toby &amp; Silvia&quot;,\r\n        &quot;Family Phone&quot;: &quot;358-4645&quot;,\r\n        &quot;Family Email&quot;: null,\r\n        &quot;Family Address&quot;: &quot;333 Cindy St. Stoic, California 95388 &quot;,\r\n        &quot;Head Of House Name&quot;: &quot;Blair, Toby&quot;,\r\n        &quot;Head Of House Phone&quot;: null,\r\n        &quot;Head Of House Email&quot;: &quot;email@stuff.net&quot;,\r\n        &quot;Spouse Name&quot;: &quot;Blair, Silvia&quot;,\r\n        &quot;Spouse Phone&quot;: null,\r\n        &quot;Spouse Email&quot;: null,\r\n        &quot;Child Name&quot;: null,\r\n        &quot;Child Phone&quot;: null,\r\n        &quot;Child Email&quot;: null\r\n      }\r\n    ]\r\n\r\nI can use this to filter:\r\n\r\n    cat data.json | jq &#39;.[] | select(.Selected != null) | {&quot;Head Of House Name&quot;, &quot;Head Of House Phone&quot;, &quot;Head Of House Email&quot;, &quot;Family Phone&quot;, &quot;Family Email&quot;}&#39;\r\n\r\nThe results:\r\n\r\n    {\r\n      &quot;Head Of House Name&quot;: &quot;Xiong, Arlene Frances&quot;,\r\n      &quot;Head Of House Phone&quot;: &quot;583-500-7917&quot;,\r\n      &quot;Head Of House Email&quot;: &quot;email@junk.net&quot;,\r\n      &quot;Family Phone&quot;: null,\r\n      &quot;Family Email&quot;: null\r\n    }\r\n    {\r\n      &quot;Head Of House Name&quot;: &quot;Blair, Toby&quot;,\r\n      &quot;Head Of House Phone&quot;: null,\r\n      &quot;Head Of House Email&quot;: &quot;email@stuff.net&quot;,\r\n      &quot;Family Phone&quot;: &quot;358-4645&quot;,\r\n      &quot;Family Email&quot;: null\r\n    }\r\n\r\nNotice there are no array brackets around the array of objects and no comma between the objects... indicating the result is not an array.\r\n\r\nThe problem is that the result is not an array of objects (frankly, I&#39;m not sure what it is).  How can I start with an array of json objects, filter them and end up with a filtered list of objects?\r\n",
        "link": "https://stackoverflow.com/questions/28458046/how-can-i-filter-an-array-of-json-objects-using-jq",
        "title": "How can I filter an array of json objects using jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1423728595,
                "post_id": 28472204,
                "comment_id": 45268691,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1734483,
                    "reputation": 3376,
                    "user_id": 1587370,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/d74a81f6ec0cb1e9cdcf0d36e4312f73?s=256&d=identicon&r=PG",
                    "display_name": "pratZ",
                    "link": "https://stackoverflow.com/users/1587370/pratz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1423729325,
                "post_id": 28472204,
                "comment_id": 45269047,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1299098,
                    "reputation": 1283,
                    "user_id": 1249379,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f321bb5ca87c13f07555ae616d1bdedf?s=256&d=identicon&r=PG",
                    "display_name": "TheMightyLlama",
                    "link": "https://stackoverflow.com/users/1249379/themightyllama"
                },
                "reply_to_user": {
                    "account_id": 1734483,
                    "reputation": 3376,
                    "user_id": 1587370,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/d74a81f6ec0cb1e9cdcf0d36e4312f73?s=256&d=identicon&r=PG",
                    "display_name": "pratZ",
                    "link": "https://stackoverflow.com/users/1587370/pratz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1423729702,
                "post_id": 28472204,
                "comment_id": 45269225,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1423761704,
                "last_edit_date": 1423761704,
                "creation_date": 1423729992,
                "answer_id": 28472706,
                "question_id": 28472204,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have multiple independent inputs. To be able to combine them in any meaningful way, you&#39;ll have to slurp up the input. The inputs will be treated as an array of the inputs. Then you could combine them into a single array by `add`ing them.\r\n\r\nSince the dates are all in a certain fixed format, you can take substrings of the dates.\r\n\r\n    &quot;2014-10-13T09:01:23.000+0200&quot;[:10] -&gt; &quot;2014-10-13&quot;\r\n\r\nGiven that, you can then filter by the date you want and count using the `length` filter.\r\n\r\n    add | map(select(.closedDate[:10]==&quot;2014-10-13&quot;)) | length\r\n\r\ne.g.,\r\n\r\n    $ cat input.json\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;645&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Crash when saving document&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-10-03T09:01:23.000+0200&quot;,\r\n        &quot;flag&quot;: null,\r\n        &quot;fixVersionID&quot;: &quot;123&quot;,\r\n        &quot;fixVersionName&quot;: &quot;2.7&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;552&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Graphical Issue&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-10-13T09:01:23.000+0200&quot;,\r\n        &quot;flag&quot;: null,\r\n        &quot;fixVersionID&quot;: &quot;456&quot;,\r\n        &quot;fixVersionName&quot;: &quot;2.8&quot;\r\n      }\r\n    ]\r\n    $ jq -s &#39;add | map(select(.closedDate[:10]==&quot;2014-10-13&quot;)) | length&#39; input.json\r\n    1",
                "title": "Merging multiple json arrays in the same file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1423738760,
                "creation_date": 1423738760,
                "answer_id": 28475704,
                "question_id": 28472204,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For question 1 and 2:\r\n\r\n    $ echo -e &quot;[\\n$(sed &#39;/^[][]$/d;/closedDate/s/\\(T[^&quot;]*\\)//g&#39; json)\\n]&quot; &gt; flat-json\r\n\r\nTo count the number for special day:\r\n\r\n    $ grep &quot;closedDate&quot; flat-json | grep &quot;2014-10-13&quot; | wc -l",
                "title": "Merging multiple json arrays in the same file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1423761704,
        "creation_date": 1423728085,
        "question_id": 28472204,
        "body_markdown": "I&#39;m currently downloading a ton of jira issues to generate a report. Currently the &#39;full data&#39; file has a ton of individual records like this:\r\n\r\n    {\r\n        &quot;key&quot;: &quot;645&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Crash when saving document&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-10-03T09:01:23.000+0200&quot;,\r\n        &quot;flag&quot;: null,\r\n        &quot;fixVersionID&quot;: &quot;123&quot;,\r\n        &quot;fixVersionName&quot;: &quot;2.7&quot;\r\n    }\r\n\r\nHowever, because I&#39;m downloading multiple versions and appending to the same file I end up with this kind of structure.\r\n\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;645&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Crash when saving document&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-10-03T09:01:23.000+0200&quot;,\r\n        &quot;flag&quot;: null,\r\n        &quot;fixVersionID&quot;: &quot;123&quot;,\r\n        &quot;fixVersionName&quot;: &quot;2.7&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;552&quot;,\r\n        &quot;type&quot;: &quot;Bug&quot;,\r\n        &quot;typeid&quot;: &quot;1&quot;,\r\n        &quot;status&quot;: &quot;Closed&quot;,\r\n        &quot;summary&quot;: &quot;Graphical Issue&quot;,\r\n        &quot;closedDate&quot;: &quot;2014-10-13T09:01:23.000+0200&quot;,\r\n        &quot;flag&quot;: null,\r\n        &quot;fixVersionID&quot;: &quot;456&quot;,\r\n        &quot;fixVersionName&quot;: &quot;2.8&quot;\r\n      }\r\n    ]\r\n\r\n\r\nWhat I want to do is to count the number of records with a specific date and then doing the same looping through a starting date to an end date using [jq](http://stedolan.github.io/jq/)\r\n\r\nBut, I can&#39;t figure out how to:\r\n\r\n1. Flatten the records so that they are one array not two\r\n2. Strip the `T09:01:23.000+0200` from the closedDate value\r\n3. Count the number of objects with a specific date value such as `2014-10-13`",
        "link": "https://stackoverflow.com/questions/28472204/merging-multiple-json-arrays-in-the-same-file",
        "title": "Merging multiple json arrays in the same file"
    },
    {
        "tags": [
            "json",
            "sum",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 42,
                "is_accepted": true,
                "score": 42,
                "last_activity_date": 1545904966,
                "last_edit_date": 1545904966,
                "creation_date": 1423767177,
                "answer_id": 28485485,
                "question_id": 28484534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unless your jq has `inputs`, you will have to slurp the objects up using the `-s` flag.  Then  you&#39;ll have to do a fair amount of manipulation:\r\n\r\n1. Each of the objects needs to be mapped out to key/value pairs\r\n2. Flatten the pairs to a single array\r\n3. Group up the pairs by key\r\n4. Map out each group accumulating the values to a single key/value pair\r\n5. Map the pairs back to an object\r\n\r\n&lt;!-- --&gt;\r\n\r\n    map(to_entries)\r\n        | add\r\n        | group_by(.key)\r\n        | map({\r\n              key: .[0].key,\r\n              value: map(.value) | add\r\n          })\r\n        | from_entries\r\n\r\n&lt;hr&gt;\r\n\r\nWith jq 1.5, this could be greatly improved:  You can do away with slurping and just read the `inputs` directly.\r\n\r\n    $ jq -n &#39;\r\n    reduce (inputs | to_entries[]) as {$key,$value} ({}; .[$key] += $value)\r\n    &#39; input.json\r\n\r\nSince we&#39;re simply accumulating all the values in each of the objects, it&#39;ll be easier to just run through the key/value pairs of all the inputs, and add them all up.",
                "title": "How do I sum the values in an array of maps in jq?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1511547824,
                "last_edit_date": 1511547824,
                "creation_date": 1424066912,
                "answer_id": 28535453,
                "question_id": 28484534,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another approach, which illustrates the power of jq quite nicely, is to use a filter named &quot;sum&quot; defined as follows:\r\n\r\n    def sum(f): reduce .[] as $row (0; . + ($row|f) );\r\n\r\nTo solve the particular problem at hand, one could then use the `-s` (--slurp) option as mentioned above, together with the expression:\r\n\r\n    {&quot;a&quot;: sum(.a), &quot;b&quot;: sum(.b) }  # (2)\r\n\r\nThe expression labeled (2) only computes the two specified sums, but it is easy to generalize, e.g. as follows:\r\n\r\n\r\n    # Produce an object with the same keys as the first object in the \r\n    # input array, but with values equal to the sum of the corresponding\r\n    # values in all the objects.\r\n    def sumByKey:\r\n      . as $in\r\n      | reduce (.[0] | keys)[] as $key\r\n        ( {}; . + {($key): ($in | sum(.[$key]))})\r\n    ;\r\n\r\n",
                "title": "How do I sum the values in an array of maps in jq?"
            },
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1583953036,
                "creation_date": 1583953036,
                "answer_id": 60642810,
                "question_id": 28484534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I faced the same question when listing all artifacts from GitHub (see [here][1] for details) and want to sum their size.\r\n\r\n    curl https://api.github.com/repos/:owner/:repo/actions/artifacts \\\r\n         -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n         -H &quot;Authorization:  token &lt;your_pat_here&gt;&quot; \\\r\n         | jq &#39;.artifacts | map(.size_in_bytes) | add&#39;\r\n\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;total_count&quot;: 3,\r\n      &quot;artifacts&quot;: [\r\n        {\r\n          &quot;id&quot;: 0000001,\r\n          &quot;node_id&quot;: &quot;MDg6QXJ0aWZhY3QyNzUxNjI1&quot;,\r\n          &quot;name&quot;: &quot;artifact-1&quot;,\r\n          &quot;size_in_bytes&quot;: 1,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/:owner/:repo/actions/artifacts/2751625&quot;,\r\n          &quot;archive_download_url&quot;: &quot;https://api.github.com/repos/:owner/:repo/actions/artifacts/2751625/zip&quot;,\r\n          &quot;expired&quot;: false,\r\n          &quot;created_at&quot;: &quot;2020-03-10T18:21:23Z&quot;,\r\n          &quot;updated_at&quot;: &quot;2020-03-10T18:21:24Z&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 0000002,\r\n          &quot;node_id&quot;: &quot;MDg6QXJ0aWZhY3QyNzUxNjI0&quot;,\r\n          &quot;name&quot;: &quot;artifact-2&quot;,\r\n          &quot;size_in_bytes&quot;: 2,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/:owner/:repo/actions/artifacts/2751624&quot;,\r\n          &quot;archive_download_url&quot;: &quot;https://api.github.com/repos/:owner/:repo/actions/artifacts/2751624/zip&quot;,\r\n          &quot;expired&quot;: false,\r\n          &quot;created_at&quot;: &quot;2020-03-10T18:21:23Z&quot;,\r\n          &quot;updated_at&quot;: &quot;2020-03-10T18:21:24Z&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 0000003,\r\n          &quot;node_id&quot;: &quot;MDg6QXJ0aWZhY3QyNzI3NTk1&quot;,\r\n          &quot;name&quot;: &quot;artifact-3&quot;,\r\n          &quot;size_in_bytes&quot;: 3,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/docker/mercury-ui/actions/artifacts/2727595&quot;,\r\n          &quot;archive_download_url&quot;: &quot;https://api.github.com/repos/:owner/:repo/actions/artifacts/2727595/zip&quot;,\r\n          &quot;expired&quot;: false,\r\n          &quot;created_at&quot;: &quot;2020-03-10T08:46:08Z&quot;,\r\n          &quot;updated_at&quot;: &quot;2020-03-10T08:46:09Z&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nOutput:\r\n\r\n    6\r\n\r\n  [1]: https://developer.github.com/v3/actions/artifacts/#list-artifacts-for-a-repository\r\n",
                "title": "How do I sum the values in an array of maps in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 46,
        "last_activity_date": 1583953036,
        "creation_date": 1423763985,
        "last_edit_date": 1511547218,
        "question_id": 28484534,
        "body_markdown": "Given a JSON stream of the following form:\r\n\r\n    { &quot;a&quot;: 10, &quot;b&quot;: 11 } { &quot;a&quot;: 20, &quot;b&quot;: 21 } { &quot;a&quot;: 30, &quot;b&quot;: 31 }\r\n\r\nI would like to sum the values in each of the objects and output a single object, namely:\r\n\r\n    { &quot;a&quot;: 60, &quot;b&quot;: 63 }\r\n\r\nI&#39;m guessing this will probably require flattening the above list of objects into a an array of `[name, value]` pairs and then summing the values using `reduce` but the documentation of the syntax for using `reduce` is woeful.\r\n",
        "link": "https://stackoverflow.com/questions/28484534/how-do-i-sum-the-values-in-an-array-of-maps-in-jq",
        "title": "How do I sum the values in an array of maps in jq?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "amazon-dynamodb",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1424484149,
                "post_id": 28593471,
                "comment_id": 45581364,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1578713,
                    "reputation": 511,
                    "user_id": 1464556,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1815d1042c8a872911794561eef35878?s=256&d=identicon&r=PG",
                    "display_name": "Dave Stern",
                    "link": "https://stackoverflow.com/users/1464556/dave-stern"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1429924642,
                "post_id": 28593471,
                "comment_id": 47845618,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "reply_to_user": {
                    "account_id": 1578713,
                    "reputation": 511,
                    "user_id": 1464556,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1815d1042c8a872911794561eef35878?s=256&d=identicon&r=PG",
                    "display_name": "Dave Stern",
                    "link": "https://stackoverflow.com/users/1464556/dave-stern"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1507766399,
                "post_id": 28593471,
                "comment_id": 80346032,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 54729,
                    "reputation": 3524,
                    "user_id": 163827,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b26354198c6e8a01b014a81810bafe36?s=256&d=identicon&r=PG",
                    "display_name": "johnboiles",
                    "link": "https://stackoverflow.com/users/163827/johnboiles"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580759290,
                "post_id": 28593471,
                "comment_id": 106195686,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14509139,
                    "reputation": 420,
                    "user_id": 10480074,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-fp1KFpQdquo/AAAAAAAAAAI/AAAAAAAA5EA/n5895F1FYUU/s256-rj/photo.jpg",
                    "display_name": "Paul Fowler",
                    "link": "https://stackoverflow.com/users/10480074/paul-fowler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624921188,
                "post_id": 28593471,
                "comment_id": 120484263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 936658,
                    "reputation": 185,
                    "user_id": 965479,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/rVPEo.png?s=256",
                    "display_name": "juanes",
                    "link": "https://stackoverflow.com/users/965479/juanes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639441093,
                "post_id": 28593471,
                "comment_id": 124344709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1424358170,
                "last_edit_date": 1495535370,
                "creation_date": 1424358170,
                "answer_id": 28609604,
                "question_id": 28593471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As far as I know, there is no other output like the &quot;verbose&quot; one you&#39;ve posted. Therefore I think, you can&#39;t avoid intermediate tools like `jq` oder `sed`\r\n\r\nThere are several proposals in this post for converting the raw dynamo data:\r\n\r\nhttps://stackoverflow.com/questions/18896329/export-data-from-dynamodb/23705962#23705962\r\n\r\nMaybe you can adapt one of these scripts in conjunction with `jq` or `sed`\r\n\r\n",
                "title": "How to simplify aws DynamoDB query JSON output from the command line?"
            },
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1671653762,
                "last_edit_date": 1671653762,
                "creation_date": 1424487959,
                "answer_id": 28641626,
                "question_id": 28593471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can decode the values recursively with a well crafted function.  It looks like the key names correspond to a type:\r\n\r\n    S -&gt; string\r\n    N -&gt; number\r\n    M -&gt; map\r\n\r\nHandle each of the cases you want to decode if possible, otherwise filter it out.  You can make use of the various [type filters](http://stedolan.github.io/jq/manual/#arraysobjectsiterablesbooleansnumbersstringsnullsvaluesscalars) and the [alternative operator](http://stedolan.github.io/jq/manual/#Alternativeoperator) to do so.\r\n\r\n    $ cat input.json\r\n    {\r\n      &quot;Count&quot;: 1,\r\n      &quot;Items&quot;: [\r\n        {\r\n          &quot;Id&quot;: { &quot;S&quot;: &quot;app1&quot; },\r\n          &quot;Parameters&quot;: {\r\n            &quot;M&quot;: {\r\n              &quot;nfs#IP&quot;: { &quot;S&quot;: &quot;192.17.0.13&quot; },\r\n              &quot;maxCount&quot;: { &quot;N&quot;: &quot;1&quot; },\r\n              &quot;nfs#defaultPath&quot;: { &quot;S&quot;: &quot;/mnt/ebs/&quot; }\r\n            }\r\n          }\r\n        }\r\n      ],\r\n      &quot;ScannedCount&quot;: 1,\r\n      &quot;ConsumedCapacity&quot;: null\r\n    }\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ cat ~/.jq\r\n    def decode_ddb:\r\n        def _sprop($key): select(keys == [$key])[$key];                 # single property objects only\r\n           ((objects | { value: _sprop(&quot;S&quot;) })                          # string (from string)\r\n        // (objects | { value: _sprop(&quot;NULL&quot;) | null })                 # null (from boolean)\r\n        // (objects | { value: _sprop(&quot;B&quot;) })                           # blob (from string)\r\n        // (objects | { value: _sprop(&quot;N&quot;) | tonumber })                # number (from string)\r\n        // (objects | { value: _sprop(&quot;BOOL&quot;) })                        # boolean (from boolean)\r\n        // (objects | { value: _sprop(&quot;M&quot;) | map_values(decode_ddb) })  # map (from object)\r\n        // (objects | { value: _sprop(&quot;L&quot;) | map(decode_ddb) })         # list (from encoded array)\r\n        // (objects | { value: _sprop(&quot;SS&quot;) })                          # string set (from string array)\r\n        // (objects | { value: _sprop(&quot;NS&quot;) | map(tonumber) })          # number set (from string array)\r\n        // (objects | { value: _sprop(&quot;BS&quot;) })                          # blob set (from string array)\r\n        // (objects | { value: map_values(decode_ddb) })                # all other non-conforming objects\r\n        // (arrays | { value: map(decode_ddb) })                        # all other non-conforming arrays\r\n        // { value: . }).value                                          # everything else\r\n        ;\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ jq &#39;decode_ddb&#39; input.json\r\n    {\r\n      &quot;Count&quot;: 1,\r\n      &quot;Items&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;app1&quot;,\r\n          &quot;Parameters&quot;: {\r\n            &quot;nfs#IP&quot;: &quot;192.17.0.13&quot;,\r\n            &quot;maxCount&quot;: 1,\r\n            &quot;nfs#defaultPath&quot;: &quot;/mnt/ebs/&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;ScannedCount&quot;: 1,\r\n      &quot;ConsumedCapacity&quot;: null\r\n    }\r\n\r\n\r\n",
                "title": "How to simplify aws DynamoDB query JSON output from the command line?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1583142651,
                "last_edit_date": 1583142651,
                "creation_date": 1424720788,
                "answer_id": 28682081,
                "question_id": 28593471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another way to achieve the post&#39;s goal would be to use a `node.js` extension like [`node-dynamodb`][1] or [`dynamodb-marshaler`][2] and build a `node` command line tool.\r\n\r\nInteresting tutorial to build a `node.js` command line application with [`commander` package][4]: [Creating Your First Node.js Command-line Application][3]\r\n\r\n---\r\n\r\nHere&#39;s a quick and dirty oneliner that reads one record from stdin and prints it in simplified form:\r\n\r\n    node -e &#39;console.log(JSON.stringify(require(&quot;aws-sdk&quot;).DynamoDB.Converter.unmarshall(JSON.parse(require(&quot;fs&quot;).readFileSync(0, &quot;utf-8&quot;)))))&#39;\r\n\r\n  [1]: https://www.npmjs.com/package/dynamodb\r\n  [2]: https://www.npmjs.com/package/dynamodb-marshaler\r\n  [3]: http://tutorialzine.com/2014/09/creating-your-first-node-js-command-line-application/\r\n  [4]: https://www.npmjs.com/package/commander",
                "title": "How to simplify aws DynamoDB query JSON output from the command line?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507774958,
                "last_edit_date": 1507774958,
                "creation_date": 1507774523,
                "answer_id": 46700355,
                "question_id": 28593471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another approach.  This may be a little brutal but it shows the basic idea.\r\n\r\n    def unwanted:    [&quot;B&quot;,&quot;BOOL&quot;,&quot;M&quot;,&quot;S&quot;,&quot;L&quot;,&quot;BS&quot;,&quot;SS&quot;];\r\n    def fixpath(p):  [ p[] | select( unwanted[[.]]==[] ) ];\r\n    def fixnum(p;v):\r\n        if   p[-2]==&quot;NS&quot; then [p[:-2]+p[-1:],(v|tonumber)]\r\n        elif p[-1]==&quot;N&quot; then [p[:-1], (v|tonumber)]\r\n        else [p,v] end;\r\n    \r\n    reduce (tostream|select(length==2)) as [$p,$v] (\r\n        {}\r\n      ; fixnum(fixpath($p);$v) as [$fp,$fv]      \r\n      | setpath($fp;$fv)\r\n    )\r\n\r\n\r\n[Try it online!](https://tio.run/##bZJdc5pAFIbv/RXMjhcyRSOrxBbHi@J0rE2KmdjGD4aLFZZIw8cWFowf/PXas2s06TTArrvved7jYTm/fh/3aJgWCUemrqExp3GOTGePxj4y92iKTEQY01GloTuSkZhymuUi8l1MSfC6Ht@dDXoPt/TrVrul9z4Ko08DUkT8jvD1GbmKE35FV/mViD/RrdAt0P3Rmnlbq72cr9vjUbQbj76tPfwT20M9WsV2uRw9PAkL8XhYEk5lkdZkcotMnhW0qiC2eVNfEa9oJlY2JDeEsyRRQSVxK99TFoyx0eka152ueIA6yRg03DFOaveNbIgIaDru4IssGKMHWXriuchCvQa5J29UuVUlq5xEPt@yUyViMZ3Ks4HZQUGaIg2tSCbnHXKBF4wtGVsybYjpMDCMDowuDONCWpK0JPkwetiuZlGxmN@X3mM6APAfKfy8nYTWjT@7T1azh8IfWl8W86eb/7EdYFMyt6Px6FM8/nqfLqeWvZjZKZkZkbd5L3MbLD8Ws2cMe7bC3Xey6oB8XYoMONoNHwcDJI7I1dDUI0lC/dfmHKZJXsSgEEa8kEPTJEUUVYcjNJhSJBuSQEOYClwONJN26gsNOgFywRBrSyzgkN1@TZiC8JlBVzaYCjZHYY6rHJScRtTjjUtGx2m57mAAMVV59UFrNVi/VM2a@MMwgIk5TQyg@EAKX9NEcZhjgvQBArrpao3ywNNTS6qutNEIjCIqbW9duqsp7/E5hbhWugpN/H6tllG/8KjS4GnOM0riw0vxEU0e@XowwKqqkFxx6kyrg6khs@wr@OmfX@J8BnWm9uvlCx4AH4BBXkCLU@EnLGB9CKk19Xj8kzIewkc5NpviSzTDhBUcNhnZNNOCw@Yv &quot;jq – Try It Online&quot;)\r\n\r\nSample Run (assuming filter in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -M -f filter.jq data.json\r\n    {\r\n      &quot;ConsumedCapacity&quot;: null,\r\n      &quot;Count&quot;: 1,\r\n      &quot;Items&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;app1&quot;,\r\n          &quot;Oldtypes&quot;: {\r\n            &quot;typeBS&quot;: [\r\n              &quot;VGVybWluYXRvcgo=&quot;,\r\n              &quot;VGVybWluYXRvciAyOiBKdWRnbWVudCBEYXkK&quot;,\r\n              &quot;VGVybWluYXRvciAzOiBSaXNlIG9mIHRoZSBNYWNoaW5lcwo=&quot;,\r\n              &quot;VGVybWluYXRvciA0OiBTYWx2YXRpb24K&quot;,\r\n              &quot;VGVybWluYXRvciA1OiBHZW5lc2lzCg==&quot;\r\n            ],\r\n            &quot;typeNS&quot;: [\r\n              0,\r\n              1,\r\n              2,\r\n              3,\r\n              4,\r\n              5\r\n            ],\r\n            &quot;typeSS&quot;: [\r\n              &quot;foo&quot;,\r\n              &quot;bar&quot;,\r\n              &quot;baz&quot;\r\n            ]\r\n          },\r\n          &quot;Parameters&quot;: {\r\n            &quot;nfs&quot;: {\r\n              &quot;IP&quot;: &quot;172.16.0.178&quot;,\r\n              &quot;activated&quot;: true,\r\n              &quot;defaultPath&quot;: &quot;/mnt/ebs/&quot;,\r\n              &quot;key&quot;: &quot;dGhpcyB0ZXh0IGlzIGJhc2U2NC1lbmNvZGVk&quot;\r\n            },\r\n            &quot;ws&quot;: {\r\n              &quot;number&quot;: 5,\r\n              &quot;values&quot;: [\r\n                &quot;12253456346346&quot;,\r\n                &quot;23452353463464&quot;,\r\n                &quot;23523453461232&quot;,\r\n                &quot;34645745675675&quot;,\r\n                &quot;46456745757575&quot;\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ],\r\n      &quot;ScannedCount&quot;: 1\r\n    }\r\n",
                "title": "How to simplify aws DynamoDB query JSON output from the command line?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589930858,
                "creation_date": 1589930858,
                "answer_id": 61902487,
                "question_id": 28593471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a script in node to do this.\r\n\r\n\r\nI named the file `reformat.js` but you can call it whatever you want\r\n\r\n```\r\n&#39;use strict&#39;;\r\n\r\n/**\r\n * This script will parse the AWS dynamo CLI JSON response into JS.\r\n * This parses out the type keys in the objects.\r\n */\r\n\r\nconst fs = require(&#39;fs&#39;);\r\n\r\nconst rawData = fs.readFileSync(&#39;response.json&#39;); // Import the raw response from the dynamoDB CLI query\r\nconst response = JSON.parse(rawData); // Parse to JS to make it easier to work with.\r\n\r\nfunction shallowFormatData(data){\r\n  // Loop through the object and replace the Type key with the value.\r\n  for(const key in data){\r\n    const innerRawObject = data[key]\r\n    const innerKeys = Object.keys(innerRawObject)\r\n    innerKeys.forEach(innerKey =&gt; {\r\n      const innerFormattedObject = innerRawObject[innerKey]\r\n      if(typeof innerFormattedObject == &#39;object&#39;){\r\n        data[key] = shallowFormatData(innerFormattedObject) // Recursively call formatData if there are nested objects\r\n      }else{\r\n        // Null items come back with a type of &quot;NULL&quot; and value of true. we want to set the value to null if the type is &quot;NULL&quot;\r\n        data[key] = innerKey == &#39;NULL&#39; ? null : innerFormattedObject\r\n      }\r\n    })\r\n  }\r\n  return data\r\n}\r\n\r\n// this only gets the Items and not the meta data.\r\nconst result = response.Items.map(item =&gt; {\r\n  return shallowFormatData(item)\r\n})\r\n\r\nconsole.dir(result, {&#39;maxArrayLength&#39;: null}); // There is a default limit on how big a console.log can be, this removes that limit.\r\n```\r\n\r\nStep 1) run your dynamoDB query via the CLI and save it to a JSON file. To save the response from the CLI just add `&gt; somefile.json`. For convenience, I saved this in the same directory as my reformat file\r\n```\r\n// Example: Run in CLI\r\n\r\n$ aws dynamodb query --table-name stage_requests-service_FoxEvents \\\r\n --key-condition-expression &quot;PK = :v1&quot; \\\r\n --expression-attribute-values file://expression-attributes.json &gt; response.json\r\n```\r\n\r\nexpression-attributes.json\r\n```\r\n{\r\n  &quot;:v1&quot;: {&quot;S&quot;: &quot;SOMEVAL&quot;}\r\n}\r\n\r\n```\r\nIf you need more information on how I queried DynamoDB look at these examples in the documentation https://docs.aws.amazon.com/cli/latest/reference/dynamodb/query.html#examples\r\n\r\nNow that you have a JSON file of the data you need to reformat run the format.js script from your terminal\r\n\r\nStep 2)\r\n```\r\n// Run this in your terminal\r\n$ node reformat.js &gt; formatted.js \r\n```\r\n\r\n\r\nYou should have a clean JS Object output if you want a JSON object output just put a `JSON.stringify(result)` in the `console.dir` at the end of the script\r\n\r\n  \r\n",
                "title": "How to simplify aws DynamoDB query JSON output from the command line?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1639441396,
                "creation_date": 1639441396,
                "answer_id": 70342424,
                "question_id": 28593471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an updated version of the `jq` solution that can handle null values.\r\n\r\n```sh\r\n$&gt; cat unmarshal_dynamodb.jq\r\ndef unmarshal_dynamodb:\r\n  # null\r\n  walk( if type == &quot;object&quot; and .NULL then . |= null else . end ) |\r\n\r\n  # DynamoDB string type\r\n  (objects | .S)\r\n\r\n  # DynamoDB blob type\r\n  // (objects | .B)\r\n\r\n  # DynamoDB number type\r\n  // (objects | .N | strings | tonumber)\r\n\r\n  # DynamoDB boolean type\r\n  // (objects | .BOOL)\r\n\r\n  # DynamoDB map type, recursion on each item\r\n  // (objects | .M | objects | with_entries(.value |= unmarshal_dynamodb))\r\n\r\n  # DynamoDB list type, recursion on each item\r\n  // (objects | .L | arrays | map(unmarshal_dynamodb))\r\n\r\n  # DynamoDB typed list type SS, string set\r\n  // (objects | .SS | arrays | map(unmarshal_dynamodb))\r\n\r\n  # DynamoDB typed list type NS, number set\r\n  // (objects | .NS | arrays | map(tonumber))\r\n\r\n  # DynamoDB typed list type BS, blob set\r\n  // (objects | .BS | arrays | map(unmarshal_dynamodb))\r\n\r\n  # managing others DynamoDB output entries: &quot;Count&quot;, &quot;Items&quot;, &quot;ScannedCount&quot; and &quot;ConsumedCapcity&quot;\r\n  // (objects | with_entries(.value |= unmarshal_dynamodb))\r\n  // (arrays | map(unmarshal_dynamodb))\r\n\r\n  # leaves values\r\n  // .\r\n  ;\r\nunmarshal_dynamodb\r\n```\r\n\r\n```sh\r\n$&gt; jq -f unmarshal_dynamodb.jq ddb-query-result.json\r\n```\r\n\r\nCredit to @jeff-mercado and @herve for the original version.",
                "title": "How to simplify aws DynamoDB query JSON output from the command line?"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 32,
        "last_activity_date": 1671653762,
        "creation_date": 1424291999,
        "last_edit_date": 1424719907,
        "question_id": 28593471,
        "body_markdown": "I&#39;m working with [The AWS Command Line Interface for DynamoDB][1].\r\n\r\nWhen we query an item, we get a very detailed JSON output. You get something like this (it has been built from the `get-item` in order to be almost exhaustive (the `NULL` type has been omitted) [aws command line help][2]:\r\n\r\n    {\r\n        &quot;Count&quot;: 1, \r\n        &quot;Items&quot;: [\r\n            {\r\n                &quot;Id&quot;: {\r\n                    &quot;S&quot;: &quot;app1&quot;\r\n                }, \r\n                &quot;Parameters&quot;: {\r\n                    &quot;M&quot;: {\r\n                        &quot;nfs&quot;: {\r\n                            &quot;M&quot;: {\r\n                                &quot;IP&quot; : {\r\n                                    &quot;S&quot; : &quot;172.16.0.178&quot;\r\n                                }, \r\n                                &quot;defaultPath&quot;: {\r\n                                    &quot;S&quot;: &quot;/mnt/ebs/&quot;\r\n                                },\r\n                                &quot;key&quot;: {\r\n                                    &quot;B&quot;: &quot;dGhpcyB0ZXh0IGlzIGJhc2U2NC1lbmNvZGVk&quot;\r\n                                },\r\n                                &quot;activated&quot;: {\r\n                                    &quot;BOOL&quot;: true \r\n                                }\r\n                            }\r\n                        },\r\n                        &quot;ws&quot; : {\r\n                            &quot;M&quot; : {\r\n                                &quot;number&quot; : {\r\n                                    &quot;N&quot; : &quot;5&quot;\r\n                                },\r\n                                &quot;values&quot; : {\r\n                                    &quot;L&quot; : [\r\n                                        { &quot;S&quot; : &quot;12253456346346&quot;},\r\n                                        { &quot;S&quot; : &quot;23452353463464&quot;},\r\n                                        { &quot;S&quot; : &quot;23523453461232&quot;},\r\n                                        { &quot;S&quot; : &quot;34645745675675&quot;},\r\n                                        { &quot;S&quot; : &quot;46456745757575&quot;}\r\n                                    ]\r\n                                }\r\n                            } \r\n                        }\r\n                    }\r\n                },\r\n                &quot;Oldtypes&quot;: {\r\n                    &quot;typeSS&quot; : {&quot;SS&quot; : [&quot;foo&quot;, &quot;bar&quot;, &quot;baz&quot;]},\r\n                    &quot;typeNS&quot; : {&quot;NS&quot; : [&quot;0&quot;, &quot;1&quot;, &quot;2&quot;, &quot;3&quot;, &quot;4&quot;, &quot;5&quot;]},\r\n                    &quot;typeBS&quot; : {&quot;BS&quot; : [&quot;VGVybWluYXRvcgo=&quot;, &quot;VGVybWluYXRvciAyOiBKdWRnbWVudCBEYXkK&quot;, &quot;VGVybWluYXRvciAzOiBSaXNlIG9mIHRoZSBNYWNoaW5lcwo=&quot;, &quot;VGVybWluYXRvciA0OiBTYWx2YXRpb24K&quot;,&quot;VGVybWluYXRvciA1OiBHZW5lc2lzCg==&quot;]}\r\n                }\r\n            }\r\n        ], \r\n        &quot;ScannedCount&quot;: 1, \r\n        &quot;ConsumedCapacity&quot;: null\r\n    }\r\n\r\nIs there any way to get a simpler output for the `Items` part? Like this:\r\n\r\n    {\r\n        &quot;ConsumedCapacity&quot;: null,\r\n        &quot;Count&quot;: 1,\r\n        &quot;Items&quot;: [\r\n            {\r\n                &quot;Id&quot;: &quot;app1&quot;,\r\n                &quot;Parameters&quot;: {\r\n                    &quot;nfs&quot;: {\r\n                        &quot;IP&quot;: &quot;172.16.0.178&quot;,\r\n                        &quot;activated&quot;: true,\r\n                        &quot;defaultPath&quot;: &quot;/mnt/ebs/&quot;,\r\n                        &quot;key&quot;: &quot;dGhpcyB0ZXh0IGlzIGJhc2U2NC1lbmNvZGVk&quot;\r\n                    },\r\n                    &quot;ws&quot;: {\r\n                        &quot;number&quot;: 5,\r\n                        &quot;values&quot;: [&quot;12253456346346&quot;,&quot;23452353463464&quot;,&quot;23523453461232&quot;,&quot;34645745675675&quot;,&quot;46456745757575&quot;]\r\n                    }\r\n                },\r\n                &quot;Oldtypes&quot;: {\r\n                    &quot;typeBS&quot;: [&quot;VGVybWluYXRvcgo=&quot;, &quot;VGVybWluYXRvciAyOiBKdWRnbWVudCBEYXkK&quot;, &quot;VGVybWluYXRvciAzOiBSaXNlIG9mIHRoZSBNYWNoaW5lcwo=&quot;, &quot;VGVybWluYXRvciA0OiBTYWx2YXRpb24K&quot;, &quot;VGVybWluYXRvciA1OiBHZW5lc2lzCg==&quot;],\r\n                    &quot;typeNS&quot;: [0, 1, 2, 3, 4, 5],\r\n                    &quot;typeSS&quot;: [&quot;foo&quot;,&quot;bar&quot;,&quot;baz&quot;]\r\n                }\r\n            }\r\n        ],\r\n        &quot;ScannedCount&quot;: 1\r\n    }\r\n\r\nThere is nothing helpful in the [dynamodb - AWS CLI 1.7.10 documentation][3].\r\n\r\nWe must get the result from the command line. I&#39;m willing to use other command line tools like [`jq`][4] if necessary, but such a `jq` mapping appears to complicated to me. \r\n\r\n&lt;br/&gt;\r\n**Update 1: `jq` based solution** (with help from DanielH&#39;s answer)\r\n\r\nWith `jq` it is easy, but not quite pretty, you can do something like: \r\n\r\n    $&gt; aws dynamodb query --table-name ConfigCatalog --key-conditions &#39;{ &quot;Id&quot; : {&quot;AttributeValueList&quot;: [{&quot;S&quot;:&quot;app1&quot;}], &quot;ComparisonOperator&quot;: &quot;EQ&quot;}}&#39; | jq -r &#39;.Items[0].Parameters.M.&quot;nfs#IP&quot;.S&#39;\r\n\r\nResult will be: `172.16.0.178`\r\n\r\nThe `jq` `-r` option gives you a raw output.\r\n\r\n&lt;br/&gt;\r\n**Update 2: `jq` based solution** (with help from @jeff-mercado)\r\n\r\nHere is an updated and commented version of Jeff Mercado `jq` function to unmarshall DynamoDB output. It will give you the expected output:\r\n\r\n    $&gt; cat unmarshal_dynamodb.jq\r\n    def unmarshal_dynamodb:\r\n\t  # DynamoDB string type\r\n\t  (objects | .S)\r\n\r\n\t  # DynamoDB blob type\r\n\t  // (objects | .B)\r\n\r\n\t  # DynamoDB number type\r\n\t  // (objects | .N | strings | tonumber)\r\n\r\n\t  # DynamoDB boolean type\r\n\t  // (objects | .BOOL)\r\n\r\n\t  # DynamoDB map type, recursion on each item\r\n\t  // (objects | .M | objects | with_entries(.value |= unmarshal_dynamodb))\r\n\r\n\t  # DynamoDB list type, recursion on each item\r\n\t  // (objects | .L | arrays | map(unmarshal_dynamodb))\r\n\r\n\t  # DynamoDB typed list type SS, string set\r\n\t  // (objects | .SS | arrays | map(unmarshal_dynamodb))\r\n\r\n\t  # DynamoDB typed list type NS, number set\r\n\t  // (objects | .NS | arrays | map(tonumber))\r\n\r\n\t  # DynamoDB typed list type BS, blob set\r\n\t  // (objects | .BS | arrays | map(unmarshal_dynamodb))\r\n\r\n\t  # managing others DynamoDB output entries: &quot;Count&quot;, &quot;Items&quot;, &quot;ScannedCount&quot; and &quot;ConsumedCapcity&quot;\r\n\t  // (objects | with_entries(.value |= unmarshal_dynamodb))\r\n\t  // (arrays | map(unmarshal_dynamodb))\r\n\r\n\t  # leaves values\r\n\t  // .\r\n\t  ;\r\n    unmarshal_dynamodb\r\n\r\nIf you save the `DynamoDB` query output to a file, lets say `ddb-query-result.json`, you can execute to get desired result:\r\n\r\n    $&gt; jq -f unmarshal_dynamodb.jq ddb-query-result.json\r\n\r\n\r\n  [1]: http://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Tools.CLI.html\r\n  [2]: http://docs.aws.amazon.com/cli/latest/reference/dynamodb/get-item.html\r\n  [3]: http://docs.aws.amazon.com/cli/latest/reference/dynamodb/index.html\r\n  [4]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/28593471/how-to-simplify-aws-dynamodb-query-json-output-from-the-command-line",
        "title": "How to simplify aws DynamoDB query JSON output from the command line?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1424340215,
                "post_id": 28603357,
                "comment_id": 45511840,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3121952,
                    "reputation": 8843,
                    "user_id": 2641547,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://graph.facebook.com/660520007/picture?type=large",
                    "display_name": "Spearfisher",
                    "link": "https://stackoverflow.com/users/2641547/spearfisher"
                },
                "reply_to_user": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1424340303,
                "post_id": 28603357,
                "comment_id": 45511880,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 404686,
                    "reputation": 36382,
                    "user_id": 773159,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4fcd72af6d7d5fdd28fc45289da3792a?s=256&d=identicon&r=PG",
                    "display_name": "Birei",
                    "link": "https://stackoverflow.com/users/773159/birei"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1424340323,
                "post_id": 28603357,
                "comment_id": 45511894,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 404686,
                    "reputation": 36382,
                    "user_id": 773159,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4fcd72af6d7d5fdd28fc45289da3792a?s=256&d=identicon&r=PG",
                    "display_name": "Birei",
                    "link": "https://stackoverflow.com/users/773159/birei"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1424340554,
                "post_id": 28603357,
                "comment_id": 45512029,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 404686,
                    "reputation": 36382,
                    "user_id": 773159,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4fcd72af6d7d5fdd28fc45289da3792a?s=256&d=identicon&r=PG",
                    "display_name": "Birei",
                    "link": "https://stackoverflow.com/users/773159/birei"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1424341758,
                "post_id": 28603357,
                "comment_id": 45512800,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1424340142,
                "creation_date": 1424340142,
                "answer_id": 28603420,
                "question_id": 28603357,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could try the below.\r\n\r\n    $ sed &#39;s/\\(\\blocation: \\+&quot;[^,]*, *\\)MA&quot;/\\1Massachussetts&quot;/g&#39; file\r\n    { name: &quot;Bob&quot;, location: &quot;Boston, Massachussetts&quot; }\r\n    { name: &quot;Peter&quot;, location: &quot;San Francisco, CA&quot; }\r\n    { name: &quot;Jane&quot;, location: &quot;New York City, NY&quot; }\r\n\r\n**OR**\r\n\r\n    $ sed &#39;s/\\(\\blocation: \\+&quot;[^&quot;]*\\)\\bMA/\\1Massachussetts/g&#39; file\r\n    { name: &quot;Bob&quot;, location: &quot;Boston, Massachussetts&quot; }\r\n    { name: &quot;Peter&quot;, location: &quot;San Francisco, CA&quot; }\r\n    { name: &quot;Jane&quot;, location: &quot;New York City, NY&quot; }",
                "title": "Make replacements in a property of a json item using sed and jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1424487580,
                "last_edit_date": 1424487580,
                "creation_date": 1424364424,
                "answer_id": 28612017,
                "question_id": 28603357,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In the current public build of jq (1.4), there is no option to do regex replacements.  However that will change in the next version.\r\n\r\nThe [sub](http://stedolan.github.io/jq/manual/#subresubgsubresub) filter will alow you to do regex replacement on strings.  Then you could do something like this:\r\n\r\n    .location |= sub(&quot;MA$&quot;; &quot;Massachussetts&quot;)\r\n\r\nThough, you&#39;ll have to do some creative manipulation to allow for multiple alternatives.",
                "title": "Make replacements in a property of a json item using sed and jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503603469,
                "creation_date": 1503603469,
                "answer_id": 45869641,
                "question_id": 28603357,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which assumes your data is clean and the substitutions you need are limited.\r\n\r\n    .location = (\r\n       {\r\n         &quot;Boston, MA&quot;:        &quot;Boston, Massachussettts&quot;,\r\n         &quot;San Francisco, CA&quot;: &quot;San Francisco, California&quot;,\r\n         &quot;New York City, NY&quot;: &quot;New York City, New York&quot;\r\n       }[.location] // .location\r\n    )\r\n    \r\nif `filter.jq` contains the above filter and `input.json` contains\r\n\r\n    { &quot;name&quot;: &quot;Bob&quot;, &quot;location&quot;: &quot;Boston, MA&quot; }\r\n    { &quot;name&quot;: &quot;Peter&quot;, &quot;location&quot;: &quot;San Francisco, CA&quot; }\r\n    { &quot;name&quot;: &quot;Jane&quot;, &quot;location&quot;: &quot;New York City, NY&quot; }\r\n    { &quot;name&quot;: &quot;Unknown&quot;, &quot;location&quot;: &quot;Unknown&quot; }\r\n\r\nthen\r\n\r\n    jq -M -c -f filter.jq input.json\r\n    \r\nwill produce\r\n\r\n    {&quot;name&quot;:&quot;Bob&quot;,&quot;location&quot;:&quot;Boston, Massachussettts&quot;}\r\n    {&quot;name&quot;:&quot;Peter&quot;,&quot;location&quot;:&quot;San Francisco, California&quot;}\r\n    {&quot;name&quot;:&quot;Jane&quot;,&quot;location&quot;:&quot;New York City, New York&quot;}\r\n    {&quot;name&quot;:&quot;Unknown&quot;,&quot;location&quot;:&quot;Unknown&quot;}\r\n\r\nNote the use of `//` to leave location unchanged if the lookup failed.\r\n",
                "title": "Make replacements in a property of a json item using sed and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1503603469,
        "creation_date": 1424339963,
        "question_id": 28603357,
        "body_markdown": "I have a file with a list of json items (one per line), looking like this:\r\n\r\n    { name: &quot;Bob&quot;, location: &quot;Boston, MA&quot; }\r\n    { name: &quot;Peter&quot;, location: &quot;San Francisco, CA&quot; }\r\n    { name: &quot;Jane&quot;, location: &quot;New York City, NY&quot; }\r\n\r\nLet&#39;s say, I would like to replace `MA` with `Massachussetts` in the location property. I know I could use `sed &#39;s/MA/Massachussetts&#39;` but this would also replace every `MA` in the `name` field.\r\n\r\nIs there a way to do this from the command line, using `jq` for example?",
        "link": "https://stackoverflow.com/questions/28603357/make-replacements-in-a-property-of-a-json-item-using-sed-and-jq",
        "title": "Make replacements in a property of a json item using sed and jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 31,
                "is_accepted": true,
                "score": 31,
                "last_activity_date": 1424381700,
                "creation_date": 1424381700,
                "answer_id": 28617380,
                "question_id": 28615174,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "use `with_entries` to convert to/from an intermediate format that represents that data as an array of objects with `key` and `value` elements:\r\n\r\n    cat people.json | jq &#39;with_entries(select(.value.Job == &quot;Clown&quot;))&#39;\r\n\r\nas per the docs here: http://stedolan.github.io/jq/manual/",
                "title": "jq Filter on sub object value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501781696,
                "creation_date": 1501781696,
                "answer_id": 45491060,
                "question_id": 28615174,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **reduce** \r\n\r\n      . as $v\r\n    | reduce keys[] as $k (\r\n        {};\r\n        if $v[$k].Job == &quot;Clown&quot; then .[$k] = $v[$k] else . end\r\n      )\r\n",
                "title": "jq Filter on sub object value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 18,
        "last_activity_date": 1501781696,
        "creation_date": 1424374095,
        "question_id": 28615174,
        "body_markdown": "I have a json file people.json:\r\n\r\n    {\r\n      &quot;Joe&quot; : {&quot;Job&quot; : &quot;Clown&quot;, &quot;Age&quot; : 22},\r\n      &quot;Sally&quot; : {&quot;Job&quot; : &quot;Programmer&quot;, &quot;Age&quot; : 32},\r\n      &quot;Anne&quot; : {&quot;Job&quot; : &quot;Clown&quot;, &quot;Age&quot; : 29}\r\n    }\r\nI would like to select everyone who is a Clown. My output should look like this:\r\n\r\n    {\r\n      &quot;Joe&quot; : {&quot;Job&quot; : &quot;Clown&quot;, &quot;Age&quot; : 22},\r\n      &quot;Anne&quot; : {&quot;Job&quot; : &quot;Clown&quot;, &quot;Age&quot; : 29}\r\n    }\r\n\r\nI have tried the .. operator as in \r\n\r\n    cat people.json | jq &#39;. | map(select(.Job == &quot;Clown&quot;))&#39;\r\n\r\nBut it seems to match Joe and Anne at multiple levels and produces more output then I want. Any ideas? Thanks.\r\n",
        "link": "https://stackoverflow.com/questions/28615174/jq-filter-on-sub-object-value",
        "title": "jq Filter on sub object value"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1424896687,
                "creation_date": 1424896687,
                "answer_id": 28729093,
                "question_id": 28727274,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just set the new field directly using simple assignment.\r\n\r\n    .Category = &quot;Unknown&quot;",
                "title": "How to append a json object from command line?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1424896687,
        "creation_date": 1424890401,
        "last_edit_date": 1424894925,
        "question_id": 28727274,
        "body_markdown": "I have a json file and I need to read it and write back an additional value (string) to the root of the object. Is there any way to do that from the command line?\r\n  I&#39;ve found an utility named  [JQ][1] but it&#39;s a bit unclear how we can write the values back. \r\nHere is a sample of the object JSON object. The json tree is unimportant as I&#39;m interested only to inject the string only into the root of the json object.  \r\n\r\n    {&quot;widget&quot;: {\r\n        &quot;debug&quot;: &quot;on&quot;,\r\n        &quot;window&quot;: {\r\n            &quot;height&quot;: 500\r\n        },\r\n        &quot;text&quot;: {\r\n            &quot;data&quot;: &quot;Click Here&quot;,\r\n            &quot;size&quot;: 36,\r\n            &quot;style&quot;: &quot;bold&quot;,\r\n            &quot;name&quot;: &quot;text1&quot;,\r\n            &quot;hOffset&quot;: 250,\r\n            &quot;vOffset&quot;: 100,\r\n            &quot;alignment&quot;: &quot;center&quot;,\r\n            &quot;onMouseUp&quot;: &quot;sun1.opacity = (sun1.opacity / 100) * 90;&quot;\r\n        }\r\n    }}    \r\n\r\nThe json written back should look like this:\r\n\r\n    {\r\n      &quot;Category&quot;: &quot;Unknown&quot;,\r\n      &quot;widget&quot;: {\r\n        &quot;debug&quot;: &quot;on&quot;,\r\n        &quot;window&quot;: {\r\n          &quot;height&quot;: 500\r\n        },\r\n        &quot;text&quot;: {\r\n          &quot;data&quot;: &quot;Click Here&quot;,\r\n          &quot;size&quot;: 36,\r\n          &quot;style&quot;: &quot;bold&quot;,\r\n          &quot;name&quot;: &quot;text1&quot;,\r\n          &quot;hOffset&quot;: 250,\r\n          &quot;vOffset&quot;: 100,\r\n          &quot;alignment&quot;: &quot;center&quot;,\r\n          &quot;onMouseUp&quot;: &quot;sun1.opacity = (sun1.opacity / 100) * 90;&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n  [1]: http://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/28727274/how-to-append-a-json-object-from-command-line",
        "title": "How to append a json object from command line?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "moving-average",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1424911873,
                "creation_date": 1424911873,
                "answer_id": 28732594,
                "question_id": 28731718,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This question inspired me to learn jq, thanks!\r\n\r\nmy solution is\r\n\r\n    &#39;. as $val | to_entries | map((.value + $val[.key-1] + $val[.key-2])/3)  | .[2:]&#39;\r\n\r\nFirst step, save whole array to variable $val\r\n\r\nsecond step transforms array into array of object with keys (try it!, it transforms your example array into\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: 0,\r\n        &quot;value&quot;: 1\r\n      },\r\n      {\r\n        &quot;key&quot;: 1,\r\n        &quot;value&quot;: 4\r\n      },\r\n      {\r\n        &quot;key&quot;: 2,\r\n        &quot;value&quot;: 6\r\n      },\r\n      {\r\n        &quot;key&quot;: 3,\r\n        &quot;value&quot;: 9\r\n      },\r\n      {\r\n        &quot;key&quot;: 4,\r\n        &quot;value&quot;: 8\r\n      },\r\n      {\r\n        &quot;key&quot;: 5,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;key&quot;: 6,\r\n        &quot;value&quot;: 5\r\n      },\r\n      {\r\n        &quot;key&quot;: 7,\r\n        &quot;value&quot;: 2\r\n      }\r\n    ]\r\n\r\n)\r\n\r\nthird step gets value from each point and adds value of two previous steps\r\n\r\nlast step is optional, it throws out values &quot;you don&#39;t care about&quot;\r\n\r\n",
                "title": "How to compute a moving average using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1424912166,
                "creation_date": 1424912166,
                "answer_id": 28732653,
                "question_id": 28731718,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use a filter like this:\r\n\r\n    def rolling_average(size): . as $items |\r\n        [ range(0;length-size)\r\n        | $items[.:.+size]\r\n        | add/size\r\n        ]\r\n        ;\r\n    rolling_average(3)\r\n\r\nThe idea is to generate the range of indices to get the averages of, then take the average of those items.",
                "title": "How to compute a moving average using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503604334,
                "creation_date": 1503604334,
                "answer_id": 45869862,
                "question_id": 28731718,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq filter which uses a recursive function to compute the moving average of every n elements.\r\n\r\n    def avg(n):\r\n        if length &lt; n then empty   # base case\r\n        else ( .[0:n] | add/n )    # average of first n elements\r\n           , ( .[1:]  | avg(n) )   # recursive call\r\n        end\r\n    ;\r\n\r\n    avg(3)\r\n",
                "title": "How to compute a moving average using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1503604334,
        "creation_date": 1424906752,
        "last_edit_date": 1424913445,
        "question_id": 28731718,
        "body_markdown": "Assume a Json array of numbers:\r\n\r\n    [ 1, 4, 6, 9, 8, 10, 5, 2]\r\n\r\nI want to compute a 3 day moving average.  The resulting array is computed by averaging the previous 3 entries.\r\n\r\nSo the first 3 entries don&#39;t care, the 4th is `(1+4+6)/3`, the 5th is `(4+6+9)/3` and so on.\r\n\r\nConceptually, this is what I&#39;m trying to do:\r\n\r\n    echo &#39;[ 1, 4, 6, ... ]&#39; | jq &#39;map(average(select(prev 3 array entries)))&#39;\r\n",
        "link": "https://stackoverflow.com/questions/28731718/how-to-compute-a-moving-average-using-jq",
        "title": "How to compute a moving average using jq?"
    },
    {
        "tags": [
            "json",
            "file",
            "split",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4947870,
                    "reputation": 2567,
                    "user_id": 4337125,
                    "user_type": "registered",
                    "accept_rate": 15,
                    "profile_image": "https://i.sstatic.net/AcwQ1.jpg?s=256",
                    "display_name": "Rajeshwar",
                    "link": "https://stackoverflow.com/users/4337125/rajeshwar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1424960778,
                "post_id": 28744361,
                "comment_id": 45772383,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3285493,
                    "reputation": 428,
                    "user_id": 2765120,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/87466dbb3155f45b5e869df5541eb0d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "r0x0r",
                    "link": "https://stackoverflow.com/users/2765120/r0x0r"
                },
                "reply_to_user": {
                    "account_id": 4947870,
                    "reputation": 2567,
                    "user_id": 4337125,
                    "user_type": "registered",
                    "accept_rate": 15,
                    "profile_image": "https://i.sstatic.net/AcwQ1.jpg?s=256",
                    "display_name": "Rajeshwar",
                    "link": "https://stackoverflow.com/users/4337125/rajeshwar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1424983415,
                "post_id": 28744361,
                "comment_id": 45786734,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1424986155,
                "post_id": 28744361,
                "comment_id": 45788048,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1533323340,
                "last_edit_date": 1533323340,
                "creation_date": 1424987254,
                "answer_id": 28753393,
                "question_id": 28744361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should give you a start:\r\n\r\n    for f in `cat input.json | jq -r &#39;keys[]&#39;` ; do\r\n      cat input.json | jq &quot;.$f&quot; &gt; $f.json\r\n    done\r\n\r\nor when you insist on more bashy syntax like some seem to prefer:\r\n\r\n    for f in $(jq -r &#39;keys[]&#39;) ; do\r\n      jq &quot;.[\\&quot;$f\\&quot;]&quot; &lt; input.json &gt; &quot;$f.json&quot;\r\n    done &lt; input.json",
                "title": "Split a JSON file into separate files"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1484049189,
                "last_edit_date": 1484049189,
                "creation_date": 1483698013,
                "answer_id": 41503531,
                "question_id": 28744361,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a solution that requires only one call to jq:\r\n\r\n    jq -cr &#39;keys[] as $k | &quot;\\($k)\\n\\(.[$k])&quot;&#39; input.json |\r\n      while read -r key ; do\r\n\t    read -r item\r\n\t    printf &quot;%s\\n&quot; &quot;$item&quot; &gt; &quot;/tmp/$key.json&quot;\r\n      done\r\n\r\nIt might be faster to pipe the output of the jq command to awk, e.g.:\r\n\r\n    jq -cr &#39;keys[] as $k | &quot;\\($k)\\t\\(.[$k])&quot;&#39; input.json |\r\n      awk -F\\\\t &#39;{ print $2 &gt; &quot;/tmp/&quot; $1 &quot;.json&quot; }&#39;\r\n\r\nOf course, these approaches will need to be modified if the key names contain characters that cannot be used in filenames.\r\n\r\n\r\n\r\n\r\n",
                "title": "Split a JSON file into separate files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1746447816,
                "last_edit_date": 1746447816,
                "creation_date": 1550403890,
                "answer_id": 54732913,
                "question_id": 28744361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; _Is it possible to achieve this using jq **or any other off-the-shelf tools**?_\r\n\r\nIt is. The command-line JSON-parser [tag:xidel] can help out.\r\n\r\nLet&#39;s assume _&#39;input.json&#39;_:\r\n```\r\n{\r\n  &quot;item1&quot;: {\r\n    &quot;a&quot;: 1\r\n  },\r\n  &quot;item2&quot;: {\r\n    &quot;b&quot;: 2\r\n  },\r\n  &quot;item3&quot;: {\r\n    &quot;c&quot;: 3\r\n  }\r\n}\r\n```\r\nYou could use Bash, as the other answers lay out...\r\n```\r\n$ for f in $(xidel -s &quot;input.json&quot; -e &#39;$json()&#39;); do\r\n  xidel -s &quot;input.json&quot; --variable f=&quot;$f&quot; -e &#39;$json($f)&#39; &gt; &quot;$f.json&quot;\r\ndone\r\n\r\n$ xidel -s &quot;input.json&quot; -e &#39;$json() ! (.,serialize($json(.),{&quot;method&quot;:&quot;json&quot;}))&#39; |\r\n  while read -r key ; do read -r item; printf &quot;%s\\n&quot; &quot;$item&quot; &gt; &quot;$key.json&quot;; done\r\n```\r\n...but with the integrated [EXPath File Module](http://www.benibela.de/documentation/internettools/xpath-functions.html#modulefile) Xidel can also do this very efficiently:\r\n```\r\n$ xidel -s &quot;input.json&quot; -e &#39;\r\n  $json() ! file:write(`{.}.json`,$json(.),{&quot;method&quot;:&quot;json&quot;})\r\n&#39;\r\n\r\n$ xidel -s item[123].json -e &#39;$raw&#39;\r\n{&quot;a&quot;:1}\r\n{&quot;b&quot;:2}\r\n{&quot;c&quot;:3}\r\n```\r\n```\r\n$ xidel -s &quot;input.json&quot; -e &#39;\r\n  $json() ! file:write(`{.}.json`,$json(.),{&quot;method&quot;:&quot;json&quot;,&quot;indent&quot;:true()})\r\n&#39;\r\n\r\n$ xidel -s item[123].json -e &#39;$raw&#39;\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n{\r\n  &quot;b&quot;: 2\r\n}\r\n{\r\n  &quot;c&quot;: 3\r\n}\r\n```",
                "title": "Split a JSON file into separate files"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 16,
        "last_activity_date": 1746447816,
        "creation_date": 1424959100,
        "last_edit_date": 1483715840,
        "question_id": 28744361,
        "body_markdown": "I have a large JSON file that is an object of objects, which I would like to split into separate files name after object keys. Is it possible to achieve this using jq or any other off-the-shelf tools?\r\n\r\nThe original JSON is in the following format\r\n\r\n  `{ &quot;item1&quot;: {...}, &quot;item2&quot;: {...}, ...}`\r\n\r\nGiven this input I would like to produce files item1.json, item2.json etc.",
        "link": "https://stackoverflow.com/questions/28744361/split-a-json-file-into-separate-files",
        "title": "Split a JSON file into separate files"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1425426925,
                "post_id": 28844295,
                "comment_id": 45957514,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2588497,
                    "reputation": 335,
                    "user_id": 2243651,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/190727925f5bd516325caf1ba34d5554?s=256&d=identicon&r=PG",
                    "display_name": "user2243651",
                    "link": "https://stackoverflow.com/users/2243651/user2243651"
                },
                "reply_to_user": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1425433945,
                "post_id": 28844295,
                "comment_id": 45959459,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1425438003,
                "post_id": 28844295,
                "comment_id": 45960472,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1425446095,
                "creation_date": 1425446095,
                "answer_id": 28847101,
                "question_id": 28844295,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just the number gets interpreted as a float.  You need to use it in a context where it is unambiguously a key string.\r\n\r\n    echo &quot;$temp&quot; | jq &#39;.[&quot;1&quot;][&quot;my_name&quot;]&#39;\r\n\r\nand\r\n\r\n    echo &quot;$temp&quot; | jq &#39;.[&quot;1&quot;]&#39;\r\n\r\nto get the containing dict.\r\n\r\nWith a sufficiently new `jq` (I think &gt;= 1.4) you can also say\r\n\r\n    echo &quot;$temp&quot; | jq &#39;.&quot;1&quot;.my_name&#39;",
                "title": "Getting data from json using jq when key is numerical string"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1425449560,
                "creation_date": 1425449560,
                "answer_id": 28847741,
                "question_id": 28844295,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Whenever you are trying to reference a key that is not a valid identifier, you have to quote it.  See the [manual](http://stedolan.github.io/jq/manual/#foofoobar) for more details.\r\n\r\nTo select the item under the key `1`, you&#39;d do this:\r\n\r\n    .&quot;1&quot;\r\n\r\nFor your other question on how to obtain the `my_name` values, you could do this:\r\n\r\n    to_entries | map(.value.my_name)",
                "title": "Getting data from json using jq when key is numerical string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 20,
        "last_activity_date": 1553923808,
        "creation_date": 1425426735,
        "last_edit_date": 1553923808,
        "question_id": 28844295,
        "body_markdown": "I am new to jq and facing an issue while parsing my json\r\n\r\nI have a json stored in a variable like this \r\n\r\n    temp=&#39;{ &quot;1&quot;: { &quot;my_name&quot;: &quot;one&quot; }, &quot;2&quot;: { &quot;my_name&quot;: &quot;two&quot; } }&#39;\r\n\r\nNow I need to get the value of my_name for both other entries\r\n\r\nI have tried something like this\r\n\r\n    echo $temp | jq &#39;.1&#39; //out put 0.1\r\n    I was assuming to get { &quot;my_name&quot;: &quot;one&quot; } \r\n\r\nAnd similarly to get my_name value I did \r\n\r\n    echo $temp | jq &#39;.1.my_name&#39; // Its output is giving me error\r\n\r\nCan any one please help to identify what is wrong with my syntax and how can I correct it. \r\n",
        "link": "https://stackoverflow.com/questions/28844295/getting-data-from-json-using-jq-when-key-is-numerical-string",
        "title": "Getting data from json using jq when key is numerical string"
    },
    {
        "tags": [
            "json",
            "recursion",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1426170595,
                "last_edit_date": 1426170595,
                "creation_date": 1426098791,
                "answer_id": 28994662,
                "question_id": 28989994,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can create a recursive filter by defining a new function:\r\n\r\n    def untag: (objects | .&quot;$t&quot;)\r\n        // (objects | with_entries(.value |= untag))\r\n        // (arrays | map(untag))\r\n        // .\r\n        ;\r\n    untag\r\n\r\nSo given input like this:\r\n\r\n    {\r\n      &quot;log&quot;: {\r\n        &quot;version&quot;: {\r\n          &quot;$t&quot;: &quot;1.1&quot;\r\n        },\r\n        &quot;creator&quot;: {\r\n          &quot;name&quot;: {\r\n            &quot;$t&quot;: &quot;Internet Explorer Network Inspector&quot;\r\n          },\r\n          &quot;version&quot;: {\r\n            &quot;$t&quot;: &quot;10.0.9200.17229&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nYou&#39;ll get back:\r\n\r\n    {\r\n      &quot;log&quot;: {\r\n        &quot;creator&quot;: {\r\n          &quot;name&quot;: &quot;Internet Explorer Network Inspector&quot;,\r\n          &quot;version&quot;: &quot;10.0.9200.17229&quot;\r\n        },\r\n        &quot;version&quot;: &quot;1.1&quot;\r\n      }\r\n    }",
                "title": "jq - apply a filter on multiple levels"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1528978231,
                "creation_date": 1528978231,
                "answer_id": 50857255,
                "question_id": 28989994,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your jq has `walk`, you could use it as follows, and if not, you can easily google its def and include it by cut-and-paste:\r\n\r\n    walk( if type==&quot;object&quot; and has(&quot;$t&quot;)\r\n          then .[&quot;$t&quot;] else . end )",
                "title": "jq - apply a filter on multiple levels"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532623617,
                "last_edit_date": 1532623617,
                "creation_date": 1532622634,
                "answer_id": 51543601,
                "question_id": 28989994,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Expanding on @JeffMercado&#39;s excellent answer:\r\n\r\n**PROBLEM**\r\n\r\nYou have some command that produces JSON where string values represented like this\r\n\r\n    {&quot;some key&quot;: {&quot;$t&quot;: &quot;some string value&quot;}}\r\n\r\nand you&#39;d like to transform it to look like this: \r\n\r\n    {&quot;some key&quot;: &quot;some string value&quot;}\r\n\r\n**SOLUTION**\r\n\r\nPut this in your `~/.jq` file:\r\n\r\n    def untag: (objects | .&quot;$t&quot;)\r\n      // (objects | with_entries(.value |= untag))\r\n      // (arrays | map(untag))\r\n      // .\r\n      ;\r\n\r\nUse it like this:\r\n\r\n    some_command | jq untag\r\n\r\nExamples:\r\n\r\n    $ echo &#39;{&quot;some key&quot;: {&quot;$t&quot;: &quot;some string value&quot;}}&#39; | jq\r\n    {\r\n      &quot;some key&quot;: {\r\n        &quot;$t&quot;: &quot;some string value&quot;\r\n      }\r\n    }\r\n\r\n    $ echo &#39;{&quot;some key&quot;: {&quot;$t&quot;: &quot;some string value&quot;}}&#39; | jq untag\r\n    {\r\n      &quot;some key&quot;: &quot;some string value&quot;\r\n    }\r\n\r\n\r\n\r\n\r\n",
                "title": "jq - apply a filter on multiple levels"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1532623617,
        "creation_date": 1426085814,
        "last_edit_date": 1529074191,
        "question_id": 28989994,
        "body_markdown": "I have a json file like this\r\n\r\n    {\r\n        &quot;log&quot;: {\r\n                &quot;version&quot;: {\r\n                        &quot;$t&quot;: &quot;1.1&quot;\r\n                },\r\n                &quot;creator&quot;: {\r\n                        &quot;name&quot;: {\r\n                                &quot;$t&quot;: &quot;Internet Explorer Network Inspector&quot;\r\n                        },\r\n                        &quot;version&quot;: {\r\n                                &quot;$t&quot;: &quot;10.0.9200.17229&quot;\r\n                        }\r\n                }\r\n    }\r\n\r\nAnd I need to flatten the file so it should read\r\n\r\n    {\r\n        &quot;log&quot;: {\r\n                &quot;version&quot;: &quot;1.1&quot;,\r\n                &quot;creator&quot;: {\r\n                        &quot;name&quot;: &quot;Internet Explorer Network Inspector&quot;,\r\n                        &quot;version&quot;: &quot;10.0.9200.17229&quot;\r\n                }\r\n    }\r\n\r\nI know the filter `{&quot;version&quot;: .version .&quot;$t&quot;}` reduce the single element `&quot;version&quot;: {&quot;$t&quot;: &quot;10.0.9200.17229&quot;}` to `{&quot;version&quot;: &quot;10.0.9200.17229&quot;}` but this filter should be applied recursively to any element at any level.\r\n\r\n\r\n  ",
        "link": "https://stackoverflow.com/questions/28989994/jq-apply-a-filter-on-multiple-levels",
        "title": "jq - apply a filter on multiple levels"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1426261288,
                "last_edit_date": 1426261288,
                "creation_date": 1426256716,
                "answer_id": 29034742,
                "question_id": 29034529,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use this filter:\r\n\r\n    &quot;\\(.files[].name) \\(.id)&quot;\r\n\r\nThis will yield a string for each of the files containing the name and the outer id.\r\n\r\nYou will probably want to get the raw output so don&#39;t forget the `-r` flag.\r\n\r\nIf you wanted to pull more than just the name from each of the files, you would need to make adjustments to the filter.  The key is to use `.[]` at most, once within any one part of the filter.  Depending on where you want each part in the string, there are a number of approaches you can take.\r\n\r\nIf they are all together in one part of your string, you can just add another string combining the properties you want:\r\n\r\n    &quot;\\(.files[] | &quot;\\(.name) \\(.size)&quot;) \\(.id)&quot;\r\n\r\nOtherwise, it would be easier to introduce a variable:\r\n\r\n    .id as $id | .files[] | &quot;\\(.name) \\($id) \\(.size)&quot;",
                "title": "How to print outer JSON attribute on each line with the inner ones?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1426261655,
        "creation_date": 1426256125,
        "last_edit_date": 1426261655,
        "question_id": 29034529,
        "body_markdown": "I have JSON like this:\r\n\r\n    {\r\n      &quot;files&quot;: [\r\n        { &quot;size&quot;: 3227238, &quot;name&quot;: &quot;file1.mp3&quot; },\r\n        { &quot;size&quot;: 3737995, &quot;name&quot;: &quot;file2.mp3&quot; }\r\n      ],\r\n      &quot;id&quot;: &quot;music&quot;\r\n    }\r\n\r\nAnd I want to print each file on its own line, but including the id from the outer element.\r\n\r\n    file1.mp3 music\r\n    file2.mp3 music\r\n\r\nI can get the file attributes like this:\r\n\r\n    jq -r &#39;.files | .[] | .name&#39;\r\nBut how do I include the id on each line?\r\n",
        "link": "https://stackoverflow.com/questions/29034529/how-to-print-outer-json-attribute-on-each-line-with-the-inner-ones",
        "title": "How to print outer JSON attribute on each line with the inner ones?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1426618905,
                "creation_date": 1426618905,
                "answer_id": 29107554,
                "question_id": 29106846,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not familiar with jq, so there might be some way to get it to process many files in a single invocation. This will work for invoking it once per file though:\r\n\r\n    #!/bin/bash\r\n\r\n    for file in *.json; do\r\n        ./jq &#39;[.[&quot;messages&quot;...&#39; &lt; &quot;$file&quot; &gt; &quot;$file.scrubbed&quot;\r\n    done\r\n\r\nUsing `cat` for redirecting the input to a file is redundant. Just use `&lt;` instead.\r\n\r\nIf your input files follow a consistent naming scheme like *data**n**.json* and you want the output files to be called e.g. *result**n**.json*, you could use `&gt; &quot;${file/data/result}&quot;` instead (though it might not be portable to some non-Bash shells). Watch out so you don&#39;t accidentally overwrite some file whose name doesn&#39;t contain &quot;data&quot; though. Search for *${parameter/pattern/string}* in [the Bash manual][1].\r\n\r\n\r\n  [1]: http://www.gnu.org/software/bash/manual/bashref.html",
                "title": "How to iterate over a directory of files and save out to new files with jq and shell scripting?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1426618905,
        "creation_date": 1426616467,
        "question_id": 29106846,
        "body_markdown": "I&#39;m using jq (http://stedolan.github.io/jq/) to pull some specific data from some JSON files and convert it to another JSON file eg: \r\n\r\n    cat data1.json | ./jq &#39;[.[&quot;messages&quot;][] | {to: .to, from: .from, body: .body, direction: .direction, date_sent: .date_sent }]&#39; &gt; results1.json\r\n\r\nI have 50 JSON files in a directory to do this to. How do I write a bit of shell script to iterate over all 50 files, perform said function, and save out to 50 scrubbed JSON files?\r\n\r\nI&#39;m thinking its something along these lines, but need some guidance:\r\n\r\n    for file in *.json | ./jq | &#39;[.[&quot;messages&quot;][] | {to: .to, from: .from, body: .body, direction: .direction, date_sent: .date_sent }]&#39; &quot;$file&quot; &quot;$newfile.json&quot; ; done\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/29106846/how-to-iterate-over-a-directory-of-files-and-save-out-to-new-files-with-jq-and-s",
        "title": "How to iterate over a directory of files and save out to new files with jq and shell scripting?"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426622773,
                "post_id": 29108688,
                "comment_id": 46446899,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 122338,
                    "reputation": 15030,
                    "user_id": 316082,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/a18baaf9417df189af31b53af03adb1c?s=256&d=identicon&r=PG",
                    "display_name": "liv2hak",
                    "link": "https://stackoverflow.com/users/316082/liv2hak"
                },
                "reply_to_user": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426622835,
                "post_id": 29108688,
                "comment_id": 46446933,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426622881,
                "post_id": 29108688,
                "comment_id": 46446958,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 122338,
                    "reputation": 15030,
                    "user_id": 316082,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/a18baaf9417df189af31b53af03adb1c?s=256&d=identicon&r=PG",
                    "display_name": "liv2hak",
                    "link": "https://stackoverflow.com/users/316082/liv2hak"
                },
                "reply_to_user": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426622916,
                "post_id": 29108688,
                "comment_id": 46446976,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426623025,
                "post_id": 29108688,
                "comment_id": 46447038,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 122338,
                    "reputation": 15030,
                    "user_id": 316082,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/a18baaf9417df189af31b53af03adb1c?s=256&d=identicon&r=PG",
                    "display_name": "liv2hak",
                    "link": "https://stackoverflow.com/users/316082/liv2hak"
                },
                "reply_to_user": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426623093,
                "post_id": 29108688,
                "comment_id": 46447066,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1426623626,
                "last_edit_date": 1426623626,
                "creation_date": 1426622985,
                "answer_id": 29108762,
                "question_id": 29108688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As a combination of `jq` and `sed`:\r\n\r\n    jq &quot;.url = \\&quot;$(jq &#39;.Message&#39; input.json | sed &#39;s/.*proxy=\\([^&amp;]*\\).*/\\1/&#39;)\\&quot;&quot; input.json &gt; output.json\r\n\r\nThis consists of three steps:\r\n\r\n    jq &#39;.Message&#39; input.json\r\n\r\nextracts the message part from the input JSON, \r\n\r\n    sed &#39;s/.*proxy=\\([^&amp;]*\\).*/\\1/&#39;\r\n\r\nextracts the domain from the message, and\r\n\r\n    jq &quot;.url = \\&quot;domainname\\&quot;&quot; input.json &gt; output.json\r\n\r\nsets the `.url` attribute of the input json to the extracted domain name, writing the result to `output.json`.\r\n\r\nI feel compelled to point out, by the way, that a domain name by itself is not technically a URL, so you may want to rethink that attribute name.",
                "title": "Formatting a json file to add another field"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1426625411,
                "creation_date": 1426625411,
                "answer_id": 29109402,
                "question_id": 29108688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For `perl` users, using [ojo][1]:\r\n\r\n    perl -Mojo -E &#39;$j=j(b(&quot;input.file&quot;)-&gt;slurp);if($j-&gt;{Message}=~m/proxy=(.*?)&amp;/){$j-&gt;{url}=$1;say j($j)}&#39;\r\n\r\ndecomposed:\r\n\r\n - `b()-&gt;slurp` - reads the `input.file`\r\n - `j()` - converts the json to perl data\r\n - if the `Message` contains &quot;proxy=site&amp;&quot; - get the site\r\n - add to the data the `url =&gt; site`\r\n - `j()` convert to json string\r\n - and print it.\r\n\r\n\r\n  [1]: https://metacpan.org/pod/ojo",
                "title": "Formatting a json file to add another field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1426637009,
        "creation_date": 1426622699,
        "question_id": 29108688,
        "body_markdown": "I have a json file with the format given below.I want to modify the file so as to add another key-value pair to it. The key should be `url` and the value should be `www.mywebsite.co.nz` extracted from the message given below. What is the easiset way to do this?\r\n\r\n    {&quot;  \r\n    Timestamp&quot;:&quot;Mon Mar 16 21:37:22 EDT 2015&quot;,&quot;Event&quot;:&quot;Reporting  Time&quot;,&quot;Message&quot;:&quot;load for http://xxx.xx.xx.xx:1xxxx/operations&amp;proxy=www.mywebsite.co.nz&amp;send=https://xxx.xx.xx.xx:xxxx/operations?event took 9426 ms (X Time: 306 ms, Y Time: 1923 ms)\r\n    StatusCode: Unknown&lt;br&gt;Cookies: nzh_weatherlocation=12; dax_ppv=11|NZH:home|NZH:home|NZH:home|9|undefined; _ga=GA1.4.1415798036.1426208630; _gat=1&lt;br&gt;Links: 225&lt;br&gt;Images: 24&lt;br&gt;Forms: 10&lt;br&gt;Browser: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Ubuntu Chromium/41.0.2272.76 Chrome/41.0.2272.76 Safari/537.36&lt;br&gt;CPUs: 2&lt;br&gt;Language: en-GB&quot;,&quot;UserInfo&quot;:&quot;Reporting Time&quot;}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/29108688/formatting-a-json-file-to-add-another-field",
        "title": "Formatting a json file to add another field"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1426633028,
                "last_edit_date": 1426633028,
                "creation_date": 1426632528,
                "answer_id": 29111170,
                "question_id": 29110979,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you use `myVar=$(some bash commands)` to store the stdout into a variable and you call it like `echo &quot;$myVar&quot;`; putting `&quot;&quot;` around `$myVar` to pretend the shell preprocess your string (trimming, new line, &quot;&quot;)\r\n\r\nor even you can put it into an array like this: `myArray=( $(some bash commands) )`",
                "title": "Extracting a key from JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1426634325,
        "creation_date": 1426631598,
        "last_edit_date": 1426634325,
        "question_id": 29110979,
        "body_markdown": "I have a JSON formatted file which has an Event field\r\n\r\n    for file in /home/ec2-user/Workspace/events_parts/*\r\n    do\r\n            cat $file | jq &#39;.Event&#39;\r\n            \r\n    done\r\n\r\nI get the list of &quot;Event&quot; values extracted from JSON file.I want to assign this value to a bash variable so that I can use it for comparision later. How do I do that?",
        "link": "https://stackoverflow.com/questions/29110979/extracting-a-key-from-json-file-using-jq",
        "title": "Extracting a key from JSON file using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1892463,
                    "reputation": 4561,
                    "user_id": 1775715,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/vzyZN.png?s=256",
                    "display_name": "ShellFish",
                    "link": "https://stackoverflow.com/users/1775715/shellfish"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426642834,
                "post_id": 29112204,
                "comment_id": 46454601,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1426639941,
                "creation_date": 1426639941,
                "answer_id": 29112375,
                "question_id": 29112204,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    file=&quot;/home/ec2-user/Workspace/events_parts/input.json&quot;\r\n    filename=&quot;$(basename &quot;$file&quot;)&quot;\r\n    echo &quot;$filename&quot;\r\n\r\nOutput:\r\n\r\n&lt;pre&gt;\r\ninput.json\r\n&lt;/pre&gt;",
                "title": "processing JSON file using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1426639941,
        "creation_date": 1426638976,
        "question_id": 29112204,
        "body_markdown": "I have the following bash script\r\n\r\n    counter=0\r\n    for file in /home/ec2-user/Workspace/events_parts/*\r\n    do\r\n            counter=$[counter + 1]\r\n            event=$(cat $file | jq &#39;.Event&#39;)\r\n            echo $event\r\n            if [ &quot;$event&quot; = &quot;Page Exceeded&quot; ]  || [ &quot;$event&quot; = &quot;Reporting Time&quot; ]; then\r\n                    echo &quot;Coming Here&quot;\r\n                    jq &quot;.url = \\&quot;$(jq &#39;.Message&#39; $file | sed &#39;s/.*proxy=\\([^&amp;]*\\).*/\\1/&#39;)\\&quot;&quot; $file  &gt; events_parts/out_$file\r\n            else\r\n                    jq &quot;.url = null&quot; $file &gt; events_parts/out_$file\r\n            fi\r\n    done\r\n\r\nIt does processing of a set of JSON files.I want to redirect it to a filename which has out_$input_file_name. But the variable file prints out the whole path not just the file name (for e.g. `/home/ec2-user/Workspace/events_parts/input.json`) How do I get just the &quot;input file name&quot; from this?\r\n",
        "link": "https://stackoverflow.com/questions/29112204/processing-json-file-using-jq-in-bash",
        "title": "processing JSON file using jq in bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316301,
                    "reputation": 64134,
                    "user_id": 632407,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/AfGWW.jpg?s=256",
                    "display_name": "clt60",
                    "link": "https://stackoverflow.com/users/632407/clt60"
                },
                "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": 1,
                "creation_date": 1426641907,
                "post_id": 29112449,
                "comment_id": 46454325,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1426642205,
                "last_edit_date": 1426642205,
                "creation_date": 1426641078,
                "answer_id": 29112553,
                "question_id": 29112449,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Check once if there are leading or trailing unwanted characters (whitespace, newline ...) in output of `cat $file | jq &#39;.Event&#39;`:\r\n\r\n    cat $file | jq &#39;.Event&#39; | hexdump -C\r\n\r\n**Update:**\r\n\r\nReplace\r\n\r\n    [ &quot;$event&quot; = &quot;Time Exceeded&quot; ]\r\n\r\nby\r\n\r\n    [ &quot;$event&quot; = &quot;Time Exceeded.&quot; ]\r\n\r\nor replace by\r\n\r\n    [ &quot;${event%.}&quot; = &quot;Time Exceeded&quot; ]\r\n\r\nor replace by\r\n\r\n    [[ &quot;$event&quot; =~ &quot;Time Exceeded&quot; ]]\r\n\r\nto match a substring. `${event%.}` crops a trailing `.`.",
                "title": "processing JSON file in bash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1426642205,
        "creation_date": 1426640362,
        "question_id": 29112449,
        "body_markdown": "I have a bash script\r\n\r\n    counter=0\r\n    for file in /home/ec2-user/Workspace/events_parts/*\r\n    do\r\n            counter=$[counter + 1]\r\n            event=$(cat $file | jq &#39;.Event&#39;)\r\n            echo $event\r\n            if [ &quot;$event&quot; = &quot;Time Exceeded&quot; ]  || [ &quot;$event&quot; = &quot;Load Time&quot; ]; then\r\n                    echo &quot;Coming Here&quot;\r\n                    jq &quot;.url = \\&quot;$(jq &#39;.Message&#39; $file | sed &#39;s/.*proxy=\\([^&amp;]*\\).*/\\1/&#39;)\\&quot;&quot; $file \r\n            else\r\n                    jq &quot;.url = null&quot;\r\n            fi\r\n    done\r\n    ~   \r\nIn the bash script above I am trying to extract `Event` field from a JSON file and check for two possible values.` if [ &quot;$event&quot; = &quot;Time Exceeded&quot; ]  || [ &quot;$event&quot; = &quot;Load Time&quot; ];` is not workign as I would expect. I have verified that the values that I am comparing against are indeed there.",
        "link": "https://stackoverflow.com/questions/29112449/processing-json-file-in-bash-using-jq",
        "title": "processing JSON file in bash using jq"
    },
    {
        "tags": [
            "json",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2440193,
                    "reputation": 10411,
                    "user_id": 2128937,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/HeU5b.jpg?s=256",
                    "display_name": "duyn9uyen",
                    "link": "https://stackoverflow.com/users/2128937/duyn9uyen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1426650309,
                "post_id": 29113687,
                "comment_id": 46456312,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3046411,
                    "reputation": 7822,
                    "user_id": 2581928,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/c5iS3.png?s=256",
                    "display_name": "RainingChain",
                    "link": "https://stackoverflow.com/users/2581928/rainingchain"
                },
                "reply_to_user": {
                    "account_id": 2440193,
                    "reputation": 10411,
                    "user_id": 2128937,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/HeU5b.jpg?s=256",
                    "display_name": "duyn9uyen",
                    "link": "https://stackoverflow.com/users/2128937/duyn9uyen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1426650637,
                "post_id": 29113687,
                "comment_id": 46456375,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1427709120,
                "last_edit_date": 1427709120,
                "creation_date": 1426650296,
                "answer_id": 29113788,
                "question_id": 29113687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use grep.\r\n\r\n    $ grep -o &#39;[YX]\\s*Time:\\s*[^,)]*&#39; file\r\n    X Time: 306 ms\r\n    Y Time: 1923 ms\r\n\r\n\r\n- `[YX]` will match either `X` or `Y`\r\n\r\n- `\\s*` matches zero or more space characters.\r\n\r\n- `Time:\\s*` Matches the string `Time` plus the following zero or more spaces.\r\n\r\n- `[^,)]*` Negated character class which matches any character but not of comma or `)`, zero or more times.",
                "title": "Extracting a particular value from a JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1426650793,
                "creation_date": 1426650793,
                "answer_id": 29113849,
                "question_id": 29113687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First of all, i recomend to your Gson or Jackson Libraries (are used to serialize/deserialize) json objects easier.\r\n\r\nBut, if i were you i make it manually of this way:\r\n\r\nJsonObject MyJson= new JsonObject(yourstring);\r\n\r\n1.- To obtain the X Time or Y Time:\r\n\r\n    String FullMessage=MyJson.getString(&quot;message&quot;);\r\n\r\n    int XPosition=FullMessage.indexOf(&quot;X Time:&quot;);\r\n    int YPosition=FullMessage.indexOf(&quot;Y Time:&quot;);\r\n    int EndYPosition=FullMessage.indexOf(&quot;ms)&quot;);\r\n\r\n    String XTime=FullMessage.substring(XPosition,Yposition);\r\n    String YTime=FullMessage.subString(Yposition,EndYPosition);\r\n /*\r\nof that way you could obtain x and y data, i havent tested it, but the main idea i write.\r\n*/\r\n\r\n2.-And to Write the url is easy, just make it:\r\n\r\n    MyObject.putString(&quot;url&quot;,&quot;www.mywebsite.co.nz&quot;); //and thats all\r\n\r\nBut i recommend to use and Serializer/deserializer library, its easier and better.\r\n\r\nRegards.\r\n",
                "title": "Extracting a particular value from a JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503605843,
                "creation_date": 1503605843,
                "answer_id": 45870209,
                "question_id": 29113687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq solution using **capture**:\r\n\r\n      .Message\r\n    | capture(&quot;X Time: (?&lt;X Time&gt;[^,]+), Y Time: (?&lt;Y Time&gt;[^)]+)&quot;)\r\n\r\nIf this filter is in `filter.jq` and input data is in `input.json`\r\n\r\n    jq -M -f filter.jq input.json\r\n    \r\nwill produce\r\n\r\n    {\r\n      &quot;X Time&quot;: &quot;306 ms&quot;,\r\n      &quot;Y Time&quot;: &quot;1923 ms&quot;\r\n    }\r\n",
                "title": "Extracting a particular value from a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1503605843,
        "creation_date": 1426649619,
        "last_edit_date": 1427481987,
        "question_id": 29113687,
        "body_markdown": "From the JSON file below I want to extract `X Time` and `Y Time`. What is the easiest way to do this?\r\n\r\n\t{\r\n\t\t&quot;Timestamp&quot;: &quot;Mon Mar 16 21:37:22 EDT 2015&quot;,\r\n\t\t&quot;Event&quot;: &quot;Reporting  Time&quot;,\r\n\t\t&quot;Message&quot;: &quot;load for http://xxx.xx.xx.xx:1xxxx/operations&amp;proxy=www.mywebsite.co.nz&amp;send=https://xxx.xx.xx.xx:xxxx took (X Time: 306 ms, Y Time: 1923 ms)StatusCode: Unknown&lt;br&gt;Cookies: nzh_weatherlocation=12; dax_ppv=11|NZH:home|NZH:home|NZH:home|9|undefined; Safari/537.36&lt;br&gt;CPUs: 2&lt;br&gt;Language: en-GB&quot;,\r\n\t\t\r\n\t}",
        "link": "https://stackoverflow.com/questions/29113687/extracting-a-particular-value-from-a-json-file",
        "title": "Extracting a particular value from a JSON file"
    },
    {
        "tags": [
            "bash",
            "amazon-ec2",
            "vpc",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1426767856,
                "creation_date": 1426767856,
                "answer_id": 29144504,
                "question_id": 29142185,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is a little tricky, but it can be done with `reduce`. The whole thing could look like this:\r\n\r\n    selected_subnets_json=$(echo &quot;\\&quot;$selected_subnets\\&quot;&quot; | jq -c -M &#39;split(&quot; &quot;)&#39;)\r\n    echo &quot;$input&quot; | jq -M &#39;.elements = [.elements[] | select(.VPCZoneIdentifier as $id | &#39;&quot;$selected_subnets_json&quot;&#39; | reduce .[] as $v (false; . or $id == $v))]&#39;\r\n\r\nThe first part makes a JSON array from the shell list:\r\n\r\n    $ echo &quot;\\&quot;$selected_subnets\\&quot;&quot; | jq -c -M &#39;split(&quot; &quot;)&#39;\r\n    [&quot;valueA&quot;,&quot;valueB&quot;]\r\n\r\nThe second part uses the `reduce` filter to compare the `.VPCZoneIdentifier` property with all elements of this array. With the `selected_subnets_json` variable expanded into it, the filter looks as follows:\r\n\r\n    .elements = [\r\n      .elements[] |\r\n        select(.VPCZoneIdentifier as $id |\r\n               [ &quot;valueA&quot;, &quot;valueB&quot; ] | reduce .[] as $v (false; . or $id == $v))\r\n    ]\r\n\r\nThat is to say, the `elements` property is overwritten with those elements of it that match the selection criterium\r\n\r\n    .VPCZoneIdentifier as $id | [ &quot;valueA&quot;, &quot;valueB&quot; ] | reduce .[] as $v (false; . or $id == $v))\r\n\r\nOf this the first part remembers the `VPCZoneIdentifier` as `$id` (because `.` will shortly mean something entirely different), and \r\n\r\n    [ &quot;valueA&quot;, &quot;valueB&quot; ] | reduce .[] as $v (false; . or $id == $v))\r\n\r\nis an or-reduction of the subnet array. It expands to `false or $id == &quot;valueA&quot; or $id == &quot;valueB&quot;` in this case.\r\n\r\nIf you prefer to have it all in one go, you could write\r\n\r\n    echo &quot;$input&quot; | jq -M &#39;.elements = [.elements[] | select(.VPCZoneIdentifier as $id | (&quot;&#39;&quot;$selected_subnets&quot;&#39;&quot; | split(&quot; &quot;)) | reduce .[] as $v (false; . or $id == $v))]&#39;\r\n\r\nThis works essentially the same way, except the splitting of `$selected_subnets` is done inline.",
                "title": "JQ: Select when attribute value exists in a bash array"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1428645046,
                "last_edit_date": 1428645046,
                "creation_date": 1426815729,
                "answer_id": 29158025,
                "question_id": 29142185,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can set variables from the command line to be available in your queries using the `--arg` option.  You can then filter out the elements using the `select` filter.  Given an array of values, you could do a `&quot;value in array&quot;` test doing the following:\r\n\r\n    value == (array[])\r\n\r\nSo your filter would have the following structure:\r\n\r\n    .elements | map(\r\n        select(\r\n            .VPCZoneIdentifier == ($subnets | split(&quot; &quot;)[])\r\n        )\r\n    )\r\n\r\nPutting it all together with your variables:\r\n\r\n    $ echo $input | jq --arg subnets &quot;$selected_subnets&quot; &#39;.elements | map(select(.VPCZoneIdentifier == ($subnets | split(&quot; &quot;)[])))&#39;\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;nameA&quot;,\r\n        &quot;VPCZoneIdentifier&quot;: &quot;valueA&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;nameB&quot;,\r\n        &quot;VPCZoneIdentifier&quot;: &quot;valueB&quot;\r\n      }\r\n    ]",
                "title": "JQ: Select when attribute value exists in a bash array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1503688761,
        "creation_date": 1426761055,
        "last_edit_date": 1503688761,
        "question_id": 29142185,
        "body_markdown": "I&#39;m using jq 1.4.\r\nI trying to select elements when VPCZoneIdentifier exists in my `$selected_subnets` (bash variable).\r\n\r\n    selected_subnets=&quot;valueA valueB&quot;\r\n    \r\n    input=&#39;{&quot;elements&quot;:[\r\n               {&quot;name&quot;: &quot;nameA&quot;, &quot;VPCZoneIdentifier&quot;: &quot;valueA&quot;}, \r\n               {&quot;name&quot;: &quot;nameB&quot;, &quot;VPCZoneIdentifier&quot;: &quot;valueB&quot;}, \r\n               {&quot;name&quot;: &quot;nameC&quot;, &quot;VPCZoneIdentifier&quot;: &quot;valueC&quot;}\r\n           ]}&#39;\r\n\r\n`test` and `match` fn are only available on v1.5.",
        "link": "https://stackoverflow.com/questions/29142185/jq-select-when-attribute-value-exists-in-a-bash-array",
        "title": "JQ: Select when attribute value exists in a bash array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1427296250,
                "creation_date": 1427296250,
                "answer_id": 29259478,
                "question_id": 29259249,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this filter:\r\n\r\n    map(\r\n        .properties |= with_entries(select(.key == (&quot;NAME&quot;, &quot;NAME_LONG&quot;)))\r\n    )\r\n\r\nThis maps each item in the array where the `properties` object is filtered to only include the `NAME` and `NAME_LONG` properties.",
                "title": "Extracting selected properties from a nested JSON object with jq"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1459502075,
                "creation_date": 1459502075,
                "answer_id": 36352395,
                "question_id": 29259249,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`map(.properties |= {NAME, NAME_LONG})` is more straight-forward and understandable.\r\n\r\nI&#39;d add this as a comment to Jeff&#39;s answer, but SO rules about comments are stupid so it goes as an answer instead.",
                "title": "Extracting selected properties from a nested JSON object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1459502075,
        "creation_date": 1427295670,
        "question_id": 29259249,
        "body_markdown": "Given a JSON array of objects thus:\r\n\r\n    [\r\n      {\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;coordinates&quot;: [[[-69.9969376289999, 12.577582098000036]]]\r\n        },\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;NAME&quot;: &quot;Aruba&quot;,\r\n          &quot;WB_A2&quot;: &quot;AW&quot;,\r\n          &quot;INCOME_GRP&quot;: &quot;2. High income: nonOECD&quot;,\r\n          &quot;SOV_A3&quot;: &quot;NL1&quot;,\r\n          &quot;CONTINENT&quot;: &quot;North America&quot;,\r\n          &quot;NOTE_ADM0&quot;: &quot;Neth.&quot;,\r\n          &quot;BRK_A3&quot;: &quot;ABW&quot;,\r\n          &quot;TYPE&quot;: &quot;Country&quot;,\r\n          &quot;NAME_LONG&quot;: &quot;Aruba&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n          &quot;coordinates&quot;: [[[-63.037668423999946, 18.212958075000028]]]\r\n        },\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;NAME&quot;: &quot;Anguilla&quot;,\r\n          &quot;WB_A2&quot;: &quot;-99&quot;,\r\n          &quot;INCOME_GRP&quot;: &quot;3. Upper middle income&quot;,\r\n          &quot;SOV_A3&quot;: &quot;GB1&quot;,\r\n          &quot;NOTE_ADM0&quot;: &quot;U.K.&quot;,\r\n          &quot;BRK_A3&quot;: &quot;AIA&quot;,\r\n          &quot;TYPE&quot;: &quot;Dependency&quot;,\r\n          &quot;NAME_LONG&quot;: &quot;Anguilla&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nI&#39;d like to extract a subset of the key/values from the nested `properties`, whilst keeping other properties from the outer object intact, producing something like:\r\n\r\n    [\r\n      {\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;coordinates&quot;: [[[-69.9969376289999, 12.577582098000036]]]\r\n        },\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;NAME&quot;: &quot;Aruba&quot;,\r\n          &quot;NAME_LONG&quot;: &quot;Aruba&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n          &quot;coordinates&quot;: [[[-63.037668423999946, 18.212958075000028]]]\r\n        },\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;NAME&quot;: &quot;Anguilla&quot;,\r\n          &quot;NAME_LONG&quot;: &quot;Anguilla&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\ni.e. remove all keys except `NAME` and `NAME_LONG`.\r\n\r\nI&#39;m sure there must be a reasonably easy way of achieving this with jq. Help appreciated.",
        "link": "https://stackoverflow.com/questions/29259249/extracting-selected-properties-from-a-nested-json-object-with-jq",
        "title": "Extracting selected properties from a nested JSON object with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52616,
                    "reputation": 1079223,
                    "user_id": 157247,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/lUM5Z.jpg?s=256",
                    "display_name": "T.J. Crowder",
                    "link": "https://stackoverflow.com/users/157247/t-j-crowder"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1427885979,
                "post_id": 29389010,
                "comment_id": 46955404,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4236748,
                    "reputation": 379,
                    "user_id": 3467696,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d4fa7272b05a906e28a3223e67433034?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3467696",
                    "link": "https://stackoverflow.com/users/3467696/user3467696"
                },
                "reply_to_user": {
                    "account_id": 52616,
                    "reputation": 1079223,
                    "user_id": 157247,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/lUM5Z.jpg?s=256",
                    "display_name": "T.J. Crowder",
                    "link": "https://stackoverflow.com/users/157247/t-j-crowder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1427886257,
                "post_id": 29389010,
                "comment_id": 46955593,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2201395,
                    "reputation": 619,
                    "user_id": 1945702,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/ZTLOC.png?s=256",
                    "display_name": "Fabian de Pabian",
                    "link": "https://stackoverflow.com/users/1945702/fabian-de-pabian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1427886911,
                "post_id": 29389010,
                "comment_id": 46955966,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 48,
                "is_accepted": true,
                "score": 48,
                "last_activity_date": 1427893409,
                "last_edit_date": 1427893409,
                "creation_date": 1427887403,
                "answer_id": 29389469,
                "question_id": 29389010,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**EDIT:** After clarification in the comments, to retrieve the states of devices whose key begins with &quot;dimmer&quot;, use\r\n\r\n    jq &#39;[ .devices | to_entries[] | select(.key | startswith(&quot;dimmer&quot;)) | .value = .value.state ] | from_entries&#39; filename.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;dimmer1&quot;: &quot;off&quot;,\r\n      &quot;dimmer2&quot;: &quot;off&quot;\r\n    }\r\n\r\n\r\nThis works as follows:\r\n\r\n* `.devices` selects the `.devices` attribute of the JSON object\r\n* `to_entries` explodes the object into an array of key-value pairs describing its attributes (the devices), which is to say that an attribute `&quot;foo&quot;: &quot;bar&quot;` becomes an object `{ &quot;key&quot;: &quot;foo&quot;, &quot;value&quot;: &quot;bar&quot; }`, and the exploded object is expanded into an array of such objects (one for each attribute)\r\n* `to_entries[]` unpacks that array, in order to pipe it through\r\n* `select(.key | startswith(&quot;dimmer&quot;))`, which selects of the devices those whose key begins with `dimmer`\r\n* `.value = .value.state` restructures the key-value pair that describes the device so that the value is replaced with just its `state` attribute\r\n* `[ all that ]` makes a JSON array of all that, and\r\n* `[ all that ] | from_entries` converts the array of key-value pairs back to JSON objects.\r\n\r\n### Old answer (shortened), now obsolete but possibly of interest:\r\n\r\nTo retrieve the keys of the attributes of `devices` in an array:\r\n\r\n    jq &#39;.devices | keys&#39; filename.json\r\n\r\nTo retrieve the values (also in an array),\r\n\r\n    jq &#39;[ .devices[] ]&#39; filename.json\r\n\r\nI wasn&#39;t entirely sure which of those two you meant.",
                "title": "jq parsing get value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 32,
        "last_activity_date": 1427893409,
        "creation_date": 1427885826,
        "question_id": 29389010,
        "body_markdown": "I need to get some values from a json file. I need to get a array (dimmer1, dimmer2) \r\n\r\nSomebody any idea?\r\n\r\n    {\r\n     &quot;devices&quot;: {\r\n        &quot;dimmer1&quot;: {\r\n          &quot;protocol&quot;: [&quot;kaku_dimmer&quot;],\r\n          &quot;state&quot;: &quot;off&quot;,\r\n          &quot;dimlevel&quot;: 1\r\n        },\r\n        &quot;dimmer2&quot;: {\r\n          &quot;protocol&quot;: [&quot;kaku_dimmer&quot;],\r\n          &quot;state&quot;: &quot;off&quot;,\r\n          &quot;dimlevel&quot;: 1\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/29389010/jq-parsing-get-value",
        "title": "jq parsing get value"
    }
]