[
    {
        "tags": [
            "json",
            "key",
            "extract",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2894695,
                    "reputation": 36141,
                    "user_id": 2482744,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://i.sstatic.net/OQPNY.png?s=256",
                    "display_name": "Alex Hall",
                    "link": "https://stackoverflow.com/users/2482744/alex-hall"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475273453,
                "post_id": 39800718,
                "comment_id": 66894045,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 48,
                "is_accepted": true,
                "score": 48,
                "last_activity_date": 1606384252,
                "last_edit_date": 1606384252,
                "creation_date": 1475274991,
                "answer_id": 39801036,
                "question_id": 39800718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input:\r\n\r\n    $ jq -c &#39;paths | select(.[-1] == &quot;foo&quot;)&#39; \r\n    [&quot;A&quot;,&quot;A1&quot;,&quot;foo&quot;]\r\n    [&quot;foo&quot;]\r\n\r\nBonus points:\r\n\r\n(1) If your jq has `tostream`:\r\n\r\n    $ jq &#39;fromstream(tostream| select(.[0]|index(&quot;foo&quot;)))&#39;\r\n\r\nOr better yet, since your input is large, you can use the streaming parser (`jq -n --stream`) with this filter:\r\n\r\n    fromstream( inputs|select( (.[0]|index(&quot;foo&quot;))))\r\n\r\n(2) Whether or not your jq has `tostream`:\r\n\r\n    . as $in\r\n    | reduce (paths(scalars) | select(index(&quot;foo&quot;))) as $p\r\n        (null; setpath($p; $in|getpath($p)))\r\n\r\n\r\nIn all three cases, the output is:\r\n\r\n    {\r\n      &quot;A&quot;: {\r\n        &quot;A1&quot;: {\r\n          &quot;foo&quot;: {\r\n            &quot;_&quot;: &quot;_&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;foo&quot;: {\r\n        &quot;_&quot;: &quot;_&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "How to use jq to find all paths to a certain key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1624290738,
                "creation_date": 1624290738,
                "answer_id": 68071019,
                "question_id": 39800718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had the same fundamental problem. \r\n\r\nWith (yaml) input like:\r\n\r\n```\r\ndeveloper:\r\n  android:\r\n    members:\r\n    - alice\r\n    - bob\r\n    oncall:\r\n    - bob\r\nhr:\r\n  members:\r\n  - charlie\r\n  - doug\r\nthis:\r\n  is:\r\n    really:\r\n      deep:\r\n        nesting:\r\n          members:\r\n          - example deep nesting\r\n\r\n```\r\n\r\nI wanted to find all arbitrarily nested groups and get their members. \r\n\r\nUsing this:\r\n\r\n```bash\r\nyq . | # convert yaml to json using python-yq\r\n    jq &#39; \r\n    . as $input | # Save the input for later\r\n    . | paths | # Get the list of paths \r\n        select(.[-1] | tostring | test(&quot;^(members|oncall|priv)$&quot;; &quot;ix&quot;)) | # Only find paths which end with members, oncall, and priv\r\n        . as $path | # save each path in the $path variable\r\n    ( $input | getpath($path) ) as $members | # Get the value of each path from the original input\r\n    {\r\n        &quot;key&quot;: ( $path | join(&quot;-&quot;) ), # The key is the join of all path keys\r\n        &quot;value&quot;: $members  # The value is the list of members\r\n    }\r\n    &#39; |\r\n    jq -s &#39;from_entries&#39; | # collect kv pairs into a full object using slurp\r\n    yq --sort-keys -y . # Convert back to yaml using python-yq\r\n```\r\n\r\nI get output like this:\r\n\r\n```\r\ndeveloper-android-members:\r\n  - alice\r\n  - bob\r\ndeveloper-android-oncall:\r\n  - bob\r\nhr-members:\r\n  - charlie\r\n  - doug\r\nthis-is-really-deep-nesting-members:\r\n  - example deep nesting\r\n```",
                "title": "How to use jq to find all paths to a certain key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 26,
        "last_activity_date": 1624290738,
        "creation_date": 1475273125,
        "last_edit_date": 1475286015,
        "question_id": 39800718,
        "body_markdown": "In a very large nested json structure I&#39;m trying to find all of the paths that end in a key. \r\n\r\nex:\r\n\r\n    {\r\n      &quot;A&quot;: {\r\n        &quot;A1&quot;: {\r\n          &quot;foo&quot;: {\r\n            &quot;_&quot;: &quot;_&quot;\r\n          }\r\n        },\r\n        &quot;A2&quot;: {\r\n          &quot;_&quot;: &quot;_&quot;\r\n        }\r\n      },\r\n      &quot;B&quot;: {\r\n        &quot;B1&quot;: {}\r\n      },\r\n      &quot;foo&quot;: {\r\n        &quot;_&quot;: &quot;_&quot;\r\n      }\r\n    }\r\n\r\nwould print something along the lines of:\r\n[&quot;A&quot;,&quot;A1&quot;,&quot;foo&quot;], [&quot;foo&quot;]\r\n\r\n\r\n----------\r\n\r\n\r\nUnfortunately I don&#39;t know at what level of nesting the keys will appear, so I haven&#39;t been able to figure it out with a simple select. I&#39;ve gotten close with `jq &#39;[paths] | .[] | select(contains([&quot;foo&quot;]))&#39; `, but the output contains all the permutations of any tree that contains foo. \r\noutput: `[&quot;A&quot;, &quot;A1&quot;, &quot;foo&quot;][&quot;A&quot;, &quot;A1&quot;, &quot;foo&quot;, &quot;_&quot;][&quot;foo&quot;][ &quot;foo&quot;, &quot;_&quot;]`\r\n\r\n\r\nBonus points if I could keep the original data structure format but simply filter out all paths that don&#39;t contain the key (in this case the sub trees under &quot;foo&quot; wouldn&#39;t need to be hidden).",
        "link": "https://stackoverflow.com/questions/39800718/how-to-use-jq-to-find-all-paths-to-a-certain-key",
        "title": "How to use jq to find all paths to a certain key"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1475380570,
                "last_edit_date": 1475380570,
                "creation_date": 1475380192,
                "answer_id": 39813672,
                "question_id": 39813641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    &gt;&gt;&gt; d = {\r\n    ...   &quot;bill&quot;: {\r\n    ...     &quot;congress&quot;: 114,\r\n    ...     &quot;type&quot;: &quot;hr&quot;\r\n    ...   },\r\n    ...   &quot;category&quot;: &quot;passage&quot;,\r\n    ...   &quot;votes&quot;: {\r\n    ...     &quot;Aye&quot;: [\r\n    ...       {\r\n    ...         &quot;display_name&quot;: &quot;Abraham&quot;,\r\n    ...         &quot;id&quot;: &quot;A000374&quot;,\r\n    ...       },\r\n    ...       {\r\n    ...         &quot;display_name&quot;: &quot;Yarmuth&quot;,\r\n    ...         &quot;id&quot;: &quot;Y000062&quot;,\r\n    ...       }\r\n    ...     ],\r\n    ...     &quot;Nay&quot;: [\r\n    ...       {\r\n    ...         &quot;display_name&quot;: &quot;Clyburn&quot;,\r\n    ...     &quot;id&quot;: &quot;C000537&quot;,\r\n    ...       },\r\n    ...     ]}}\r\n    &gt;&gt;&gt; \r\n    &gt;&gt;&gt; # store lookup value in variable to more easily change later\r\n    ... lookup_value = &#39;Y000062&#39;\r\n    &gt;&gt;&gt; \r\n    &gt;&gt;&gt; # you&#39;re only concerned with the data in d[&#39;votes&#39;]\r\n    ... for key, value in d[&#39;votes&#39;].items():\r\n    ...     # for each &#39;display_name&#39; in the each vote type (&#39;Aye&#39; or &#39;Nay&#39;)\r\n    ...     for element in value:\r\n    ...         if element[&#39;id&#39;] == lookup_value:\r\n    ...             print(key)\r\n    ... \r\n    Aye\r\n    &gt;&gt;&gt; ",
                "title": "Retrieve a value in Json based on a nested value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1475382655,
                "creation_date": 1475382655,
                "answer_id": 39813879,
                "question_id": 39813641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Below is the sample function to achieve this:\r\n    \r\n    \r\n    def get_vote_cast_from_id(id):\r\n        global my_json\r\n        for name, nested_values in my_json[&#39;votes&#39;].items():\r\n            if any(nested_value[&#39;id&#39;] == id for nested_value in nested_values):\r\n                return name\r\n        else:\r\n            return None\r\n    \r\n    get_vote_cast_from_id(&quot;A000374&quot;)\r\n    # returns: &quot;Aye&quot;\r\n    \r\n    get_vote_cast_from_id(&quot;random_id&quot;)\r\n    # returns: None\r\n\r\nwhere `my_json` is global variable storing your `JSON`object.\r\n\r\n",
                "title": "Retrieve a value in Json based on a nested value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504165675,
                "last_edit_date": 1504165675,
                "creation_date": 1475385310,
                "answer_id": 39814084,
                "question_id": 39813641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are three solutions using jq.  If an individual is constrained to vote exactly once, then the results should be the same; otherwise, they may differ, e.g if an individual is recorded as voting both Aye and Nay.\r\n\r\nThe first solution assumes that each person votes at most once. If this assumption is satisfied, then it is also the most efficient because it uses `any/2`, which has &quot;short-circuit&quot; semantics:\r\n\r\n    $ jq  --arg id Y000062 &#39;.votes\r\n    | if any( .Aye[]; select(.id == $id) ) then &quot;Aye&quot; \r\n    elif any( .Nay[]; select(.id == $id) ) then &quot;Nay&quot;\r\n    else &quot;none&quot;\r\n    end&#39; votes.json\r\n\r\nThe next solution reports &quot;Aye&quot; for each occurrence of the individual on the Ayes list, and only proceeds to do likewise for the Nays list if no occurrences on the Ayes list were found:\r\n\r\n    $ jq  --arg id Y000062 &#39;.votes\r\n    | ((.Aye[] | select(.id == $id) | &quot;Aye&quot;) // \r\n       (.Nay[] | select(.id == $id) | &quot;Nay&quot;)) &#39; votes.json\r\n\r\nThe third solution might be appropriate if there are no constraints on how many times an individual can appear on the two lists. It first constructs a stream of [ VOTE, ID ] pairs, and then selects the IDs of interest:\r\n\r\n    $ jq --arg id Y000062 &#39;.votes\r\n    | ((.Nay[] | [&quot;Nay&quot;, .id]),\r\n       (.Aye[] | [&quot;Aye&quot;, .id])))\r\n    | select(.[1] == $id)\r\n    | .[0]&#39; votes.json\r\n\r\nWith the given input (altered slightly to make it valid JSON), the output of all three solutions is:\r\n\r\n    &quot;Aye&quot;\r\n\r\n(You can use a command-line tool such as `hjson` to convert the JSON-with-extra-commas to JSON.)",
                "title": "Retrieve a value in Json based on a nested value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504142701,
                "creation_date": 1504142701,
                "answer_id": 45971884,
                "question_id": 39813641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq solution using [tostream](https://stedolan.github.io/jq/manual/#tostream)\r\n\r\n      .votes\r\n    | tostream\r\n    | select(length==2) as [$p,$v]\r\n    | select($v == $id)\r\n    | $p[0]\r\n\r\nIf this filter is in `filter.jq` and the sample data is in `data.json` then\r\n\r\n    jq -M --arg id Y000062 -f filter.jq data.json\r\n \r\nproduces\r\n\r\n    &quot;Aye&quot;",
                "title": "Retrieve a value in Json based on a nested value"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1504165675,
        "creation_date": 1475379691,
        "question_id": 39813641,
        "body_markdown": "I would like is to retrieve the vote cast given a specific id, the data (compliments to [govtrack.us][1]) is stored in json and I am writing in python and intend to use [js][2].\r\n\r\nFor example the input &quot;Y000062&quot; should yield &quot;Aye&quot;\r\n\r\n    {\r\n      &quot;bill&quot;: {\r\n        &quot;congress&quot;: 114,\r\n        &quot;type&quot;: &quot;hr&quot;\r\n      },\r\n      &quot;category&quot;: &quot;passage&quot;,\r\n      &quot;votes&quot;: {\r\n        &quot;Aye&quot;: [\r\n          {\r\n            &quot;display_name&quot;: &quot;Abraham&quot;,\r\n            &quot;id&quot;: &quot;A000374&quot;,\r\n          },\r\n          {\r\n            &quot;display_name&quot;: &quot;Yarmuth&quot;,\r\n            &quot;id&quot;: &quot;Y000062&quot;,\r\n          }\r\n        ],\r\n        &quot;Nay&quot;: [\r\n          {\r\n           \t&quot;display_name&quot;: &quot;Clyburn&quot;,\r\n    \t&quot;id&quot;: &quot;C000537&quot;,\r\n          },\r\n        ]}}\r\n\r\n\r\nIn terminal a solution is cat /ccc/114/votes/2015/H384/data.json | egrep &#39;Nay|Not Voting|Present|Yea|Aye|Y000062&#39; | grep -B 1 &#39;Y000062&#39; | head -1\r\nbut relaying that into a python subprocess seems like a clunky solution.\r\n\r\nNoted: In Json {} is an Object, [] is an Array\r\n\r\n  [1]: https://www.govtrack.us/\r\n  [2]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/39813641/retrieve-a-value-in-json-based-on-a-nested-value",
        "title": "Retrieve a value in Json based on a nested value"
    },
    {
        "tags": [
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1475513802,
                "creation_date": 1475513802,
                "answer_id": 39836671,
                "question_id": 39826489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s no builtin way to do it as far as I know, but it shouldn&#39;t take much to roll out an implementation.\r\n\r\nThere&#39;s only three cases you would need to worry about: when the path is empty, the path contains a string, and the path contains a number.\r\n\r\nIf it&#39;s empty, it&#39;s just referring to the input itself.  If it&#39;s a string, it&#39;s a property of an object. If it&#39;s a number, it&#39;s an index into an array.\r\n\r\nSo you could use this:\r\n\r\n    def to_expression($path): $path |\r\n        if length == 0\r\n            then &quot;.&quot;\r\n            else map(\r\n                if type == &quot;string&quot;\r\n                    then &quot;.\\&quot;\\(.)\\&quot;&quot;\r\n                elif type == &quot;number&quot;\r\n                    then &quot;[\\(.)]&quot;\r\n                else\r\n                    error(&quot;unexpected path type: \\(type)&quot;)\r\n                end\r\n            ) | add\r\n        end;\r\n\r\nNote that this always wraps the property names in quotes.  It&#39;s not strictly required, but easier than trying to figure out if it is actually needed.",
                "title": "A way for jq to output paths in a way itself can read?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475515922,
                "creation_date": 1475515922,
                "answer_id": 39837225,
                "question_id": 39826489,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq **can** read paths specified as JSON arrays.  See in particular `getpath` and `setpath`.  `fromstream` also reads paths in the array format.  ",
                "title": "A way for jq to output paths in a way itself can read?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1475515922,
        "creation_date": 1475479923,
        "question_id": 39826489,
        "body_markdown": "Is there a way to make `jq` output paths in a way itself can read?\r\n\r\nExample input:\r\n\r\n    {\r\n    \t&quot;foo&quot;: [{\r\n    \t\t&quot;bar&quot;: 2,\r\n    \t\t&quot;bor&quot;: 3\r\n    \t}]\r\n    }\r\n\r\nOutput the location and value of &quot;bar&quot; by e.g.:\r\n\r\n    jq -c &#39;tostream | select(.[0]|index(&quot;bar&quot;))&#39;\r\n    [[&quot;foo&quot;,0,&quot;bar&quot;],2]\r\n\r\nIs there a way to instead output the path in the `jq` path selection format, i.e. `.foo[0].bar`?",
        "link": "https://stackoverflow.com/questions/39826489/a-way-for-jq-to-output-paths-in-a-way-itself-can-read",
        "title": "A way for jq to output paths in a way itself can read?"
    },
    {
        "tags": [
            "json",
            "inner-join",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6723222,
                    "reputation": 3233,
                    "user_id": 5182321,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/qnPKc.jpg?s=256",
                    "display_name": "S M",
                    "link": "https://stackoverflow.com/users/5182321/s-m"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1475493963,
                "post_id": 39830426,
                "comment_id": 66950482,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1499002316,
                "last_edit_date": 1499002316,
                "creation_date": 1475512861,
                "answer_id": 39836412,
                "question_id": 39830426,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This response illustrates an efficient approach using jq.\r\n\r\nIn the example, the value of .id in each object is a string\r\nand therefore in the first part of this response, it is assumed that the key is always string-valued (in the P.S., this assumption is relaxed).\r\n\r\nIt is also assumed that the &quot;rows&quot; can be combined without regard to conflicting values.  (We use jq&#39;s `+` to combine objects.)\r\n\r\n    # hashJoin(a1; a2; field) expects a1 and a2 to be arrays of JSON objects\r\n    # and that for each of the objects, the field value is a string.\r\n    # A relational join is performed on &quot;field&quot;.\r\n  \r\n    def hashJoin(a1; a2; field):\r\n      # hash phase:\r\n      (reduce a1[] as $o ({};  . + { ($o | field): $o } )) as $h1\r\n      | (reduce a2[] as $o ({};  . + { ($o | field): $o } )) as $h2\r\n      # join phase:\r\n      | reduce ($h1|keys[]) as $key\r\n          ([]; if $h2|has($key) then . + [ $h1[$key] + $h2[$key] ] else . end) ;\r\n\r\n    hashJoin( $file1; $file2; .id)[]\r\n\r\n\r\nInvocation:\r\n\r\n    $ jq -nc --slurpfile file1 file1.json --slurpfile file2 file2.json -f join.jq\r\n\r\nOutput:\r\n\r\n    {&quot;id&quot;:&quot;10&quot;,&quot;data&quot;:&quot;abc&quot;,&quot;content&quot;:&quot;yui&quot;}  \r\n    {&quot;id&quot;:&quot;30&quot;,&quot;data&quot;:&quot;qwe&quot;,&quot;content&quot;:&quot;ujm&quot;}\r\n    {&quot;id&quot;:&quot;40&quot;,&quot;data&quot;:&quot;wsx&quot;,&quot;content&quot;:&quot;tgb&quot;}\r\n\r\n\r\n\r\nP.S. Here is a still more efficient implementation of `hashJoin/3`, which relaxes all assumptions about the specified &quot;key&quot; except that it specify a valid key. Composite keys can be specified as arrays.\r\n\r\n    def hashJoin(a1; a2; key):\r\n      def akey: key | if type == &quot;string&quot; then . else tojson end;\r\n      def wrap: { (akey) : . } ;\r\n      # hash phase:\r\n      (reduce a1[] as $o ({};  . + ($o | wrap ))) as $h1\r\n      | (reduce a2[] as $o \r\n          ( {};\r\n            ($o|akey) as $v\r\n            | if $h1[$v] then . + { ($v): $o } else . end )) as $h2\r\n      # join phase:\r\n      | reduce ($h2|keys[]) as $key\r\n          ([];  . + [ $h1[$key] + $h2[$key] ] ) ;\r\n\r\n",
                "title": "join two json files based on common key with jq utility or alternative way from command line"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1612906258,
                "creation_date": 1612906258,
                "answer_id": 66127460,
                "question_id": 39830426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@user239558 asked:\r\n&gt; Is there a ... more succinct solution available?\r\n\r\nThe following solution is both efficient and more succinct:\r\n```\r\njq --slurpfile file2 file2.json &#39;\r\n  INDEX($file2[]; .id) as $dict\r\n  | $dict[.id] as $x\r\n  | if $x then . + $x else empty end\r\n&#39;  file1.json\r\n```",
                "title": "join two json files based on common key with jq utility or alternative way from command line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1641630228,
        "creation_date": 1475493760,
        "last_edit_date": 1475544217,
        "question_id": 39830426,
        "body_markdown": "I have 2 json files with common key and I need to JOIN them with ***jq*** utility or alternative way from command line As follows:\r\n\r\n(for example: jq -join -key &quot;id&quot; jsonFile1 jsonFile2)\r\n\r\njsonFile1:\r\n\r\n    {&quot;id&quot;:&quot;10&quot;,&quot;data&quot;:&quot;abc&quot;}\r\n    {&quot;id&quot;:&quot;20&quot;,&quot;data&quot;:&quot;xyz&quot;}\r\n    {&quot;id&quot;:&quot;30&quot;,&quot;data&quot;:&quot;qwe&quot;}\r\n    {&quot;id&quot;:&quot;40&quot;,&quot;data&quot;:&quot;wsx&quot;}\r\n    {&quot;id&quot;:&quot;50&quot;,&quot;data&quot;:&quot;zxc&quot;}\r\n\r\njsonFile2:\r\n\r\n    {&quot;id&quot;:&quot;60&quot;,&quot;content&quot;:&quot;ert&quot;}\r\n    {&quot;id&quot;:&quot;40&quot;,&quot;content&quot;:&quot;tgb&quot;}\r\n    {&quot;id&quot;:&quot;10&quot;,&quot;content&quot;:&quot;yui&quot;}\r\n    {&quot;id&quot;:&quot;30&quot;,&quot;content&quot;:&quot;ujm&quot;}\r\n    {&quot;id&quot;:&quot;70&quot;,&quot;content&quot;:&quot;rfv&quot;}\r\n\r\noutput:\r\n\r\n    {&quot;id&quot;:&quot;10&quot;,&quot;data&quot;:&quot;abc&quot;,&quot;content&quot;:&quot;yui&quot;}\r\n    {&quot;id&quot;:&quot;30&quot;,&quot;data&quot;:&quot;qwe&quot;,&quot;content&quot;:&quot;ujm&quot;}\r\n    {&quot;id&quot;:&quot;40&quot;,&quot;data&quot;:&quot;wsx&quot;,&quot;content&quot;:&quot;tgb&quot;}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39830426/join-two-json-files-based-on-common-key-with-jq-utility-or-alternative-way-from",
        "title": "join two json files based on common key with jq utility or alternative way from command line"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1475628288,
                "last_edit_date": 1475628288,
                "creation_date": 1475626192,
                "answer_id": 39863560,
                "question_id": 39863036,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Negation can be achieved using `not`.  In your case, since you mentioned using regular expressions, you could use `test/1` as follows:\r\n\r\n    map( select(.path | test(&quot;replication&quot;) | not))",
                "title": "JQ: how to delete object from array based on regex filter?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1475675764,
                "last_edit_date": 1475675764,
                "creation_date": 1475674257,
                "answer_id": 39875382,
                "question_id": 39863036,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;ve found another way to do it (I was missing the &#39;not&#39; from the accepted answer): \r\n\r\n     .[] | (select( .path | contains(&quot;value&quot;) | not ))",
                "title": "JQ: how to delete object from array based on regex filter?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1504030230,
        "creation_date": 1475622044,
        "last_edit_date": 1504030230,
        "question_id": 39863036,
        "body_markdown": "I have the following JSON array (simplified example):\r\n\r\n    [  {\r\n        &quot;op&quot;: &quot;remove&quot;,\r\n        &quot;path&quot;: &quot;/cache&quot;\r\n      },\r\n      {\r\n        &quot;op&quot;: &quot;add&quot;,\r\n        &quot;path&quot;: &quot;/game_config&quot;\r\n      },\r\n      {\r\n        &quot;op&quot;: &quot;remove&quot;,\r\n        &quot;path&quot;: &quot;/use_replication&quot;\r\n      },\r\n      {\r\n        &quot;op&quot;: &quot;add&quot;,\r\n        &quot;path&quot;: &quot;/copy_replication&quot;\r\n      }\r\n    ]\r\n\r\nI want to remove from the array the objects that contain &quot;replication&quot;. The result would be:\r\n\r\n    [  {\r\n        &quot;op&quot;: &quot;remove&quot;,\r\n        &quot;path&quot;: &quot;/cache&quot;\r\n      },\r\n      {\r\n        &quot;op&quot;: &quot;add&quot;,\r\n        &quot;path&quot;: &quot;/game_config&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;ve found a way to get only them:\r\n\r\n     .[] | select( .path | contains(&quot;replication&quot;))\r\n\r\nHowever I could not find a way to remove only them from my array, keeping all the other objects.",
        "link": "https://stackoverflow.com/questions/39863036/jq-how-to-delete-object-from-array-based-on-regex-filter",
        "title": "JQ: how to delete object from array based on regex filter?"
    },
    {
        "tags": [
            "json",
            "amazon-ec2",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1475691179,
                "last_edit_date": 1475691179,
                "creation_date": 1475658253,
                "answer_id": 39869691,
                "question_id": 39863816,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "# Working with AWS CLI alone\r\n\r\nI love jq and it&#39;s really really helpful to combine with aws cli but you can already do a lot simply with aws cli in your case.\r\n\r\n&gt; But how do I extract two or more fields and separate them by a space or comma or something? I want PublicDnsName and VpcId to be listed side-by-side for each Instance.\r\n\r\n    aws ec2 describe-instances --query &#39;\r\n      Reservations[*].Instances[].{PublicDnsName:PublicDnsName,VpcId:VpcId}&#39; --output text\r\n\r\n&gt; Specifically what I&#39;m looking for is a list of instances where VpcId is null, undefined, or non-existent\r\n\r\nIf you search for empty VpcId, the following will work:\r\n\r\n    aws ec2 describe-instances --query &#39;\r\n      Reservations[].Instances[?VpcId==``].[PublicDnsName]&#39; --output text\r\n\r\n# Working with `jq`\r\n\r\nAs the original question is \r\n\r\n&gt; How to tell jq to print multiples fields(keys) from aws ec2 cli\r\n\r\nsure you can work with `jq`, you can get multiple fields with the following by separating by a comma\r\n\r\n    aws ec2 describe-instances |\\\r\n      jq &#39;.Reservations[].Instances[].PublicDnsName, .Reservations[].Instances[].VpcId&#39;\r\n\r\nYou can better write it by factoring `Reservations[].Instances`:\r\n\r\n    aws ec2 describe-instances |\\\r\n      jq &#39;.Reservations[].Instances[] | .PublicDnsName, .VpcId&#39;\r\n\r\nand jq supports transformation into csv but it needs to take an array and to avoid issues with double-quotes, you can work with raw data:\r\n\r\n    aws ec2 describe-instances |\\\r\n      jq -r &#39;.Reservations[].Instances[]\r\n             | [.PublicDnsName, .VpcId]\r\n             | @csv&#39;\r\n\r\nThe last will just product the expected result:\r\n\r\n    &quot;ec2-some_id_region.amazonaws.com&quot;,&quot;vpc-some_other_id&quot;",
                "title": "How to tell jq to print multiples fields(keys) from aws ec2 cli"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1475691179,
        "creation_date": 1475628377,
        "last_edit_date": 1475667799,
        "question_id": 39863816,
        "body_markdown": "running aws ec2 describe-instances will return a json text similar to the following:\r\n\r\n    {\r\n        &quot;Reservations&quot;: [\r\n            {\r\n                &quot;Instances&quot;: [\r\n                      &quot;PublicDnsName&quot;: &quot;ec2...&quot;\r\n                        &quot;VpcId&quot;: &quot;vpc-...&quot;,\r\n                            ...\r\n                &quot;Instances&quot;: [\r\n             \r\nI know for each &quot;Instance&quot; I can extract the contents of a single field, for example PublicDnsName, using jq as follows:\r\n`jq &#39;.Reservations[].Instances[].PublicDnsName&#39;` which will list the dns names for my instances\r\nBut how do I extract two or more fields and separate them by a space or comma or something? I want PublicDnsName and VpcId to be listed side-by-side for each Instance. \r\n\r\nSpecifically what I&#39;m looking for is a list of instances where VpcId is null, undefined, or non-existent. In other words I&#39;d like a list of my Classic instances and I need this through api so I can process the results.",
        "link": "https://stackoverflow.com/questions/39863816/how-to-tell-jq-to-print-multiples-fieldskeys-from-aws-ec2-cli",
        "title": "How to tell jq to print multiples fields(keys) from aws ec2 cli"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1475697612,
                "last_edit_date": 1475697612,
                "creation_date": 1475696928,
                "answer_id": 39882484,
                "question_id": 39881728,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just add the appropriate null checks.\r\n\r\n    .users[] | select (.last_login | . == null or fromdateiso8601 &gt; 1475625600).id ",
                "title": "jq filter json by dates"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1475814671,
                "last_edit_date": 1475814671,
                "creation_date": 1475697461,
                "answer_id": 39882649,
                "question_id": 39881728,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to protect against null values of .last_login would be as follows:\r\n\r\n    .users[]\r\n    | select ( .last_login // empty | fromdateiso8601 &gt; 1475625600)\r\n    | .id \r\n\r\n \r\nFor clarity, though, I&#39;d add parentheses, e.g.:\r\n\r\n    .users[]\r\n    | select ( (.last_login // empty) | fromdateiso8601 &gt; 1475625600)\r\n    | .id \r\n\r\nOr more defensively still, use `?`:\r\n\r\n    .users[]\r\n    | select ( .last_login | fromdateiso8601? &gt; 1475625600)\r\n    | .id \r\n\r\nIf you want to include items for which .last_login evaluates to `null`, then you could use the filter that Jeff suggested, or perhaps:\r\n\r\n     (.last_login | fromdateiso8601? &gt; 1475625600) // true\r\n\r\nP.S. For &quot;90 days before now, expressed in seconds since the beginning of the Unix epoch&quot;, you could use:\r\n\r\n    def daysAgo(days):  (now | floor) - (days * 86400);\r\n\r\n\r\n\r\n",
                "title": "jq filter json by dates"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 15,
        "last_activity_date": 1475814671,
        "creation_date": 1475693983,
        "last_edit_date": 1475696642,
        "question_id": 39881728,
        "body_markdown": "I have some json that looks like this\r\n\r\n     {\r\n      &quot;users&quot;:[ {  \r\n         &quot;id&quot;:8734,\r\n         &quot;last_login&quot;:&quot;2016-10-04T06:59:40Z&quot;\r\n      },\r\n      {  \r\n        &quot;id&quot;:9376,\r\n        &quot;last_login&quot;:&quot;2016-05-04T20:37:32Z&quot;\r\n      },\r\n      {  \r\n        &quot;id&quot;:9376,\r\n        &quot;last_login&quot;:null\r\n      }\r\n    ]}\r\n\r\nI want to return ids that the last login date is &gt; 90days so in this case it should only return 9376.  I am thinking I need to use fromdateiso8601  in combination with a select but am having a little trouble getting the syntax right. \r\n\r\nThis seems to work\r\n\r\n    .users[] | select ( .last_login | fromdateiso8601 &gt; 1475625600) | .id \r\n\r\nbut I still get \r\n\r\n    jq: error (at &lt;stdin&gt;:0): strptime/1 requires string inputs and arguments\r\n\r\nhow do I deal with the null,  ideally those would be included in the results. ",
        "link": "https://stackoverflow.com/questions/39881728/jq-filter-json-by-dates",
        "title": "jq filter json by dates"
    },
    {
        "tags": [
            "csv",
            "neo4j",
            "cypher",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4496958,
                    "reputation": 53951,
                    "user_id": 4296747,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-muYS9LV5AoA/AAAAAAAAAAI/AAAAAAAACG4/KcTmlFyGWRI/s256-rj/photo.jpg",
                    "display_name": "Frederic Henri",
                    "link": "https://stackoverflow.com/users/4296747/frederic-henri"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1475760778,
                "post_id": 39896605,
                "comment_id": 67080464,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475776911,
                "post_id": 39896605,
                "comment_id": 67090898,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2559692,
                    "reputation": 541,
                    "user_id": 2220958,
                    "user_type": "registered",
                    "accept_rate": 28,
                    "profile_image": "https://i.sstatic.net/RYXvu.jpg?s=256",
                    "display_name": "Jeroen Steen",
                    "link": "https://stackoverflow.com/users/2220958/jeroen-steen"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475782193,
                "post_id": 39896605,
                "comment_id": 67093811,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475791322,
                "post_id": 39896605,
                "comment_id": 67097986,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1475859367,
                "last_edit_date": 1475859367,
                "creation_date": 1475809654,
                "answer_id": 39908745,
                "question_id": 39896605,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you want the keys in their original order, use `keys_unsorted`.  This should get you on your way:\r\n\r\n    $ jq -r -c &#39;.results[0] | .data[] | .row[]\r\n      | add\r\n      | keys_unsorted as $keys\r\n      | ($keys, [.[$keys[]]])\r\n      | @csv&#39; input.json\r\n\r\n(The newlines here are mainly for legibility.)\r\n\r\nWith your illustrative input, the output would be:\r\n \r\n    &quot;email&quot;,&quot;date_found&quot;,&quot;last_name&quot;,&quot;provider_id&quot;,&quot;first_name&quot;,&quot;number&quot;,&quot;lon&quot;,&quot;lat&quot;,&quot;street_name&quot;,&quot;hood&quot;\r\n    &quot;gdggdd@gmail.com&quot;,&quot;2011-11-29 12:51:14&quot;,&quot;Doe&quot;,2649,&quot;John&quot;,&quot;133&quot;,3.21114,22.8844,&quot;Govstreet&quot;,&quot;Rotterdam&quot;\r\n\r\nOf course, in practice, you will probably have multiple lines of data, so in that case, you will probably want to make adjustments to ensure the headers are only printed once.",
                "title": "Fix &quot;is not valid in a csv row&quot; for jq, by transforming array to string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1475885534,
                "last_edit_date": 1475885534,
                "creation_date": 1475810630,
                "answer_id": 39908866,
                "question_id": 39896605,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Forgive me but I&#39;m not familiar with Cypher syntax or how your data is actually structured, you don&#39;t provide much detail about that.  But what I can gather, based on your sample output, each &quot;row&quot; item seems to correspond to what you return in your Cypher query.\r\n\r\nApparently you&#39;re returning `path` which is an entire set of nodes and relationships, and not necessarily just the data you&#39;re actually interested in.\r\n\r\n    MATCH path=(()&lt;--(p:Person)--&gt;(h:House)&lt;--(s:Street)--&gt;(n:Neighbourhood))\r\n    RETURN path\r\n\r\nYou just want the email addresses so you should probably just return the email.  If I understand the syntax correctly, you could change that to this:\r\n\r\n    MATCH (i)&lt;--(p:Person)--&gt;(h:House)&lt;--(s:Street)--&gt;(n:Neighbourhood)\r\n    RETURN i.email\r\n\r\nI believe that should result in something that looks something like this:\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;columns&quot;: [ &quot;email&quot; ],\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;row&quot;: [\r\n                &quot;gdggdd@gmail.com&quot;\r\n              ],\r\n              &quot;meta&quot;: [\r\n                {\r\n                  &quot;id&quot;: 71390,\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;deleted&quot;: false\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;errors&quot;: []\r\n    }\r\n\r\nThen it should be trivial to export that data to csv using jq since the rows can be converted directly:\r\n\r\n    .results[0] | .columns, .data[].row | @csv\r\n\r\n&lt;hr&gt;\r\n\r\nOn the other hand, I could be completely wrong on what that output would actually look like.  So just working with your example, if you just want emails, you need to map the rows to just the email.\r\n\r\n    .results[0] | .columns, (.data[].row | map(.[0].email)) | @csv\r\n\r\n&lt;hr&gt;\r\n\r\nIn case I misinterpreted, if you were intending to output all values and not just the email, you should select just the values in your Cypher query.\r\n\r\n    MATCH (i)&lt;--(p:Person)--&gt;(h:House)&lt;--(s:Street)--&gt;(n:Neighbourhood)\r\n    RETURN i.email, p.date_found, p.last_name, p.provider_id, p.first_name,\r\n        h.number, h.lon, h.lat, s.street_name, n.hood\r\n\r\nThen if my assumptions on the output are correct, the trivial jq query should give you your csv.",
                "title": "Fix &quot;is not valid in a csv row&quot; for jq, by transforming array to string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1475885534,
        "creation_date": 1475758523,
        "last_edit_date": 1475810806,
        "question_id": 39896605,
        "body_markdown": "I try to export a CSV from Neo4j with jq, with:\r\n\r\n    curl --header &quot;Authorization: Basic myBase64hash=&quot; -H accept:application/json -H content-type:application/json \\\r\n      -d &#39;{&quot;statements&quot;:[{&quot;statement&quot;:&quot;MATCH path=(()&lt;--(p:Person)--&gt;(h:House)&lt;--(s:Street)--&gt;(n:Neighbourhood)) RETURN path&quot;}]}&#39; \\\r\n      http://localhost:7474/db/data/transaction/commit \\\r\n      | jq -r &#39;(.results[0]) | .columns,.data[].row | @csv&#39; &gt; &#39;/tmp/export-subset.csv&#39;\r\n\r\nBut I&#39;m getting this error message:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): array ([{&quot;email&quot;:&quot;...) is not valid in a csv row\r\n\r\nI think it&#39;s because of I have multiple e-mail adresses,\r\nis it possible to place all of them in a CSV cell seperated by comma?\r\nHow can I achieve that with `jq`?\r\n\r\n**Edit:**\r\n\r\nThis is an example of my JSON file:\r\n\r\n    {&quot;results&quot;:[{&quot;columns&quot;:[&quot;path&quot;],&quot;data&quot;:[{&quot;row&quot;:[[{&quot;email&quot;:&quot;gdggdd@gmail.com&quot;},{},{&quot;date_found&quot;:&quot;2011-11-29 12:51:14&quot;,&quot;last_name&quot;:&quot;Doe&quot;,&quot;provider_id&quot;:2649,&quot;first_name&quot;:&quot;John&quot;},{},{&quot;number&quot;:&quot;133&quot;,&quot;lon&quot;:3.21114,&quot;lat&quot;:22.8844},{},{&quot;street_name&quot;:&quot;Govstreet&quot;},{},{&quot;hood&quot;:&quot;Rotterdam&quot;}]],&quot;meta&quot;:[[{&quot;id&quot;:71390,&quot;type&quot;:&quot;node&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:226866,&quot;type&quot;:&quot;relationship&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:63457,&quot;type&quot;:&quot;node&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:227100,&quot;type&quot;:&quot;relationship&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:65076,&quot;type&quot;:&quot;node&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:214799,&quot;type&quot;:&quot;relationship&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:63915,&quot;type&quot;:&quot;node&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:226552,&quot;type&quot;:&quot;relationship&quot;,&quot;deleted&quot;:false},{&quot;id&quot;:71120,&quot;type&quot;:&quot;node&quot;,&quot;deleted&quot;:false}]]}]}],&quot;errors&quot;:[]}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39896605/fix-is-not-valid-in-a-csv-row-for-jq-by-transforming-array-to-string",
        "title": "Fix &quot;is not valid in a csv row&quot; for jq, by transforming array to string"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475778113,
                "last_edit_date": 1475778113,
                "creation_date": 1475777010,
                "answer_id": 39902804,
                "question_id": 39902450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can get all the values with this:\r\n\r\n    jq -r &#39;.info.file.hashes[] | .value&#39; *.json\r\n\r\nSuppose you need only the values where name == &quot;B&quot;\r\n\r\n    jq -r &#39;.info.file.hashes[] | select(.name == &quot;B&quot;) | .value&#39;\r\n\r\nSuppose you need only the values where name == &quot;B&quot; *or* &quot;C&quot;\r\n\r\n    jq -r &#39;.info.file.hashes[] | select(.name | in({&quot;B&quot;:1,&quot;C&quot;:1})) | .value&#39;\r\n\r\nThe &quot;in&quot; function checks if the passed-in string is a key in the given object. The values of `{&quot;B&quot;:1,&quot;C&quot;:1}` are arbitrary. Ref: https://stedolan.github.io/jq/manual/#in",
                "title": "Parsing JSON with Bash jq Issue"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504144262,
                "creation_date": 1504144262,
                "answer_id": 45972047,
                "question_id": 39902450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; How can we select only the hash values from desired &#39;name&#39;. Example : If we want to select only hash values of string &#39;names&#39; B,C,E in any JSON files using JQ ?\r\n\r\nHere is a solution which uses [indices](https://stedolan.github.io/jq/manual/#indices\\(s\\))\r\n\r\n      .info.file.hashes\r\n    | (map(.name) | [ indices($names[]) | .[] ]) as $found\r\n    | .[ $found[] ]\r\n    | .value\r\n\r\nIf this filter is in `filter.jq` and the sample data in `a.json` and `b.json` then    \r\n\r\n    jq -M -r --argjson names &#39;[&quot;B&quot;,&quot;C&quot;,&quot;E&quot;]&#39; -f filter.jq a.json b.json\r\n\r\nproduces\r\n\r\n    3c6781d16dc26baf6422bb24d1cd0f650e451b99\r\n    3c6781d16dc26baf6422bb24d1cd0f650e451b99\r\n    66031dad95dfe6ad10b35f06c4342faa\r\n    9df25fa4e379837e42aaf6d05d92012018d4b659\r\n    e445f412f92b25f3343d5f7adc3c94bdc950601521d5b91e7ce77c21a18259c9\r\n\r\nnote the first hash is duplicated in the sample data.  If that is a problem it can easily be handled with [unique](https://stedolan.github.io/jq/manual/#unique,unique_by\\(path_exp\\)) or other post-processing.",
                "title": "Parsing JSON with Bash jq Issue"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1572452890,
        "creation_date": 1475775737,
        "last_edit_date": 1572452890,
        "question_id": 39902450,
        "body_markdown": "Using bash JQ parser, Im trying parse the fields from a cURL `JSON` response.\r\n\r\nIn file `&#39;a.json&#39;` has 4 &#39;hash&#39; values and `&#39;b.json&#39;` has 5 &#39;hash&#39; values. Based on the assumption that my results will be similar to `&quot;a.json&quot;` I wrote a parser for it.\r\n\r\n    #jq -r &#39;.info[].hashes[0].value&#39;,&#39;.info[].hashes[1].value&#39;,&#39;.info[].hashes[2].value&#39;,&#39;.info[].hashes[3].value&#39; a.json\r\n\r\n\r\n\r\nSample JSON files\r\n\r\n\r\n    #a.json\r\n\r\n    {\r\n    &quot;info&quot;: {\r\n                    &quot;file&quot;: {\r\n                        &quot;Score&quot;: 4.01207390507143,\r\n                        &quot;file_subtype&quot;: &quot;None&quot;,\r\n                        &quot;file_type&quot;: &quot;EXE&quot;,\r\n                        &quot;hashes&quot;: [\r\n                            {\r\n                                &quot;name&quot;: &quot;A&quot;,\r\n                                &quot;value&quot;: &quot;7e5dcd8ffdfa8d726ecbdd3c69e18230&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;B&quot;,\r\n                                &quot;value&quot;: &quot;3c6781d16dc26baf6422bb24d1cd0f650e451b99&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;C&quot;,\r\n                                &quot;value&quot;: &quot;3c6781d16dc26baf6422bb24d1cd0f650e451b99&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;D&quot;,\r\n                                &quot;value&quot;: &quot;c25561f3246ef188467a47971821bab93934842a1e2a48910db9768a2f66e828&quot;\r\n                            }\r\n                        ],\r\n                        &quot;size&quot;: 1912\r\n              }\r\n    }\r\n    }\r\n\r\n   \r\n\r\n     #b.json\r\n    {\r\n    &quot;info&quot;: {\r\n                    &quot;file&quot;: {\r\n                        &quot;Score&quot;: 4,\r\n                        &quot;file_subtype&quot;: &quot;None&quot;,\r\n                        &quot;file_type&quot;: &quot;Image&quot;,\r\n                        &quot;hashes&quot;: [\r\n                          {\r\n                                &quot;name&quot;: &quot;A&quot;,\r\n                                &quot;value&quot;: &quot;f34d5f2d4577ed6d9ceec516c1f5a744&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;B&quot;,\r\n                                &quot;value&quot;: &quot;66031dad95dfe6ad10b35f06c4342faa&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;C&quot;,\r\n                                &quot;value&quot;: &quot;9df25fa4e379837e42aaf6d05d92012018d4b659&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;D&quot;,\r\n                                &quot;value&quot;: &quot;4a51cc531082d216a3cf292f4c39869b462bf6aa&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;E&quot;,\r\n                                &quot;value&quot;: &quot;e445f412f92b25f3343d5f7adc3c94bdc950601521d5b91e7ce77c21a18259c9&quot;\r\n                            }\r\n                        ],\r\n                        &quot;size&quot;: 500\r\n              }\r\n    }\r\n    }\r\n\r\n\r\n\r\nBut some times the results will be like &quot;b.json&quot; too and have 5 fields .  when i&#39;m trying to parse with the JQ command that i have written , Will give me only 4 fields and missing out the last value of &quot;E&quot;.\r\n\r\n\r\n    #jq -r &#39;.info[].hashes[0].value&#39;,&#39;.info[].hashes[1].value&#39;,&#39;.info[].hashes[2].value&#39;,&#39;.info[].hashes[3].value&#39; b.json\r\n\r\n    Result : \r\n    \r\n    f34d5f2d4577ed6d9ceec516c1f5a744\r\n    66031dad95dfe6ad10b35f06c4342faa\r\n    9df25fa4e379837e42aaf6d05d92012018d4b659\r\n    4a51cc531082d216a3cf292f4c39869b462bf6aa\r\n\r\nNow , How can we select only the hash values from desired &#39;name&#39;. \r\n\r\nExample : If we want to select only hash values of string &#39;names&#39; B,C,E in any JSON files using JQ  ?\r\n\r\nAny suggestions please ? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/39902450/parsing-json-with-bash-jq-issue",
        "title": "Parsing JSON with Bash jq Issue"
    },
    {
        "tags": [
            "amazon-web-services",
            "amazon-ec2",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475777231,
                "post_id": 39902587,
                "comment_id": 67091073,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2482303,
                    "reputation": 2883,
                    "user_id": 2640435,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/5fe3cd7d7540ad42af0e9ab6047b0139?s=256&d=identicon&r=PG",
                    "display_name": "Michael Martinez",
                    "link": "https://stackoverflow.com/users/2640435/michael-martinez"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475796463,
                "post_id": 39902587,
                "comment_id": 67099671,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1622795960,
                "last_edit_date": 1622795960,
                "creation_date": 1475777755,
                "answer_id": 39903001,
                "question_id": 39902587,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq 1.5 or later, the simplest approach is to use `from_entries`.\r\n\r\nAfter a minimal fix of the illustrative input, the following invocation:\r\n\r\n    $ jq &#39;.Reservations[]\r\n          | .Instances[]\r\n          | [.PublicDnsName, (.Tags|from_entries|.budget_cluster)]&#39; input.json\r\n\r\nproduces:\r\n\r\n    [\r\n      &quot;ec2-xxxxx.amazonaws.com&quot;,\r\n      &quot;zzzzz&quot;\r\n    ]\r\n\r\nIf you do not have jq 1.5 or later, the following should work:\r\n\r\n    $ jq1.4 &#39;.Reservations[]\r\n    | .Instances[]\r\n    | [.PublicDnsName, (.Tags[]|select(.Key==&quot;budget_cluster&quot;) | .Value)]&#39; input.json\r\n\r\n",
                "title": "How to extract a particular Key-Value Tag from ec2 describe-instances"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1475823870,
                "last_edit_date": 1475823870,
                "creation_date": 1475779122,
                "answer_id": 39903395,
                "question_id": 39902587,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The answer of @peak is great and I keep learning from him on the `jq` part but again you can achieve quite a lot from the AWS CLI\r\n\r\n    aws ec2 describe-instances --query \\\r\n       &#39;Reservations[].Instances[].{PublicDnsName:PublicDnsName, Budget:Tags[?Key==`budget_cluster`].Value}&#39;\r\n\r\nwould produce \r\n\r\n    [\r\n        {\r\n            &quot;PublicDnsName&quot;: &quot;ec2-xxxxx.amazonaws.com&quot;,\r\n            &quot;Budget&quot;: [\r\n                    &quot;zzzz&quot;,\r\n            ]\r\n        }\r\n    ]\r\n\r\nIf you do not want to make a new strict JSon out of it, just take the values\r\n\r\n    aws ec2 describe-instances --query \\\r\n       &#39;Reservations[].Instances[].[PublicDnsName, Tags[?Key==`budget_cluster`].Value][]&#39;\r\n\r\nwill produce\r\n\r\n    [\r\n        &quot;ec2-xxxxx.amazonaws.com&quot;,\r\n        [\r\n            &quot;zzzz&quot;\r\n        ]\r\n    ]",
                "title": "How to extract a particular Key-Value Tag from ec2 describe-instances"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1475855616,
                "creation_date": 1475855616,
                "answer_id": 39921326,
                "question_id": 39902587,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Modifying Fr&#233;d&#233;ric&#39;s answer:\r\n\r\n    aws ec2 describe-instances --output text --query \\\r\n       &#39;Reservations[].Instances[].[PublicDnsName, Tags[?Key==`budget_cluster`].Value | [0]]&#39;\r\n\r\nWould produce:\r\n\r\n    ec2-xxxxx.amazonaws.com zzzzz\r\n    ec2-bbbbb.amazonaws.com yyyyy\r\n\r\nI&#39;ve changed the output to text, which removes as much formatting as possible and selected the individual tag value with ` | [0]` since there will only ever be one per instance anyway. Finally, I removed the `[]` at the end so that the resulting list isn&#39;t flattened. That way in text output each entry will be on its own line.\r\n\r\nYou can also make this more robust by only selecting instances that actually have that tag. You could do so with further modifications to the `--query` parameter, but it is better in this case to use the `--filters` parameter since it does service-side filtering. Specifically you want the `tag-key` filter: `--filters &quot;Name=tag-key,Values=budget_cluster&quot;`\r\n\r\n    aws ec2 describe-instances --output text \\\r\n        --filters &quot;Name=tag-key,Values=budget_cluster&quot; --query \\\r\n       &#39;Reservations[].Instances[?Tags[?Key==`budget_cluster`]].[PublicDnsName, Tags[?Key==`budget_cluster`].Value | [0]]&#39;\r\n\r\n\r\nWould still produce:\r\n\r\n    ec2-xxxxx.amazonaws.com zzzzz\r\n    ec2-bbbbb.amazonaws.com yyyyy\r\n\r\nBut over the wire you would only be getting the instances you care about, thus saving money on bandwidth.",
                "title": "How to extract a particular Key-Value Tag from ec2 describe-instances"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1622795960,
        "creation_date": 1475776249,
        "last_edit_date": 1576637929,
        "question_id": 39902587,
        "body_markdown": "I&#39;ve got the following from describe-instances:\r\n```\r\n{\r\n    &quot;Reservations&quot;: [\r\n        {\r\n            &quot;Instances&quot;: [\r\n                {\r\n                    &quot;PublicDnsName&quot;: &quot;ec2-xxxxx.amazonaws.com&quot;,\r\n                    &quot;Tags&quot;: [\r\n                        {\r\n                            &quot;Key&quot;: &quot;Name&quot;,\r\n                            &quot;Value&quot;: &quot;yyyyy&quot;\r\n                        },\r\n                        {\r\n                            &quot;Key&quot;: &quot;budget_cluster&quot;,\r\n                            &quot;Value&quot;: &quot;zzzzz&quot;\r\n                        },\r\n                        {\r\n                            &quot;Key&quot;: &quot;poc&quot;,\r\n                            &quot;Value&quot;: &quot;aaaaaaa&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\nFor each instance, I would like to extract the PublicDnsName and the value of the &quot;budget_cluster&quot; tag key. How to do this either with `ec2 describe-instances` or with `jq` ?",
        "link": "https://stackoverflow.com/questions/39902587/how-to-extract-a-particular-key-value-tag-from-ec2-describe-instances",
        "title": "How to extract a particular Key-Value Tag from ec2 describe-instances"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475828226,
                "post_id": 39912584,
                "comment_id": 67109485,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 796162,
                    "reputation": 204291,
                    "user_id": 893780,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3j1db.jpg?s=256",
                    "display_name": "robertklep",
                    "link": "https://stackoverflow.com/users/893780/robertklep"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475829294,
                "post_id": 39912584,
                "comment_id": 67110076,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4584319,
                    "reputation": 549,
                    "user_id": 3815591,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/76daf60343b1873ea8e8d1dd0a14703c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheDcoder",
                    "link": "https://stackoverflow.com/users/3815591/thedcoder"
                },
                "reply_to_user": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475831450,
                "post_id": 39912584,
                "comment_id": 67111316,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4584319,
                    "reputation": 549,
                    "user_id": 3815591,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/76daf60343b1873ea8e8d1dd0a14703c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheDcoder",
                    "link": "https://stackoverflow.com/users/3815591/thedcoder"
                },
                "reply_to_user": {
                    "account_id": 796162,
                    "reputation": 204291,
                    "user_id": 893780,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3j1db.jpg?s=256",
                    "display_name": "robertklep",
                    "link": "https://stackoverflow.com/users/893780/robertklep"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475831488,
                "post_id": 39912584,
                "comment_id": 67111337,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 796162,
                    "reputation": 204291,
                    "user_id": 893780,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3j1db.jpg?s=256",
                    "display_name": "robertklep",
                    "link": "https://stackoverflow.com/users/893780/robertklep"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475831602,
                "post_id": 39912584,
                "comment_id": 67111406,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4584319,
                    "reputation": 549,
                    "user_id": 3815591,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/76daf60343b1873ea8e8d1dd0a14703c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheDcoder",
                    "link": "https://stackoverflow.com/users/3815591/thedcoder"
                },
                "reply_to_user": {
                    "account_id": 796162,
                    "reputation": 204291,
                    "user_id": 893780,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3j1db.jpg?s=256",
                    "display_name": "robertklep",
                    "link": "https://stackoverflow.com/users/893780/robertklep"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475832106,
                "post_id": 39912584,
                "comment_id": 67111706,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5846003,
                    "reputation": 5236,
                    "user_id": 4606130,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/a595c54e7d7ed0321d0efa0663d09ed9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "micstr",
                    "link": "https://stackoverflow.com/users/4606130/micstr"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1475837453,
                "post_id": 39912584,
                "comment_id": 67114917,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475976948,
                "post_id": 39912584,
                "comment_id": 67159743,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4584319,
                    "reputation": 549,
                    "user_id": 3815591,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/76daf60343b1873ea8e8d1dd0a14703c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheDcoder",
                    "link": "https://stackoverflow.com/users/3815591/thedcoder"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476030441,
                "post_id": 39912584,
                "comment_id": 67171807,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1475910167,
                "last_edit_date": 1475910167,
                "creation_date": 1475834518,
                "answer_id": 39914566,
                "question_id": 39912584,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`-f` is for specifying a filename to read your &quot;filter&quot; from - the filter in this case being `.sm_api_content` \r\n\r\nIt sounds as if you just want to run `jq` without `-f`, e.g.\r\n\r\n    jq -r .sm_api_content JSON.txt",
                "title": "What is the correct syntax for jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -7,
        "last_activity_date": 1476030577,
        "creation_date": 1475828085,
        "last_edit_date": 1476030577,
        "question_id": 39912584,
        "body_markdown": "Is there a commandline documentation to use `jq`? I am currently running this command:\r\n\r\n    %jq% -f JSON.txt -r &quot;.sm_api_content&quot;\r\n\r\nIt is supposed to read from `JSON.txt` and to output the value of `sm_api_content` (which is a string).\r\n\r\nBut I am getting this error:\r\n\r\n    jq: error: Could not open file .sm_api_content: No such file or directory\r\n\r\nCan anyone help me out here?",
        "link": "https://stackoverflow.com/questions/39912584/what-is-the-correct-syntax-for-jq",
        "title": "What is the correct syntax for jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4203120,
                    "reputation": 11256,
                    "user_id": 4923629,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/2abZO.png?s=256",
                    "display_name": "123",
                    "link": "https://stackoverflow.com/users/4923629/123"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475832790,
                "post_id": 39913930,
                "comment_id": 67112090,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1475834051,
                "post_id": 39913930,
                "comment_id": 67112849,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6592170,
                    "reputation": 1220,
                    "user_id": 5093018,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/222918ac8974b6601a46eab6eb1c0053?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Arun",
                    "link": "https://stackoverflow.com/users/5093018/arun"
                },
                "reply_to_user": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475834342,
                "post_id": 39913930,
                "comment_id": 67113032,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475834381,
                "post_id": 39913930,
                "comment_id": 67113070,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1475834781,
                "creation_date": 1475834781,
                "answer_id": 39914662,
                "question_id": 39913930,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Literally just downloaded and read the manual \r\n\r\nTry \r\n\r\n    jq &#39;(.info.file.hashes[] |select(.name == (&quot;A&quot;,&quot;B&quot;,&quot;C&quot;)).value), .Finish, .Start&#39; b.json\r\n    \r\n    &quot;f34d5f2d4577ed6d9ceec516c1f5a744&quot;\r\n    &quot;66031dad95dfe6ad10b35f06c4342faa&quot;\r\n    &quot;9df25fa4e379837e42aaf6d05d92012018d4b659&quot;\r\n    1475668827\r\n    1475668826\r\n\r\nNote the brackets used for grouping the pipe separately from the Finish and Start values.",
                "title": "Bash JQ getting multiple values Issue in JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1493132030,
        "creation_date": 1475832511,
        "last_edit_date": 1493132030,
        "question_id": 39913930,
        "body_markdown": "I&#39;m trying to parse a JSON file for getting multiple values. I know how to parse the specific values ( &quot;A&quot;/&quot;B&quot;/&quot;C&quot;) in the array `(.info.file.hashes[])`. \r\n\r\nFor Example : When issuing the following command over the file `b.json`\r\n\r\n    jq -r &#39;.info.file.hashes[] | select(.name == (&quot;A&quot;,&quot;B&quot;,&quot;C&quot;)).value&#39; b.json\r\n\r\nResult : \r\n\r\n    f34d5f2d4577ed6d9ceec516c1f5a744\r\n    66031dad95dfe6ad10b35f06c4342faa\r\n    9df25fa4e379837e42aaf6d05d92012018d4b659  \r\n\r\nWhere **b.json**:\r\n\r\n    {\r\n      &quot;Finish&quot;: 1475668827,\r\n      &quot;Start&quot;: 1475668826,\r\n      &quot;info&quot;: {\r\n        &quot;file&quot;: {\r\n          &quot;Score&quot;: 4,\r\n          &quot;file_subtype&quot;: &quot;None&quot;,\r\n          &quot;file_type&quot;: &quot;Image&quot;,\r\n          &quot;hashes&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;A&quot;,\r\n              &quot;value&quot;: &quot;f34d5f2d4577ed6d9ceec516c1f5a744&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;B&quot;,\r\n              &quot;value&quot;: &quot;66031dad95dfe6ad10b35f06c4342faa&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;C&quot;,\r\n              &quot;value&quot;: &quot;9df25fa4e379837e42aaf6d05d92012018d4b659&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;D&quot;,\r\n              &quot;value&quot;: &quot;4a51cc531082d216a3cf292f4c39869b462bf6aa&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;E&quot;,\r\n              &quot;value&quot;: &quot;e445f412f92b25f3343d5f7adc3c94bdc950601521d5b91e7ce77c21a18259c9&quot;\r\n            }\r\n          ],\r\n          &quot;size&quot;: 500\r\n        }\r\n      }\r\n    }\r\n\r\nNow, how can i get multiple values with &quot;Finish&quot;, &quot;Start&quot; along with the hash values? I have tried issuing the command.\r\n\r\n     jq -r &#39;.info.file.hashes[] | select(.name == (&quot;A&quot;,&quot;B&quot;,&quot;C&quot;)).value&#39;,&#39;.Finish&#39;,&#39;.Start&#39; b.json \r\n\r\nand Im getting the result as:\r\n    \r\n    f34d5f2d4577ed6d9ceec516c1f5a744\r\n    null\r\n    66031dad95dfe6ad10b35f06c4342faa\r\n    null\r\n    9df25fa4e379837e42aaf6d05d92012018d4b659\r\n    null\r\n    null\r\n    null\r\n\r\nExpected Result :\r\n    \r\n    f34d5f2d4577ed6d9ceec516c1f5a744\r\n    66031dad95dfe6ad10b35f06c4342faa\r\n    9df25fa4e379837e42aaf6d05d92012018d4b659\r\n    1475668827\r\n    1475668826",
        "link": "https://stackoverflow.com/questions/39913930/bash-jq-getting-multiple-values-issue-in-json-file",
        "title": "Bash JQ getting multiple values Issue in JSON file"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "any"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1475871978,
                "last_edit_date": 1475871978,
                "creation_date": 1475864496,
                "answer_id": 39923609,
                "question_id": 39914570,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `unique` is safe but it does require sorting, which may not be necessary.  In your particular case, for example, the repetition is an artifact of the jq query.  Consider using `any` instead (or as well), as it more precisely captures the intention (&quot;at least one&quot;), as well as having &quot;short-circuit&quot; semantics (i.e., it stops searching once the condition is true):\r\n\r\n\r\n    $ jq &#39;.nodes[]\r\n    | select( any(.attributes[]; .required == true))\r\n    | .address&#39; input.json\r\n\r\nOutput:\r\n\r\n    &quot;127.0.0.1&quot;\r\n\r\nYou can always add `unique` if necessary.",
                "title": "jq select attribute if any array element satisfies a condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1476543280,
        "creation_date": 1475834525,
        "last_edit_date": 1476543280,
        "question_id": 39914570,
        "body_markdown": "With the help of **jq** i would like to select all addresses of nodes that have at least one **required=true** in their attribute list. The result list should have unique items.\r\n\r\nHere is my Json:\r\n\r\n    {\r\n    &quot;nodes&quot;: [\r\n        {\r\n            &quot;address&quot;:&quot;127.0.0.1&quot;,\r\n            &quot;attributes&quot;: [\r\n                {\r\n                    &quot;id&quot;:&quot;abc&quot;,\r\n                    &quot;required&quot;:true\r\n                },\r\n                {\r\n                    &quot;id&quot;:&quot;def&quot;,\r\n                    &quot;required&quot;:true\r\n                },\r\n                {\r\n                    &quot;id&quot;:&quot;ghi&quot;,\r\n                    &quot;required&quot;:false\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;address&quot;:&quot;127.0.0.2&quot;,\r\n            &quot;attributes&quot;: [\r\n                {\r\n                    &quot;id&quot;:&quot;abc&quot;,\r\n                    &quot;required&quot;:false\r\n                },\r\n                {\r\n                    &quot;id&quot;:&quot;def&quot;,\r\n                    &quot;required&quot;:false\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n    }\r\n\r\n\r\nI first tried with:\r\n\r\n    jq &#39;.nodes[] | select(.attributes[].required == true) | .address&#39;\r\n\r\nThis produces:\r\n\r\n    &quot;127.0.0.1&quot;\r\n    &quot;127.0.0.1&quot;\r\n\r\nSo it gets the address for every **required=true** field it finds in the attributes section. How to make the result list unique? There is also a unique keyword in jq, but I couldn&#39;t figure out how this could help me.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39914570/jq-select-attribute-if-any-array-element-satisfies-a-condition",
        "title": "jq select attribute if any array element satisfies a condition"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475950831,
                "creation_date": 1475950831,
                "answer_id": 39935781,
                "question_id": 39935596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`from_entries` expects an array of objects with `key` and `value` properties.  You are however generating separate objects with `user` and `age` properties which just would not work.  First of all, you would need to make sure that the properties are in an array, then have the separate key/value pairs for each of the values you want in the array.\r\n\r\n\r\nWith that said, you don&#39;t really need to use entries to build out the result, it&#39;s not the right tool for the job.  You just want to pull some properties from each of the data objects and add to another object mapping users to ages.  There&#39;s many ways this can be achieved, I would use `reduce` to accomplish this.\r\n\r\n    reduce .data[] as $d ({}; .[$d.user] = $d.age)\r\n\r\nTo get your final result, just combine the parts you need into the object you&#39;re requiring.  I&#39;m not sure where you got that 2016 from, I&#39;m assuming it&#39;s just hardcoded.\r\n\r\n    {department: .arg1, user_age: (reduce .data[] as $d ({}; .[$d.user] = $d.age)), year: 2016}",
                "title": "How can I output a json with the new key name from the value in an existing json by jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1476116520,
                "creation_date": 1476116520,
                "answer_id": 39962613,
                "question_id": 39935596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you can also try:\r\n\r\n    cat tmp.json|jq &#39;{department: .arg1, user_age: (.data|map({(.user): .age})|add), year: 2016}&#39;\r\n\r\nor\r\n\r\n    cat tmp.json|jq &#39;{department: .arg1, user_age: .data|map({(.user): .age})|add, year: 2016}&#39;\r\n\r\n",
                "title": "How can I output a json with the new key name from the value in an existing json by jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504024969,
                "creation_date": 1504024969,
                "answer_id": 45944332,
                "question_id": 39935596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As [Jeff](https://stackoverflow.com/users/390278/jeff-mercado) explained, [from_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) expects input of the form\r\n\r\n    [ {key:xxx, value:yyy} ]\r\n    \r\nso [Hao](https://stackoverflow.com/users/3949473/hao)&#39;s filter\r\n\r\n    .data | .[] | {user,age} | from_entries\r\n    \r\nrequires two small modifications to generate the desired `user_age` object:\r\n\r\n* the values must be `{key,value}` objects\r\n* the values need to be collected into an array\r\n    \r\ne.g.\r\n    \r\n    .data | [.[]|{key:user, value:age|tostring}] | from_entries\r\n\r\n(we include `tostring` because the values in the example output are strings)\r\n\r\nBut since `[ .[]| ... ]` is the same as `map(...)` this could be written\r\n\r\n    .data | map({key:user, value:age|tostring}) | from_entries\r\n\r\nHere is a complete solution:\r\n\r\n    {\r\n      &quot;department&quot;: .arg1,\r\n      &quot;user_age&quot;: .data | map({key:.user, value:.age|tostring}) | from_entries,\r\n      &quot;year&quot;: 2016\r\n    }\r\n\r\nSample output\r\n\r\n    {\r\n      &quot;department&quot;: &quot;Admin&quot;,\r\n      &quot;user_age&quot;: {\r\n        &quot;user1&quot;: &quot;51&quot;,\r\n        &quot;user2&quot;: &quot;52&quot;,\r\n        &quot;user3&quot;: &quot;53&quot;,\r\n        &quot;user4&quot;: &quot;54&quot;\r\n      },\r\n      &quot;year&quot;: 2016\r\n    }",
                "title": "How can I output a json with the new key name from the value in an existing json by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1504024969,
        "creation_date": 1475949689,
        "last_edit_date": 1475949887,
        "question_id": 39935596,
        "body_markdown": "I have an existing json which have a from like this:\r\n\r\n    {\r\n      &quot;arg1&quot;: &quot;Admin&quot;,\r\n      &quot;arg2&quot;: 0,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;arg3&quot;: &quot;11&quot;,\r\n          &quot;user&quot;: &quot;user1&quot;,\r\n          &quot;age&quot;: 51,\r\n          &quot;arg4&quot;: &quot;11&quot;\r\n        },\r\n        {\r\n          &quot;arg3&quot;: &quot;22&quot;,\r\n          &quot;user&quot;: &quot;user2&quot;,\r\n          &quot;age&quot;: 52,\r\n          &quot;arg4&quot;: &quot;22&quot;\r\n        },\r\n        {\r\n          &quot;arg3&quot;: &quot;33&quot;,\r\n          &quot;user&quot;: &quot;user3&quot;,\r\n          &quot;age&quot;: 53,\r\n          &quot;arg4&quot;: &quot;33&quot;\r\n        },\r\n        {\r\n          &quot;arg3&quot;: &quot;44&quot;,\r\n          &quot;user&quot;: &quot;user4&quot;,\r\n          &quot;age&quot;: 54,\r\n          &quot;arg4&quot;: &quot;44&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThen I try this command:\r\n\r\n    $ cat tmp.json|jq &#39;.data|.[]|{user,age}&#39;\r\n    {\r\n      &quot;user&quot;: &quot;user1&quot;,\r\n      &quot;age&quot;: 51,\r\n    }\r\n    {\r\n      &quot;user&quot;: &quot;user2&quot;,\r\n      &quot;age&quot;: 52,\r\n    }\r\n    {\r\n      &quot;user&quot;: &quot;user3&quot;,\r\n      &quot;age&quot;: 53,\r\n    }\r\n    {\r\n      &quot;user&quot;: &quot;user4&quot;,\r\n      &quot;age&quot;: 54,\r\n    }\r\n\r\nWhat I expect to output is:\r\n\r\n    {\r\n      &quot;department&quot;: &quot;Admin&quot;,\r\n      &quot;user_age&quot;: {\r\n        &quot;user1&quot;: &quot;51&quot;,\r\n        &quot;user2&quot;: &quot;52&quot;,\r\n        &quot;user3&quot;: &quot;53&quot;,\r\n        &quot;user4&quot;: &quot;54&quot;\r\n      },\r\n      &quot;year&quot;: 2016\r\n    }\r\n\r\nIn jq&#39;s manual, my request is close to [example 23](https://stedolan.github.io/jq/manual/#example23).\r\n\r\nSo I tried to use `from_entries` function\r\n\r\n    cat tmp.json|jq &#39;.data|.[]|{user,age}|from_entries&#39;\r\n\r\nbut get this error:\r\n\r\n&gt;__jq: error (at &lt;stdin&gt;:30): Cannot index string with string &quot;key&quot;__\r\n\r\nI know this is because of its format not equal an entry.\r\n\r\nSo, what should I do to convert to the expected output?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39935596/how-can-i-output-a-json-with-the-new-key-name-from-the-value-in-an-existing-json",
        "title": "How can I output a json with the new key name from the value in an existing json by jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1476108233,
                "creation_date": 1476108233,
                "answer_id": 39960140,
                "question_id": 39960034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you are printing every instance of a userId:4 on every line you can pipe that to a `wc -l` to get the counts.\r\n\r\n    curl -s &#39;http://jsonplaceholder.typicode.com/posts&#39; |  jq &#39;.[] |select(.userId==4) | length&#39; | wc -l\r\n\r\n    output: 10",
                "title": "Counting posts by user id with JQ and bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1476109961,
                "last_edit_date": 1476109961,
                "creation_date": 1476108465,
                "answer_id": 39960217,
                "question_id": 39960034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    $ curl -s &#39;http://jsonplaceholder.typicode.com/posts&#39; |\r\n        jq &#39;[ .[] |select(.userId==4) ] | length&#39;\r\n    10\r\n\r\nThe outer `[ ]` converts the command result to an array you can apply the `length` on.\r\n\r\n",
                "title": "Counting posts by user id with JQ and bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1476113098,
                "last_edit_date": 1476113098,
                "creation_date": 1476111126,
                "answer_id": 39961072,
                "question_id": 39960034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A very slightly shorter alternative: \r\n\r\n     map(select(.userId==4))|length\r\n\r\nA handy `def` to keep around (perhaps in ~/.jq) is:\r\n\r\n     def count(s): reduce s as $i (0; .+1);\r\n\r\nThe filter you could then use would be:\r\n\r\n     count(.[]|select(.userId==4))\r\n\r\n(Which is one fewer non-blank characters :-)\r\n\r\n\r\n ",
                "title": "Counting posts by user id with JQ and bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1476115785,
                "creation_date": 1476115785,
                "answer_id": 39962398,
                "question_id": 39960034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could also try:\r\n\r\n    curl -s &#39;http://jsonplaceholder.typicode.com/posts&#39; |  jq &#39;group_by(.userId)|.[]|{userId: .[0].userId, count: (.|length)}|select(.userId==4)&#39;\r\n\r\nIn a more generic way, you can use just:\r\n\r\n    curl -s &#39;http://jsonplaceholder.typicode.com/posts&#39; |  jq &#39;group_by(.userId)|.[]|{userId: .[0].userId, count: (.|length)}&#39;\r\n\r\nto count the posts per userId and another variant could be:\r\n\r\n    curl -s &#39;http://jsonplaceholder.typicode.com/posts&#39; |  jq &#39;group_by(.userId)|map({(.[0].userId|tostring): (.|length)})&#39;\r\n\r\nreturn a result with format `[{userId: count},...]`",
                "title": "Counting posts by user id with JQ and bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504027033,
                "creation_date": 1504027033,
                "answer_id": 45944830,
                "question_id": 39960034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [reduce](https://stedolan.github.io/jq/manual/#Reduce):\r\n\r\n    jq &#39;reduce .[] as $i(0;if $i.userId==4 then .+1 else . end)&#39; \\\r\n      &lt;(curl -s http://jsonplaceholder.typicode.com/posts)",
                "title": "Counting posts by user id with JQ and bash"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1504027033,
        "creation_date": 1476107866,
        "last_edit_date": 1476133319,
        "question_id": 39960034,
        "body_markdown": "I am trying to count the posts made by userid 4 \r\n\r\nthis is what i have so far \r\n\r\n        curl -s &#39;http://jsonplaceholder.typicode.com/posts&#39; |  jq &#39;.[] |select(.userId==4) | length&#39;\r\n\r\n\r\noutput : \r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\n       4\r\n\r\ndata can be found at the url but here is a quick sample \r\n\r\n        [\r\n          {\r\n            &quot;userId&quot;: 1,\r\n            &quot;id&quot;: 1,\r\n            &quot;title&quot;: &quot;sunt aut facere repellat provident occaecati excepturi optio reprehenderit&quot;,\r\n            &quot;body&quot;: &quot;quia et suscipit\\nsuscipit recusandae consequuntur expedita et cum\\nreprehenderit molestiae ut ut quas totam\\nnostrum rerum est autem sunt rem eveniet architecto&quot;\r\n          },\r\n          {\r\n            &quot;userId&quot;: 1,\r\n            &quot;id&quot;: 2,\r\n            &quot;title&quot;: &quot;qui est esse&quot;,\r\n            &quot;body&quot;: &quot;est rerum tempore vitae\\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\\nqui aperiam non debitis possimus qui neque nisi nulla&quot;\r\n          },\r\n          {\r\n            &quot;userId&quot;: 1,\r\n            &quot;id&quot;: 3,\r\n            &quot;title&quot;: &quot;ea molestias quasi exercitationem repellat qui ipsa sit aut&quot;,\r\n            &quot;body&quot;: &quot;et iusto sed quo iure\\nvoluptatem occaecati omnis eligendi aut ad\\nvoluptatem doloribus vel accusantium quis pariatur\\nmolestiae porro eius odio et labore et velit aut&quot;\r\n          }]\r\n\r\nI know there are 10 post by the userId 4 so its picking them up i think there is a problem with the length part ? \r\n\r\nit should just count the posts by userId and display the answer which is  10\r\n\r\n\r\nEDIT :: If you think the question is acceptable please could you up-vote so i can gain reputation etc",
        "link": "https://stackoverflow.com/questions/39960034/counting-posts-by-user-id-with-jq-and-bash",
        "title": "Counting posts by user id with JQ and bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476167055,
                "post_id": 39971324,
                "comment_id": 67222143,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1476199153,
                "last_edit_date": 1476199153,
                "creation_date": 1476168819,
                "answer_id": 39971841,
                "question_id": 39971324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your jq has `any/2`, a simple and efficient solution would be:\r\n\r\n    .Subnets[]\r\n    | select( any (.Tags[]; .Key == &quot;Name&quot; and .Value == &quot;TheName&quot;) )\r\n\r\nThis produces the output you want, so I won&#39;t repeat it here.\r\n\r\nIf your jq does not have `any/2`, I&#39;d suggest upgrading, but if that&#39;s inconvenient or not an option, you could use this def:\r\n\r\n    def any(f;g): reduce f as $i (false; . or ($i|g));\r\n\r\np.s. `any(str; cond)` can be read as: &#39;Is there any element, e, in the stream, str, such that `e|cond` has a value other than `null` or `false`?&#39;",
                "title": "Using jq to select a parent by searching child key/value pair"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504028660,
                "creation_date": 1504028660,
                "answer_id": 45945296,
                "question_id": 39971324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [indices](https://stedolan.github.io/jq/manual/#indices\\(s\\))\r\n\r\n    .Subnets[] | select(.Tags | indices({Key:&quot;Name&quot;, Value:&quot;TheName&quot;}) != [])",
                "title": "Using jq to select a parent by searching child key/value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 13,
        "last_activity_date": 1504028660,
        "creation_date": 1476166140,
        "last_edit_date": 1476169894,
        "question_id": 39971324,
        "body_markdown": "Using [jq][1], how do I select a parent object if it contains a child object that meets two filter requirements?\r\n\r\nIn this example I want to select all Subnets elements that have a child tag with key &quot;Name&quot; and value &quot;TheName&quot;.  My example has two subnets.  The first has &quot;TheName&quot; in the wrong key.  The second subnet has the name/value pair I am looking for.  i.e. `&quot;Key&quot;: &quot;Name&quot;, &quot;Value&quot;: &quot;TheName&quot;`\r\n\r\nThe following selects a subnet with the specified value in one of the tags but not the pair.  It returns both subnets instead of only the second subnet.\r\n\r\n    jq &#39;.Subnets[] | select(.Tags[].Value==&quot;TheName&quot;)&#39; output\r\n\r\nHow do I use jq to select only the subnets that have the name/value pair I am looking for?\r\n\r\n    {\r\n        &quot;Subnets&quot;: [\r\n            {\r\n                &quot;VpcId&quot;: &quot;vpc-12345678&quot;,\r\n                &quot;SubnetId&quot;: &quot;subnet-1234567a&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;IgnoreThis&quot;,\r\n                        &quot;Value&quot;: &quot;TheName&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Name&quot;,\r\n                        &quot;Value&quot;: &quot;NotTheName&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;VpcId&quot;: &quot;vpc-12345678&quot;,\r\n                &quot;SubnetId&quot;: &quot;subnet-1234567b&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;IgnoreThis&quot;,\r\n                        &quot;Value&quot;: &quot;ignore&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Name&quot;,\r\n                        &quot;Value&quot;: &quot;TheName&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nThe desired output would be:\r\n\r\n    {\r\n        &quot;VpcId&quot;: &quot;vpc-12345678&quot;,\r\n        &quot;SubnetId&quot;: &quot;subnet-1234567b&quot;,\r\n        &quot;Tags&quot;: [\r\n            {\r\n                &quot;Key&quot;: &quot;IgnoreThis&quot;,\r\n                &quot;Value&quot;: &quot;ignore&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;Name&quot;,\r\n                &quot;Value&quot;: &quot;TheName&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/ &quot;jq&quot;",
        "link": "https://stackoverflow.com/questions/39971324/using-jq-to-select-a-parent-by-searching-child-key-value-pair",
        "title": "Using jq to select a parent by searching child key/value pair"
    },
    {
        "tags": [
            "json",
            "hierarchical-data",
            "jq",
            "data-extraction"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1476202465,
                "creation_date": 1476202465,
                "answer_id": 39981915,
                "question_id": 39977784,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following filter, laid out here for easy reading, will aggregate the input as requested:\r\n\r\n    .nsgs\r\n    | map(.comments as $comments\r\n          | .properties.securityRules[]\r\n          | {comments: $comments,\r\n             name, \r\n             protocol: .properties.protocol,\r\n             sourcePortRange: .properties.sourcePortRange } )\r\n\r\nIf you wanted to avoid the repetition in the last two lines, you could replace the last four lines with:\r\n\r\n          | {comments: $comments, name }\r\n            + (.properties | {protocol, sourcePortRange} ) )\r\n",
                "title": "Create array from multi-dimensional one with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504029358,
                "creation_date": 1504029358,
                "answer_id": 45945519,
                "question_id": 39977784,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution:\r\n\r\n    .nsgs | map({comments} + (.properties.securityRules[] | {name}+.properties))\r\n",
                "title": "Create array from multi-dimensional one with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1504029358,
        "creation_date": 1476190634,
        "last_edit_date": 1476205037,
        "question_id": 39977784,
        "body_markdown": "I would like to use &#39;jq&#39; json processor to transform a json structure to an array of simple objects.\r\n\r\nMy structure is like this:\r\n\r\n    {&quot;nsgs&quot;: [\r\n        {\r\n            &quot;comments&quot;: &quot;text1&quot;,\r\n            &quot;properties&quot;: {\r\n                &quot;securityRules&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;1&quot;,\r\n                        &quot;properties&quot;: {\r\n                            &quot;protocol&quot;: &quot;TCP&quot;,\r\n                            &quot;sourcePortRange&quot;: &quot;*&quot;\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;2&quot;,\r\n                        &quot;properties&quot;: {\r\n                            &quot;protocol&quot;: &quot;UDP&quot;,\r\n                            &quot;sourcePortRange&quot;: &quot;*&quot;\r\n                        }\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;comments&quot;: &quot;text2&quot;,\r\n            &quot;properties&quot;: {\r\n                &quot;securityRules&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;3&quot;,\r\n                        &quot;properties&quot;: {\r\n                            &quot;protocol&quot;: &quot;TCP&quot;,\r\n                            &quot;sourcePortRange&quot;: &quot;*&quot;\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;4&quot;,\r\n                        &quot;properties&quot;: {\r\n                            &quot;protocol&quot;: &quot;UDP&quot;,\r\n                            &quot;sourcePortRange&quot;: &quot;*&quot;\r\n                        }\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]}\r\n\r\nAnd what I want to get is:\r\n\r\n    [\r\n    { &quot;comments&quot;: &quot;text1&quot;,\r\n      &quot;name&quot;: &quot;1&quot;,\r\n      &quot;protocol&quot;: &quot;TCP&quot;,\r\n      &quot;sourcePortRange&quot;: &quot;*&quot;\r\n    },\r\n    \r\n    { &quot;comments&quot;: &quot;text1&quot;,\r\n      &quot;name&quot;: &quot;2&quot;,\r\n      &quot;protocol&quot;: &quot;UDP&quot;,\r\n      &quot;sourcePortRange&quot;: &quot;*&quot;\r\n    },\r\n    \r\n    { &quot;comments&quot;: &quot;text2&quot;,\r\n      &quot;name&quot;: &quot;3&quot;,\r\n      &quot;protocol&quot;: &quot;TCP&quot;,\r\n      &quot;sourcePortRange&quot;: &quot;*&quot;\r\n    },\r\n    \r\n    { &quot;comments&quot;: &quot;text2&quot;,\r\n      &quot;name&quot;: &quot;4&quot;,\r\n      &quot;protocol&quot;: &quot;UDP&quot;,\r\n      &quot;sourcePortRange&quot;: &quot;*&quot;\r\n    }\r\n    ]\r\n\r\nI tried lots of approaches but nothing helps.\r\n\r\nWill appreciate any help.",
        "link": "https://stackoverflow.com/questions/39977784/create-array-from-multi-dimensional-one-with-jq",
        "title": "Create array from multi-dimensional one with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "string-interpolation"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1476217779,
                "last_edit_date": 1476217779,
                "creation_date": 1476211090,
                "answer_id": 39984378,
                "question_id": 39983705,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I was dumb as a stack of bricks. JQ doesn&#39;t render variables in strings in the same way as some languages will do. In my case, I could simply have kept the variable out of the string and written: $user + &quot;...&quot;.",
                "title": "How do I assign something to a JQ variable I&#39;ve already set in JQ?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1476217819,
                "last_edit_date": 1476217819,
                "creation_date": 1476212895,
                "answer_id": 39984885,
                "question_id": 39983705,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` does do variable interpolation; the syntax is just a little different from other languages. You have to explicitly request interpolation with `\\(...)`.\r\n\r\n    jq --arg user &quot;$SOME_USER&quot; &#39;.something.user|=&quot;\\($user) did a thing&quot;&#39;",
                "title": "How do I assign something to a JQ variable I&#39;ve already set in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1476226592,
        "creation_date": 1476208880,
        "last_edit_date": 1476226592,
        "question_id": 39983705,
        "body_markdown": "I&#39;m setting some variables before I run a JQ that I want to set some fields to. Like so:\r\n\r\njq --arg user $SOME_USER &#39;.something.user|=&quot;$user Did a thing&quot;&#39; \r\n\r\nBut when I pipe this to a file or look at stdout it seems to pick up the variable but not replace it in the string in the JQ script.",
        "link": "https://stackoverflow.com/questions/39983705/how-do-i-assign-something-to-a-jq-variable-ive-already-set-in-jq",
        "title": "How do I assign something to a JQ variable I&#39;ve already set in JQ?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "addition",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1476270199,
                "creation_date": 1476270199,
                "answer_id": 39996995,
                "question_id": 39994652,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "OK, after finally finding out what I wanted I also understand that my previous filters didn&#39;t keep the input array but resulted in objects being output after each other. So that was basically the reason why all examples I found wouldn&#39;t work.\r\n\r\nI wanted to group by keys (hence the key/value requirement), which group_by already does, but wouldn&#39;t work.\r\n\r\nFrom grouping working its only a small step to my solution (unique keys, values in arrays).\r\n\r\n    &#39;… group_by(.key) | map({ &quot;key&quot;: .[0].key, &quot;values&quot;: map(.value) | unique })&#39;\r\n\r\nThe output now looks like this, which is perfectly fine for my requirements:\r\n\r\n    [\r\n        {\r\n            &quot;key&quot;: &quot;1&quot;,\r\n            &quot;values&quot;: [\r\n                &quot;value 1&quot;,\r\n                &quot;value 3&quot;\r\n            ],\r\n        },\r\n        {\r\n            &quot;key&quot;: &quot;2&quot;,\r\n            &quot;values&quot;: [\r\n                &quot;value 2&quot;\r\n            ]\r\n        }\r\n    ]\r\n\r\n",
                "title": "JQ: Reduce array of objects to object, adding to array"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1589141754,
                "last_edit_date": 1589141754,
                "creation_date": 1476293231,
                "answer_id": 40004786,
                "question_id": 39994652,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The drawback of a solution relying on `group_by` is that `group_by` requires a sort, which is unnecessary here.  In this response, I&#39;ll show how to avoid any sorting by using a generic (and generally useful) jq function that &quot;melds&quot; an array of JSON objects, essentially by popping the value at each key into an array, and then concatenating corresponding arrays.\r\n\r\n    # input should be an array of objects\r\n    def meld:\r\n      reduce .[] as $o\r\n        ({}; reduce ($o|keys)[] as $key (.; .[$key] += [$o[$key]] ));\r\n\r\n\r\nLet&#39;s also define some data:\r\n\r\n    def data:\r\n    [\r\n        { &quot;key&quot;: &quot;1&quot;, &quot;value&quot;: &quot;value 1&quot;},\r\n        { &quot;key&quot;: &quot;2&quot;, &quot;value&quot;: &quot;value 2&quot;},\r\n        { &quot;key&quot;: &quot;1&quot;, &quot;value&quot;: &quot;value 3&quot;}\r\n    ]\r\n    ;\r\n\r\n\r\nThen the filter:\r\n\r\n    data |  map([.] | from_entries) | meld\r\n\r\nproduces:\r\n\r\n    {&quot;1&quot;:[&quot;value 1&quot;,&quot;value 3&quot;],&quot;2&quot;:[&quot;value 2&quot;]}\r\n",
                "title": "JQ: Reduce array of objects to object, adding to array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1589141754,
        "creation_date": 1476263139,
        "last_edit_date": 1476325204,
        "question_id": 39994652,
        "body_markdown": "I&#39;ve got a more complex JQ expression that&#39;s handling an array of objects.\r\n\r\nThe input looks like this:\r\n\r\n    [\r\n        { &quot;key&quot;: &quot;1&quot;, &quot;value&quot;: &quot;value 1&quot;},\r\n        { &quot;key&quot;: &quot;2&quot;, &quot;value&quot;: &quot;value 2&quot;},\r\n        { &quot;key&quot;: &quot;1&quot;, &quot;value&quot;: &quot;value 3&quot;},\r\n    ]\r\n\r\nWhat I want to get is this:\r\n\r\n    {\r\n        &quot;1&quot;: { &quot;values&quot;: [&quot;value 1&quot;, &quot;value 3&quot;] },\r\n        &quot;2&quot;: { &quot;values&quot;: [&quot;value 2&quot;] }\r\n    }\r\n\r\nor, for my use case:\r\n\r\n    {\r\n        &quot;1&quot;: [ &quot;value 1&quot;, &quot;value 3&quot; ],\r\n        &quot;2&quot;: [ &quot;value 2&quot; ]\r\n    }\r\n\r\nwould also be OK.\r\n\r\n\r\nI&#39;ve already tried to use ``… | { (.key): [.value] }`` but the result is (to no real surprise to me) that later occurrences of keys simply overwrite already existing ones. What I want to accomplish is something like &quot;create a new key/value pair or add .value to an already existing one&#39;s &#39;values&#39; array&quot;.",
        "link": "https://stackoverflow.com/questions/39994652/jq-reduce-array-of-objects-to-object-adding-to-array",
        "title": "JQ: Reduce array of objects to object, adding to array"
    },
    {
        "tags": [
            "javascript",
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476348406,
                "post_id": 40016256,
                "comment_id": 67309687,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5066167,
                    "reputation": 544,
                    "user_id": 4066210,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://lh3.googleusercontent.com/-KBDczJ9S_S4/AAAAAAAAAAI/AAAAAAAABXs/XnsHqaZvE7Q/s256-rj/photo.jpg",
                    "display_name": "krckumar",
                    "link": "https://stackoverflow.com/users/4066210/krckumar"
                },
                "reply_to_user": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476348924,
                "post_id": 40016256,
                "comment_id": 67310000,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1476394919,
                "last_edit_date": 1476394919,
                "creation_date": 1476369850,
                "answer_id": 40024185,
                "question_id": 40016256,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As it stands there is a bug in the question, as Javascript&#39;s Array.push appends to an array.\r\n\r\nThe jq equivalent of the given expression:\r\n\r\n    data.Sample[0].values.push([1028088000000,0]);\r\n\r\nwould be:\r\n\r\n    .Sample[0].values += [[1028088000000,0]]\r\n\r\nor if you want to use the Javascript syntax, you could define `def push(x): .[length] = x;` \r\n\r\nIf you want to replace the last value in the `values` array by another value, say $x, you could (using jq 1.5 or later) write:\r\n\r\n    .Sample[0].values[-1] = $x\r\n\r\nA more robust (with respect to different jq releases) approach would be:\r\n\r\n    .Sample[0].values |= (.[length-1] = $x)\r\n\r\n\r\nWith jq 1.5 or later, if you wanted only to change the negative number to 0, you would write:\r\n\r\n        .Sample[0].values[-1][-1] = 0\r\n\r\nEtc.\r\n\r\n",
                "title": "How to perform JSON object updates using jq commandline utility"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1476394919,
        "creation_date": 1476348349,
        "last_edit_date": 1476349353,
        "question_id": 40016256,
        "body_markdown": "I have a JSON object as follows\r\n\r\n&gt; {&quot;Sample&quot; : [{ \t\t&quot;key&quot;: &quot;KeyName&quot;, \t\t&quot;values&quot;: [ \t\t\t[1025409600000,\r\n&gt; 10], \t\t\t[1028088000000, -6.3382185140371]\r\n&gt;          ] }]}\r\n\r\nUsing javascript I can modify any values as follows\r\n\r\n    data.Sample[0].values.push([1028088000000,0]);\r\n\r\nHow to perform the similar operation using jq commandline json processor? So the JSON object becomes\r\n\r\n&gt; {&quot;Sample&quot; : [{ &quot;key&quot;: &quot;KeyName&quot;, &quot;values&quot;: [ [1025409600000, 10],\r\n&gt; [1028088000000, 0] ] }]}\r\n\r\nThank you.\r\n\t\t\t",
        "link": "https://stackoverflow.com/questions/40016256/how-to-perform-json-object-updates-using-jq-commandline-utility",
        "title": "How to perform JSON object updates using jq commandline utility"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3406795,
                    "reputation": 2137,
                    "user_id": 10376320,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/caefb1f9b1ddeef538f83fb7e24ae3ee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "enharmonic",
                    "link": "https://stackoverflow.com/users/10376320/enharmonic"
                },
                "edited": false,
                "score": 9,
                "creation_date": 1582135874,
                "post_id": 40027395,
                "comment_id": 106676611,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679647986,
                "post_id": 40027395,
                "comment_id": 133762105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 267730,
                    "reputation": 873,
                    "user_id": 556078,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/c0bbd7c139dc8abc512ea70ee15454af?s=256&d=identicon&r=PG",
                    "display_name": "Max Cascone",
                    "link": "https://stackoverflow.com/users/556078/max-cascone"
                },
                "reply_to_user": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1744130088,
                "post_id": 40027395,
                "comment_id": 140312755,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1752239411,
                "post_id": 40027395,
                "comment_id": 140582503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 22,
                "last_activity_date": 1681914708,
                "last_edit_date": 1681914708,
                "creation_date": 1476379850,
                "answer_id": 40027427,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s a quote issue, you need :\r\n\r\n    projectID=$(\r\n      cat file.json | jq -r &quot;.resource[] | select(.username==\\&quot;$EMAILID\\&quot;) | .id&quot;\r\n    )\r\n\r\nIf you put _single quotes_ to delimit the main string, the shell takes `$EMAILID` literally.\r\n\r\n&quot;Double quote&quot; every literal that contains spaces/metacharacters and _every_ expansion: `&quot;$var&quot;`, `&quot;$(command &quot;$var&quot;)&quot;`, `&quot;${array[@]}&quot;`, `&quot;a &amp; b&quot;`. Use `&#39;single quotes&#39;` for code or literal `$&#39;s: &#39;Costs $5 US&#39;`, `ssh host &#39;echo &quot;$HOSTNAME&quot;&#39;`. See    \r\n&lt;http://mywiki.wooledge.org/Quotes&gt;    \r\n&lt;http://mywiki.wooledge.org/Arguments&gt;    \r\n&lt;http://wiki.bash-hackers.org/syntax/words&gt;    \r\n\r\n",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 59,
                "is_accepted": false,
                "score": 57,
                "last_activity_date": 1476380481,
                "creation_date": 1476380481,
                "answer_id": 40027614,
                "question_id": 40027395,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I resolved this issue by escaping the inner double quotes\r\n\r\n    projectID=$(cat file.json | jq -r &quot;.resource[] | select(.username==\\&quot;$EMAILID\\&quot;) | .id&quot;)",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 417,
                "is_accepted": true,
                "score": 416,
                "last_activity_date": 1677947977,
                "last_edit_date": 1677947977,
                "creation_date": 1476380560,
                "answer_id": 40027637,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider also passing in the shell variable (EMAILID) as a jq variable (here also EMAILID, for the sake of illustration):\r\n\r\n       projectID=$(jq -r --arg EMAILID &quot;$EMAILID&quot; &#39;\r\n            .resource[]\r\n            | select(.username==$EMAILID) \r\n            | .id&#39; file.json)\r\n\r\n\r\n\r\n### Postscript\r\n\r\nFor the record, another possibility would be to use jq&#39;s `env` function for accessing environment variables.  For example, consider this sequence of bash commands:\r\n\r\n    EMAILID=foo@bar.com  # not exported\r\n    EMAILID=&quot;$EMAILID&quot; jq -n &#39;env.EMAILID&#39;\r\n\r\nThe output is a JSON string:\r\n\r\n    &quot;foo@bar.com&quot;\r\n\r\n\r\n### shell arrays\r\nUnfortunately, shell arrays are a different kettle of fish.\r\nHere are two SO resources regarding the ingestion of such arrays:\r\n\r\nhttps://stackoverflow.com/questions/61588841/jq-create-json-array-using-bash-array-with-space\r\n\r\nhttps://stackoverflow.com/questions/49184557/convert-bash-array-to-json-array-and-insert-to-file-using-jq",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1511308429,
                "creation_date": 1511308429,
                "answer_id": 47424688,
                "question_id": 40027395,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another way to accomplish this is with the jq &quot;--arg&quot; flag. \r\nUsing the original example: \r\n\r\n    #!/bin/sh\r\n\r\n    #this works ***\r\n    projectID=$(cat file.json | jq -r &#39;.resource[] | \r\n    select(.username==&quot;myemail@hotmail.com&quot;) | .id&#39;)\r\n    echo &quot;$projectID&quot;\r\n\r\n    EMAILID=myemail@hotmail.com\r\n\r\n    # Use --arg to pass the variable to jq. This should work:\r\n    projectID=$(cat file.json | jq --arg EMAILID $EMAILID -r &#39;.resource[] \r\n    | select(.username==&quot;$EMAILID&quot;) | .id&#39;)\r\n    echo &quot;$projectID&quot;\r\n \r\nSee here, which is where I found this solution: \r\nhttps://github.com/stedolan/jq/issues/626\r\n\r\n",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1563541339,
                "creation_date": 1563541339,
                "answer_id": 57113096,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I know is a bit later to reply, sorry. But that works for me.\r\n\r\n    export K8S_public_load_balancer_url=&quot;$(kubectl get services -n ${TENANT}-production -o wide | grep &quot;ingress-nginx-internal$&quot; | awk &#39;{print $4}&#39;)&quot;\r\n\r\nAnd now I am able to fetch and pass the content of the variable to jq\r\n\r\n    export TF_VAR_public_load_balancer_url=&quot;$(aws elbv2 describe-load-balancers --region eu-west-1 | jq -r &#39;.LoadBalancers[] | select (.DNSName == &quot;&#39;$K8S_public_load_balancer_url&#39;&quot;) | .LoadBalancerArn&#39;)&quot;\r\n\r\nIn my case I needed to use double quote and quote to access the variable value. \r\n\r\nCheers.",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 30,
                "last_activity_date": 1573124454,
                "creation_date": 1573124454,
                "answer_id": 58747326,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Posting it here as it might help others. In string it might be necessary to pass the quotes to jq. To do the following with jq:\r\n\r\n    .items[] | select(.name==&quot;string&quot;)\r\n\r\nin bash you could do\r\n\r\n    EMAILID=$1\r\n    projectID=$(cat file.json | jq -r &#39;.resource[] | select(.username==&#39;\\&quot;$EMAILID\\&quot;&#39;) | .id&#39;)\r\n\r\nessentially escaping the quotes and passing it on to jq\r\n",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1622016678,
                "last_edit_date": 1622016678,
                "creation_date": 1585735262,
                "answer_id": 60968286,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Jq now have better way to access environment variables, you can use `env.EMAILID`:\r\n\r\n    projectID=$(cat file.json | jq -r &quot;.resource[] | select(.username==env.EMAILID) | .id&quot;)",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 51,
                "is_accepted": false,
                "score": 48,
                "last_activity_date": 1589528828,
                "creation_date": 1589528828,
                "answer_id": 61814269,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Little unrelated but I will still put it here,\r\nFor other practical purposes shell variables can be used as - \r\n```shell\r\nvalue=10\r\njq  &#39;.&quot;key&quot; = &quot;&#39;&quot;$value&quot;&#39;&quot;&#39; file.json\r\n```",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634336462,
                "creation_date": 1634336462,
                "answer_id": 69591175,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case where we want to append some string to the variable value and we are using the escaped double quotes, for example appending `.crt` to a variable `CERT_TYPE`; the following should work:\r\n\r\n```shell\r\n$ CERT_TYPE=client.reader\r\n$ cat certs.json | jq -r &quot;.\\&quot;${CERT_TYPE}\\&quot;.crt&quot; #### This will *not* work #####\r\n$ cat certs.json | jq -r &quot;.\\&quot;${CERT_TYPE}.crt\\&quot;&quot;\r\n```",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640862209,
                "creation_date": 1640862209,
                "answer_id": 70530727,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I also faced same issue of variable substitution with jq. I found that `--arg` is the option which must be used with square bracket `[]` otherwise it won&#39;t work.. I am giving you sample example below:\r\n\r\n\r\n    RUNNER_TOKEN=$(aws secretsmanager get-secret-value --secret-id $SECRET_ID | jq &#39;.SecretString|fromjson&#39; | jq --arg kt $SECRET_KEY -r &#39;.[$kt]&#39; | tr -d &#39;&quot;&#39;)",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1690874668,
                "creation_date": 1690874668,
                "answer_id": 76809346,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All solution above is failed, I got Success from below using one equal &#39;=&#39; not two &#39;==&#39; in select \r\n\r\n    shell_script | sed &#39;1d&#39;|  jq --arg VAR ${SHELL_VAR} -cC &#39;.[]|select(.branch = $VAR).branch&#39;",
                "title": "Passing bash variable to jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723017362,
                "last_edit_date": 1723017362,
                "creation_date": 1722914748,
                "answer_id": 78837125,
                "question_id": 40027395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "it is simple to filter with the variable you set.My case is test on **jq-1.6**   \r\n\r\n    projectID=$(cat file.json | jq -r &quot;.resource[] | select(.username==&quot;$EMAILID&quot;) | .id&quot;)&quot;\r\n\r\n\r\n",
                "title": "Passing bash variable to jq"
            }
        ],
        "is_answered": true,
        "answer_count": 12,
        "score": 277,
        "last_activity_date": 1723017362,
        "creation_date": 1476379735,
        "last_edit_date": 1598014943,
        "question_id": 40027395,
        "body_markdown": "I have written a script to retrieve certain value from `file.json`. It works if I provide the value to jq `select`, but the variable doesn&#39;t seem to work (or I don&#39;t know how to use it).\r\n\r\n    #!/bin/sh\r\n\r\n    #this works ***\r\n    projectID=$(cat file.json | jq -r &#39;.resource[] | select(.username==&quot;myemail@hotmail.com&quot;) | .id&#39;)\r\n    echo &quot;$projectID&quot;\r\n\r\n    EMAILID=myemail@hotmail.com\r\n\r\n    #this does not work *** no value is printed\r\n    projectID=$(cat file.json | jq -r &#39;.resource[] | select(.username==&quot;$EMAILID&quot;) | .id&#39;)\r\n    echo &quot;$projectID&quot;",
        "link": "https://stackoverflow.com/questions/40027395/passing-bash-variable-to-jq",
        "title": "Passing bash variable to jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-ec2",
            "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": 1476464536,
                "post_id": 40043029,
                "comment_id": 67372884,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1476448941,
                "creation_date": 1476448941,
                "answer_id": 40043451,
                "question_id": 40043029,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As I mentioned in my answer to your original post, you can do most of it directly from the AWS CLI\r\n\r\nget the instance Tag value and also the EBS volumeid:\r\n\r\n    aws ec2 describe-instances --query &quot;Reservations[].Instances[].[BlockDeviceMappings[].Ebs.VolumeId, Tags[].Value]&quot;\r\n\r\nIf you want to extend to get the `DeviceName` field\r\n\r\n    aws ec2 describe-instances --query &quot;Reservations[].Instances[].[BlockDeviceMappings[].[DeviceName, Ebs.VolumeId], Tags[].Value]&quot;\r\n\r\nand if you want to keep text (as you run raw data from jq) you can add the `--output text` flag to the CLI command",
                "title": "Multiple array level of json rendering with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1476451023,
                "last_edit_date": 1476451023,
                "creation_date": 1476449904,
                "answer_id": 40043794,
                "question_id": 40043029,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I will make another answer to work with jq\r\n\r\nFirst you can rewrite the first query\r\n\r\n    cat all-ec2-instance.json \\\r\n    | jq -r &#39;.Reservations[].Instances[] | .Tags[].Value +&quot; &quot;+ .BlockDeviceMappings[].Ebs.VolumeId&#39;\r\n\r\nThen if you want to add additional value from the Json like `DeviceName``\r\n\r\n    cat all-ec2-instance.json \\\r\n    | jq -r &#39;.Reservations[].Instances[] | .Tags[].Value +&quot; &quot;+(.BlockDeviceMappings[] | .Ebs.VolumeId +&quot; &quot;+ .DeviceName)&#39;\r\n\r\nyou get the following\r\n\r\n    &quot;ec2-test1 vol-11111111 /dev/sda1&quot;\r\n    &quot;ec2-test1 vol-22222222 /dev/sdf&quot;\r\n    &quot;ec2-test1 vol-33333333 /dev/sdg&quot;\r\n    &quot;ec2-test2 vol-44444444 /dev/sda1&quot;\r\n    &quot;ec2-test2 vol-55555555 /dev/sdf&quot;\r\n    &quot;ec2-test2 vol-66666666 /dev/sdg&quot;\r\n\r\nwhich are the 6 lines you expect\r\n",
                "title": "Multiple array level of json rendering with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1476693515,
        "creation_date": 1476447640,
        "last_edit_date": 1495540839,
        "question_id": 40043029,
        "body_markdown": "Here is all-ec2-instance.json output from ec2-describe-instances:\r\n \r\n\r\n     \r\n    {\r\n        &quot;Reservations&quot;: [\r\n            {\r\n                &quot;OwnerId&quot;: &quot;&quot;,\r\n                &quot;ReservationId&quot;: &quot;&quot;,\r\n                &quot;Groups&quot;: [],\r\n                &quot;Instances&quot;: [\r\n                    {\r\n     \r\n                        &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n                        &quot;Hypervisor&quot;: &quot;xen&quot;,\r\n                        &quot;BlockDeviceMappings&quot;: [\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sda1&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-11111111&quot;,\r\n                                    &quot;AttachTime&quot;: &quot;2016-04-19T15:53:53.000Z&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdf&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-22222222&quot;,\r\n                                    &quot;AttachTime&quot;: &quot;2016-05-25T08:22:33.000Z&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdg&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-33333333&quot;,\r\n                                    &quot;AttachTime&quot;: &quot;2016-02-28T04:22:07.000Z&quot;\r\n                                }\r\n                            }\r\n                        ],\r\n                         &quot;Tags&quot;: [\r\n                            {\r\n                                &quot;Value&quot;: &quot;ec2-test1&quot;,\r\n                                &quot;Key&quot;: &quot;Name&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;OwnerId&quot;: &quot;&quot;,\r\n                &quot;ReservationId&quot;: &quot;&quot;,\r\n                &quot;Groups&quot;: [],\r\n                &quot;Instances&quot;: [\r\n                    {\r\n     \r\n                        &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n                        &quot;Hypervisor&quot;: &quot;xen&quot;,\r\n                        &quot;BlockDeviceMappings&quot;: [\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sda1&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-44444444&quot;,\r\n                                    &quot;AttachTime&quot;: &quot;2016-05-19T15:53:53.000Z&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdf&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-55555555&quot;,\r\n                                    &quot;AttachTime&quot;: &quot;2015-08-25T08:22:33.000Z&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdg&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-66666666&quot;,\r\n                                    &quot;AttachTime&quot;: &quot;2016-07-28T04:22:07.000Z&quot;\r\n                                }\r\n                            }\r\n                        ],\r\n                         &quot;Tags&quot;: [\r\n                            {\r\n                                &quot;Value&quot;: &quot;ec2-test2&quot;,\r\n                                &quot;Key&quot;: &quot;Name&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n    \r\nThis is a further question from the previous answer given https://stackoverflow.com/a/39204803/567761 . I could now use the following syntax to get the instance **Tag value** and also the **EBS volumeid**:\r\n\r\n    cat all-ec2-instance.json |jq -r &#39;.Reservations[] | .Instances[] |  .Tags[].Value  +&quot; &quot;+ .BlockDeviceMappings[].Ebs.VolumeId &#39;\r\n\r\nbut if I want to get another value from the array **BlockDeviceMappings** I will have wrong result, which mean I can&#39;t get the value of different level array to display correctly, for example, **Tag value** and **VolumeId** and **DeviceName**, I will still get redundant of output. I tried:\r\n\r\n    cat all-ec2-instance.json |jq -c -r &#39;.Reservations[] | .Instances[] |  .Tags[].Value +&quot; &quot;+ .BlockDeviceMappings[].Ebs.VolumeId +&quot; &quot;+ .BlockDeviceMappings[].DeviceName &#39;\r\n\r\nI will get 16 result which is wrong, suppose to be 6 only. If by only taking **VolumeId** and **DeviceName** which are in the same level array **BlockDeviceMappings** we can do this: \r\n\r\n    cat all-ec2-instance.json |jq -c -r &#39;.Reservations[] | .Instances[] |  .BlockDeviceMappings[] |.Ebs.VolumeId +&quot; &quot;+ .DeviceName &#39;\r\n\r\nIn `jq`, how do we store the value of the previous level of array and assign it to a later array loop ? I tried using variables and other jq function but not success :(\r\n\r\nHere is the desired output (comma or any other delimiter are fine):\r\n\r\n    ec2-test1,vol-11111111,/dev/sda1\r\n    ec2-test1,vol-22222222,/dev/sdf\r\n    ec2-test1,vol-33333333,/dev/sdg\r\n    ec2-test2,vol-44444444,/dev/sda1\r\n    ec2-test2,vol-55555555,/dev/sdf\r\n    ec2-test2,vol-66666666,/dev/sdg\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40043029/multiple-array-level-of-json-rendering-with-jq",
        "title": "Multiple array level of json rendering with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1476780488,
                "creation_date": 1476780488,
                "answer_id": 40103632,
                "question_id": 40103370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It was pretty easy actually\r\n\r\n.values | unique_by(.myProp)",
                "title": "jq filter array of object unique property values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1503046137,
        "creation_date": 1476779715,
        "last_edit_date": 1503046137,
        "question_id": 40103370,
        "body_markdown": "Very simple but beginning with jq.\r\n\r\nWhat I have is an array of object. I want to have an array of object filtered by unique value &#39;myprop&#39;\r\n\r\n    [\r\n\r\n        {\r\n          &quot;myProp&quot;: &quot;similarValue&quot;\r\n        },\r\n        {\r\n          &quot;myProp&quot;: &quot;similarValue&quot;\r\n        },\r\n        {\r\n          &quot;myProp&quot;: &quot;OtherValue&quot;\r\n        }\r\n    ]\r\n\r\nResult I want:\r\n\r\n    [\r\n\r\n        {\r\n          &quot;myProp&quot;: &quot;similarValue&quot;\r\n        },\r\n        {\r\n          &quot;myProp&quot;: &quot;OtherValue&quot;\r\n        }\r\n    ]\r\n\r\nWhat I&#39;ve tried:\r\n.someContainerProp | unique[] .myProp\r\n\r\nThe problem is that is returns just the list of values not list of object",
        "link": "https://stackoverflow.com/questions/40103370/jq-filter-array-of-object-unique-property-values",
        "title": "jq filter array of object unique property values"
    },
    {
        "tags": [
            "php",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3595277,
                    "reputation": 46250,
                    "user_id": 3000206,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/BK1fo.jpg?s=256",
                    "display_name": "Carcigenicate",
                    "link": "https://stackoverflow.com/users/3000206/carcigenicate"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1476792829,
                "post_id": 40107941,
                "comment_id": 67487119,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4975657,
                    "reputation": 470,
                    "user_id": 4002074,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/88c75349e62820db3f6fafb92af520c6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "domi771",
                    "link": "https://stackoverflow.com/users/4002074/domi771"
                },
                "reply_to_user": {
                    "account_id": 3595277,
                    "reputation": 46250,
                    "user_id": 3000206,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/BK1fo.jpg?s=256",
                    "display_name": "Carcigenicate",
                    "link": "https://stackoverflow.com/users/3000206/carcigenicate"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476799689,
                "post_id": 40107941,
                "comment_id": 67492273,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1476801768,
                "creation_date": 1476801768,
                "answer_id": 40111283,
                "question_id": 40107941,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The issue is that you have single quote in your command execution\r\n\r\nyou can probably split your command in two\r\n\r\n    $jq_args = &#39;.hits .hits [] .fields[&quot;termListData.terms&quot;] | .[]&#39;;\r\n    $cmd = &#39;cd /home/scripts/scripts; ./total.sh | jq &#39;.escapeshellarg($jq_args).&#39; | wc -l &gt; /home/data/total.csv&#39;;\r\n    shell_exec($cmd);\r\n\r\n",
                "title": "PHP exec with JQ - [] brackets error: PHP Fatal error: Cannot use [] for reading"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1476801768,
        "creation_date": 1476792718,
        "question_id": 40107941,
        "body_markdown": "I have the following command within a PHP script:\r\n\r\n    shell_exec(&#39;cd /home/scripts/scripts; ./total.sh | jq &#39;.hits .hits [] .fields[&quot;termListData.terms&quot;] | .[]&#39; | wc -l &gt; /home/data/total.csv&#39;);\r\n\r\nwhich gives me: PHP Fatal error: Cannot use [] for reading ...\r\n\r\nthe command alone from the command line works perfect but not when within the php script. What I am doing wrong?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40107941/php-exec-with-jq-brackets-error-php-fatal-error-cannot-use-for-reading",
        "title": "PHP exec with JQ - [] brackets error: PHP Fatal error: Cannot use [] for reading"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4509439,
                    "reputation": 35,
                    "user_id": 4854900,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a52317de9c91dce655c0cec0bd62189a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user284274",
                    "link": "https://stackoverflow.com/users/4854900/user284274"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476828977,
                "post_id": 40117713,
                "comment_id": 67509398,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4509439,
                    "reputation": 35,
                    "user_id": 4854900,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a52317de9c91dce655c0cec0bd62189a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user284274",
                    "link": "https://stackoverflow.com/users/4854900/user284274"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1476832335,
                "post_id": 40117713,
                "comment_id": 67510286,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1476823338,
        "creation_date": 1476823338,
        "question_id": 40117713,
        "body_markdown": "The following gives me the logins of authors that have contributed to stedolan&#39;s jq repo:\r\n\r\n    curl &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39; | jq &#39;.[].author.login&#39;\r\n\r\nWith the following result:\r\n\r\n    &quot;nicowilliams&quot;\r\n    &quot;dtolnay&quot;\r\n    &quot;nicowilliams&quot;\r\n    &quot;nicowilliams&quot;\r\n    &quot;stedolan&quot;\r\n\r\nHow do I search for commits from specific authors?  For example, if I only want to return commits from &quot;dtolnay&quot; and &quot;stedolan&quot;?\r\n\r\nI can for example get commit messages from just &#39;stedolan&#39;; however, I&#39;d like to do something like `select(.author.login in(&quot;stedolan&quot;, &quot;dtolnay&quot;))` \r\n\r\n    curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=20&#39; | jq &#39;.[] | select(.author.login == &quot;stedolan&quot;) | .commit.message&#39;",
        "link": "https://stackoverflow.com/questions/40117713/using-jq-how-do-i-search-against-an-array-of-strings",
        "title": "Using jq how do I search against an array of strings?"
    },
    {
        "tags": [
            "json",
            "command-line",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1476841581,
                "creation_date": 1476841581,
                "answer_id": 40120742,
                "question_id": 40120333,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following assumes the input consists of a stream of valid JSON objects.\r\n\r\nOne approach is to use `add`:\r\n\r\n    $ jq &#39;{testId, numStudents: ([select(.studentId[].score &gt; 50) | 1] | add // 0)}&#39; \r\n\r\nWith the given input (after corrections have been made), the output would be:\r\n\r\n``` \r\n{\r\n  &quot;testId&quot;: &quot;1&quot;,\r\n  &quot;numStudents&quot;: 1\r\n}\r\n{\r\n  &quot;testId&quot;: &quot;2&quot;,\r\n  &quot;numStudents&quot;: 2\r\n}\r\n{\r\n  &quot;testId&quot;: &quot;3&quot;,\r\n  &quot;numStudents&quot;: 0\r\n} \r\n```\r\n\r\nAn alternative would be to use `length`, e.g. with this filter:\r\n\r\n    {testId,\r\n     numStudents: ([select(.studentId[].score &gt; 50) ] | length)}\r\n\r\nHowever, if you don&#39;t mind adding a &#39;def&#39;, then the best solution (e.g. because it does not involve construction of an intermediate array) would be along the following lines:\r\n\r\n    def count(s): reduce s as $i (0; .+1);\r\n\r\n    {testId, numStudents: count(select(.studentId[].score &gt; 50))} \r\n\r\n",
                "title": "jq: count nest object values which satisfy condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1476843224,
        "creation_date": 1476838258,
        "last_edit_date": 1476843224,
        "question_id": 40120333,
        "body_markdown": "json data:\r\n\r\n    {testId: &#39;1&#39; studentId:{&#39;s1&#39;:{score: 20} &#39;s2&#39;:{score: 80}}}\r\n    {testId: &#39;2&#39; studentId:{&#39;s1&#39;:{score: 60} &#39;s2&#39;:{score: 70}}}\r\n    {testId: &#39;3&#39; studentId:{&#39;s5&#39;:{score: 40} &#39;s7&#39;:{score: 30}}}\r\n    ...\r\n\r\nI would like to use JQ to tell me how many students achieved a score &gt; x, for each test.\r\n\r\nThus for the above input and x = 50, the output:\r\n\r\n    {testId: &#39;1&#39; numStudents:1}\r\n    {testId: &#39;2&#39; numStudents:2}\r\n    {testId: &#39;3&#39; numStudents:0}\r\n\r\nI am able to generate a list of all students who achieved &gt; 50 on each test with\r\n\r\n    {testId, studentId: .studentId[]?} | select(.studentId.score&gt;50)\r\n\r\nThis command creates a list of objects where each object contains testId, studentId and score, where all scores are greater than 50. However I do not know how to recombine these results into the output I want.",
        "link": "https://stackoverflow.com/questions/40120333/jq-count-nest-object-values-which-satisfy-condition",
        "title": "jq: count nest object values which satisfy condition"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1476873095,
                "creation_date": 1476873095,
                "answer_id": 40128833,
                "question_id": 40125663,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not ideal, but you can use `printf` to format a number in scientific notation as a decimal.\r\n\r\n    $ printf &#39;%.8f&#39; $(curl -s https://bittrex.com/api/v1.1/public/getticker?market=btc-doge | jq &quot;.result.Ask&quot;)\r\n    0.00000035\r\n\r\nThe `.8` in the printf command is specifying 8 places of precision. You can specify `.10` and you will get:\r\n\r\n    0.0000003500\r\n\r\nOr specify lower precision  `.4` and lose data.\r\n\r\n    0.0000\r\n",
                "title": "JQ number output format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1476873095,
        "creation_date": 1476864670,
        "last_edit_date": 1476867734,
        "question_id": 40125663,
        "body_markdown": "For an input below:\r\n\r\n    \r\n    abc@abc:~$ curl https://bittrex.com/api/v1.1/public/getticker?market=btc-doge | jq &quot;.result.Ask&quot;\r\n\r\nOutput to jq: \r\n\r\n`{&quot;success&quot;:true,&quot;message&quot;:&quot;&quot;,&quot;result&quot;:&quot;Bid&quot;:0.00000034,&quot;Ask&quot;:0.00000035,&quot;Last&quot;:0.00000035}}`\r\n\r\nOutput from jq:\r\n  \r\n\r\n    3.5e-07\r\n\r\nhow in JQ switch number output format `3.5e-07` to `0.00000035` ?",
        "link": "https://stackoverflow.com/questions/40125663/jq-number-output-format",
        "title": "JQ number output format"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "cat",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1476875814,
                "creation_date": 1476875814,
                "answer_id": 40129931,
                "question_id": 40129843,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Remove the quotes around your delimieter `EOF` as this causes `cat` to not expand variables.",
                "title": "Write bash variables into JSON template file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1476875814,
        "creation_date": 1476875566,
        "question_id": 40129843,
        "body_markdown": "I need, using bash script, create json file with some variables within.\r\n\r\nFor this purposes, I have a bash file, who creates json template file using cat: \r\n\r\n\tcat &lt;&lt;&#39;EOF&#39; &gt; template.json\r\n    {\r\n    &quot;ip_range&quot; : &quot;$snmp_ip1&quot;, \r\n    &quot;types&quot; : [ &quot;snmp&quot; ],\r\n    &quot;description&quot; : &quot;$snmp_cred1&quot;,\r\n    &quot;snmp.version&quot;: &quot;v2c&quot;,\r\n    &quot;snmp.port&quot; : 161,\r\n    &quot;snmp.community&quot; : &quot;$snmp_cred1&quot;,\r\n    &quot;snmp.retries&quot; : 3,\r\n    &quot;snmp.timeout&quot; : 2\r\n    }\r\n    EOF\r\n\r\nUnfortunately, cat does not expand variables into values.\r\nSo, then I need to insert some variables into template using jq and create some new file with expanded variables. \r\nI tried to use jq for this with following code:\r\n    \r\n    jq \\\r\n\t--arg snmp_ip1 &quot;$snmp_ip&quot; \\\r\n\t--arg snmp_cred1 &quot;$snmp_cred&quot; \\\r\n\t&#39;.[&quot;snmp_ip1&quot;]=$snmp_ip1 | .[&quot;snmp_cred&quot;]=$snmp_cred1&#39; \\\r\n\t&lt;$DIR/template.json &gt;$DIR/cred.json\r\n\r\nUnfortunatelly, it just inserts new strings with variables, but not expands variables in template:\r\n\r\n    {\r\n    &quot;snmp_cred&quot;: &quot;fortinet/fortigate/1.3.6.1.4.1.12356.101.1.37000_fortigate3700d/10.82.112.21@public&quot;,\r\n    &quot;snmp_ip1&quot;: &quot;10.82.112.21&quot;,\r\n    &quot;ip_range&quot;: &quot;$snmp_ip1&quot;,\r\n    &quot;types&quot;: [\r\n    &quot;snmp&quot;\r\n    ],\r\n    &quot;description&quot;: &quot;$snmp_cred1&quot;,\r\n    &quot;snmp.version&quot;: &quot;v2c&quot;,\r\n    &quot;snmp.port&quot;: 161,\r\n    &quot;snmp.community&quot;: &quot;snmp_cred1&quot;,\r\n    &quot;snmp.retries&quot;: 3,\r\n    &quot;snmp.timeout&quot;: 2\r\n    }\r\n\r\nCan you hint me, how to rewrite script (or, maybe use another approach) to create json files with this output:\r\n\r\n    {\r\n    &quot;ip_range&quot;: &quot;10.82.112.21&quot;,\r\n    &quot;types&quot;: [ &quot;snmp&quot; ],\r\n    &quot;description&quot;: &quot;fortinet/fortigate/1.3.6.1.4.1.12356.101.1.37000_fortigate3700d/10.82.112.21@public&quot;,\r\n    &quot;snmp.version&quot;: &quot;v2c&quot;,\r\n    &quot;snmp.port&quot;: 161,\r\n    &quot;snmp.community&quot;: &quot;fortinet/fortigate/1.3.6.1.4.1.12356.101.1.37000_fortigate3700d/10.82.112.21@public&quot;,\r\n    &quot;snmp.retries&quot;: 3,\r\n    &quot;snmp.timeout&quot;: 2\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/40129843/write-bash-variables-into-json-template-file",
        "title": "Write bash variables into JSON template file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1476879620,
                "last_edit_date": 1476879620,
                "creation_date": 1476879216,
                "answer_id": 40131109,
                "question_id": 40130112,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This\r\n---\r\n\r\n    echo &#39;{&quot;aggregations&quot;:{&quot;sent&quot;:{&quot;value&quot;:25},&quot;bounced&quot;:{&quot;value&quot;:null},&quot;incoming_act&quot;:{&quot;value&quot;:12}}}&#39; | jq &#39;.aggregations | {&quot;num_sent&quot;: .sent.value, &quot;num_incoming_act&quot;: .incoming_act.value } | {diff:(.num_sent as $x | .num_incoming_act as $y | $y-$x as $d | $d)}&#39;\r\n\r\nWill Produce:\r\n------\r\n\r\n    {\r\n      &quot;diff&quot;: -13\r\n    }\r\n\r\n\r\n###Difference being here;\r\n\r\nPrevious: `.num_sent as $x | .num_incoming_act as $y | $y-$x as $d | {diff: $d}&#39;`\r\n\r\nNow: `{diff:(.num_sent as $x | .num_incoming_act as $y | $y-$x as $d | $d)}&#39;`\r\n\r\nYou can probably see by visualising the difference, where `jq` is processing things.\r\n\r\n---\r\n\r\n",
                "title": "jq: error: number and object cannot be subtracted"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1476886340,
                "last_edit_date": 1592644375,
                "creation_date": 1476879599,
                "answer_id": 40131258,
                "question_id": 40130112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the examples where you get an error, write `($y-$x) as $d` rather than just `$y-$x as $d`.  The parentheses are sometimes necessary, and always advisable, when writing `(COMPOUND INFIX EXPRESSION) as $variable`.\n\n### Explanation:\n\nThe parser treats expressions of the form:\n\n    3-2 as $d | EXPR\n\nas:\n\n    3-(2 as $d | EXPR)\n\nThis means that `3-2 as $d|$d` is parsed as `3-(2 as $d|$d)` which evaluates to 3-2.  Notice, though, that in this case, $d itself has the value 2.",
                "title": "jq: error: number and object cannot be subtracted"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1476886340,
        "creation_date": 1476876350,
        "last_edit_date": 1476879099,
        "question_id": 40130112,
        "body_markdown": "I&#39;m using jq 1.4 and am confused about the following situation. I can calculate a number, but get an error when I try to construct an object with this number:\r\n\r\n    echo &#39;{&quot;aggregations&quot;:{&quot;sent&quot;:{&quot;value&quot;:25},&quot;bounced&quot;:{&quot;value&quot;:null},&quot;incoming_act&quot;:{&quot;value&quot;:25}}}&#39; |\r\n      jq &#39;.aggregations\r\n          | {&quot;num_sent&quot;: .sent.value, &quot;num_incoming_act&quot;: .incoming_act.value }\r\n          | .num_sent as $x\r\n          | .num_incoming_act as $y\r\n          | $y-$x as $d\r\n          | $d&#39;\r\n    0\r\n\r\nworks fine. But\r\n\r\n    echo &#39;{&quot;aggregations&quot;:{&quot;sent&quot;:{&quot;value&quot;:25},&quot;bounced&quot;:{&quot;value&quot;:null},&quot;incoming_act&quot;:{&quot;value&quot;:25}}}&#39; |\r\n      jq &#39;.aggregations\r\n          | {&quot;num_sent&quot;: .sent.value, &quot;num_incoming_act&quot;: .incoming_act.value }\r\n          | .num_sent as $x\r\n          | .num_incoming_act as $y\r\n          | $y-$x as $d\r\n          | {diff: $d}&#39;\r\n    jq: error: number and object cannot be subtracted\r\n\r\ndoesn&#39;t work. Same happens when I ask for objects in the last part:\r\n\r\n    echo &#39;{&quot;aggregations&quot;:{&quot;sent&quot;:{&quot;value&quot;:25},&quot;bounced&quot;:{&quot;value&quot;:null},&quot;incoming_act&quot;:{&quot;value&quot;:25}}}&#39; |\r\n      jq &#39;.aggregations\r\n          | {&quot;num_sent&quot;: .sent.value, &quot;num_incoming_act&quot;: .incoming_act.value }\r\n          | .num_sent as $x\r\n          | .num_incoming_act as $y\r\n          | $y-$x as $d \r\n          | objects&#39;\r\n    jq: error: number and object cannot be subtracted\r\n\r\nI love jq&#39;s pipe system. However, something seems to be going on here. What is the &quot;0&quot; that I get in the first example? It doesn&#39;t seem to be a normal number 0. This works again:\r\n\r\n    jq -n &#39; 0 as $x | {diff: $x} &#39;",
        "link": "https://stackoverflow.com/questions/40130112/jq-error-number-and-object-cannot-be-subtracted",
        "title": "jq: error: number and object cannot be subtracted"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "any"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1476911992,
                "last_edit_date": 1476911992,
                "creation_date": 1476911600,
                "answer_id": 40141628,
                "question_id": 40135852,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are three ways in which your program can be improved:\r\n\r\n1. (efficiency) avoiding the creation of an unnecessary array (in `is_json`);\r\n2. (efficiency) using &quot;short-circuit&quot; semantics to avoid\r\niterating unnecessarily;\r\n3. (efficiency) avoid the construction/deconstruction involved with with_entries;\r\n\r\nFor the most part, I think you will agree that the alternatives offered here are simpler, more concise, or more readable.\r\n\r\nIf you have version 1.5 of jq or later, the main improvements\r\ncan be had using any/2:\r\n\r\n    def is_json($o): any( (&quot;a&quot;,&quot;b&quot;); . == $o );\r\n\r\n    with_entries(if is_json(.key) then .value |= fromjson else . end)\r\n\r\nNotice also the use of &#39;|=&#39; where you had used &#39;=&#39;.\r\n\r\nIf your jq does not have `any/2`, then you could use the following\r\ndefinition, though it lacks short-circuit semantics:\r\n\r\n    def any(s): reduce s as $i (false; . == true or $i);\r\n\r\n\r\nFinally, to avoid using `with_entries`, you could use `reduce` and eliminate `is_json` entirely:\r\n\r\n    reduce keys[] as $key\r\n      (.; if any((&quot;a&quot;,&quot;b&quot;); . == $key) then .[$key] |= fromjson else . end)\r\n",
                "title": "jq: Testing if a key is in a list of predefined keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1477485533,
        "creation_date": 1476891226,
        "last_edit_date": 1477485533,
        "question_id": 40135852,
        "body_markdown": "I have a case where I need to parse quoted JSON in JSON.\r\nI know which *optional* attributes will contain quoted JSON and which not.\r\nTherefore, I want to check if the attribute keys are in a list of possible keys. I already have the following:\r\n\r\n    # attributes &quot;a&quot; and &quot;b&quot; contain quoted JSON\r\n    echo &#39;{&quot;a&quot;:&quot;{\\&quot;x\\&quot;:1}&quot;,&quot;y&quot;:2}&#39; |\r\n    jq -c &#39;\r\n       def is_json($o): [&quot;a&quot;,&quot;b&quot;] | (map(select(. == $o)) | length) &gt; 0;\r\n       with_entries(if is_json(.key) then .value = (.value|fromjson) else . end)\r\n    &#39;\r\nThis already produces the desired output: `{&quot;a&quot;:{&quot;x&quot;:1},&quot;y&quot;:2}`. However, the checking of the attribute name looks clumsy, given that `jq` provides a lot built-in functions such as `has`, `in`, `contains`, `inside`, etc.\r\n\r\n**Question:** Is there a better way of checking if an attribute key is in a given list?\r\n\r\n**Edit:** Here is the current solution, based on peak&#39;s answer.\r\n\r\n    #!/bin/bash\r\n    to_array_string() { echo &quot;$*&quot; | awk -v OFS=&#39;&quot;,&quot;&#39; &#39;NF &gt; 0 {$1=$1; print &quot;\\&quot;&quot;$0&quot;\\&quot;&quot;}&#39;; }\r\n    to_json_array_string() { echo &quot;[&quot;`to_array_string &quot;$@&quot;`&quot;]&quot;; }\r\n\r\n    parse_json_jq() { jq -c &quot;\r\n       reduce keys[] as \\$key\r\n       (.; if any((`to_array_string &quot;$@&quot;`); . == \\$key) and .[\\$key] != null then .[\\$key] |= fromjson else . end)\r\n    &quot;;}",
        "link": "https://stackoverflow.com/questions/40135852/jq-testing-if-a-key-is-in-a-list-of-predefined-keys",
        "title": "jq: Testing if a key is in a list of predefined keys"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "blacklist"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1476984647,
                "last_edit_date": 1476984647,
                "creation_date": 1476913431,
                "answer_id": 40142006,
                "question_id": 40141310,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One solution would simply be to use `index` with `not`:\r\n\r\n    .[] | .author.login | select( . as $i | $blacklist | index($i) | not)\r\n\r\n\r\nHowever, assuming your jq has `all/2`, there is something to be said for using it:\r\n\r\n    .[] | .author.login | select( . as $i | all($blacklist[]; $i != .))\r\n\r\nIf your jq does not have it, then there is still something to be said for using this solution, with `all/2` defined as follows:\r\n\r\n    def all(s; condition): reduce s as $i (true; . and ($i | condition));",
                "title": "jq - How to select objects based on a &#39;blacklist&#39; of property values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1476984647,
        "creation_date": 1476910283,
        "last_edit_date": 1495540839,
        "question_id": 40141310,
        "body_markdown": "Similar to the question answered here: [jq - How to select objects based on a &#39;whitelist&#39; of property values][1], I&#39;d like to select objects based on a blacklist of property values...\r\n\r\nThe following works fine as a whitelist: `curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=10&#39; | jq --argjson whitelist &#39;[&quot;stedolan&quot;, &quot;dtolnay&quot;]&#39; &#39;.[] | select(.author.login == $whitelist[]) | {author: .author.login, message: .commit.message}&#39;`\r\n\r\n    {\r\n      &quot;author&quot;: &quot;dtolnay&quot;,\r\n      &quot;message&quot;: &quot;Remove David from maintainers&quot;\r\n    }\r\n    {\r\n      &quot;author&quot;: &quot;stedolan&quot;,\r\n      &quot;message&quot;: &quot;Make jv_sort stable regardless of qsort details.&quot;\r\n    }\r\n    {\r\n      &quot;author&quot;: &quot;stedolan&quot;,\r\n      &quot;message&quot;: &quot;Add AppVeyor badge to README.md\\n\\nThanks @JanSchulz, @nicowilliams!&quot;\r\n    }\r\n\r\nThe problem is, I want to negate that and only show commits from authors besides &#39;stedolan&#39; and &#39;dtolnay&#39;; however, if I use `!=` or `not`, I seem to get the same wrong result:\r\n\r\n    nhenry@BONHENRY:~⟫ curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=10&#39; | jq --argjson blacklist &#39;[&quot;stedolan&quot;, &quot;dtolnay&quot;]&#39; &#39;.[] | select(.author.login == $blacklist[] | not) | .author.login&#39; | sort | uniq -c | sort -nr\r\n         14 &quot;nicowilliams&quot;\r\n          2 &quot;stedolan&quot;\r\n          1 &quot;dtolnay&quot;\r\n    nhenry@BONHENRY:~⟫ curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=10&#39; | jq --argjson blacklist &#39;[&quot;stedolan&quot;, &quot;dtolnay&quot;]&#39; &#39;.[] | select(.author.login != $blacklist[]) | .author.login&#39; | sort | uniq -c | sort -nr\r\n         14 &quot;nicowilliams&quot;\r\n          2 &quot;stedolan&quot;\r\n          1 &quot;dtolnay&quot;\r\n\r\nAny suggestions?\r\n\r\n  [1]: https://stackoverflow.com/questions/34878915/jq-how-to-select-objects-based-on-a-whitelist-of-property-values &quot;jq - How to select objects based on a &#39;whitelist&#39; of property values&quot;",
        "link": "https://stackoverflow.com/questions/40141310/jq-how-to-select-objects-based-on-a-blacklist-of-property-values",
        "title": "jq - How to select objects based on a &#39;blacklist&#39; of property values"
    },
    {
        "tags": [
            "bash",
            "sed",
            "aws-cli",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1476978868,
                "last_edit_date": 1476978868,
                "creation_date": 1476970841,
                "answer_id": 40156165,
                "question_id": 40152622,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "JMESPATH has a [sort_by](http://jmespath.readthedocs.io/en/latest/specification.html#sort-by) method that can be used for this - here is just an example\r\n\r\n    aws cloudwatch get-metric-statistics \\\r\n      --metric-name CPUUtilization \\\r\n      --start-time 2016-10-01T23:18:00 --end-time 2016-10-19T23:18:00 --period 3600 \\\r\n      --namespace AWS/EC2 --statistics Maximum \\\r\n      --dimensions Name=InstanceId,Value=&lt;YOURINSTANCE&gt; \\\r\n      --query &#39;sort_by(Datapoints,&amp;Timestamp)[*]&#39;\r\n\r\nIf want to go with jq instead you&#39;ll use jq&#39;s [`sort_by`](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions) method as follow\r\n\r\n    aws cloudwatch get-metric-statistics \\\r\n      --metric-name CPUUtilization \\\r\n      --start-time 2016-10-01T23:18:00 --end-time 2016-10-19T23:18:00 --period 3600 \\\r\n      --namespace AWS/EC2 --statistics Maximum \\\r\n      --dimensions Name=InstanceId,Value=&lt;YOURINSTANCE&gt; \\\r\n    | jq -r &#39;.Datapoints | sort_by(.Timestamp)[]&#39;\r\n\r\nIf you&#39;re more a bash guy, you can use linux sort command\r\n\r\n    aws cloudwatch get-metric-statistics \\\r\n      --metric-name CPUUtilization \\\r\n      --start-time 2016-10-01T23:18:00 --end-time 2016-10-19T23:18:00 --period 3600 \\\r\n      --namespace AWS/EC2 --statistics Maximum \\\r\n      --dimensions Name=InstanceId,Value=&lt;YOURINSTANCE&gt; \\\r\n      --output text \\\r\n    | sort -k 3\r\n\r\nthe dates are in the 3rd column so you will sort this column(`-k 3`)",
                "title": "Shell script - Sorting &#39;AWS cloudwatch metrics&#39; json array based on the &quot;Timestamp&quot; property value which comes in ISO 8601 UTC format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1476978868,
        "creation_date": 1476961404,
        "question_id": 40152622,
        "body_markdown": "I have an Amazon cloudwatch ELB **Latency** metrics like below.\r\n\r\n    {\r\n    &quot;Datapoints&quot;: [\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2016-10-18T12:11:00Z&quot;,\r\n            &quot;Average&quot;: 0.25880099632013942,\r\n            &quot;Minimum&quot;: 0.00071811676025390625,\r\n            &quot;Maximum&quot;: 3.2039437294006352,\r\n            &quot;Unit&quot;: &quot;Seconds&quot;\r\n        },\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2016-10-18T12:10:00Z&quot;,\r\n            &quot;Average&quot;: 0.25197337517680762,\r\n            &quot;Minimum&quot;: 0.00063610076904296875,\r\n            &quot;Maximum&quot;: 2.839790821075439,\r\n            &quot;Unit&quot;: &quot;Seconds&quot;\r\n        },\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2016-10-18T12:19:00Z&quot;,\r\n            &quot;Average&quot;: 0.2287127116954388,\r\n            &quot;Minimum&quot;: 0.00061678886413574219,\r\n            &quot;Maximum&quot;: 1.416410446166992,\r\n            &quot;Unit&quot;: &quot;Seconds&quot;\r\n        }\r\n     ]\r\n }\r\n\r\ni&#39;m running &#39;awscli&#39; inside shell script for getting this , but data is not returned in chronological order and timestamp is in ISO 8601 UTC format. I need to sort this array based on the Timestamp to get the data in chronological order.\r\n\r\n**My Aim:**\r\nI have one more cloudwatch metrics data from ELB **RequestCount** metrics like below.\r\n\r\n    {\r\n    &quot;Datapoints&quot;: [\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2016-10-18T12:11:00Z&quot;,\r\n            &quot;Sum&quot;: 217732.0,\r\n            &quot;Unit&quot;: &quot;Count&quot;\r\n        },\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2016-10-18T12:15:00Z&quot;,\r\n            &quot;Sum&quot;: 227120.0,\r\n            &quot;Unit&quot;: &quot;Count&quot;\r\n        },\r\n      ]\r\n}\r\n\r\nI was looking to sort these metrices based on the timestamp and create a match between the latency and number of request at each timestamp. \r\nAlso , i have to calculate the time difference between the starttime and endtime which might not be possible from the format that is received here.\r\n\r\nI&#39;m using shell script and cannot figure out a way to so this. Any help would be really appreciated. TIA\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40152622/shell-script-sorting-aws-cloudwatch-metrics-json-array-based-on-the-timesta",
        "title": "Shell script - Sorting &#39;AWS cloudwatch metrics&#39; json array based on the &quot;Timestamp&quot; property value which comes in ISO 8601 UTC format"
    },
    {
        "tags": [
            "json",
            "macos",
            "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": 2,
                "creation_date": 1477328362,
                "post_id": 40210276,
                "comment_id": 67710822,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1477597323,
                "post_id": 40210276,
                "comment_id": 67844245,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 12,
                "last_activity_date": 1477597131,
                "last_edit_date": 1495535655,
                "creation_date": 1477282970,
                "answer_id": 40210652,
                "question_id": 40210276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using command-line JSON parser [`jq`](https://stedolan.github.io/jq/), as requested:\r\n\r\n&lt;sup&gt;Note:  [Jeff Mercado&#39;s helpful answer](https://stackoverflow.com/a/40211953/45375) demonstrates a lot of great advanced `jq` techniques, but for the specific problem at hand I believe that the _text_-based approach in this answer is much simpler while still being flexible enough.&lt;/sup&gt;\r\n\r\n\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    # Create variable with sample input.\r\n    IFS= read -r -d &#39;&#39; json &lt;&lt;&#39;EOF&#39;\r\n    [\r\n      {\r\n        &quot;id&quot;: 3624,\r\n        &quot;created_at&quot;: &quot;2016-10-21T20:51:16.000+08:00&quot;\r\n      },\r\n      {\r\n         &quot;id&quot;: 3625,\r\n        &quot;created_at&quot;: &quot;2016-10-22T08:09:16.000+08:00&quot;\r\n      },\r\n      {\r\n         &quot;id&quot;: 3626,\r\n        &quot;created_at&quot;: &quot;2016-10-23T09:19:55.000+08:00&quot;\r\n      }\r\n    ]\r\n    EOF\r\n    \r\n    # Use `jq` to select the objects in the array whose .created_at\r\n    # property value falls between &quot;2016-10-21:T20:51&quot; and &quot;2016-10-22T08:09&quot;\r\n    # and return them as an array (effectively a sub-array of the input).\r\n    # (To solve the problem as originally stated, simply pass &quot;2016-10-21&quot; \r\n    #  and &quot;2016-10-22&quot; instead.)\r\n    jq --arg s &#39;2016-10-21T20:51&#39; --arg e &#39;2016-10-22T08:09&#39; &#39;\r\n      map(select(.created_at | . &gt;= $s and . &lt;= $e + &quot;z&quot;))\r\n    &#39; &lt;&lt;&lt;&quot;$json&quot;\r\n\r\n* Arguments `--arg s &#39;2016-10-21T20:51&#39;` and `--arg e &#39;2016-10-22T08:09&#39;` define variables `$s` (start of date+time range) and `$e` (end of date+time range) respectively, for use inside the `jq` script.\r\n\r\n* Function `map()` applies the enclosed expression to all the elements of the input array and outputs the results as an array, too.\r\n\r\n* Function `select()` accepts a filtering expression: every input object is evaluated against the enclosed expression, and the input object is only passed out if the expression evaluates to a &quot;truthy&quot; value.\r\n\r\n* Expression `.created_at | . &gt;= $s and . &lt;= $e + &quot;z&quot;` accesses each input object&#39;s `created_at` property and sends its value to the comparison expression, which performs _lexical_ comparison, which - due to the formatting of the date+time strings - amounts to _chronological_ comparison.\r\n\r\n  * Note the trailing `&quot;z&quot;` appended to the range endpoint, to ensure that it matches all date+time strings in the JSON string that _prefix-match_ the endpoint; e.g., endpoint `2016-10-22T08:09` should match `2016-10-22T08:09:01` as well as `2016-10-22T08:59`.\r\n\r\n  * This lexical approach allows you to specify as many components from the beginning as desired in order to narrow or widen the date range; e.g. `--arg s &#39;2016-10-01&#39; --arg e &#39;2016-10-31&#39;` would match all entries for the entire month of October 2016.",
                "title": "How to select a date range from a JSON string by using jq?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1477332429,
                "last_edit_date": 1477332429,
                "creation_date": 1477290561,
                "answer_id": 40211953,
                "question_id": 40210276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For a more robust solution, it would be better to parse the dates to get its components and compare those components. The closest you can get is to use `strptime/1` to parse the date which returns an array of its components.  Then compare the components to check if it&#39;s in range.\r\n\r\nThe array that `strptime` returns are the components:\r\n\r\n    year (%Y)\r\n    month (%m)\r\n    date (%d)\r\n    hours (%H)\r\n    minutes (%M)\r\n    seconds (%S)\r\n    day of week (%w)\r\n    day of year (%j)\r\n\r\nSince you&#39;re only comparing the dates, the comparisons should only look at the first 3 components.\r\n\r\n    $ jq --arg s &#39;2016-10-21&#39; --arg e &#39;2016-10-22&#39; &#39;\r\n    [($s, $e) | strptime(&quot;%Y-%m-%d&quot;)[0:3]] as $r\r\n      | map(select(\r\n            (.created_at[:19] | strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;)[0:3]) as $d\r\n              | $d &gt;= $r[0] and $d &lt;= $r[1]\r\n        ))\r\n    &#39; input.json\r\n\r\nSince you&#39;re running on a Mac, I&#39;d expect these methods would be available to you in your build.  You may have to make adjustments to the format of the dates for it to work as expected.  As you can see in the comments, we had to massage it a bit to make it work.",
                "title": "How to select a date range from a JSON string by using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1549890069,
        "creation_date": 1477279595,
        "last_edit_date": 1549890069,
        "question_id": 40210276,
        "body_markdown": "I have a JSON string like this (MacOS):\r\n\r\n    [{\r\n        &quot;id&quot;: 3624,\r\n        &quot;created_at&quot;: &quot;2016-10-21T20:51:16.000+08:00&quot;,\r\n      },\r\n      {\r\n         &quot;id&quot;: 3625,\r\n        &quot;created_at&quot;: &quot;2016-10-22T08:09:16.000+08:00&quot;,\r\n      },\r\n     {\r\n         &quot;id&quot;: 3626,\r\n        &quot;created_at&quot;: &quot;2016-10-23T09:19:55.000+08:00&quot;,\r\n      }]\r\n     \r\nI wanna select &quot;created_at&quot; from &quot;2016-10-21&quot; to &quot;2016-10-22&quot;;\r\nI wanna get result like this:\r\n\r\n    [{\r\n        &quot;id&quot;: 3624,\r\n        &quot;created_at&quot;: &quot;2016-10-21T20:51:16.000+08:00&quot;,\r\n      },\r\n      {\r\n         &quot;id&quot;: 3625,\r\n        &quot;created_at&quot;: &quot;2016-10-22T08:09:16.000+08:00&quot;,\r\n      }]\r\n\r\nCan someone point me in the right direction?\r\n\r\n\r\n**The problem is solved.**\r\nNow,i use this code to select date right to the minute,i hope it&#39;s useful for others:\r\n\r\n    jq --arg s &#39;2016-10-26T18:16&#39; --arg e &#39;2016-10-27T20:24&#39; &#39;[($s, $e) | strptime(&quot;%Y-%m-%dT%H:%M&quot;) | mktime] as $r\r\n      | map(select(\r\n            (.updated_at[:19] | strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;) | mktime) as $d\r\n              | $d &gt;= $r[0] and $d &lt;= $r[1]))&#39; &lt;&lt;&lt; &quot;$requestJson&quot;\r\n        ",
        "link": "https://stackoverflow.com/questions/40210276/how-to-select-a-date-range-from-a-json-string-by-using-jq",
        "title": "How to select a date range from a JSON string by using jq?"
    },
    {
        "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": 1,
                "creation_date": 1477405660,
                "post_id": 40242529,
                "comment_id": 67747335,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7866408,
                    "reputation": 323,
                    "user_id": 5945108,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6MghY.png?s=256",
                    "display_name": "GrumpyMelon",
                    "link": "https://stackoverflow.com/users/5945108/grumpymelon"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1477449930,
                "post_id": 40242529,
                "comment_id": 67767860,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1477409931,
                "last_edit_date": 1477409931,
                "creation_date": 1477406453,
                "answer_id": 40242925,
                "question_id": 40242529,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Let jq do the iterating. (That is, let jq do the iterating through the input stream of JSON objects.)  For example:\r\n\r\n    $ jq .id &lt;&lt;&lt; &quot;$json&quot; | while read id ; do echo &quot;hello $id&quot;; done\r\n\r\nOutput:\r\n\r\n    hello 3397\r\n    hello 3396\r\n\r\nThis way, you don&#39;t have to know how many JSON objects are in the input. You might want to use &quot;read -r&quot;, or &quot;IFS= read -r&quot;.\r\n\r\nThe alternatives are ugly and inefficient, e.g.:\r\n\r\n    $ for ((i=0;i&lt;2;i++)) ; do jq -s --argjson i &quot;$i&quot; &#39;.[$i].id&#39; &lt;&lt;&lt; &quot;$json&quot; ; done\r\n",
                "title": "how can i use variable in jq?(MacOS,shell)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1477409931,
        "creation_date": 1477405232,
        "last_edit_date": 1477406617,
        "question_id": 40242529,
        "body_markdown": "I got a Json string as:\r\n\r\n    {\r\n      &quot;id&quot;: 3397,\r\n      &quot;title&quot;: &quot;title_1&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 3396,\r\n      &quot;title&quot;: &quot;title_2&quot;\r\n    }\r\n\r\nwhat I want to do is get every `id` in a loop,\r\nI use the following code :\r\n\r\n    for (( i = 0; i &lt; requestCount; i++ )); do\r\n     \t  requestId=$(echo $jsonString[$i] | jq &#39;.id&#39;)\r\n          echo requestId;\r\n    done\r\n\r\nbut it doesn&#39;t work, I think the way I use variable is wrong, I can&#39;t find anything useful here [jq][1].\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40242529/how-can-i-use-variable-in-jqmacos-shell",
        "title": "how can i use variable in jq?(MacOS,shell)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1477647732,
                "last_edit_date": 1477647732,
                "creation_date": 1477645577,
                "answer_id": 40301679,
                "question_id": 40301450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The answer is in the rest of the text\r\n\r\n&gt; `Usage: jq [options] &lt;jq filter&gt; [file...]`\r\n\r\nA filter should be mandatory then, a filter takes an input and produces an output, but in many times you dont need to produce an output and just want the result printed so the default was `.` (see the [issue](https://github.com/stedolan/jq/issues/220) believe introduced in 1.5, before you must had to include the filter) \r\n\r\nso it should be the same if `.` is the default filtering, unfortunately is how pipe is reading stdin and stout. You can read the details in the GitHub issue \r\n\r\n&gt; Maybe we should print the usage message only when the program is empty, and stdin and stdout are both terminals? That is, assume . when stdin is not a terminal or when stdout is not a terminal.\r\n\r\nso the rule is :\r\n\r\n- if you want to be perfectionist always use a filter even if `.` is the filter you want\r\n- if you want the result of your command to be the input of another pipe, you must indicate the filter, again if you just want the same result to be taken as input of the next command.\r\n\r\nso the same\r\n\r\n`echo -e &quot;a\\nb&quot; | jq -Rc &gt; test.txt` will produce an error but `echo -e &quot;a\\nb&quot; | jq -Rc . &gt; test.txt` will write the result of the command into the file\r\n",
                "title": "When it is allowed to omit the dot filter in jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1477686497,
                "last_edit_date": 1477686497,
                "creation_date": 1477647901,
                "answer_id": 40302374,
                "question_id": 40301450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Before directly answering the question, I&#39;d like to clarify that:\r\n\r\n1. It is always acceptable to specify a filter explicitly. \r\n2. Some versions of jq expect that a filter will be specified explicitly.\r\n3. Different versions of jq behave differently in the absence of an explicit filter.\r\n\r\nThe main idea guiding jq&#39;s evolution with regard to interpreting the absence of a filter intelligently has been that if there&#39;s something to read on STDIN, and if a filter has not been specified explicitly, and if it looks like you meant `.`, then assume you did mean `.`.\r\n\r\nThe answer to the question, then, is that the perplexing behavior noted in the question is a bug in a particular version of jq.\r\n\r\n(Or if you like, the perplexing behavior reflects the difficulties that arise when developers seek to endow software with the ability to read your mind.)\r\n\r\nBy the way, the bug has been fixed:\r\n\r\n    $ jq --version\r\n    jq-1.5rc2-150-g1740fd0\r\n\r\n    $ echo -e &quot;a\\nb&quot; | jq -Rc | jq -sc \r\n    [&quot;a&quot;,&quot;b&quot;]\r\n",
                "title": "When it is allowed to omit the dot filter in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1477686497,
        "creation_date": 1477644773,
        "last_edit_date": 1477647993,
        "question_id": 40301450,
        "body_markdown": "I do not understand, when it is allowed to omit the dot expression.\r\n\r\nIt is possible to convert every line of raw input into a JSON string:\r\n\r\n    $ echo -e &quot;a\\nb&quot; | jq -Rc . \r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n\r\nIn that example it makes no difference, when the dot expression is missing:\r\n\r\n    $ echo -e &quot;a\\nb&quot; | jq -Rc \r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n\r\nNext I can read the output from the first `jq` and slurp it into an array:\r\n\r\n    $ echo -e &quot;a\\nb&quot; | jq -Rc . | jq -sc .\r\n    [&quot;a&quot;,&quot;b&quot;]\r\n\r\nHere it makes also no difference, when I omit the dot expression:\r\n\r\n    $ echo -e &quot;a\\nb&quot; | jq -Rc . | jq -sc  \r\n    [&quot;a&quot;,&quot;b&quot;]\r\n\r\nBut when I omit both dot expressions, I get an usage error and an empty array as result:\r\n\r\n    $ echo -e &quot;a\\nb&quot; | jq -Rc | jq -sc \r\n    jq - commandline JSON processor [version 1.5]\r\n    Usage: jq [options] &lt;jq filter&gt; [file...]\r\n    ...\r\n    []\r\n\r\nWhy?\r\n",
        "link": "https://stackoverflow.com/questions/40301450/when-it-is-allowed-to-omit-the-dot-filter-in-jq",
        "title": "When it is allowed to omit the dot filter in jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "jq",
            "control-characters"
        ],
        "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": 1477757836,
                "post_id": 40321035,
                "comment_id": 67897860,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1477759019,
                "post_id": 40321035,
                "comment_id": 67898187,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4685100,
                    "reputation": 389,
                    "user_id": 3792699,
                    "user_type": "registered",
                    "accept_rate": 18,
                    "profile_image": "https://graph.facebook.com/100000520280130/picture?type=large",
                    "display_name": "user3792699",
                    "link": "https://stackoverflow.com/users/3792699/user3792699"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1477761372,
                "post_id": 40321035,
                "comment_id": 67898905,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1477766964,
                "post_id": 40321035,
                "comment_id": 67900616,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1478032461,
                "last_edit_date": 1478032461,
                "creation_date": 1477763035,
                "answer_id": 40321859,
                "question_id": 40321035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your input, the following incantation:\r\n\r\n    $ jq &#39;walk(if type == &quot;string&quot; then gsub(&quot;\\\\p{Cc}&quot;; &quot;&lt;&gt;&quot;) else . end)&#39; \r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;HOSTNAME&quot;: &quot;server1.example&quot;,\r\n      &quot;content&quot;: {\r\n        &quot;message&quot;: &quot;ERROR LALALLA&lt;&gt;ERROR INFO NANANAN&lt;&gt;SOME MORE ERROR INFO&lt;&gt;BABABABABABBA&lt;&gt; BABABABA&lt;&gt; ABABBABAA&lt;&gt;&lt;&gt; BABABABAB&lt;&gt;&lt;&gt;&quot;\r\n      },\r\n      &quot;level&quot;: &quot;WARN&quot;,\r\n      &quot;level_value&quot;: 30000,\r\n      &quot;logger_name&quot;: &quot;server1.example.adapter&quot;\r\n    }\r\n\r\nOf course, the above invocation is just illustrative:\r\n\r\n*  you might not need to use `walk/1` at all.  (`walk/1` walks the input JSON.) \r\n* you might want to use a different character class, or specify a pipeline of `gsub/2` invocations.\r\n* if you simply want to excise the control characters, specify &quot;&quot; as the second argument of `gsub/2`.\r\n\r\nIf you do want to use `walk/1` but your jq does not have it, then simply add its definition (easily available on the web, such as [here](https://github.com/stedolan/jq/blob/master/src/builtin.jq)) before its invocation.\r\n",
                "title": "Remove escape sequence characters like newline, tab and carriage return from JSON file"
            },
            {
                "up_vote_count": 31,
                "is_accepted": true,
                "score": 31,
                "last_activity_date": 1478032279,
                "last_edit_date": 1495540909,
                "creation_date": 1477766304,
                "answer_id": 40322380,
                "question_id": 40321035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A **pure `jq` solution**:\r\n\r\n    $ jq -r &#39;.content.message | gsub(&quot;[\\\\n\\\\t]&quot;; &quot;&quot;)&#39; file.json\r\n    ERROR LALALLAERROR INFO NANANANSOME MORE ERROR INFOBABABABABABBA BABABABA ABABBABAA BABABABAB\r\n\r\nIf you want to keep the enlosing `&quot;` characters, omit `-r`.\r\n\r\n&lt;sup&gt;Note: [peak&#39;s helpful answer](https://stackoverflow.com/a/40321859/45375) contains a *generalized* regular expression that matches _all_ control characters in the ASCII and Latin-1 Unicode range by way of a [Unicode category specifier](http://www.regular-expressions.info/unicode.html), `\\p{Cc}`. `jq` uses the [Oniguruma](https://en.wikipedia.org/wiki/Oniguruma) regex engine.&lt;/sup&gt;\r\n\r\n----------\r\n\r\nOther solutions, **using an additional utility**, such as `sed` and `tr`.\r\n\r\nUsing `sed` to unconditionally remove escape sequences `\\n` and `t`:\r\n\r\n    $ jq &#39;.content.message&#39; file.json | sed &#39;s/\\\\[tn]//g&#39;\r\n    &quot;ERROR LALALLAERROR INFO NANANANSOME MORE ERROR INFOBABABABABABBA BABABABA ABABBABAA BABABABAB&quot;\r\n\r\nNote that the enclosing `&quot;` are still there, however.\r\nTo remove them, add another substitution to the `sed` command:\r\n\r\n    $ jq &#39;.content.message&#39; file.json | sed &#39;s/\\\\[tn]//g; s/&quot;\\(.*\\)&quot;/\\1/&#39;\r\n    ERROR LALALLAERROR INFO NANANANSOME MORE ERROR INFOBABABABABABBA BABABABA ABABBABAA BABABABAB\r\n\r\nA simpler option that also removes the enclosing `&quot;` (note: output has no trailing `\\n`):\r\n\r\n    $ jq -r &#39;.content.message&#39; file.json | tr -d &#39;\\n\\t&#39;\r\n    ERROR LALALLAERROR INFO NANANANSOME MORE ERROR INFOBABABABABABBA BABABABA ABABBABAA BABABABAB\r\n\r\nNote how `-r` is used to make `jq` _interpolate_ the string (expanding the `\\n` and `\\t` sequences), which are then removed - as literals - by `tr`.\r\n",
                "title": "Remove escape sequence characters like newline, tab and carriage return from JSON file"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1672842596,
                "creation_date": 1672842596,
                "answer_id": 75006912,
                "question_id": 40321035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With **jq** v1.6 the following is possible\r\n\r\n    jq -rc &quot;.content.message&quot; file.json",
                "title": "Remove escape sequence characters like newline, tab and carriage return from JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 19,
        "last_activity_date": 1672842596,
        "creation_date": 1477757452,
        "last_edit_date": 1477766718,
        "question_id": 40321035,
        "body_markdown": "I have a JSON with 80+ fields. While extracting the message field in the below mentioned JSON file using jq, I&#39;m getting newline characters and tab spaces. I want to remove the escape sequence characters and I have tried it using sed, but it did not work.\r\n\r\nSample JSON file:\r\n\r\n    {\r\n    &quot;HOSTNAME&quot;:&quot;server1.example&quot;,\r\n    &quot;level&quot;:&quot;WARN&quot;,\r\n    &quot;level_value&quot;:30000,\r\n    &quot;logger_name&quot;:&quot;server1.example.adapter&quot;,\r\n    &quot;content&quot;:{&quot;message&quot;:&quot;ERROR LALALLA\\nERROR INFO NANANAN\\tSOME MORE ERROR INFO\\nBABABABABABBA\\n BABABABA\\t ABABBABAA\\n\\n BABABABAB\\n\\n&quot;}\r\n    }\r\n\r\nCan anyone help me on this?\r\n",
        "link": "https://stackoverflow.com/questions/40321035/remove-escape-sequence-characters-like-newline-tab-and-carriage-return-from-jso",
        "title": "Remove escape sequence characters like newline, tab and carriage return from JSON file"
    },
    {
        "tags": [
            "json",
            "rest",
            "unix",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1478095843,
                "last_edit_date": 1478095843,
                "creation_date": 1477839246,
                "answer_id": 40330344,
                "question_id": 40327037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You don&#39;t give any details about the expected form of the output, but the following jq filter produces the information you seem to want (but some of your requirements are not too clear to me):\r\n\r\n    (.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress}),\r\n    (.issues|length)\r\n\r\n\r\nOutput:\r\n\r\n     {  \r\n      &quot;key&quot;: &quot;SEA-739&quot;,\r\n      &quot;status&quot;: &quot;Open&quot;,\r\n      &quot;assignee&quot;: null\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;SEA-738&quot;,\r\n      &quot;status&quot;: &quot;Resolved&quot;,\r\n      &quot;assignee&quot;: &quot;user2@mycompany.com&quot;\r\n    }\r\n    2\r\n\r\n### Postscript\r\nIf you want a one-liner that will produce the values as a stream, without quotation marks, consider:\r\n\r\n    $ jq -r &#39;.issues | ((.[] | (.key, .fields.status.name, .fields.assignee.emailAddress)),length)&#39;\r\n\r\nOutput:\r\n\r\n    SEA-739\r\n    Open\r\n    null\r\n    SEA-738\r\n    Resolved\r\n    user2@mycompany.com\r\n    2\r\n",
                "title": "Extract object/array value from rest API output using unix and jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1477985967,
                "creation_date": 1477985967,
                "answer_id": 40355895,
                "question_id": 40327037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; I would like to get &quot;key&quot; (SEA-739), &quot;status&quot; (Open) and &quot;assignee&quot;\r\n&gt; (null or emailAddress).\r\n&gt;                                  \r\n&gt;  ....\r\n&gt; count of no. of issues retrieved via &quot;expand&quot;: operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n\r\nThis:\r\n\r\n- &lt;pre&gt;\r\n jq &#39;.issues[] | { key, status:.fields.status.name, assignee: .fields.assignee.emailAddress, &quot;total issues&quot;:{expand,count:**(** .expand | split(&quot;,&quot;) | length **)** } }&#39; \r\n \r\n&lt;/pre&gt;\r\n\r\nWill result;\r\n\r\n- &lt;pre&gt;\r\n    {\r\n      &quot;key&quot;: &quot;SEA-739&quot;,\r\n      &quot;status&quot;: **&quot;Open&quot;,**\r\n      &quot;assignee&quot;: null,\r\n      &quot;total issues&quot;: {\r\n        &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n        &quot;count&quot;: 5\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;SEA-738&quot;,\r\n      &quot;status&quot;: **&quot;Resolved&quot;,**\r\n      &quot;assignee&quot;: &quot;user2@mycompany.com&quot;,\r\n      &quot;total issues&quot;: {\r\n        &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n        &quot;count&quot;: 5\r\n      }\r\n    }\r\n\r\n&lt;/pre&gt;\r\n\r\nIf that&#39;s what you&#39;re after.  It&#39;s not entirely clear as you have some non-unique keys being used in different places, and you&#39;re explicit requirements to count the expand properties don&#39;t really make a lot of sense to me, but your requirements seemed well explained.\r\n",
                "title": "Extract object/array value from rest API output using unix and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1526634092,
        "creation_date": 1477813900,
        "last_edit_date": 1526634092,
        "question_id": 40327037,
        "body_markdown": "When I run below curl query which makes call to REST API, it gives me two record in terms of issues. I would like to get &quot;key&quot; (SEA-739), &quot;status&quot; (Open) and &quot;assignee&quot; (null or emailAddress). Also how can i get count of no. of issues retrieved via &quot;expand&quot;: operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n\r\nI tried curl | jq &#39;.issues[0].id&#39; and it gives me valid id but I couldn&#39;t loop through both issues and get mentioned 3 values for both? How can I count issue using shell and get required output for all issues one by one?\r\n\r\nJSON output from jq:\r\n\r\n\troot@server# curl -u username:password -X GET -H &#39;Content-Type: application/json&#39; --insecure --silent &#39;https://myserver.com/rest/api/2/search?jql=project=SE&amp;status=Closed%20order%20by%20key%20desc&amp;maxResults=2&#39; | jq\r\n\r\n\t{\r\n\t  &quot;expand&quot;: &quot;schema,names&quot;,\r\n\t  &quot;startAt&quot;: 0,\r\n\t  &quot;maxResults&quot;: 2,\r\n\t  &quot;total&quot;: 733,\r\n\t  &quot;issues&quot;: [\r\n\t    {\r\n\t      &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n\t      &quot;id&quot;: &quot;292697&quot;,\r\n\t      &quot;self&quot;: &quot;https://testserver.com/rest/api/2/issue/292697&quot;,\r\n\t      &quot;key&quot;: &quot;SEA-739&quot;,\r\n\t      &quot;fields&quot;: {\r\n\t\t&quot;customfield_10190&quot;: null,\r\n\t\t&quot;customfield_13580&quot;: null,\r\n\t\t&quot;customfield_10192&quot;: null,\r\n\t\t&quot;customfield_10072&quot;: null,\r\n\t\t&quot;customfield_13582&quot;: null,\r\n\t\t&quot;customfield_10194&quot;: null,\r\n\t\t&quot;customfield_13581&quot;: [],\r\n\t\t&quot;customfield_10074&quot;: null,\r\n\t\t&quot;customfield_13980&quot;: [\r\n\t\t  {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/15071&quot;,\r\n\t\t    &quot;value&quot;: &quot;check user base&quot;,\r\n\t\t    &quot;id&quot;: &quot;15071&quot;\r\n\t\t  }\r\n\t\t],\r\n\t\t&quot;customfield_10075&quot;: null,\r\n\t\t&quot;customfield_11680&quot;: null,\r\n\t\t&quot;customfield_13583&quot;: null,\r\n\t\t&quot;customfield_10076&quot;: null,\r\n\t\t&quot;customfield_10230&quot;: null,\r\n\t\t&quot;fixVersions&quot;: [],\r\n\t\t&quot;customfield_10231&quot;: null,\r\n\t\t&quot;customfield_13189&quot;: null,\r\n\t\t&quot;customfield_13981&quot;: null,\r\n\t\t&quot;customfield_10232&quot;: null,\r\n\t\t&quot;resolution&quot;: null,\r\n\t\t&quot;customfield_10233&quot;: null,\r\n\t\t&quot;customfield_10234&quot;: null,\r\n\t\t&quot;customfield_14380&quot;: null,\r\n\t\t&quot;lastViewed&quot;: null,\r\n\t\t&quot;customfield_10580&quot;: null,\r\n\t\t&quot;customfield_12880&quot;: null,\r\n\t\t&quot;customfield_10581&quot;: null,\r\n\t\t&quot;customfield_12882&quot;: null,\r\n\t\t&quot;customfield_10220&quot;: null,\r\n\t\t&quot;customfield_12881&quot;: null,\r\n\t\t&quot;priority&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/priority/4&quot;,\r\n\t\t  &quot;iconUrl&quot;: &quot;https://testserver.com/images/icons/priorities/minor.svg&quot;,\r\n\t\t  &quot;name&quot;: &quot;P4&quot;,\r\n\t\t  &quot;id&quot;: &quot;4&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10221&quot;: null,\r\n\t\t&quot;customfield_10980&quot;: null,\r\n\t\t&quot;customfield_10101&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/10377&quot;,\r\n\t\t  &quot;value&quot;: &quot;NO&quot;,\r\n\t\t  &quot;id&quot;: &quot;10377&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10222&quot;: null,\r\n\t\t&quot;customfield_12883&quot;: &quot;0|i16rjz:&quot;,\r\n\t\t&quot;labels&quot;: [],\r\n\t\t&quot;customfield_13208&quot;: null,\r\n\t\t&quot;aggregatetimeoriginalestimate&quot;: null,\r\n\t\t&quot;timeestimate&quot;: null,\r\n\t\t&quot;versions&quot;: [],\r\n\t\t&quot;issuelinks&quot;: [],\r\n\t\t&quot;assignee&quot;: null,\r\n\t\t&quot;status&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/status/1&quot;,\r\n\t\t  &quot;description&quot;: &quot;The issue is open and ready for the assignee to start work on it.&quot;,\r\n\t\t  &quot;iconUrl&quot;: &quot;https://testserver.com/images/icons/statuses/open.png&quot;,\r\n\t\t  &quot;name&quot;: &quot;Open&quot;,\r\n\t\t  &quot;id&quot;: &quot;1&quot;,\r\n\t\t  &quot;statusCategory&quot;: {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/statuscategory/2&quot;,\r\n\t\t    &quot;id&quot;: 2,\r\n\t\t    &quot;key&quot;: &quot;new&quot;,\r\n\t\t    &quot;colorName&quot;: &quot;blue-gray&quot;,\r\n\t\t    &quot;name&quot;: &quot;To Do&quot;\r\n\t\t  }\r\n\t\t},\r\n\t\t&quot;components&quot;: [],\r\n\t\t&quot;customfield_13281&quot;: null,\r\n\t\t&quot;customfield_13280&quot;: null,\r\n\t\t&quot;customfield_13283&quot;: null,\r\n\t\t&quot;customfield_13282&quot;: null,\r\n\t\t&quot;customfield_13680&quot;: null,\r\n\t\t&quot;customfield_11780&quot;: &quot;9223372036854775807&quot;,\r\n\t\t&quot;customfield_11782&quot;: null,\r\n\t\t&quot;customfield_13201&quot;: null,\r\n\t\t&quot;customfield_11781&quot;: null,\r\n\t\t&quot;customfield_10210&quot;: null,\r\n\t\t&quot;customfield_13203&quot;: null,\r\n\t\t&quot;customfield_13202&quot;: null,\r\n\t\t&quot;customfield_13204&quot;: null,\r\n\t\t&quot;aggregatetimeestimate&quot;: null,\r\n\t\t&quot;customfield_14480&quot;: &quot;com.atlassian.servicedesk.plugins.approvals.internal.customfield.ApprovalsCFValue@7735d8eb&quot;,\r\n\t\t&quot;creator&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/user?username=user1&quot;,\r\n\t\t  &quot;name&quot;: &quot;user1&quot;,\r\n\t\t  &quot;key&quot;: &quot;user1&quot;,\r\n\t\t  &quot;emailAddress&quot;: &quot;user1@mycompany.com&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/useravatar?avatarId=10312&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/useravatar?size=small&amp;avatarId=10312&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/useravatar?size=xsmall&amp;avatarId=10312&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/useravatar?size=medium&amp;avatarId=10312&quot;\r\n\t\t  },\r\n\t\t  &quot;displayName&quot;: &quot;User1&quot;,\r\n\t\t  &quot;active&quot;: true,\r\n\t\t  &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10280&quot;: null,\r\n\t\t&quot;subtasks&quot;: [],\r\n\t\t&quot;customfield_10160&quot;: &quot;org.hakanai.jira.plugins.StatusColor@50&quot;,\r\n\t\t&quot;customfield_12580&quot;: null,\r\n\t\t&quot;reporter&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/user?username=user1&quot;,\r\n\t\t  &quot;name&quot;: &quot;user1&quot;,\r\n\t\t  &quot;key&quot;: &quot;user1&quot;,\r\n\t\t  &quot;emailAddress&quot;: &quot;user1@mycompany.com&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/useravatar?avatarId=10312&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/useravatar?size=small&amp;avatarId=10312&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/useravatar?size=xsmall&amp;avatarId=10312&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/useravatar?size=medium&amp;avatarId=10312&quot;\r\n\t\t  },\r\n\t\t  &quot;displayName&quot;: &quot;User1&quot;,\r\n\t\t  &quot;active&quot;: true,\r\n\t\t  &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n\t\t},\r\n\t\t&quot;customfield_12980&quot;: null,\r\n\t\t&quot;aggregateprogress&quot;: {\r\n\t\t  &quot;progress&quot;: 0,\r\n\t\t  &quot;total&quot;: 0\r\n\t\t},\r\n\t\t&quot;customfield_10200&quot;: null,\r\n\t\t&quot;progress&quot;: {\r\n\t\t  &quot;progress&quot;: 0,\r\n\t\t  &quot;total&quot;: 0\r\n\t\t},\r\n\t\t&quot;customfield_14080&quot;: null,\r\n\t\t&quot;issuetype&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/issuetype/25&quot;,\r\n\t\t  &quot;id&quot;: &quot;25&quot;,\r\n\t\t  &quot;description&quot;: &quot;test account checking&quot;,\r\n\t\t  &quot;iconUrl&quot;: &quot;https://testserver.com/download/resources/com.thed.zephyr.je/images/icons/ico_zephyr_issuetype.png&quot;,\r\n\t\t  &quot;name&quot;: &quot;Test&quot;,\r\n\t\t  &quot;subtask&quot;: false\r\n\t\t},\r\n\t\t&quot;customfield_11080&quot;: null,\r\n\t\t&quot;customfield_14191&quot;: null,\r\n\t\t&quot;customfield_11081&quot;: null,\r\n\t\t&quot;customfield_11082&quot;: null,\r\n\t\t&quot;customfield_11083&quot;: null,\r\n\t\t&quot;customfield_10270&quot;: null,\r\n\t\t&quot;customfield_11084&quot;: null,\r\n\t\t&quot;customfield_13780&quot;: null,\r\n\t\t&quot;timespent&quot;: null,\r\n\t\t&quot;customfield_10150&quot;: 99999,\r\n\t\t&quot;customfield_11480&quot;: null,\r\n\t\t&quot;customfield_13782&quot;: null,\r\n\t\t&quot;customfield_10152&quot;: null,\r\n\t\t&quot;customfield_13781&quot;: null,\r\n\t\t&quot;project&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/project/10162&quot;,\r\n\t\t  &quot;id&quot;: &quot;10162&quot;,\r\n\t\t  &quot;key&quot;: &quot;SEA&quot;,\r\n\t\t  &quot;name&quot;: &quot;Test Automation&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/projectavatar?pid=10162&amp;avatarId=10032&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/projectavatar?size=small&amp;pid=10162&amp;avatarId=10032&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/projectavatar?size=xsmall&amp;pid=10162&amp;avatarId=10032&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/projectavatar?size=medium&amp;pid=10162&amp;avatarId=10032&quot;\r\n\t\t  },\r\n\t\t  &quot;projectCategory&quot;: {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/projectCategory/10020&quot;,\r\n\t\t    &quot;id&quot;: &quot;10020&quot;,\r\n\t\t    &quot;description&quot;: &quot;All IT related tasks and projects&quot;,\r\n\t\t    &quot;name&quot;: &quot;Corporate IT&quot;\r\n\t\t  }\r\n\t\t},\r\n\t\t&quot;customfield_11880&quot;: null,\r\n\t\t&quot;aggregatetimespent&quot;: null,\r\n\t\t&quot;resolutiondate&quot;: null,\r\n\t\t&quot;workratio&quot;: -1,\r\n\t\t&quot;customfield_14190&quot;: null,\r\n\t\t&quot;customfield_14182&quot;: null,\r\n\t\t&quot;customfield_14183&quot;: null,\r\n\t\t&quot;watches&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/issue/SEA-739/watchers&quot;,\r\n\t\t  &quot;watchCount&quot;: 1,\r\n\t\t  &quot;isWatching&quot;: false\r\n\t\t},\r\n\t\t&quot;customfield_14181&quot;: null,\r\n\t\t&quot;customfield_14186&quot;: null,\r\n\t\t&quot;customfield_10380&quot;: null,\r\n\t\t&quot;customfield_12680&quot;: null,\r\n\t\t&quot;created&quot;: &quot;2016-10-29T16:17:57.000-0400&quot;,\r\n\t\t&quot;customfield_10260&quot;: null,\r\n\t\t&quot;customfield_14185&quot;: null,\r\n\t\t&quot;customfield_10140&quot;: null,\r\n\t\t&quot;customfield_10261&quot;: null,\r\n\t\t&quot;customfield_10020&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/10380&quot;,\r\n\t\t  &quot;value&quot;: &quot;S3&quot;,\r\n\t\t  &quot;id&quot;: &quot;10380&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10262&quot;: null,\r\n\t\t&quot;customfield_10780&quot;: null,\r\n\t\t&quot;updated&quot;: &quot;2016-10-29T16:17:57.000-0400&quot;,\r\n\t\t&quot;customfield_13081&quot;: null,\r\n\t\t&quot;customfield_13080&quot;: null,\r\n\t\t&quot;customfield_13083&quot;: &quot;To be filled in by Engineering&quot;,\r\n\t\t&quot;customfield_11180&quot;: null,\r\n\t\t&quot;customfield_13082&quot;: null,\r\n\t\t&quot;customfield_11181&quot;: null,\r\n\t\t&quot;customfield_13085&quot;: null,\r\n\t\t&quot;customfield_11182&quot;: null,\r\n\t\t&quot;customfield_13084&quot;: null,\r\n\t\t&quot;customfield_11580&quot;: null,\r\n\t\t&quot;customfield_11183&quot;: null,\r\n\t\t&quot;customfield_13087&quot;: null,\r\n\t\t&quot;customfield_13086&quot;: null,\r\n\t\t&quot;timeoriginalestimate&quot;: null,\r\n\t\t&quot;customfield_13881&quot;: null,\r\n\t\t&quot;customfield_10130&quot;: null,\r\n\t\t&quot;description&quot;: &quot;Please ignore test bug..&quot;,\r\n\t\t&quot;customfield_13880&quot;: null,\r\n\t\t&quot;customfield_10011&quot;: null,\r\n\t\t&quot;customfield_10253&quot;: null,\r\n\t\t&quot;customfield_10012&quot;: null,\r\n\t\t&quot;customfield_10007&quot;: null,\r\n\t\t&quot;customfield_10008&quot;: null,\r\n\t\t&quot;customfield_10009&quot;: null,\r\n\t\t&quot;summary&quot;: &quot;Please ignore test bug..&quot;,\r\n\t\t&quot;customfield_13191&quot;: null,\r\n\t\t&quot;customfield_13190&quot;: null,\r\n\t\t&quot;customfield_14282&quot;: null,\r\n\t\t&quot;customfield_13193&quot;: null,\r\n\t\t&quot;customfield_13192&quot;: null,\r\n\t\t&quot;customfield_14280&quot;: null,\r\n\t\t&quot;customfield_13195&quot;: null,\r\n\t\t&quot;customfield_14285&quot;: [\r\n\t\t  {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/15507&quot;,\r\n\t\t    &quot;value&quot;: &quot; YES&quot;,\r\n\t\t    &quot;id&quot;: &quot;15507&quot;\r\n\t\t  }\r\n\t\t],\r\n\t\t&quot;customfield_13194&quot;: null,\r\n\t\t&quot;customfield_14283&quot;: null,\r\n\t\t&quot;customfield_10480&quot;: null,\r\n\t\t&quot;customfield_13196&quot;: null,\r\n\t\t&quot;customfield_14284&quot;: null,\r\n\t\t&quot;customfield_10085&quot;: null,\r\n\t\t&quot;customfield_12780&quot;: null,\r\n\t\t&quot;customfield_10120&quot;: null,\r\n\t\t&quot;customfield_10241&quot;: null,\r\n\t\t&quot;customfield_10088&quot;: null,\r\n\t\t&quot;customfield_10121&quot;: null,\r\n\t\t&quot;customfield_10000&quot;: null,\r\n\t\t&quot;customfield_10242&quot;: null,\r\n\t\t&quot;customfield_10880&quot;: null,\r\n\t\t&quot;customfield_10089&quot;: null,\r\n\t\t&quot;customfield_10122&quot;: null,\r\n\t\t&quot;customfield_10243&quot;: null,\r\n\t\t&quot;customfield_10002&quot;: null,\r\n\t\t&quot;customfield_10244&quot;: null,\r\n\t\t&quot;customfield_10486&quot;: null,\r\n\t\t&quot;customfield_10124&quot;: null,\r\n\t\t&quot;customfield_10003&quot;: null,\r\n\t\t&quot;customfield_10245&quot;: null,\r\n\t\t&quot;customfield_10487&quot;: null,\r\n\t\t&quot;customfield_10488&quot;: null,\r\n\t\t&quot;customfield_10236&quot;: null,\r\n\t\t&quot;customfield_10237&quot;: null,\r\n\t\t&quot;environment&quot;: null,\r\n\t\t&quot;duedate&quot;: null\r\n\t      }\r\n\t    },\r\n\r\n\t    {\r\n\t      &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n\t      &quot;id&quot;: &quot;273625&quot;,\r\n\t      &quot;self&quot;: &quot;https://testserver.com/rest/api/2/issue/273625&quot;,\r\n\t      &quot;key&quot;: &quot;SEA-738&quot;,\r\n\t      &quot;fields&quot;: {\r\n\t\t&quot;customfield_10190&quot;: null,\r\n\t\t&quot;customfield_13580&quot;: null,\r\n\t\t&quot;customfield_10192&quot;: null,\r\n\t\t&quot;customfield_10072&quot;: null,\r\n\t\t&quot;customfield_10193&quot;: null,\r\n\t\t&quot;customfield_13582&quot;: null,\r\n\t\t&quot;customfield_10194&quot;: null,\r\n\t\t&quot;customfield_13581&quot;: [],\r\n\t\t&quot;customfield_10074&quot;: null,\r\n\t\t&quot;customfield_13980&quot;: null,\r\n\t\t&quot;customfield_10075&quot;: null,\r\n\t\t&quot;customfield_11680&quot;: null,\r\n\t\t&quot;customfield_13583&quot;: null,\r\n\t\t&quot;customfield_10076&quot;: null,\r\n\t\t&quot;customfield_10230&quot;: null,\r\n\t\t&quot;fixVersions&quot;: [],\r\n\t\t&quot;customfield_10231&quot;: null,\r\n\t\t&quot;customfield_13189&quot;: null,\r\n\t\t&quot;customfield_13981&quot;: null,\r\n\t\t&quot;customfield_10232&quot;: null,\r\n\t\t&quot;customfield_11685&quot;: null,\r\n\t\t&quot;resolution&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/resolution/1&quot;,\r\n\t\t  &quot;id&quot;: &quot;1&quot;,\r\n\t\t  &quot;description&quot;: &quot;A fix for this issue is checked into the tree and tested.&quot;,\r\n\t\t  &quot;name&quot;: &quot;Fixed&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10233&quot;: null,\r\n\t\t&quot;customfield_10234&quot;: null,\r\n\t\t&quot;customfield_14380&quot;: null,\r\n\t\t&quot;lastViewed&quot;: null,\r\n\t\t&quot;customfield_10580&quot;: null,\r\n\t\t&quot;customfield_12880&quot;: null,\r\n\t\t&quot;customfield_10581&quot;: null,\r\n\t\t&quot;customfield_12882&quot;: null,\r\n\t\t&quot;customfield_10220&quot;: null,\r\n\t\t&quot;customfield_12881&quot;: null,\r\n\t\t&quot;priority&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/priority/3&quot;,\r\n\t\t  &quot;iconUrl&quot;: &quot;https://testserver.com/images/icons/priorities/major.svg&quot;,\r\n\t\t  &quot;name&quot;: &quot;P3&quot;,\r\n\t\t  &quot;id&quot;: &quot;3&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10221&quot;: null,\r\n\t\t&quot;customfield_10980&quot;: null,\r\n\t\t&quot;customfield_10101&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/10377&quot;,\r\n\t\t  &quot;value&quot;: &quot;NO&quot;,\r\n\t\t  &quot;id&quot;: &quot;10377&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10222&quot;: null,\r\n\t\t&quot;customfield_12883&quot;: &quot;0|i13y67:&quot;,\r\n\t\t&quot;labels&quot;: [],\r\n\t\t&quot;customfield_13208&quot;: null,\r\n\t\t&quot;aggregatetimeoriginalestimate&quot;: null,\r\n\t\t&quot;timeestimate&quot;: null,\r\n\t\t&quot;versions&quot;: [],\r\n\t\t&quot;issuelinks&quot;: [],\r\n\t\t&quot;assignee&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/user?username=user2&quot;,\r\n\t\t  &quot;name&quot;: &quot;user2&quot;,\r\n\t\t  &quot;key&quot;: &quot;user2&quot;,\r\n\t\t  &quot;emailAddress&quot;: &quot;user2@mycompany.com&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/useravatar?avatarId=10312&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/useravatar?size=small&amp;avatarId=10312&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/useravatar?size=xsmall&amp;avatarId=10312&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/useravatar?size=medium&amp;avatarId=10312&quot;\r\n\t\t  },\r\n\t\t  &quot;displayName&quot;: &quot;Russell Pratt&quot;,\r\n\t\t  &quot;active&quot;: true,\r\n\t\t  &quot;timeZone&quot;: &quot;EST5EDT&quot;\r\n\t\t},\r\n\t\t&quot;status&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/status/5&quot;,\r\n\t\t  &quot;description&quot;: &quot;A resolution has been taken and is awaiting verification by reporter. From here issues are either reopened or are closed.&quot;,\r\n\t\t  &quot;iconUrl&quot;: &quot;https://testserver.com/images/icons/statuses/resolved.png&quot;,\r\n\t\t  &quot;name&quot;: &quot;Resolved&quot;,\r\n\t\t  &quot;id&quot;: &quot;5&quot;,\r\n\t\t  &quot;statusCategory&quot;: {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/statuscategory/3&quot;,\r\n\t\t    &quot;id&quot;: 3,\r\n\t\t    &quot;key&quot;: &quot;done&quot;,\r\n\t\t    &quot;colorName&quot;: &quot;green&quot;,\r\n\t\t    &quot;name&quot;: &quot;Done&quot;\r\n\t\t  }\r\n\t\t},\r\n\t\t&quot;components&quot;: [],\r\n\t\t&quot;customfield_13281&quot;: null,\r\n\t\t&quot;customfield_13280&quot;: null,\r\n\t\t&quot;customfield_13283&quot;: null,\r\n\t\t&quot;customfield_13282&quot;: null,\r\n\t\t&quot;customfield_13680&quot;: null,\r\n\t\t&quot;customfield_11780&quot;: &quot;9223372036854775807&quot;,\r\n\t\t&quot;customfield_11782&quot;: null,\r\n\t\t&quot;customfield_13201&quot;: null,\r\n\t\t&quot;customfield_11781&quot;: null,\r\n\t\t&quot;customfield_10210&quot;: null,\r\n\t\t&quot;customfield_13203&quot;: null,\r\n\t\t&quot;customfield_13202&quot;: null,\r\n\t\t&quot;customfield_13204&quot;: null,\r\n\t\t&quot;aggregatetimeestimate&quot;: null,\r\n\t\t&quot;customfield_14480&quot;: &quot;com.atlassian.servicedesk.plugins.approvals.internal.customfield.ApprovalsCFValue@c4b41a5&quot;,\r\n\t\t&quot;creator&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/user?username=userads&quot;,\r\n\t\t  &quot;name&quot;: &quot;userads&quot;,\r\n\t\t  &quot;key&quot;: &quot;userads&quot;,\r\n\t\t  &quot;emailAddress&quot;: &quot;userads@mycompany.com&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/useravatar?ownerId=userads&amp;avatarId=15412&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/useravatar?size=small&amp;ownerId=userads&amp;avatarId=15412&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/useravatar?size=xsmall&amp;ownerId=userads&amp;avatarId=15412&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/useravatar?size=medium&amp;ownerId=userads&amp;avatarId=15412&quot;\r\n\t\t  },\r\n\t\t  &quot;displayName&quot;: &quot;User Ads&quot;,\r\n\t\t  &quot;active&quot;: true,\r\n\t\t  &quot;timeZone&quot;: &quot;EST5EDT&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10280&quot;: null,\r\n\t\t&quot;subtasks&quot;: [],\r\n\t\t&quot;customfield_10160&quot;: &quot;org.hakanai.jira.plugins.StatusColor@54&quot;,\r\n\t\t&quot;customfield_12580&quot;: null,\r\n\t\t&quot;reporter&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/user?username=userads&quot;,\r\n\t\t  &quot;name&quot;: &quot;userads&quot;,\r\n\t\t  &quot;key&quot;: &quot;userads&quot;,\r\n\t\t  &quot;emailAddress&quot;: &quot;userads@mycompany.com&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/useravatar?ownerId=userads&amp;avatarId=15412&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/useravatar?size=small&amp;ownerId=userads&amp;avatarId=15412&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/useravatar?size=xsmall&amp;ownerId=userads&amp;avatarId=15412&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/useravatar?size=medium&amp;ownerId=userads&amp;avatarId=15412&quot;\r\n\t\t  },\r\n\t\t  &quot;displayName&quot;: &quot;User Ads&quot;,\r\n\t\t  &quot;active&quot;: true,\r\n\t\t  &quot;timeZone&quot;: &quot;EST5EDT&quot;\r\n\t\t},\r\n\t\t&quot;customfield_12980&quot;: null,\r\n\t\t&quot;aggregateprogress&quot;: {\r\n\t\t  &quot;progress&quot;: 0,\r\n\t\t  &quot;total&quot;: 0\r\n\t\t},\r\n\t\t&quot;customfield_10200&quot;: null,\r\n\t\t&quot;progress&quot;: {\r\n\t\t  &quot;progress&quot;: 0,\r\n\t\t  &quot;total&quot;: 0\r\n\t\t},\r\n\t\t&quot;customfield_14080&quot;: null,\r\n\t\t&quot;issuetype&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/issuetype/3&quot;,\r\n\t\t  &quot;id&quot;: &quot;3&quot;,\r\n\t\t  &quot;description&quot;: &quot;A task that needs to be done.&quot;,\r\n\t\t  &quot;iconUrl&quot;: &quot;https://testserver.com/secure/viewavatar?size=xsmall&amp;avatarId=14808&amp;avatarType=issuetype&quot;,\r\n\t\t  &quot;name&quot;: &quot;Task&quot;,\r\n\t\t  &quot;subtask&quot;: false,\r\n\t\t  &quot;avatarId&quot;: 14808\r\n\t\t},\r\n\t\t&quot;customfield_11080&quot;: null,\r\n\t\t&quot;customfield_14191&quot;: null,\r\n\t\t&quot;customfield_11081&quot;: null,\r\n\t\t&quot;customfield_11082&quot;: null,\r\n\t\t&quot;customfield_11083&quot;: null,\r\n\t\t&quot;customfield_10270&quot;: null,\r\n\t\t&quot;customfield_11084&quot;: null,\r\n\t\t&quot;customfield_13780&quot;: null,\r\n\t\t&quot;timespent&quot;: null,\r\n\t\t&quot;customfield_10150&quot;: null,\r\n\t\t&quot;customfield_11480&quot;: null,\r\n\t\t&quot;customfield_13782&quot;: null,\r\n\t\t&quot;customfield_10152&quot;: null,\r\n\t\t&quot;customfield_13781&quot;: null,\r\n\t\t&quot;project&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/project/10162&quot;,\r\n\t\t  &quot;id&quot;: &quot;10162&quot;,\r\n\t\t  &quot;key&quot;: &quot;SEA&quot;,\r\n\t\t  &quot;name&quot;: &quot;Test Automation&quot;,\r\n\t\t  &quot;avatarUrls&quot;: {\r\n\t\t    &quot;48x48&quot;: &quot;https://testserver.com/secure/projectavatar?pid=10162&amp;avatarId=10032&quot;,\r\n\t\t    &quot;24x24&quot;: &quot;https://testserver.com/secure/projectavatar?size=small&amp;pid=10162&amp;avatarId=10032&quot;,\r\n\t\t    &quot;16x16&quot;: &quot;https://testserver.com/secure/projectavatar?size=xsmall&amp;pid=10162&amp;avatarId=10032&quot;,\r\n\t\t    &quot;32x32&quot;: &quot;https://testserver.com/secure/projectavatar?size=medium&amp;pid=10162&amp;avatarId=10032&quot;\r\n\t\t  },\r\n\t\t  &quot;projectCategory&quot;: {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/projectCategory/10020&quot;,\r\n\t\t    &quot;id&quot;: &quot;10020&quot;,\r\n\t\t    &quot;description&quot;: &quot;All IT related tasks and projects&quot;,\r\n\t\t    &quot;name&quot;: &quot;Corporate IT&quot;\r\n\t\t  }\r\n\t\t},\r\n\t\t&quot;customfield_11880&quot;: null,\r\n\t\t&quot;aggregatetimespent&quot;: null,\r\n\t\t&quot;resolutiondate&quot;: &quot;2016-04-21T09:59:34.000-0400&quot;,\r\n\t\t&quot;workratio&quot;: -1,\r\n\t\t&quot;customfield_14190&quot;: null,\r\n\t\t&quot;customfield_14182&quot;: null,\r\n\t\t&quot;customfield_14183&quot;: null,\r\n\t\t&quot;watches&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/issue/SEA-738/watchers&quot;,\r\n\t\t  &quot;watchCount&quot;: 2,\r\n\t\t  &quot;isWatching&quot;: false\r\n\t\t},\r\n\t\t&quot;customfield_14181&quot;: null,\r\n\t\t&quot;customfield_14186&quot;: null,\r\n\t\t&quot;customfield_10380&quot;: null,\r\n\t\t&quot;customfield_12680&quot;: null,\r\n\t\t&quot;created&quot;: &quot;2016-04-07T13:11:56.000-0400&quot;,\r\n\t\t&quot;customfield_10260&quot;: null,\r\n\t\t&quot;customfield_14185&quot;: null,\r\n\t\t&quot;customfield_10140&quot;: null,\r\n\t\t&quot;customfield_10261&quot;: null,\r\n\t\t&quot;customfield_10020&quot;: {\r\n\t\t  &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/10380&quot;,\r\n\t\t  &quot;value&quot;: &quot;S3&quot;,\r\n\t\t  &quot;id&quot;: &quot;10380&quot;\r\n\t\t},\r\n\t\t&quot;customfield_10262&quot;: null,\r\n\t\t&quot;customfield_10780&quot;: null,\r\n\t\t&quot;updated&quot;: &quot;2016-04-21T10:27:28.000-0400&quot;,\r\n\t\t&quot;customfield_13081&quot;: null,\r\n\t\t&quot;customfield_13080&quot;: null,\r\n\t\t&quot;customfield_13083&quot;: &quot;To be filled in by Engineering&quot;,\r\n\t\t&quot;customfield_11180&quot;: null,\r\n\t\t&quot;customfield_13082&quot;: null,\r\n\t\t&quot;customfield_11181&quot;: null,\r\n\t\t&quot;customfield_13085&quot;: null,\r\n\t\t&quot;customfield_11182&quot;: null,\r\n\t\t&quot;customfield_13084&quot;: null,\r\n\t\t&quot;customfield_11580&quot;: null,\r\n\t\t&quot;customfield_11183&quot;: null,\r\n\t\t&quot;customfield_13087&quot;: null,\r\n\t\t&quot;customfield_13086&quot;: null,\r\n\t\t&quot;timeoriginalestimate&quot;: null,\r\n\t\t&quot;customfield_13881&quot;: null,\r\n\t\t&quot;customfield_10130&quot;: null,\r\n\t\t&quot;description&quot;: &quot;We need to update CTL logins for Cuke and RC.Currently the way the automation is setup, we can only use one user per environment, so please pick one from below for UAT and a different one for Prod.\\r\\n\\r\\n1. uat_centurylinknet:\\r\\n  :username: syntest6@centurylink.net\\r\\n  :password: P@ssw0rd!\\r\\n2. uat_embarqmailcom:\\r\\n  :username: synqe12@embarqmail.com\\r\\n  :password: P@ssw0rd!\\r\\n3. uat_qcom:\\r\\n  :username: syn_test_prism@q.com\\r\\n  :password: P@ssw0rd!\\r\\n4. prod_centurylinknet:\\r\\n  :username: syn_test_res03@centurylink.net\\r\\n  :password: test03\\r\\n5. prod_embarqmailcom:\\r\\n  :username: syn_test_res25@embarqmail.com\\r\\n  :password: test25\\r\\n6. prod_qcom:\\r\\n  :username: syn_test_prism@q.com\\r\\n  :password: test01&quot;,\r\n\t\t&quot;customfield_13880&quot;: null,\r\n\t\t&quot;customfield_11980&quot;: null,\r\n\t\t&quot;customfield_10011&quot;: null,\r\n\t\t&quot;customfield_10253&quot;: null,\r\n\t\t&quot;customfield_10012&quot;: null,\r\n\t\t&quot;customfield_10007&quot;: null,\r\n\t\t&quot;customfield_10008&quot;: null,\r\n\t\t&quot;customfield_10009&quot;: null,\r\n\t\t&quot;summary&quot;: &quot;Update CTL Logins&quot;,\r\n\t\t&quot;customfield_13191&quot;: null,\r\n\t\t&quot;customfield_13190&quot;: null,\r\n\t\t&quot;customfield_14282&quot;: null,\r\n\t\t&quot;customfield_13193&quot;: null,\r\n\t\t&quot;customfield_13192&quot;: null,\r\n\t\t&quot;customfield_14280&quot;: null,\r\n\t\t&quot;customfield_13195&quot;: null,\r\n\t\t&quot;customfield_14285&quot;: null,\r\n\t\t&quot;customfield_13194&quot;: null,\r\n\t\t&quot;customfield_14283&quot;: null,\r\n\t\t&quot;customfield_10084&quot;: null,\r\n\t\t&quot;customfield_10480&quot;: null,\r\n\t\t&quot;customfield_13196&quot;: null,\r\n\t\t&quot;customfield_14284&quot;: null,\r\n\t\t&quot;customfield_10085&quot;: null,\r\n\t\t&quot;customfield_12780&quot;: null,\r\n\t\t&quot;customfield_10120&quot;: null,\r\n\t\t&quot;customfield_10241&quot;: null,\r\n\t\t&quot;customfield_10088&quot;: null,\r\n\t\t&quot;customfield_10121&quot;: null,\r\n\t\t&quot;customfield_10000&quot;: [\r\n\t\t  {\r\n\t\t    &quot;self&quot;: &quot;https://testserver.com/rest/api/2/customFieldOption/10009&quot;,\r\n\t\t    &quot;value&quot;: &quot;CenturyLink&quot;,\r\n\t\t    &quot;id&quot;: &quot;10009&quot;\r\n\t\t  }\r\n\t\t],\r\n\t\t&quot;customfield_10242&quot;: null,\r\n\t\t&quot;customfield_10880&quot;: null,\r\n\t\t&quot;customfield_10089&quot;: null,\r\n\t\t&quot;customfield_10122&quot;: null,\r\n\t\t&quot;customfield_10243&quot;: null,\r\n\t\t&quot;customfield_10002&quot;: null,\r\n\t\t&quot;customfield_10244&quot;: null,\r\n\t\t&quot;customfield_10486&quot;: null,\r\n\t\t&quot;customfield_10124&quot;: null,\r\n\t\t&quot;customfield_10003&quot;: null,\r\n\t\t&quot;customfield_10245&quot;: null,\r\n\t\t&quot;customfield_10487&quot;: null,\r\n\t\t&quot;customfield_10488&quot;: null,\r\n\t\t&quot;customfield_10236&quot;: null,\r\n\t\t&quot;customfield_10237&quot;: null,\r\n\t\t&quot;environment&quot;: null,\r\n\t\t&quot;duedate&quot;: null\r\n\t      }\r\n\t    }\r\n\t  ]\r\n\t}\r\n",
        "link": "https://stackoverflow.com/questions/40327037/extract-object-array-value-from-rest-api-output-using-unix-and-jq",
        "title": "Extract object/array value from rest API output using unix and jq"
    },
    {
        "tags": [
            "json",
            "select",
            "filtering",
            "identifier",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1477985788,
                "last_edit_date": 1477985788,
                "creation_date": 1477979173,
                "answer_id": 40354725,
                "question_id": 40354176,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are basically two ways to proceed:\r\n\r\n1. read the file of ids from STDIN\r\n2. read the JSON from STDIN\r\n\r\nBoth are feasible, but here we illustrate (2) as it leads to a simple but efficient solution.\r\n\r\nSuppose the JSON file is named in.json and the list of ids is in a file named ids.txt like so:\r\n\r\n    00001\r\n    00010\r\n\r\nNotice that this file has no quotation marks.  If it does, then the following can be significantly simplified as shown in the postscript.\r\n\r\nThe trick is to convert ids.txt into a JSON array.  With the above assumption about quotation marks, this can be done by: \r\n\r\n    jq -R . ids.txt | jq -s .\r\n\r\nAssuming a reasonable shell, a simple solution is now at hand:\r\n\r\n    jq --argjson ids &quot;$(jq -R . ids.txt | jq -s .)&quot; &#39;\r\n      map( select( .id as $id | $ids | index($id) ))&#39; in.json\r\n\r\n### Faster\r\nAssuming your jq has `any/2`, then a simpler and more efficient solution can be obtaining by defining:\r\n\r\n    def isin($a): . as $in | any($a[]; $in == .);\r\n\r\nThe required jq filter is then just: \r\n\r\n    map( select( .id | isin($ids) ) )\r\n\r\nIf these two lines of jq are put into a file named select.jq, the required incantation is simply:\r\n\r\n    jq --argjson ids &quot;$(jq -R . ids.txt | jq -s)&quot; -f select.jq in.json\r\n\r\n### Postscript ###\r\nIf the index file consists of a stream of valid JSON texts (e.g., strings with quotation marks) and if your jq supports the `--slurpfile` option, the invocation can be further simplified to:\r\n\r\n    jq --slurpfile ids ids.txt -f select.jq in.json \r\n\r\nOr if you want everything as a one-liner:\r\n\r\n    jq --slurpfile ids ids.txt &#39;map(select(.id as $id|any($ids[];$id==.)))&#39; in.json \r\n",
                "title": "Filter only specific keys from an external file in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1477985788,
        "creation_date": 1477974814,
        "last_edit_date": 1477981556,
        "question_id": 40354176,
        "body_markdown": "I have a JSON file with the following format:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;00001&quot;,\r\n        &quot;attr&quot;: {\r\n          &quot;a&quot;: &quot;foo&quot;,\r\n          &quot;b&quot;: &quot;bar&quot;,\r\n          ...\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;00002&quot;,\r\n        &quot;attr&quot;: {\r\n          ...\r\n        },\r\n        ...\r\n      },\r\n    ...\r\n    ]\r\n\r\nand a text file with a list of ids, one per line. I&#39;d like to use `jq` to filter only the records whose ids are mentioned in the text file. I.e. if the list contains &quot;00001&quot;, only the first one should be printed.\r\n\r\nNote, that I can&#39;t simply `grep` since each record may have an arbitrary number of attributes and sub-attributes. ",
        "link": "https://stackoverflow.com/questions/40354176/filter-only-specific-keys-from-an-external-file-in-jq",
        "title": "Filter only specific keys from an external file in jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "key",
            "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": 1478018559,
                "post_id": 40357558,
                "comment_id": 67982180,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1477997112,
                "creation_date": 1477997112,
                "answer_id": 40358486,
                "question_id": 40357558,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &#39;.&quot;application.version&quot;&#39; \r\n\r\n1.13.0-241\r\n",
                "title": "How to get the information using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1478015324,
        "creation_date": 1477993659,
        "last_edit_date": 1478015324,
        "question_id": 40357558,
        "body_markdown": "I have a url http://vis-vip.xxx.xx.net:8080/xx/info which returns the below result\r\n{&quot;application.name&quot;:&quot;var-integration-xx&quot;,&quot;application.version&quot;:&quot;1.13.0-241&quot;,&quot;os.name&quot;:&quot;Linux&quot;}.\r\n\r\nI need to get the application version from the above result.\r\nI have JQ installed. Is there a way to get the version info usng JQ?\r\n",
        "link": "https://stackoverflow.com/questions/40357558/how-to-get-the-information-using-jq",
        "title": "How to get the information using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1478001773,
                "creation_date": 1478001773,
                "answer_id": 40359688,
                "question_id": 40359573,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Something like this would work:\r\n\r\n    $ jq -r &#39;.menu.props[] | &quot;AddMenuItem(menu, \\&quot;\\(.model)\\&quot;, \\&quot;\\(.name)\\&quot;)&quot;&#39; file.txt\r\n    AddMenuItem(menu, &quot;bar1&quot;, &quot;foo1&quot;)\r\n    AddMenuItem(menu, &quot;bar2&quot;, &quot;foo2&quot;)\r\n    AddMenuItem(menu, &quot;bar3&quot;, &quot;foo3&quot;)\r\n    AddMenuItem(menu, &quot;bar4&quot;, &quot;foo4&quot;)\r\n    AddMenuItem(menu, &quot;bar5&quot;, &quot;foo5&quot;)\r\n\r\n`-r` prints raw output (Not JSON encoded).\r\n\r\nUnwrapping the `props` array with `[]` and printing the string `&quot;AddMenu...&quot;` for each element in said array.\r\n\r\nOne can also use `...props | map(&quot;AddMenu...&quot;)[]` which might be more intuitive.\r\n\r\n`\\(...)` enables string interpolation between `(` and `)`.\r\n",
                "title": "using jq to iterate json data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1478001960,
        "creation_date": 1478001420,
        "last_edit_date": 1478001960,
        "question_id": 40359573,
        "body_markdown": "I have some json input data I would like to extract the variable values into something I can paste into my script\r\n\r\n**input sample:**\r\n\r\n    {\r\n      &quot;menu&quot;: {\r\n        &quot;props&quot;: [{\r\n          &quot;name&quot;: &quot;foo1&quot;,\r\n          &quot;model&quot;: &quot;bar1&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;foo2&quot;,\r\n          &quot;model&quot;: &quot;bar2&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;foo3&quot;,\r\n          &quot;model&quot;: &quot;bar3&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;foo4&quot;,\r\n          &quot;model&quot;: &quot;bar4&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;foo5&quot;,\r\n          &quot;model&quot;: &quot;bar5&quot;\r\n        }]\r\n      }\r\n    }\r\n\r\n**desired output:**\r\n\r\n    AddMenuItem(menu, &quot;bar1&quot;, &quot;foo1&quot;);\r\n    AddMenuItem(menu, &quot;bar2&quot;, &quot;foo2&quot;);\r\n    AddMenuItem(menu, &quot;bar3&quot;, &quot;foo3&quot;);\r\n    ...etc\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40359573/using-jq-to-iterate-json-data",
        "title": "using jq to iterate json data"
    },
    {
        "tags": [
            "json",
            "recursion",
            "nested",
            "jq",
            "npm-shrinkwrap"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1478011379,
                "creation_date": 1478011379,
                "answer_id": 40362405,
                "question_id": 40361457,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In my opinion, the simplest approach to this kind of problem is to use `walk/1`:\r\n\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;resolved&quot;) then del(.resolved) else . end)\r\n\r\nIf your jq does not have `walk/1` (which was only included as a builtin after the release of jq 1.5), then simply add its definition (easily available on the web) before the above line, or perhaps include it in your ~/.jq file.",
                "title": "How to delete all nested keys with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1478013669,
        "creation_date": 1478008319,
        "last_edit_date": 1478013669,
        "question_id": 40361457,
        "body_markdown": "I would like to delete all the resloved from a npm shrinwrap json file. this is causing a problem when running npm install on other machine.\r\n\r\n     &quot;cssstyle&quot;: {\r\n          &quot;version&quot;: &quot;0.2.37&quot;,\r\n          &quot;from&quot;: &quot;cssstyle@&gt;=0.2.29 &lt;0.3.0&quot;,\r\n          &quot;resolved&quot;: &quot;https://registry.npmjs.org/cssstyle/-/cssstyle-0.2.37.tgz&quot;\r\n        },\r\n        &quot;dashdash&quot;: {\r\n          &quot;version&quot;: &quot;1.14.0&quot;,\r\n          &quot;from&quot;: &quot;dashdash@&gt;=1.12.0 &lt;2.0.0&quot;,\r\n          &quot;resolved&quot;: &quot;https://registry.npmjs.org/dashdash/-/dashdash-1.14.0.tgz&quot;,\r\n          &quot;dependencies&quot;: {\r\n            &quot;assert-plus&quot;: {\r\n              &quot;version&quot;: &quot;1.0.0&quot;,\r\n              &quot;from&quot;: &quot;assert-plus@&gt;=1.0.0 &lt;2.0.0&quot;,\r\n              &quot;resolved&quot;: &quot;https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;debug&quot;: {\r\n          &quot;version&quot;: &quot;2.2.0&quot;,\r\n          &quot;from&quot;: &quot;debug@&gt;=2.2.0 &lt;3.0.0&quot;,\r\n          &quot;resolved&quot;: &quot;https://registry.npmjs.org/debug/-/debug-2.2.0.tgz&quot;\r\n        }\r\n\r\nHow can I delete the resolved key from all the file\r\n\r\nI&#39;m using the pattern :\r\n\r\n    jq &#39;del(.resolved)&#39; file.json",
        "link": "https://stackoverflow.com/questions/40361457/how-to-delete-all-nested-keys-with-jq",
        "title": "How to delete all nested keys with JQ"
    },
    {
        "tags": [
            "json",
            "regex",
            "key",
            "jq",
            "camelcasing"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1478048955,
                "last_edit_date": 1478048955,
                "creation_date": 1478030761,
                "answer_id": 40367791,
                "question_id": 40366520,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a jq function that will convert &quot;a_bcd_ef&quot; to &quot;aBcdEf&quot;, which seems to be what you want:\r\n\r\n    def camel:\r\n      gsub( &quot;_(?&lt;a&gt;[a-z])&quot;; .a|ascii_upcase);\r\n\r\nExample usage:\r\n\r\n    &quot;a_bcd_ef&quot; | camel\r\n\r\nIf you want a simple one-liner to process JSON strings from STDIN:\r\n\r\n    $ jq &#39;gsub( &quot;_(?&lt;a&gt;[a-z])&quot;; .a|ascii_upcase)&#39;\r\n\r\nIf you only want the first occurrence of &quot;_[a-z]&quot; converted, then of course you&#39;d use `sub`. And so on.\r\n\r\nTo apply this function to ALL keys in an object, you could write:\r\n\r\n    with_entries( .key |= camel )\r\n\r\nTo change ALL keys in ALL objects within a JSON entity, you could use `walk/1`:\r\n\r\n    walk(if type == &quot;object&quot; then with_entries(.key |= camel) else . end)\r\n\r\nIf your jq does not have `walk/1` then you can simply include its definition (easily found by googling), either before it is invoked, or perhaps in your ~/.jq file.\r\n\r\n",
                "title": "Replacing underscores in JSON using JQ"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1611962028,
                "creation_date": 1611962028,
                "answer_id": 65962964,
                "question_id": 40366520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although not as concise as the gsub solution of @peak, this one is easier on the eye and easier for beginners to understand IMHO.\r\n\r\nYou can put this into a script called &#39;snake_to_camel.jq&#39; and `chmod +x snake_to_camel.jq`\r\n\r\n```javascript\r\n#!/usr/bin/env jq -f\r\ndef head:\r\n  .[0:1];\r\n\r\ndef tail:\r\n  .[1:];\r\n\r\ndef capitalize:\r\n  (head | ascii_upcase) + tail;\r\n\r\ndef snake_to_camel:\r\n  split(&quot;_&quot;) |\r\n  head + (tail | map(capitalize)) |\r\n  join(&quot;&quot;);\r\n\r\ndef map_keys(mapper):\r\n  walk(if type == &quot;object&quot; then with_entries(.key |= mapper) else . end);\r\n\r\nmap_keys(snake_to_camel)\r\n```\r\n\r\nExample usage:\r\n\r\n```bash\r\ncurl https://example.com/input.json | ./snake_to_camel.jq\r\n```\r\n\r\nSome of the jq features I&#39;ve used here:\r\n - [slices](https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15]) for head and tail\r\n - [ascii_upcase](https://stedolan.github.io/jq/manual/#ascii_downcase,ascii_upcase)\r\n - [addition](https://stedolan.github.io/jq/manual/#Addition:+) for array concatenation\r\n - [split](https://stedolan.github.io/jq/manual/#split(str)) and [join](https://stedolan.github.io/jq/manual/#join(str))\r\n - [walk](https://stedolan.github.io/jq/manual/#walk(f))\r\n - [with_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries)\r\n\r\n",
                "title": "Replacing underscores in JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1611962028,
        "creation_date": 1478025647,
        "last_edit_date": 1478102057,
        "question_id": 40366520,
        "body_markdown": "I&#39;m working with the [woocommerce](http://woocommerce.github.io/woocommerce-rest-api-docs/) API to retrieve and store information. Currently our setup is designed to use camel case instead of underscores. I&#39;m using `jq` to process our information, but I&#39;m curious how I can use the `sub(regex, tostring)` function to replace the underscores in my JSON with camelCase?\r\n\r\nHere&#39;s an example of the code\r\n\r\n    &quot;line_items&quot;: [\r\n        {\r\n         &quot;id&quot;: xxxx,\r\n         &quot;name&quot;: &quot;xxxx&quot;,\r\n         &quot;sku&quot;: &quot;xxxx&quot;,\r\n         &quot;product_id&quot;: xxxx,\r\n        }\r\n\r\nFor example, according to another answer on SO that I found, this works: `curl https://www.testsite.com/wp-json/wc/v1/orders -u user:pass | jq &#39;.[] | with_entries( if .key | contains(&quot;_&quot;) then .key |= sub(&quot;_&quot;;&quot;&quot;) else . end)&#39;` and remove the underscores.\r\n\r\nThe result is:\r\n\r\n    &quot;lineitems&quot;: [\r\n        {\r\n         &quot;id&quot;: xxxx,\r\n         &quot;name&quot;: &quot;xxxx&quot;,\r\n         &quot;sku&quot;: &quot;xxxx&quot;,\r\n         &quot;productid&quot;: xxxx,\r\n        }\r\n\r\n\r\nHowever, when I try `curl https://www.testsite.com/wp-json/wc/v1/orders -u user:pass | jq &#39;.[] | with_entries( if .key | contains(&quot;_&quot;) then .key |= sub(&quot;(\\\\_)([a-z])&quot;;&quot;$2\\u&quot;) else . end)&#39;` I don&#39;t get the results I would expect.\r\n\r\nThe expected results would be:\r\n\r\n    &quot;lineItems&quot;: [\r\n        {\r\n         &quot;id&quot;: xxxx,\r\n         &quot;name&quot;: &quot;xxxx&quot;,\r\n         &quot;sku&quot;: &quot;xxxx&quot;,\r\n         &quot;productId&quot;: xxxx,\r\n        }\r\n\r\nI don&#39;t have a lot of experience using `jq` so I&#39;m not sure what I&#39;m doing wrong. Is there a better solution to this problem?",
        "link": "https://stackoverflow.com/questions/40366520/replacing-underscores-in-json-using-jq",
        "title": "Replacing underscores in JSON using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1478095935,
                "creation_date": 1478095935,
                "answer_id": 40382097,
                "question_id": 40381981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this :\r\n\r\n    jq &#39;.[]&#39; file\r\n\r\nIf you use the `.[index]` syntax, but omit the index entirely, it will return all of the elements of an array. \r\n\r\n**Test:**\r\n\r\n    $ jq &#39;.[]&#39; file\r\n    {\r\n      &quot;email&quot;: &quot;john@company.com&quot;,\r\n      &quot;name&quot;: &quot;John&quot;\r\n    }\r\n    {\r\n      &quot;email&quot;: &quot;brad@company.com&quot;,\r\n      &quot;name&quot;: &quot;Brad&quot;\r\n    }",
                "title": "json array into json stream with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1478096213,
                "creation_date": 1478096213,
                "answer_id": 40382197,
                "question_id": 40381981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you can apply  &quot;.[]&quot; filter.\r\n\r\nThis tutorial is very informative\r\nhttps://stedolan.github.io/jq/tutorial/",
                "title": "json array into json stream with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1478096213,
        "creation_date": 1478095581,
        "last_edit_date": 1495542798,
        "question_id": 40381981,
        "body_markdown": "This task is similar to [this one][1] but in my case I would like to go other way around.\r\nSo say we have input:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;email&quot;: &quot;john@company.com&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;Brad&quot;,\r\n            &quot;email&quot;: &quot;brad@company.com&quot;\r\n        }\r\n    ]\r\n\r\nand desired output is:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;email&quot;: &quot;john@company.com&quot;\r\n    }\r\n    {\r\n        &quot;name&quot;: &quot;Brad&quot;,\r\n        &quot;email&quot;: &quot;brad@company.com&quot;\r\n    }\r\n\r\nI tried to write a bash function which will do it in loop:\r\n\r\n    #!/bin/bash\r\n    \r\n    json=`cat $1`\r\n    length=`echo $json | jq &#39;. | length&#39;`\r\n    \r\n    for (( i=0; i&lt;$length ; i++ ))\r\n    do\r\n    echo $json | jq &quot;.[$i]&quot;\r\n    done\r\n\r\nbut it is obviously extremly slow...\r\n\r\nIs there any way how to use &lt;code&gt;jq&lt;/code&gt; better for this?\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/38061346/jq-output-array-of-json-objects",
        "link": "https://stackoverflow.com/questions/40381981/json-array-into-json-stream-with-jq",
        "title": "json array into json stream with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "split",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478109168,
                "post_id": 40385830,
                "comment_id": 68024860,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 158448,
                    "reputation": 3854,
                    "user_id": 377118,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/04Y6E.jpg?s=256",
                    "display_name": "Emer",
                    "link": "https://stackoverflow.com/users/377118/emer"
                },
                "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": 1478110461,
                "post_id": 40385830,
                "comment_id": 68025685,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1478111863,
                "last_edit_date": 1478111863,
                "creation_date": 1478111459,
                "answer_id": 40387278,
                "question_id": 40385830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Splitting into two separate `jq` invocations allows the second one to use the `input` helper to process only a single piece of input at a time. Using a `try` helper in the second one lets it gracefully handle incomplete lines, if you don&#39;t have two items of input left.\r\n\r\n---\r\n\r\n    s=&#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39;\r\n\r\n    jq &#39;.[]&#39; &lt;&lt;&lt;&quot;$s&quot; | \\\r\n      jq -c -n &#39;repeat(input as $i1 | try (input as $i2 | [$i1, $i2]) catch [$i1])?&#39; | \\\r\n      split -l 2 -d -a 3 - meta_\r\n\r\n...emits, in the first file:\r\n\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n    [{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n\r\n...and, in the second:\r\n\r\n    [{&quot;key5&quot;:&quot;value5&quot;}]",
                "title": "Split a JSON array into multiple files using command line tools"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1479365671,
                "last_edit_date": 1479365671,
                "creation_date": 1478114586,
                "answer_id": 40388109,
                "question_id": 40385830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I found out the solution using `jq` and `split` tools. I was missing the double quotes, the `&#39;.&#39;` pattern in `jq` and to scape the `$` with a backslash.\r\n\r\n    $ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; |\r\n      jq -c -M &#39;.[]&#39; |\r\n      split -l 2 -d -a 3 - meta2_ --filter=&quot;jq --slurp -c -M &#39;.&#39; &gt;\\$FILE&quot;\r\n    $ tail -n +1 meta2_*\r\n    ==&gt; meta2_000 &lt;==\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n    \r\n    ==&gt; meta2_001 &lt;==\r\n    [{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n    \r\n    ==&gt; meta2_002 &lt;==\r\n    [{&quot;key5&quot;:&quot;value5&quot;}]",
                "title": "Split a JSON array into multiple files using command line tools"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1478122410,
                "last_edit_date": 1478122410,
                "creation_date": 1478121432,
                "answer_id": 40389954,
                "question_id": 40385830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;ll be easier to build out the arrays in the jq filter, then split to files per line.  No additional filtering necessary.\r\n\r\n    range(0; length; 2) as $i | .[$i:$i+2]\r\n\r\nproduces:\r\n\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n    [{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n    [{&quot;key5&quot;:&quot;value5&quot;}]\r\n\r\nSo putting it all together.\r\n\r\n    $ jq -cM --argjson sublen &#39;2&#39; &#39;range(0; length; $sublen) as $i | .[$i:$i+$sublen]&#39; \\\r\n        input.json | split -l 1 -da 3 - meta2_\r\n\r\n",
                "title": "Split a JSON array into multiple files using command line tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557744644,
                "last_edit_date": 1557744644,
                "creation_date": 1557681403,
                "answer_id": 56101625,
                "question_id": 40385830,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq might be the way to go as mentioned in the other responses. As I was not familiar with jq, I wrote a bash script (splitjson.sh) below using very common commands (echo, cat, wc, head, tail, sed, expr). This script splits the json file into chunks no longer than the specified number of bytes. If the split is not possible within the specified number of bytes (a json item is very long or the specified maximum number of bytes per chunk is too small), the script stops writing to the json files and writes an error.\r\n\r\nHere is an example with the data in the question as example.json:\r\n\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]\r\n\r\nThe command to execute the script with a maximum number of bytes per chunk is:\r\n\r\n    $ ./splitjson.sh example.json 40\r\n\r\nThe result is then:\r\n\r\n    $ head example.json.*\r\n    ==&gt; example.json.0 &lt;==\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n    ==&gt; example.json.1 &lt;==\r\n    [{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n    ==&gt; example.json.2 &lt;==\r\n    [{&quot;key5&quot;:&quot;value5&quot;}]\r\n\r\nThe script handles the cases with spaces, tabs, newlines between the end brackets &#39;}&#39;, the colon &#39;,&#39; and the start bracket &#39;{&#39;.\r\n\r\nI used this script with success on json files as big as 82 MB. I&#39;d expect it to work with bigger files.\r\n\r\nHere is the script (splitjson.sh):\r\n\r\n    #!/bin/bash\r\n    if [ $# -ne 2 ]\r\n    then\r\n    \techo &quot;usage: $0 file_to_split.json nb_bytes_max_per_split&quot;\r\n    \texit 1\r\n    fi\r\n    if [[ -r $1 ]]\r\n    then\r\n    \tinput=$1\r\n    \techo &quot;reading from file &#39;$input&#39;&quot;\r\n    else\r\n    \techo &quot;cannot read from specified input file &#39;$1&#39;&quot;\r\n    \texit 2\r\n    fi\r\n    if [[ $2 = *[[:digit:]]* ]]; then\r\n    \tmaxbytes=$2\r\n    \techo &quot;taking maximum bytes &#39;$maxbytes&#39;&quot;\r\n    else\r\n    \techo &quot;provided maximum number of bytes &#39;$2&#39; is not numeric&quot;\r\n    \texit 3\r\n    fi\r\n    \r\n    start=0\r\n    over=0\r\n    iteration=0\r\n    inputsize=`cat $input|wc -c`\r\n    tailwindow=&quot;$input.tail&quot;\r\n    echo &quot;input file size: $inputsize&quot;\r\n    tmp=&quot;$input.tmp&quot;\r\n    cp $input $tmp\r\n    sed -e &#39;:a&#39; -e &#39;N&#39; -e &#39;$!ba&#39; -e &#39;s/}[[:space:]]*,[[:space:]]*{/},{/g&#39; -i&#39;.back&#39; $tmp\r\n    rm &quot;$tmp.back&quot;\r\n    inputsize=`cat $tmp|wc -c`\r\n    if [ $inputsize -eq 0 ]; then\r\n    \tcp $input $tmp\r\n    \tsed -e &#39;s/}[[:space:]]*,[[:space:]]*{/},{/g&#39; -i&#39;.back&#39; $tmp\r\n    \trm &quot;$tmp.back&quot;\r\n    fi\r\n    inputsize=`cat $tmp|wc -c`\r\n    while [ $over -eq 0 ]; do\r\n    \toutput=&quot;$input.$iteration&quot;\r\n    \tif [ $iteration -ne 0 ]; then\r\n                    echo -n &quot;[{&quot;&gt;$output\r\n    \telse\r\n                    echo -n &quot;&quot;&gt;$output\r\n    \tfi\r\n    \ttailwindowsize=`expr $inputsize - $start`\r\n    \tcat $tmp|tail -c $tailwindowsize&gt;$tailwindow\r\n    \ttailwindowresultsize=`cat $tailwindow|wc -c`\r\n    \tif [ $tailwindowresultsize -le $maxbytes ]; then\r\n    \t\tcat $tailwindow&gt;&gt;$output\r\n    \t\tover=1\r\n    \telse\r\n    \t\tcat $tailwindow|head -c $maxbytes|sed -E &#39;s/(.*)\\},\\{(.*)/\\1}]/&#39;&gt;&gt;$output\r\n    \tfi\r\n    \tjsize=`cat $output|wc -c`\r\n    \tstart=`expr $start + $jsize`\r\n    \tif [ $iteration -eq 0 ]; then\r\n    \t\tstart=`expr $start + 1`\r\n    \telse\r\n    \t\tstart=`expr $start - 1`\r\n    \tfi\r\n    \tendofj=`cat $output|tail -c 3`\r\n    \tif [ $over -ne 1 ]; then\r\n    \t\tif [ ${endofj:1:2} != &quot;}]&quot; ]; then\r\n    \t\t\tif [ ${endofj:0:2} != &quot;}]&quot; ]; then\r\n    \t\t\t\techo -e &quot;ERROR: at least one split pattern wasn&#39;t found. Aborting. This could be due to wrongly formatted json or due to a json entry too long compared to the provided maximum bytes. Maybe you should try increasing this parameter?\\a&quot;\r\n    \t\t\t\texit 4\r\n    \t\t\tfi\r\n    \t\tfi\r\n    \tfi\r\n    \tjsizefinal=`cat $output|wc -c`\r\n    \techo &quot;wrote $jsizefinal bytes of json for iteration $iteration to $output&quot;\r\n    \titeration=`expr $iteration + 1`\r\n    done\r\n    rm $tailwindow\r\n    rm $tmp\r\n\r\n\r\n",
                "title": "Split a JSON array into multiple files using command line tools"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1741535052,
                "last_edit_date": 1741535052,
                "creation_date": 1557877132,
                "answer_id": 56139970,
                "question_id": 40385830,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; _Suppose we have a JSON array of length 5 and we want to split the\r\n&gt; array into multiple arrays of length 2 and save the grouped items into\r\n&gt; different files, **using linux command line tools**._\r\n\r\nThe JSON parser [tag:xidel] can do what you want and an XQuery 3.1 FLWOR expression with a [(tumbling) Window clause](https://www.w3.org/TR/xquery-31/#id-tumbling-windows) is the basic idea:\r\n```\r\n$ xidel -se &#39;\r\n  for tumbling window $w in 1 to 5\r\n  start $s when $s mod 2 eq 1\r\n  return\r\n  join($w)\r\n&#39;\r\n1 2\r\n3 4\r\n5\r\n\r\n$ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; | \\\r\n  xidel -se &#39;\r\n  for tumbling window $w in 1 to count($json())\r\n  start $s when $s mod 2 eq 1\r\n  return\r\n  array{$w ! $json(.)}\r\n&#39; --output-json-indent=compact\r\n[{&quot;key1&quot;: &quot;value1&quot;}, {&quot;key2&quot;: &quot;value2&quot;}]\r\n[{&quot;key3&quot;: &quot;value3&quot;}, {&quot;key4&quot;: &quot;value4&quot;}]\r\n[{&quot;key5&quot;: &quot;value5&quot;}]\r\n```\r\nTo save each array as a json-file you can use Xidel&#39;s integrated [EXPath File Module](http://www.benibela.de/documentation/internettools/xpath-functions.html#modulefile):\r\n```\r\n$ xidel -se &#39;\r\n  for tumbling window $w in 1 to 5\r\n  start $s at $i when $s mod 2 eq 1\r\n  count $i\r\n  return\r\n  `output_{$i}.json - {join($w)}`\r\n&#39;\r\noutput_1.json - 1 2\r\noutput_2.json - 3 4\r\noutput_3.json - 5\r\n\r\n$ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; | \\\r\n  xidel -se &#39;\r\n  for tumbling window $w in 1 to count($json())\r\n  start $s at $i when $s mod 2 eq 1\r\n  count $i\r\n  return\r\n  file:write(\r\n    `output_{$i}.json`,\r\n    array{$w ! $json(.)},\r\n    {&quot;method&quot;:&quot;json&quot;}\r\n  )\r\n&#39;\r\n\r\n$ xidel -s output_1.json output_2.json output_3.json -e &#39;$raw&#39;\r\n$ xidel -s output_1.json output_2.json output_3.json -e &#39;$json&#39; --output-json-indent=compact\r\n[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n[{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n[{&quot;key5&quot;:&quot;value5&quot;}]\r\n```",
                "title": "Split a JSON array into multiple files using command line tools"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1741901205,
                "creation_date": 1741901205,
                "answer_id": 79507668,
                "question_id": 40385830,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following jq script:\r\n```\r\n#!/usr/bin/env -S jq -fr --argjson group_size 2\r\n\r\nto_entries # transform to array of objects with key and value\r\n|map(.group_id=(.key/$group_size|floor)) # calculate zero-based group id\r\n|group_by(.group_id)[]                   # split by group_id\r\n|{\r\n  group_id:.[0].group_id, # all elements in the group have the same group id - so take it from the first element\r\n  values:map(.value)      # array of all values in the group\r\n}\r\n|.string=(\r\n  .values|tostring        # transform array of values to string\r\n  |gsub(&quot;\\\\\\\\&quot;;&quot;\\\\\\\\&quot;)    # believe or not, this changes \\ to \\\\\r\n  |gsub(&quot;\\&quot;&quot;;&quot;\\\\\\&quot;&quot;)      # change &quot; to \\&quot;\r\n)\r\n|.file=&quot;meta_&quot;+(.group_id|tostring|(3-length)*&quot;0&quot;+.) # construct file name with leading zeroes\r\n|&quot;echo \\&quot;\\(.string)\\&quot; | tee \\(.file)&quot;                # create echo commands\r\n```\r\ngenerates echo commands:\r\n```\r\n$ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; \\\r\n| ./split_json_array.jq \r\necho &quot;[{\\&quot;key1\\&quot;:\\&quot;value1\\&quot;},{\\&quot;key2\\&quot;:\\&quot;value2\\&quot;}]&quot; | tee meta_000\r\necho &quot;[{\\&quot;key3\\&quot;:\\&quot;value3\\&quot;},{\\&quot;key4\\&quot;:\\&quot;value4\\&quot;}]&quot; | tee meta_001\r\necho &quot;[{\\&quot;key5\\&quot;:\\&quot;value5\\&quot;}]&quot; | tee meta_002\r\n```\r\nso it can be simply piped to ```bash```:\r\n```bash\r\n$ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; \\\r\n| ./split_json_array.jq | bash -x\r\n+ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]&#39;\r\n+ tee meta_000\r\n[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n+ echo &#39;[{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]&#39;\r\n+ tee meta_001\r\n[{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n+ echo &#39;[{&quot;key5&quot;:&quot;value5&quot;}]&#39;\r\n+ tee meta_002\r\n[{&quot;key5&quot;:&quot;value5&quot;}]\r\n```\r\nresult:\r\n```bash\r\n$ head meta*\r\n==&gt; meta_000 &lt;==\r\n[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n\r\n==&gt; meta_001 &lt;==\r\n[{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n\r\n==&gt; meta_002 &lt;==\r\n[{&quot;key5&quot;:&quot;value5&quot;}]\r\n```\r\nScript can handle JSON containing single quotes and characters escaped with backslash.",
                "title": "Split a JSON array into multiple files using command line tools"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 8,
        "last_activity_date": 1741901205,
        "creation_date": 1478106702,
        "last_edit_date": 1478110036,
        "question_id": 40385830,
        "body_markdown": "Suppose we have a JSON array of length 5 and we want to split the array into multiple arrays of length 2 and save the grouped items into different files, using linux command line tools. \r\n\r\nI tried it by using the `jq` and `split` tools (I am happy with any approach that can be executed from a bash script):\r\n\r\n    $ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; | jq -c -M &#39;.[]&#39; | split -l 2 -d -a 3 - meta_\r\n    $ tail -n +1 meta_*\r\n    ==&gt; meta_000 &lt;==\r\n    {&quot;key1&quot;:&quot;value1&quot;}\r\n    {&quot;key2&quot;:&quot;value2&quot;}\r\n    \r\n    ==&gt; meta_001 &lt;==\r\n    {&quot;key3&quot;:&quot;value3&quot;}\r\n    {&quot;key4&quot;:&quot;value4&quot;}\r\n    \r\n    ==&gt; meta_002 &lt;==\r\n    {&quot;key5&quot;:&quot;value5&quot;}\r\n\r\nThe previous command saves the items into the files correctly, but we need to convert them into a valid JSON array format. I tired with `--filter` option:\r\n\r\n    $ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; | jq -c -M &#39;.[]&#39; | split -l 2 -d -a 3 - meta2_ --filter=&#39;jq --slurp -c -M&#39;\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n    [{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;}]\r\n    [{&quot;key5&quot;:&quot;value5&quot;}]\r\n    $ tail -n +1 meta2_*\r\n    tail: cannot open &#39;meta2_*&#39; for reading: No such file or directory\r\n\r\nHowever, it displays the output on the screen but the results aren&#39;t persisted. I tried forwarding the output but I get an error: \r\n\r\n    echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; | jq -c -M &#39;.[]&#39; | split -l 2 -d -a 3 - meta2_ --filter=&#39;jq --slurp -c -M &gt; $FILE&#39;\r\n    ...\r\n    split: with FILE=meta2_000, exit 2 from command: jq --slurp -c -M &gt; $FILE\r\n\r\nAny hints or better approaches? \r\n\r\n\r\nEDIT: I tried with double quotes @andlrc suggested:\r\n\r\n    $ echo &#39;[{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key3&quot;:&quot;value3&quot;},{&quot;key4&quot;:&quot;value4&quot;},{&quot;key5&quot;:&quot;value5&quot;}]&#39; | jq -c -M &#39;.[]&#39; | split -l 2 -d -a 3 - meta2_ --filter=&quot;jq --slurp -c -M &gt; $FILE&quot;\r\n    bash: -c: line 0: syntax error near unexpected token `newline&#39;\r\n    bash: -c: line 0: `jq --slurp -c -M &gt; &#39;\r\n    split: with FILE=meta2_000, exit 1 from command: jq --slurp -c -M &gt;\r\n    $ cat meta_000 | jq --slurp -c -M\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40385830/split-a-json-array-into-multiple-files-using-command-line-tools",
        "title": "Split a JSON array into multiple files using command line tools"
    },
    {
        "tags": [
            "json",
            "docker",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 229385,
                    "reputation": 1254,
                    "user_id": 492317,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/53aa33eb7ba05fe801ff4ecd5ae289e9?s=256&d=identicon&r=PG",
                    "display_name": "Ryan LaNeve",
                    "link": "https://stackoverflow.com/users/492317/ryan-laneve"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478130152,
                "post_id": 40390922,
                "comment_id": 68034850,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1295023,
                    "reputation": 307,
                    "user_id": 1246313,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fZ5ab.jpg?s=256",
                    "display_name": "Lea de Groot",
                    "link": "https://stackoverflow.com/users/1246313/lea-de-groot"
                },
                "reply_to_user": {
                    "account_id": 229385,
                    "reputation": 1254,
                    "user_id": 492317,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/53aa33eb7ba05fe801ff4ecd5ae289e9?s=256&d=identicon&r=PG",
                    "display_name": "Ryan LaNeve",
                    "link": "https://stackoverflow.com/users/492317/ryan-laneve"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478151206,
                "post_id": 40390922,
                "comment_id": 68039831,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1295023,
                    "reputation": 307,
                    "user_id": 1246313,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fZ5ab.jpg?s=256",
                    "display_name": "Lea de Groot",
                    "link": "https://stackoverflow.com/users/1246313/lea-de-groot"
                },
                "reply_to_user": {
                    "account_id": 229385,
                    "reputation": 1254,
                    "user_id": 492317,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/53aa33eb7ba05fe801ff4ecd5ae289e9?s=256&d=identicon&r=PG",
                    "display_name": "Ryan LaNeve",
                    "link": "https://stackoverflow.com/users/492317/ryan-laneve"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479168131,
                "post_id": 40390922,
                "comment_id": 68435365,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1478137296,
                "creation_date": 1478137296,
                "answer_id": 40392521,
                "question_id": 40390922,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It is trivial error.\r\n\r\nPlease change the url **from:**  \r\n\r\n    curl &#39;https://demo.cachethq.io/API/v1/components?name=Blog&#39; | tac | tac | jq &#39;.&#39;\r\n\r\n**To:**  \r\n\r\n    curl &#39;https://demo.cachethq.io/api/v1/components?name=Blog&#39; | tac | tac | jq &#39;.&#39;\r\n\r\n\r\n**Output:**  \r\n\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100   426    0   426    0     0    176      0 --:--:--  0:00:02 --:--:--   176\r\n    {\r\n      &quot;meta&quot;: {\r\n        &quot;pagination&quot;: {\r\n          &quot;total&quot;: 1,\r\n          &quot;count&quot;: 1,\r\n          &quot;per_page&quot;: 20,\r\n          &quot;current_page&quot;: 1,\r\n          &quot;total_pages&quot;: 1,\r\n          &quot;links&quot;: {\r\n            &quot;next_page&quot;: null,\r\n            &quot;previous_page&quot;: null\r\n          }\r\n        }\r\n      },\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;id&quot;: 4,\r\n          &quot;name&quot;: &quot;Blog&quot;,\r\n          &quot;description&quot;: &quot;The Alt Three Blog.&quot;,\r\n          &quot;link&quot;: &quot;https://blog.alt-three.com&quot;,\r\n          &quot;status&quot;: 1,\r\n          &quot;order&quot;: 0,\r\n          &quot;group_id&quot;: 2,\r\n          &quot;created_at&quot;: &quot;2016-11-03 01:30:01&quot;,\r\n          &quot;updated_at&quot;: &quot;2016-11-03 01:30:01&quot;,\r\n          &quot;deleted_at&quot;: null,\r\n          &quot;enabled&quot;: true,\r\n          &quot;status_name&quot;: &quot;Operational&quot;,\r\n          &quot;tags&quot;: {\r\n            &quot;&quot;: &quot;&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n",
                "title": "jq returns null from curl"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1478137296,
        "creation_date": 1478125867,
        "last_edit_date": 1478128855,
        "question_id": 40390922,
        "body_markdown": "I&#39;m running the following command inside a docker container:\r\n\r\n    curl &#39;https://demo.cachethq.io/API/v1/components?name=Blog&#39; | tac | tac | jq &#39;.&#39;\r\n\r\nBut I get null output (after the curl progress bar)\r\nRunning without the final jq command gives the correct json.\r\nAny help would be appreciated \r\n(The tac is to stop the curl output ending before the jq)",
        "link": "https://stackoverflow.com/questions/40390922/jq-returns-null-from-curl",
        "title": "jq returns null from curl"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1478146615,
                "creation_date": 1478146615,
                "answer_id": 40393799,
                "question_id": 40392637,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can change the delimiter on the fly if you parameterize it.\r\n\r\n    $ jq -r --arg delim &#39;|&#39; &#39;.[] | &quot;\\(.a)\\($delim)\\(.b[])&quot;&#39; input.json",
                "title": "Combine the value from a key with all array entries"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1478146615,
        "creation_date": 1478138235,
        "question_id": 40392637,
        "body_markdown": " I have json input as follows:\r\n\r\n       [{\r\n       \t&quot;a&quot;: &quot;123&quot;,\r\n       \t&quot;b&quot;: [\r\n       \t\t&quot;xyz&quot;,\r\n       \t\t&quot;uvw&quot;\r\n       \t]\r\n       }, {\r\n       \t&quot;a&quot;: &quot;456&quot;,\r\n       \t&quot;b&quot;: [\r\n       \t\t&quot;ghi&quot;\r\n       \t]\r\n       }]\r\n\r\nand I&#39;d like to produce a list where each object&#39;s &quot;a&quot; is combined with each element of &quot;b&quot; using a delimiter.  Is this possible to do using jq?\r\n\r\n    123|xyz\r\n    123|uvw\r\n    456|ghi",
        "link": "https://stackoverflow.com/questions/40392637/combine-the-value-from-a-key-with-all-array-entries",
        "title": "Combine the value from a key with all array entries"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 297,
                "is_accepted": true,
                "score": 296,
                "last_activity_date": 1543202056,
                "last_edit_date": 1543202056,
                "creation_date": 1478160584,
                "answer_id": 40396556,
                "question_id": 40396445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`-c`** is what you likely need\r\n\r\nUsing the output you posted above, you can process it further:\r\n\r\n &lt;pre&gt;\r\njq **-c** . input\r\n&lt;/pre&gt;\r\n\r\nTo Give;\r\n\r\n\r\n    {&quot;key&quot;:&quot;SEA-739&quot;,&quot;status&quot;:&quot;Open&quot;,&quot;assignee&quot;:null}\r\n    {&quot;key&quot;:&quot;SEA-738&quot;,&quot;status&quot;:&quot;Resolved&quot;,&quot;assignee&quot;:&quot;user2@mycompany.com&quot;}\r\n\r\nOr you can just change your original command\r\n&lt;/pre&gt;\r\n\r\n  &lt;/pre&gt;\r\n\r\n**FROM**\r\n\r\n &lt;pre&gt;\r\njq **-r** &#39;(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress})&#39;\r\n&lt;/pre&gt;\r\n\r\n&lt;/pre&gt; \r\n**TO**\r\n\r\n &lt;pre&gt;jq **-c** &#39;(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress})&#39;\r\n&lt;/pre&gt;\r\n",
                "title": "Get outputs from jq on a single line"
            },
            {
                "up_vote_count": 47,
                "is_accepted": false,
                "score": 47,
                "last_activity_date": 1656686116,
                "last_edit_date": 1656686116,
                "creation_date": 1572546966,
                "answer_id": 58649439,
                "question_id": 40396445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not precisely an answer to the long version of the question, but for people who Googled this looking for other single line output formats from jq:\r\n\r\n```\r\n$ jq -r &#39;[.key, .status, .assignee]|@tsv&#39; &lt;&lt;&lt;&#39;\r\n {\r\n   &quot;key&quot;: &quot;SEA-739&quot;,\r\n   &quot;status&quot;: &quot;Open&quot;,\r\n   &quot;assignee&quot;: null\r\n }\r\n {\r\n   &quot;key&quot;: &quot;SEA-738&quot;,\r\n   &quot;status&quot;: &quot;Resolved&quot;,\r\n   &quot;assignee&quot;: &quot;user2@mycompany.com&quot;\r\n }&#39;\r\n```\r\noutputs:\r\n```\r\nSEA-739 Open\r\nSEA-738 Resolved        user2@mycompany.com\r\n```\r\n\r\n`@sh` rather than `@tsv` returns:\r\n\r\n```\r\n&#39;SEA-739&#39; &#39;Open&#39; null\r\n&#39;SEA-738&#39; &#39;Resolved&#39; &#39;user2@mycompany.com&#39;\r\n```\r\n\r\nAdditionally, there are other output formats to do things such as escape the output, like `@html`, or encode it, as with `@base64`. The list is available in the *Format strings and escaping* section of either the *jq(1)* man page or online at [stedolan.github.io/jq/manual](https://stedolan.github.io/jq/manual/).",
                "title": "Get outputs from jq on a single line"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1706202478,
                "last_edit_date": 1706202478,
                "creation_date": 1680631801,
                "answer_id": 75932555,
                "question_id": 40396445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answers with &quot;-c&quot; and &quot;-r&quot; didn&#39;t work for me with jq version 1.6. What I did was the following:\r\n\r\nGiven input like\r\n\r\n    {\r\n      &quot;parameters&quot;: {\r\n        &quot;puppetmaster&quot;: &quot;&quot;,\r\n        &quot;ansible_job_template_id&quot;: &quot;117&quot;,\r\n        &quot;lifecycle_environment&quot;: &quot;Dev&quot;,\r\n        &quot;hostname&quot;: &quot;childmas01&quot;,\r\n    }\r\n\r\nAnd a jq command like\r\n\r\n    jq -r &#39;.parameters | .hostname,.lifecycle_environment&#39; filename\r\n\r\nI got output like this:\r\n\r\n    childmas01\r\n    Dev\r\n\r\nI got the same results with -c instead of -r, and also with -cr. So I simply made the results into an array, and joined them with a space, like this:\r\n\r\n    jq -r &#39;.parameters | [ .hostname,.lifecycle_environment ] | join(&quot; &quot;)&#39;  filename\r\n\r\nTo get this:\r\n\r\n    childmas01 Dev\r\n\r\n\r\n",
                "title": "Get outputs from jq on a single line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1725624783,
                "last_edit_date": 1725624783,
                "creation_date": 1725488167,
                "answer_id": 78950736,
                "question_id": 40396445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So when working on my script and researching I found this question. After some tinkering this is what I found worked for me. Included various styles of outputs I got so people can pick what works for them.\r\n\r\n    $ cat config/menus.json | jq -c &#39;.menus[] | select(.name == &quot;main&quot;) | (.columns[])&#39; \r\n    &quot;value1&quot;\r\n    &quot;value2&quot;\r\n    &quot;value3&quot;\r\n    &quot;value4&quot;\r\n    &quot;value5&quot;\r\n    $ cat config/menus.json | jq -c &#39;.menus[] | select(.name == &quot;main&quot;) | [.columns[]]&#39; \r\n    [&quot;value1&quot;,&quot;value2&quot;,&quot;value3&quot;,&quot;value4&quot;,&quot;value5&quot;]\r\n    $ cat config/menus.json | jq -c &#39;.menus[] | select(.name == &quot;main&quot;) | [.columns[]] | @sh&#39; \r\n    &quot;&#39;value1&#39; &#39;value2&#39; &#39;value3&#39; &#39;value4&#39; &#39;value5&#39;&quot;\r\n    $ cat config/menus.json | jq -r &#39;.menus[] | select(.name == &quot;main&quot;) | [.columns[]] | @sh&#39; \r\n    &#39;value1&#39; &#39;value2&#39; &#39;value3&#39; &#39;value4&#39; &#39;value5&#39;",
                "title": "Get outputs from jq on a single line"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 182,
        "last_activity_date": 1725624783,
        "creation_date": 1478160082,
        "last_edit_date": 1565898872,
        "question_id": 40396445,
        "body_markdown": "I got below output using: https://stackoverflow.com/a/40330344\r\n\r\n     (.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress})\r\n \r\n \r\n Output:\r\n \r\n     {  \r\n       &quot;key&quot;: &quot;SEA-739&quot;,\r\n       &quot;status&quot;: &quot;Open&quot;,\r\n       &quot;assignee&quot;: null\r\n     }\r\n     {\r\n       &quot;key&quot;: &quot;SEA-738&quot;,\r\n       &quot;status&quot;: &quot;Resolved&quot;,\r\n       &quot;assignee&quot;: &quot;user2@mycompany.com&quot;\r\n     }\r\n\r\nBut I need to parse each and every line but it&#39;s tough to identify which assignee is for which key as far as key group is concerned. Is this possible to make one bunch in one row using jq?\r\n\r\nExpected output:\r\n\r\n    { &quot;key&quot;: &quot;SEA-739&quot;, &quot;status&quot;: &quot;Open&quot;, &quot;assignee&quot;: null }\r\n    { &quot;key&quot;: &quot;SEA-738&quot;, &quot;status&quot;: &quot;Resolved&quot;, &quot;assignee&quot;: &quot;user2@mycompany.com&quot;}\r\n\r\nOR\r\n\r\n    { &quot;SEA-739&quot;, &quot;Open&quot;, null }\r\n    { &quot;SEA-738&quot;, &quot;Resolved&quot;, user2@mycompany.com }",
        "link": "https://stackoverflow.com/questions/40396445/get-outputs-from-jq-on-a-single-line",
        "title": "Get outputs from jq on a single line"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1478198540,
                "last_edit_date": 1478198540,
                "creation_date": 1478192152,
                "answer_id": 40407206,
                "question_id": 40398344,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could group them up to determine what `equip` values need to be combined, then you could build up your string.\r\n\r\n    $ jq -n --arg delim &#39;,&#39; &#39;{\r\n        site: [inputs.site[]]\r\n            | group_by(.uuid)\r\n            | map({\r\n                uuid: .[0].uuid,\r\n                testtype: .[0].testtype,\r\n                name: .[0].name,\r\n                equip: (map(.equip | tojson) | unique | join($delim))\r\n            })\r\n    }&#39; input.json\r\n\r\nThis produces: (note: the item order is not necessarily preserved)\r\n\r\n    {\r\n      &quot;site&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;23451fae-a14f-49d1-a096-8f033f69dc80&quot;,\r\n          &quot;testtype&quot;: &quot;Scheduled&quot;,\r\n          &quot;name&quot;: &quot;JANE DOE HEAD OFFICE&quot;,\r\n          &quot;equip&quot;: &quot;\\&quot;Unique Item One\\&quot;,\\&quot;Unique Item Two\\&quot;,\\&quot;Unique Item Three\\&quot;&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIf the string is meant to look like csv data and needs escaping, be sure to do so.  Assuming quotes need to be escaped, you could modify this part:\r\n\r\n    map(.equip | gsub(&quot;\\&quot;&quot;;&quot;\\&quot;\\&quot;&quot;) |  tojson)\r\n",
                "title": "How to combine (concatenate) JSON objects which contain a common key name but unique values in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1478198540,
        "creation_date": 1478166553,
        "last_edit_date": 1478181373,
        "question_id": 40398344,
        "body_markdown": "Using the **[jq][1]** command, I am trying to transform some data into a specific format\r\n \r\nI have a sample JSON set:\r\n\r\n- &lt;pre&gt;\r\n    {\r\n      &quot;site&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;23451fae-a14f-49d1-a096-8f033f69dc80&quot;,\r\n          &quot;testtype&quot;: &quot;Scheduled&quot;,\r\n          &quot;name&quot;: &quot;JANE DOE HEAD OFFICE&quot;,\r\n          &quot;equip&quot;: &quot;**Unique Item One**&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;site&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;23451fae-a14f-49d1-a096-8f033f69dc80&quot;,\r\n          &quot;testtype&quot;: &quot;Scheduled&quot;,\r\n          &quot;name&quot;: &quot;JANE DOE HEAD OFFICE&quot;,\r\n          &quot;equip&quot;: &quot;**Unique Item Two**&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;site&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;23451fae-a14f-49d1-a096-8f033f69dc80&quot;,\r\n          &quot;testtype&quot;: &quot;Scheduled&quot;,\r\n          &quot;name&quot;: &quot;JANE DOE HEAD OFFICE&quot;,\r\n          &quot;equip&quot;: &quot;**Unique Item Three**&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n   \r\n&lt;/pre&gt;\r\n\r\n\r\n&lt;/pre&gt;\r\n   \r\n&lt;/pre&gt;\r\n\r\nI want to extract the ***unique*** values (**`equip`**);&lt;br&gt;\r\n \r\n- From known locations with ***common*** names in the data set (**`site`**); **and**\r\n- Have the values concatenated with a ***string*** delimiter that I can change;\r\n\r\n- In order to get an output like this: (shown with a **`comma`** as my choice of delimiter):\r\n\r\n&lt;/pre&gt;\r\n\r\n-       &lt;pre&gt;\r\n    {\r\n      &quot;site&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;23451fae-a14f-49d1-a096-8f033f69dc80&quot;,\r\n          &quot;testtype&quot;: &quot;Scheduled&quot;,\r\n          &quot;name&quot;: &quot;JANE DOE HEAD OFFICE&quot;,\r\n          **&quot;equip&quot;: &quot;\\&quot;Unique Item One\\&quot;,\\&quot;Unique Item Two\\&quot;,\\&quot;Unique Item Three\\&quot;&quot;**\r\n        }\r\n      ]\r\n    }\r\n\r\n&lt;/pre&gt;\r\n\r\n---\r\n\r\nJust addressing the `equip` value as a first step; some of the command combinations I&#39;ve tried using the sample dataset (cropping the output to the first k:v pair on each):\r\n\r\n- Trying the **-j** flag: (Problem: *Tailing* comma)\r\n &lt;pre&gt;jq -jr &#39;.site[].equip | . + &quot;,&quot;&#39; \r\n&lt;br&gt;Unique Item One,Unique Item Two,Unique Item Three,\r\n\r\n&lt;/pre&gt;\r\n\r\n- Using ***Reduce*** (Problem: *Leading* comma)\r\n &lt;pre&gt;jq -j &#39;.site[].equip | reduce . as $item (&quot;&quot;; &quot;&quot; + &quot;,&quot; + ($item))&#39;\r\n&lt;br&gt;,Unique Item One,Unique Item Two,Unique Item Three\r\n&lt;/pre&gt;\r\n\r\n\r\n- Using ***join()***: (Problem: Not used properly so no `comma` at all)\r\n &lt;pre&gt;jq &#39;.site | map(.equip) | join(&quot;,&quot;)&#39;\r\n&lt;br&gt;&quot;Unique Item One&quot;\r\n&quot;Unique Item Two&quot;\r\n&quot;Unique Item Three&quot;\r\n\r\n&lt;/pre&gt;\r\n\r\n\r\n- Using ***@csv***: (Problem: *trailing* `comma`, and not even from @csv)\r\n &lt;pre&gt;jq -rj &#39;.site[].equip + &quot;,&quot; | [.] | @csv&#39;\r\n&lt;br&gt;&quot;Unique Item One,&quot;&quot;Unique Item Two,&quot;&quot;Unique Item Three,&quot;\r\n\r\n&lt;/pre&gt;\r\n\r\nOther things I&#39;ve tried result in a leading comma, or concatenating and stringifying every single object recursively, but I have come to the conclusion that I&#39;m fundamentally looking at this wrong.\r\n\r\n\r\n- If I bring in **external** input for testing, (In this case passing ***--arg***) I can get close enough to the desired result to progress further, using *assignment operators*, but it still produces a line for each result, and is getting very inflexible:\r\n\r\n- &lt;pre&gt;\r\njq -c --arg new2 &quot;Unique Item Two&quot; --arg new3 &quot;Unique Item Three&quot; -r &#39;.site[] |= .equip + &quot;,&quot; + $new2 + &quot;,&quot; + $new3 | add | .[] | tojson&#39;\r\n&lt;br&gt;&quot;Unique Item One,Unique Item Two,Unique Item Three&quot;\r\n&lt;/pre&gt;\r\n\r\nNow I&#39;m not sure if I&#39;m missing something simple or if this requires some complex counting and iteration.\r\n\r\n**Note:** I know how easy it would be to cut the output up externally - there are certain reasons that I want to do this entirely in **jq**, as it&#39;s really the structure I am trying to get right.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://stedolan.github.io/jq/manual/#Assignment",
        "link": "https://stackoverflow.com/questions/40398344/how-to-combine-concatenate-json-objects-which-contain-a-common-key-name-but-un",
        "title": "How to combine (concatenate) JSON objects which contain a common key name but unique values in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "split",
            "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": 1478276782,
                "post_id": 40423864,
                "comment_id": 68103466,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1478301355,
                "creation_date": 1478301355,
                "answer_id": 40432988,
                "question_id": 40423864,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "i&#39;m not entirely sure what you&#39;re asking, but maybe this helps:\r\n\r\n    echo &#39;[ &quot;myprofile&quot;, &quot;myprofile1&quot;, &quot;myprofile2&quot;, &quot;myprofile3&quot; ]&#39; |\r\n      grep -o &#39;&quot;[^&quot;]\\+&quot;&#39; | tr -d &#39;&quot;&#39; | while read x; do\r\n        echo $x\r\n        # do your thing\r\n      done\r\n\r\noutput:\r\n\r\n    myprofile\r\n    myprofile1\r\n    myprofile2\r\n    myprofile3",
                "title": "Bash Script - Parse JSON results and set separate variables to be used later in script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1478301355,
        "creation_date": 1478265987,
        "question_id": 40423864,
        "body_markdown": "I am trying to take the JSON result from a curl and set each result for a particular JSON object to separate variables.\r\n\r\nUsing the following line in my script to retrieve results:\r\nPROFILE=$(curl --user admin:admin -k -X GET https://192.168.1.1:8000/rest/call/profiles.json | jq &#39;[.profiles[].id]&#39;)\r\n\r\nwith the above line my results might look something like this (but i could have 1 to many lines returned):\r\n\r\n[\r\n  &quot;myprofile&quot;,\r\n  &quot;myprofile1&quot;,\r\n  &quot;myprofile2&quot;,\r\n  &quot;myprofile3&quot;\r\n]\r\n\r\n\r\nNext, trying to determine the best route to set each id that is returned to a unique variable to be used later on in the script. .id could return 1 to 30 results so i&#39;m assuming a do while loop and using the split command is in need here?\r\n\r\nAny help is much appreciated, thank you in advance!",
        "link": "https://stackoverflow.com/questions/40423864/bash-script-parse-json-results-and-set-separate-variables-to-be-used-later-in",
        "title": "Bash Script - Parse JSON results and set separate variables to be used later in script"
    },
    {
        "tags": [
            "json",
            "xml",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1478328600,
                "creation_date": 1478328600,
                "answer_id": 40435592,
                "question_id": 40434217,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**Strings and quotes**\r\n\r\nThe XML string you pass to `--data-urlencode` is interpreted without double quotes:\r\n\r\n    &lt;?xml version=1.0 encoding=UTF-8 standalone=yes?&gt;\r\n    &lt;time&gt;\r\n        &lt;gametime&gt;\r\n        2016-11-23T05:30:00+02:00\r\n            &lt;start&gt;${timeStart}&lt;/start&gt;\r\n            &lt;duration unit=MINUTES&gt;${durationMinutes}&lt;/duration&gt;\r\n        &lt;/gametime&gt;\r\n    &lt;/time&gt;\r\n\r\nDouble quotes are the shell syntax elements that influence parsing. They are removed before the command is called. Prepend a backslash to a double quote, if you want its literal value in the string, e.g. `&quot;version=\\&quot;1.0\\&quot;&quot;`.\r\n\r\nHowever, [here documents](http://www.tldp.org/LDP/abs/html/here-docs.html) are more convenient in most cases:\r\n\r\n    xml=$(cat &lt;&lt;XML\r\n    &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;\r\n    &lt;time&gt;\r\n      &lt;gametime&gt;\r\n        2016-11-23T05:30:00+02:00\r\n        &lt;start&gt;${timeStart}&lt;/start&gt;\r\n        &lt;duration unit=&quot;MINUTES&quot;&gt;${durationMinutes}&lt;/duration&gt;\r\n      &lt;/gametime&gt;\r\n    &lt;/time&gt;\r\n    XML\r\n    )\r\n\r\n**`jq` output**\r\n\r\nUse `--raw-output` option to skip the JSON formatting. (In particular, string values are wrapped with double quotes by default.).\r\n\r\nTurn off color output with `--monochrome-output` option. With this option, `jq` will not print the [ASCII escape codes](https://en.wikipedia.org/wiki/ANSI_escape_code#Colors).\r\n\r\nAlthough not necessary, I recommend turning off the output buffering with `--unbuffered` option. With this option, `jq` will flush the output buffer after each JSON object is printed.\r\n\r\n**Reading `jq` output line-by-line**\r\n\r\nYou don&#39;t need to store the output of `jq` command into a variable. It is possible to process the lines on-the-fly using a [`pipe`](http://www.tldp.org/HOWTO/Bash-Prog-Intro-HOWTO-4.html):\r\n\r\n    curl --user admin:admin -k -X GET https://xxx.xx.xx.xxx:8080/profiles.json | \\\r\n      jq --monochrome-output --unbuffered --raw-output \\\r\n        &#39;.Profiles[].id&#39; | while read profile\r\n      do\r\n        echo &quot;Processing profile $profile&quot;\r\n        url=&quot;https://xxx.xx.xx.xxx:8080/testprofiles/${profile}/time/${downtimename}&quot;\r\n        curl -X POST &quot;$url&quot; \\\r\n          --data-urlencode &quot;xml=$xml&quot; \\\r\n          -H &#39;Accept: application/xml&#39; \\\r\n          -H &#39;Content-Type: application/xml&#39; \\\r\n          -u admin:admin\r\n      done\r\n",
                "title": "Bash Script Project - Parse JSON and construct cURL POST of XML within loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1478328600,
        "creation_date": 1478313532,
        "question_id": 40434217,
        "body_markdown": "Looking for some advice on the direction I should take my project as I&#39;m very new to scripting. My objectives are as follows:\r\n\r\nUsing cURL to get JSON data, parse a particular object value. I was intending to use jq to parse the JSON and then store the results as a variable. \r\n\r\nHere is what I have to started with:\r\nSAMPLE JSON - \r\n\r\n\t{\r\n\t&#160;&#160;&#160;&#160;&quot;href&quot;:&#160;&quot;http://localhost:8080//profiles&quot;,\r\n\t&#160;&#160;&#160;&#160;&quot;Profiles&quot;: [\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;{\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;href&quot;:&#160;&quot;http://localhost:8080/profiles/myprofile&quot;,\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;id&quot;:&#160;&quot;myprofile&quot;,\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;isRecording&quot;:&#160;false\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;},\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;{\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;href&quot;:&#160;&quot;http://localhost:8080/profiles/yourprofile&quot;,\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;id&quot;:&#160;&quot;yourprofile&quot;,\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;isRecording&quot;:&#160;false\r\n\t&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;}\r\n\t&#160;&#160;&#160;&#160;]\r\n\t}\r\n\r\nBASH SCRIPT - \r\n\r\n\t#!/bin/bash\r\n\r\n\tread -p &quot;Please enter downtime name (and press Enter): &quot; downtimename\r\n\tread -p &quot;Please enter timestart:&quot; timeStart\r\n\tread -p &quot;Please enter time duration (in minutes): &quot; durationMinutes\r\n\t\r\n\t#!/bin/bash\r\n\tPROFILE=&quot;$(curl --user admin:admin -k -X GET https://xxx.xx.xx.xxx:8080/profiles.json | jq &#39;.Profiles[].id&#39;)&quot;  \r\n\techo &quot;$PROFILE&quot;\r\n\r\n RETURNS - \r\n\t&quot;myprofile&quot;\r\n\t&quot;yourprofile&quot;\r\n\r\nNext I need to construct 1 or more cURL POST of xml data (example below) Each post will be a single curl post of the xml, for each line in the above echo &quot;$PROFILE&quot;. I’m thinking this will be a for loop? What I&#39;m struggling with is how to read each value/line from &quot;$PROFILE&quot; and utilize a for loop to post xml while replacing ${profile] in the below curl URL, for each result above.\r\n\r\n\tcurl -X POST https://xxx.xx.xx.xxx:8080/testprofiles/${profile}/time/${downtimename} --data-urlencode xml=&quot;&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;yes&quot;?&gt;\r\n\t&lt;time&gt;\r\n\t    &lt;gametime&gt;\r\n\t    2016-11-23T05:30:00+02:00\r\n\t        &lt;start&gt;${timeStart}&lt;/start&gt;\r\n\t        &lt;duration unit=&quot;MINUTES&quot;&gt;${durationMinutes}&lt;/duration&gt;\r\n\t    &lt;/gametime&gt;\r\n\t&lt;/time&gt;&quot; -H &#39;Accept: application/xml&#39; \\ -H &#39;Content-Type: application/xml&#39; -u admin:admin\r\n\r\n\r\n\r\nThank you in advance for the help \r\n",
        "link": "https://stackoverflow.com/questions/40434217/bash-script-project-parse-json-and-construct-curl-post-of-xml-within-loop",
        "title": "Bash Script Project - Parse JSON and construct cURL POST of XML within loop"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1810057,
                    "reputation": 21707,
                    "user_id": 1646322,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/d9fd7a75e0d8ace7bb3276476786c2c0?s=256&d=identicon&r=PG",
                    "display_name": "Ruslan Osmanov",
                    "link": "https://stackoverflow.com/users/1646322/ruslan-osmanov"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1478450527,
                "post_id": 40451774,
                "comment_id": 68148960,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7632594,
                    "reputation": 111,
                    "user_id": 5787158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/16de039f0a998fd123a52a9a1bd81502?s=256&d=identicon&r=PG",
                    "display_name": "Jared",
                    "link": "https://stackoverflow.com/users/5787158/jared"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478450775,
                "post_id": 40451774,
                "comment_id": 68149045,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478451156,
                "post_id": 40451774,
                "comment_id": 68149201,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7632594,
                    "reputation": 111,
                    "user_id": 5787158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/16de039f0a998fd123a52a9a1bd81502?s=256&d=identicon&r=PG",
                    "display_name": "Jared",
                    "link": "https://stackoverflow.com/users/5787158/jared"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478451442,
                "post_id": 40451774,
                "comment_id": 68149304,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1478451498,
                "post_id": 40451774,
                "comment_id": 68149325,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7632594,
                    "reputation": 111,
                    "user_id": 5787158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/16de039f0a998fd123a52a9a1bd81502?s=256&d=identicon&r=PG",
                    "display_name": "Jared",
                    "link": "https://stackoverflow.com/users/5787158/jared"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478451592,
                "post_id": 40451774,
                "comment_id": 68149359,
                "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": 3,
                "creation_date": 1478451648,
                "post_id": 40451774,
                "comment_id": 68149378,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1478451657,
                "post_id": 40451774,
                "comment_id": 68149380,
                "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": 1478451688,
                "post_id": 40451774,
                "comment_id": 68149388,
                "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": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478451847,
                "post_id": 40451774,
                "comment_id": 68149443,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "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": 1478451900,
                "post_id": 40451774,
                "comment_id": 68149458,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7632594,
                    "reputation": 111,
                    "user_id": 5787158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/16de039f0a998fd123a52a9a1bd81502?s=256&d=identicon&r=PG",
                    "display_name": "Jared",
                    "link": "https://stackoverflow.com/users/5787158/jared"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478452040,
                "post_id": 40451774,
                "comment_id": 68149509,
                "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": 1478452074,
                "post_id": 40451774,
                "comment_id": 68149524,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7632594,
                    "reputation": 111,
                    "user_id": 5787158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/16de039f0a998fd123a52a9a1bd81502?s=256&d=identicon&r=PG",
                    "display_name": "Jared",
                    "link": "https://stackoverflow.com/users/5787158/jared"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1478452520,
                "post_id": 40451774,
                "comment_id": 68149678,
                "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": 1,
                "creation_date": 1478452601,
                "post_id": 40451774,
                "comment_id": 68149702,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1478452754,
                "last_edit_date": 1478452754,
                "creation_date": 1478451824,
                "answer_id": 40452036,
                "question_id": 40451774,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The below assume your JSON text is in a string named `s`. That is:\r\n\r\n    s=&#39;{\r\n      &quot;data&quot;: [\r\n      {\r\n        &quot;item1&quot;: {\r\n           &quot;name&quot;: &quot;string 1&quot;\r\n        },\r\n        &quot;item2&quot;: {\r\n           &quot;name&quot;: &quot;string 2&quot;\r\n        },\r\n        &quot;item3&quot;: {\r\n           &quot;name&quot;: &quot;string 3&quot;\r\n        }\r\n      }\r\n      ]\r\n    }&#39;\r\n\r\nUnfortunately, both of the below will misbehave with strings containing literal newlines; since `jq` doesn&#39;t have support for NUL-delimited output, this is difficult to work around.\r\n\r\nOn bash 4 (with slightly sloppy error handling, but tersely):\r\n\r\n    readarray -t name_array &lt; &lt;(jq -r &#39;.data[] | .[] | .name&#39; &lt;&lt;&lt;&quot;$s&quot;)\r\n\r\n...or on bash 3.x or newer (with very comprehensive error handling, but verbosely):\r\n\r\n    # -d &#39;&#39; tells read to process up to a NUL, and will exit with a nonzero exit status if that\r\n    # NUL is not seen; thus, this causes the read to pass through any error which occurred in\r\n    # jq.\r\n    IFS=$&#39;\\n&#39; read -r -d &#39;&#39; -a name_array \\\r\n      &lt; &lt;(jq -r &#39;.data[] | .[] | .name&#39; &lt;&lt;&lt;&quot;$s&quot; &amp;&amp; printf &#39;\\0&#39;)\r\n\r\n---\r\n\r\nThis populates a bash array, contents of which can be displayed with:\r\n\r\n    declare -p name_array",
                "title": "What is the best way to pipe JSON with whitespaces into a bash array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1478453113,
                "last_edit_date": 1478453113,
                "creation_date": 1478452185,
                "answer_id": 40452100,
                "question_id": 40451774,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Arrays are assigned in the form:\r\n\r\n    NAME=(VALUE1 VALUE2 ... )\r\n\r\nwhere `NAME` is the name of the variable, `VALUE1`, `VALUE2`, and the rest are fields separated with characters that are present in the `$IFS` (input field separator) variable.\r\n\r\nSince `jq` outputs the string values as lines (sequences separated with the new line character), then you can temporarily override `$IFS`, e.g.:\r\n\r\n    # Disable globbing, remember current -f flag value\r\n    [[ &quot;$-&quot; == *f* ]] || globbing_disabled=1\r\n    set -f\r\n\r\n    IFS=$&#39;\\n&#39; a=( $(jq --raw-output &#39;.data[].item.name&#39; file.json) )\r\n\r\n    # Restore globbing\r\n    test -n &quot;$globbing_disabled&quot; &amp;&amp; set +f\r\n\r\nThe above will create an array of three items for the following `file.json`:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n\r\n        {&quot;item&quot;: {\r\n           &quot;name&quot;: &quot;string 1&quot;\r\n        }},\r\n        {&quot;item&quot;: {\r\n           &quot;name&quot;: &quot;string 2&quot;\r\n        }},\r\n        {&quot;item&quot;: {\r\n           &quot;name&quot;: &quot;string 3&quot;\r\n        }}\r\n      ]\r\n    }\r\n",
                "title": "What is the best way to pipe JSON with whitespaces into a bash array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1479372101,
                "last_edit_date": 1479372101,
                "creation_date": 1479282487,
                "answer_id": 40626605,
                "question_id": 40451774,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following shows how to create a bash array consisting of arbitrary JSON texts produced by a run of jq.\r\n\r\nIn the following, I&#39;ll assume input.json is a file with the following:\r\n\r\n    [&quot;string 1&quot;, &quot;new\\nline&quot;, {&quot;x&quot;: 1}, [&quot;one\\ttab&quot;, 4]]\r\n\r\nWith this input, the jq filter `.[]` produces four JSON texts -- two JSON strings, a JSON object, and a JSON array.\r\n\r\nThe following bash script can then be used to set x to be a bash array of the JSON texts:\r\n\r\n    #!/bin/bash\r\n    x=()\r\n    while read -r value\r\n    do\r\n      x+=(&quot;$value&quot;)\r\n    done &lt; &lt;(jq -c &#39;.[]&#39; input.json)\r\n\r\nFor example, adding this bash expression to the script:\r\n\r\n    for a in &quot;${x[@]}&quot; ; do echo a=&quot;$a&quot;; done\r\n\r\nwould yield:\r\n\r\n    a=&quot;string 1&quot;\r\n    a=&quot;new\\nline&quot;\r\n    a={&quot;x&quot;:1}\r\n    a=[&quot;one\\ttab&quot;,4]\r\n\r\nNotice how (encoded) newlines and (encoded) tabs are handled properly.\r\n\r\n\r\n",
                "title": "What is the best way to pipe JSON with whitespaces into a bash array?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1479372101,
        "creation_date": 1478450270,
        "last_edit_date": 1478452335,
        "question_id": 40451774,
        "body_markdown": "I have JSON like this that I&#39;m parsing with jq:\r\n&lt;br/&gt;\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n      {\r\n        &quot;item&quot;: {\r\n           &quot;name&quot;: &quot;string 1&quot;\r\n        },\r\n        &quot;item&quot;: {\r\n           &quot;name&quot;: &quot;string 2&quot;\r\n        },\r\n        &quot;item&quot;: {\r\n           &quot;name&quot;: &quot;string 3&quot;\r\n        }\r\n      }\r\n      ]\r\n    }\r\n\r\n...and I&#39;m trying to get &quot;string 1&quot; &quot;string 2&quot; and &quot;string 3&quot; into a Bash array, but I can&#39;t find a solution that ignores the whitespace in them. Is there a method in jq that I&#39;m missing, or perhaps an elegant solution in Bash for it?\r\n\r\nCurrent method:  \r\n\r\n    json_names=$(cat file.json | jq &quot;.data[] .item .name&quot;)\r\n    read -a name_array &lt;&lt;&lt; $json_names",
        "link": "https://stackoverflow.com/questions/40451774/what-is-the-best-way-to-pipe-json-with-whitespaces-into-a-bash-array",
        "title": "What is the best way to pipe JSON with whitespaces into a bash array?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1478577394,
                "last_edit_date": 1478577394,
                "creation_date": 1478555219,
                "answer_id": 40475232,
                "question_id": 40455737,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to quote your filter so it isn&#39;t interpreted by the shell...\r\n\r\n    $ jq &#39;.&quot;bus_v320161103-12-00-44&quot;&#39; test\r\n\r\nWithout it, it&#39;s effectively being passed in like this:\r\n\r\n    .bus_v320161103-12-00-44\r\n\r\nWhich is accessing a field called `bus_v320161103` and subtracting that by `12`, then `00` then `44`.",
                "title": "What is this mysterious jq failures?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1478577394,
        "creation_date": 1478474813,
        "last_edit_date": 1478555254,
        "question_id": 40455737,
        "body_markdown": "I have seen this issue. I guess it’s related to special char. I’ve read the jq manual and quote the field but still fail, I tried both with/without the bracket\r\n\r\n    abc@uswest1aprod 13:49:59 ~\r\n       $ cat test | jq .\r\n    {\r\n      &quot;bus_v320161103-12-00-44&quot;: {\r\n        &quot;aliases&quot;: {\r\n          &quot;bus_v3&quot;: {}\r\n       },\r\n        &quot;mappings&quot;: {\r\n          &quot;business&quot;: {\r\n            &quot;dynamic&quot;: &quot;strict&quot;,\r\n            &quot;_all&quot;: {\r\n              &quot;enabled&quot;: false\r\n            }\r\n          }\r\n        }\r\n      }\r\n    abc@uswest1aprod 13:52:33 ~\r\n       $ cat test | jq .&quot;bus_v320161103-12-00-44&quot;\r\n    jq: error: null and number cannot be subtracted\r\n    abc@uswest1aprod 13:53:09 ~\r\n       $ cat test | jq .[&quot;bus_v320161103-12-00-44&quot;]\r\n    error: bus_v320161103 is not defined\r\n    .[bus_v320161103-12-00-44]  1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40455737/what-is-this-mysterious-jq-failures",
        "title": "What is this mysterious jq failures?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1478720439,
                "creation_date": 1478720439,
                "answer_id": 40514719,
                "question_id": 40513044,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Remember that it&#39;s only dependent on the last result of the filter. So it might be easier to add the check as part of your filter at the end.  You just have to remember to ignore the last result.\r\n\r\n    $ jq -re --arg key &#39;key&#39; &#39;.[$key], has($key)&#39; &lt;&lt;&lt; &#39;{&quot;key&quot;:false}&#39;\r\n    false\r\n    true\r\n    $ echo $?\r\n    0",
                "title": "How can it be determined if a jq selector succeeds or fails, given null or false might be a valid result?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1600468336,
                "last_edit_date": 1600468336,
                "creation_date": 1479277331,
                "answer_id": 40625349,
                "question_id": 40513044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is not entirely clear to me what it is you are trying to\r\ndo, but I have the impression that you are going about it the wrong way.\r\nPart of the problem may be the result of terminological issues.\r\nTo avoid them, I will adopt terminology that is appropriate to JSON and jq.\r\n\r\nLet me point out firstly that in jq, expressions such as `{} | .a` are not regarded as erroneous. If you want an error condition to be raised when an attempt to access the value of a non-existent key is made,\r\nyou could write something like: \r\n\r\n    if has(&quot;a&quot;) then .a else error(&quot;no such key&quot;) end\r\n\r\nAnother way to distinguish between the case when an input object has a key and the case when it does not have the key\r\nis to write something like:\r\n\r\n    if has(&quot;a&quot;) then .a else empty end\r\n\r\nor more compactly:\r\n\r\n    select(has(&quot;a&quot;)) | .a\r\n\r\n\r\nYou can use this technique in conjunction with the -c option of jq as illustrated by the following bash assignments:\r\n\r\n    result=$(jq -c &#39;select(has(&quot;a&quot;)) | .a&#39; INPUT.json)\r\n    n=$(wc -l &lt;&lt;&lt; &quot;$result&quot;)\r\n\r\nYou can then check the value of $n.\r\n\r\n",
                "title": "How can it be determined if a jq selector succeeds or fails, given null or false might be a valid result?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503544531,
                "creation_date": 1503544531,
                "answer_id": 45852378,
                "question_id": 40513044,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think this filter will work:\r\n\r\n    map(select(.user==$Name and .value==true))[0] or error($Name)\r\n\r\nExample:\r\n\r\n    #!/bin/bash\r\n    for i in steve tom mary; do\r\n        echo &#39;[{&quot;user&quot;:&quot;steve&quot;, &quot;value&quot;:false},{&quot;user&quot;:&quot;tom&quot;, &quot;value&quot;:true}]&#39; \\\r\n        | jq -M -r --arg Name $i &#39;map(select(.user==$Name and .value==true))[0] or error($Name)&#39; \r\n        echo $i $?\r\n    done\r\n \r\nOutput:\r\n \r\n    jq: error (at &lt;stdin&gt;:1): steve\r\n    steve 5\r\n    true\r\n    tom 0\r\n    jq: error (at &lt;stdin&gt;:1): mary\r\n    mary 5\r\n    \r\nSo in the case of `steve` and `mary` jq returns non-zero exit status and in the case of `tom` it returns zero exit status.\r\n",
                "title": "How can it be determined if a jq selector succeeds or fails, given null or false might be a valid result?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1600468336,
        "creation_date": 1478713602,
        "question_id": 40513044,
        "body_markdown": "For a given selector to `jq`, I want to know if the selector succeeds or fails given its input.  For example, the following correctly indicates an error status:\r\n\r\n    % jq -re .bad &lt;&lt;&lt;&#39;{}&#39;\r\n    null\r\n    % echo $?\r\n    1\r\n    %\r\n\r\nHowever, the following incorrectly indicates an error status (as far as my needs go):\r\n\r\n    % jq -re .key &lt;&lt;&lt;&#39;{&quot;key&quot;:false}&#39;\r\n    false\r\n    % echo $?\r\n    1\r\n    %\r\n\r\nThe problem with the above is that the -e option will give a return status of 1 if the last output value was either `false` or `null`. However, if values of false and null are present in the JSON input, then this return status gives the wrong impression that some failure occurred.\r\n\r\nAm I compelled, in the case of a return code 1, to then check to see if the key is present?  For example:\r\n\r\n    #!/bin/bash\r\n\r\n    Result=$(jq -re .key &lt;&lt;&lt;&#39;{&quot;key&quot;:false}&#39;)\r\n    Status=$?\r\n    if [[ $Status -eq 1 ]] ; then\r\n       jq -re &#39;. | has(&quot;key&quot;)&#39; &lt;&lt;&lt;&#39;{&quot;key&quot;:false}&#39; &amp;&amp; (exit 0) || (exit 1)\r\n    else\r\n       (exit $Status)\r\n    fi\r\n\r\n    # At this point $? can be relied on to indicate success/failure\r\n\r\nThe above solution would change the return status of 1 to 0 and is acceptable for simple jq selectors, but this solution is not satisfactory for computational selectors that might generate a valid result of false or null.\r\n\r\nSo, is there any approach to know whether a jq selector really succeeds or fails (even for computational selectors), considering that results such as `false` and `null` may be either valid or invalid depending on the selector and input\r\n\r\nThe solution should be done in Bash 4.2 or later.",
        "link": "https://stackoverflow.com/questions/40513044/how-can-it-be-determined-if-a-jq-selector-succeeds-or-fails-given-null-or-false",
        "title": "How can it be determined if a jq selector succeeds or fails, given null or false might be a valid result?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1478720509,
                "post_id": 40514605,
                "comment_id": 68271149,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1478720678,
                "creation_date": 1478720678,
                "answer_id": 40514778,
                "question_id": 40514605,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to escape the `$` for `$foo` so that the shell doesn&#39;t try to expand it as a parameter before `jq` even runs.\r\n\r\n    jq -r &quot;.notifiestext | map(select(.read==false))&quot; temp_notif |\r\n      jq --arg foo &quot;$max&quot; &quot;map(select(.id&lt;\\$foo))&quot;\r\n\r\nIt would be better to use single quotes for the `jq` filter instead.\r\n\r\n    jq -r &#39;.notifiestext | map(select(.read==false))&#39; temp_notif |\r\n      jq --arg foo &quot;$max&quot; &#39;map(select(.id&lt;$foo))&#39;",
                "title": "JQ argument error in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1479568332,
        "creation_date": 1478719955,
        "last_edit_date": 1479568332,
        "question_id": 40514605,
        "body_markdown": "I have a problem with a JQ query:\r\n\r\n    max=$(script) &lt;-- (return integer)\r\n    jq  -r &quot;.notifiestext | map(select(.read==false))&quot; temp_notif |\r\n      jq --arg foo &quot;$max&quot; &quot;map(select(.id&lt;$foo))&quot;\r\n\r\nI get the following error:\r\n\r\n    jq: error: syntax error, unexpected &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1: map(select(.id&lt;))\r\n\r\nThe &quot;.id&quot; parameter is an integer\r\n\r\nAny solution?",
        "link": "https://stackoverflow.com/questions/40514605/jq-argument-error-in-bash-script",
        "title": "JQ argument error in bash script"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1478758877,
                "last_edit_date": 1478758877,
                "creation_date": 1478734470,
                "answer_id": 40517777,
                "question_id": 40517324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The types don&#39;t match which is why it&#39;s not selecting.  The `id` fields are all numbers but you&#39;re comparing to a string.  `--arg` reads the parameter as a string.  You&#39;ll want to treat it as a number or the id as a string.  It&#39;ll just be easier to read the parameter as json using `--argjson`:\r\n\r\n    $ jq -r --argjson id 2000 &#39;map(select((.read | not) and .id == $id))&#39; file.json",
                "title": "Query in jq with args"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502080938,
                "creation_date": 1502080938,
                "answer_id": 45539550,
                "question_id": 40517324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a simple filter to select the object with .id 2000.\r\n\r\n      .[]\r\n    | if .id == 2000 then . else empty end\r\n",
                "title": "Query in jq with args"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1502080938,
        "creation_date": 1478731869,
        "question_id": 40517324,
        "body_markdown": "I have a problem with the JQ query results. The original json looks like this:\r\n\r\n    [\r\n      {\r\n        &quot;read&quot;: false,\r\n        &quot;mex&quot;: &quot;message 1&quot;,\r\n        &quot;id&quot;: 1000\r\n      },\r\n      {\r\n        &quot;read&quot;: false,\r\n        &quot;mex&quot;: &quot;message 2&quot;,\r\n        &quot;id&quot;: 2000\r\n      },\r\n      {\r\n        &quot;read&quot;: false,\r\n        &quot;mex&quot;: &quot;message 3&quot;,\r\n        &quot;id&quot;: 3000\r\n      }\r\n   ]\r\n\r\nI would like a query that would give me the results of the record that has the id 2000 (for example), these to be exact:\r\n\r\n    {\r\n       &quot;read&quot;: false,\r\n       &quot;mex&quot;: &quot;message 2&quot;,\r\n       &quot;id&quot;: 2000\r\n     }\r\n\r\nWith the following query outputs a blank record (&quot;[ ]&quot;)\r\n\r\n    jq &quot;map(select(.read==false))&quot; file.json| jq -r &#39;map(select(.id==$foo))&#39; --arg foo 2000",
        "link": "https://stackoverflow.com/questions/40517324/query-in-jq-with-args",
        "title": "Query in jq with args"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1479066587,
                "creation_date": 1479066587,
                "answer_id": 40578119,
                "question_id": 40577767,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;d rather preprocess your file extracting each record with a python script like this:\r\n\r\n    #!/usr/bin/env python\r\n\r\n    import json\r\n    \r\n    i = 0\r\n    for record in json.load(open(&#39;raw.json&#39;, &#39;r&#39;))[&#39;json_records&#39;]:\r\n        open(&#39;record_{}.json&#39;.format(i), &#39;w&#39;).write(json.dumps(record))\r\n        i += 1\r\n\r\nAnd then process each record_X.json separately with curl:\r\n\r\n    curl host -d recrod_X.json",
                "title": "Iteratively posting via cURL set of Json records in bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1479068205,
                "creation_date": 1479068205,
                "answer_id": 40578357,
                "question_id": 40577767,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would use `jq` to pipe each record as a single line, then read that output with a `while` loop to pass to `curl`.\r\n\r\n    jq -c &#39;.json_records[]&#39; | while IFS= read -r rec; do\r\n      curl -X POST -d&quot;$rec&quot; &quot;$URL&quot;\r\n    done",
                "title": "Iteratively posting via cURL set of Json records in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1479099112,
                "creation_date": 1479099112,
                "answer_id": 40582058,
                "question_id": 40577767,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this - \r\n\r\n    vipin@kali:~$ egrep &#39;name|mark&#39; kk -A 1 -B 1 ###A for Above and B for Below\r\n                 {\r\n                   &quot;name&quot;: &quot;name_1&quot;,\r\n                    &quot;mark&quot;: &quot;mark_1&quot;\r\n                 },\r\n                  {\r\n                   &quot;name&quot;: &quot;name_2&quot;,\r\n                    &quot;mark&quot;: &quot;mark_2&quot;\r\n                 },\r\n\r\n",
                "title": "Iteratively posting via cURL set of Json records in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1479208657,
        "creation_date": 1479064327,
        "last_edit_date": 1479208657,
        "question_id": 40577767,
        "body_markdown": "I have set of Json records in file. I would like to post iteratively.\r\nFor example file &quot;jsondata.dat&quot; contains following json records \r\n\r\n    { \r\n          &quot;json_records&quot;:[\r\n                 {\r\n                   &quot;name&quot;: &quot;name_1&quot;,\r\n                    &quot;mark&quot;: &quot;mark_1&quot;\r\n                 },\r\n                  {\r\n                   &quot;name&quot;: &quot;name_2&quot;,\r\n                    &quot;mark&quot;: &quot;mark_2&quot;\r\n                 }\r\n            ]\r\n    }\r\n\r\nI would like to post each json record i.e. \r\n\r\n    {\r\n       &quot;name&quot;: &quot;name_X&quot;,\r\n       &quot;mark&quot;: &quot;mark_X&quot;\r\n    }\r\n\r\nin separate cURL post. How to achieve this in bash? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/40577767/iteratively-posting-via-curl-set-of-json-records-in-bash",
        "title": "Iteratively posting via cURL set of Json records in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1479135920,
                "creation_date": 1479135920,
                "answer_id": 40591836,
                "question_id": 40590263,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This would work:\r\n\r\n    jq -r &#39;.result | if length &gt; 0 then .[0].value else &quot;&quot; end&#39;",
                "title": "Display empty line for non existing fields with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1516349035,
                "last_edit_date": 1516349035,
                "creation_date": 1479136452,
                "answer_id": 40592018,
                "question_id": 40590263,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this:\r\n\r\n    jq -r &#39;.result[].value // &quot;&quot; &#39; a.json\r\n\r\nThis uses the *or* operator `//`. If `.result[].value` is present, the value will get printed, otherwise an empty line gets printed.",
                "title": "Display empty line for non existing fields with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1479240429,
                "creation_date": 1479240429,
                "answer_id": 40618744,
                "question_id": 40590263,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since `false // X` and `null // X` produce X, `.result[].value // &quot;&quot;` may not be what you want in all cases.\r\n\r\nTo achieve the stated goal as I understand it, you could use the following filter:\r\n\r\n    .result[] | if has(&quot;value&quot;) then .value else &quot;&quot; end\r\n\r\n \r\n\r\n\r\n",
                "title": "Display empty line for non existing fields with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1516349035,
        "creation_date": 1479131408,
        "question_id": 40590263,
        "body_markdown": "I have the following json data:\r\n\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[{&quot;hostmacroid&quot;:&quot;2392&quot;,&quot;hostid&quot;:&quot;10953&quot;,&quot;macro&quot;:&quot;{$GATEWAY}&quot;,&quot;value&quot;:&quot;10.25.230.1&quot;}],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[{&quot;hostmacroid&quot;:&quot;1893&quot;,&quot;hostid&quot;:&quot;12093&quot;,&quot;macro&quot;:&quot;{$GATEWAY}&quot;,&quot;value&quot;:&quot;10.38.118.1&quot;}],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[{&quot;hostmacroid&quot;:&quot;2400&quot;,&quot;hostid&quot;:&quot;14471&quot;,&quot;macro&quot;:&quot;{$GATEWAY}&quot;,&quot;value&quot;:&quot;10.25.230.1&quot;}],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[{&quot;hostmacroid&quot;:&quot;799&quot;,&quot;hostid&quot;:&quot;10798&quot;,&quot;macro&quot;:&quot;{$GATEWAY}&quot;,&quot;value&quot;:&quot;10.36.136.1&quot;}],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[{&quot;hostmacroid&quot;:&quot;1433&quot;,&quot;hostid&quot;:&quot;10857&quot;,&quot;macro&quot;:&quot;{$GATEWAY}&quot;,&quot;value&quot;:&quot;10.38.24.129&quot;}],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[{&quot;hostmacroid&quot;:&quot;842&quot;,&quot;hostid&quot;:&quot;13159&quot;,&quot;macro&quot;:&quot;{$GATEWAY}&quot;,&quot;value&quot;:&quot;10.38.113.1&quot;}],&quot;id&quot;:1}\r\n    {&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;result&quot;:[],&quot;id&quot;:1}\r\n\r\nI am trying to extract the value of the &quot;value&quot; field from each line. `jq -r &#39;.result[].value&#39; &lt;jsonfile&gt;` works perfectly but it does not take into account the JSON lines where there is no &quot;value&quot; field. I would like it to print an empty line for them. Is this possible with jq?\r\n\r\n    ",
        "link": "https://stackoverflow.com/questions/40590263/display-empty-line-for-non-existing-fields-with-jq",
        "title": "Display empty line for non existing fields with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1479233286,
                "last_edit_date": 1479233286,
                "creation_date": 1479232967,
                "answer_id": 40616684,
                "question_id": 40614513,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s no &quot;right&quot; way to do it, but there are approaches to take that can make things easier for you.\r\n\r\nThe tags are already in a format that makes converting to objects simple (they&#39;re object entries).  Convert the tags to an object for easy access to the properties.\r\n\r\n    $ jq &#39;.Instances[]\r\n        | .Tags |= from_entries\r\n        | {\r\n            ip:   .PrivateIpAddress,\r\n            name: .Tags.Name,\r\n            type: .Tags.Type\r\n          }&#39; file",
                "title": "Selecting multiple conditionals in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1479233286,
        "creation_date": 1479226072,
        "last_edit_date": 1479233210,
        "question_id": 40614513,
        "body_markdown": "I&#39;ve just started using jq json parser, is there anyway to choose multiple `select`?\r\nI have this:\r\n\r\n    cat file | jq -r &#39;.Instances[] | {ip: .PrivateIpAddress, name: .Tags[]}\r\n                                   | select(.name.Key == &quot;Name&quot;)&#39;\r\n\r\nAnd I need to also include the `.name.Key == &quot;Type&quot;`\r\n\r\nThis is the JSON: \r\n\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;PrivateIpAddress&quot;: &quot;1.1.1.1&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;Daily&quot;,\r\n              &quot;Key&quot;: &quot;Backup&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;System&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;YES&quot;,\r\n              &quot;Key&quot;: &quot;Is_in_Domain&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;PROD&quot;,\r\n              &quot;Key&quot;: &quot;Type&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd this is the current output:\r\n\r\n    {\r\n      &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n      &quot;name&quot;: &quot;System&quot;\r\n    }\r\n    {\r\n      &quot;ip&quot;: &quot;2.2.2.2&quot;,\r\n      &quot;name&quot;: &quot;host&quot;\r\n    }\r\n    {\r\n      &quot;ip&quot;: &quot;3.3.3.3&quot;,\r\n      &quot;name&quot;: &quot;slog&quot;\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n      &quot;name&quot;: &quot;System&quot;,\r\n      &quot;type&quot;: &quot;PROD&quot;\r\n    }\r\n    {\r\n      &quot;ip&quot;: &quot;2.2.2.2&quot;,\r\n      &quot;name&quot;: &quot;host&quot;,\r\n      &quot;type&quot;: &quot;PROD&quot;\r\n    }\r\n    {\r\n      &quot;ip&quot;: &quot;3.3.3.3&quot;,\r\n      &quot;name&quot;: &quot;slog&quot;,\r\n      &quot;type&quot;: &quot;PROD&quot;\r\n    }\r\n\r\n\r\nWhat is the right way to do it? Thanks.\r\n",
        "link": "https://stackoverflow.com/questions/40614513/selecting-multiple-conditionals-in-jq",
        "title": "Selecting multiple conditionals in JQ"
    },
    {
        "tags": [
            "json",
            "parsing",
            "google-bigquery",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 75116,
                    "reputation": 12145,
                    "user_id": 215552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/26bda02894d869c95f620de4b7cd386d?s=256&d=identicon&r=PG",
                    "display_name": "Heretic Monkey",
                    "link": "https://stackoverflow.com/users/215552/heretic-monkey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479405456,
                "post_id": 40661704,
                "comment_id": 68554791,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 75116,
                    "reputation": 12145,
                    "user_id": 215552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/26bda02894d869c95f620de4b7cd386d?s=256&d=identicon&r=PG",
                    "display_name": "Heretic Monkey",
                    "link": "https://stackoverflow.com/users/215552/heretic-monkey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479405747,
                "post_id": 40661704,
                "comment_id": 68554963,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 75116,
                    "reputation": 12145,
                    "user_id": 215552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/26bda02894d869c95f620de4b7cd386d?s=256&d=identicon&r=PG",
                    "display_name": "Heretic Monkey",
                    "link": "https://stackoverflow.com/users/215552/heretic-monkey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479405830,
                "post_id": 40661704,
                "comment_id": 68555003,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 75116,
                    "reputation": 12145,
                    "user_id": 215552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/26bda02894d869c95f620de4b7cd386d?s=256&d=identicon&r=PG",
                    "display_name": "Heretic Monkey",
                    "link": "https://stackoverflow.com/users/215552/heretic-monkey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479406137,
                "post_id": 40661704,
                "comment_id": 68555180,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1476415,
                    "reputation": 9664,
                    "user_id": 1386703,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/o6Jbm.png?s=256",
                    "display_name": "skobaljic",
                    "link": "https://stackoverflow.com/users/1386703/skobaljic"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479406239,
                "post_id": 40661704,
                "comment_id": 68555238,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479406411,
                "post_id": 40661704,
                "comment_id": 68555327,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 75116,
                    "reputation": 12145,
                    "user_id": 215552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/26bda02894d869c95f620de4b7cd386d?s=256&d=identicon&r=PG",
                    "display_name": "Heretic Monkey",
                    "link": "https://stackoverflow.com/users/215552/heretic-monkey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479406933,
                "post_id": 40661704,
                "comment_id": 68555627,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479407254,
                "post_id": 40661704,
                "comment_id": 68555797,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1479428707,
                "last_edit_date": 1479428707,
                "creation_date": 1479421905,
                "answer_id": 40666248,
                "question_id": 40661704,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Like others who have posted comments, I won&#39;t pretend to understand the details of the specific question, but if the general question is how to use jq to emit newline-delimited JSON (that is, ensure that each JSON text is followed by a newline, and that no other (raw) newlines are added), the answer is simple: use jq with the `-c` option, and without the `-r` option.",
                "title": "Parsing Filter Needed For Newline Delimited JSON format"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503041609,
                "creation_date": 1503041609,
                "answer_id": 45751002,
                "question_id": 40661704,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From a cursory examination of your data, the filter\r\n\r\n    .users[]\r\n\r\nwill give you just the user data to load and the filter\r\n\r\n    .scroll_param\r\n\r\nwill return just the scroll parameter.  If you put your data in a file you could invoke jq once for each filter but if you have to stream the data you could simply use the `,` operator to return one value after another.  e.g.\r\n\r\n      .scroll_param\r\n    , .users[]\r\n\r\nIf you use that filter along with the `-c` option jq will generate output like\r\n\r\n    &quot;24ba0fac-b8f9-46b2-944a-9bb523dcd1b1&quot;\r\n    {&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;581c13632f25960e6e3dc89a&quot;,&quot;user_id&quot;:&quot;ieo2e6dtsqhiyhtr&quot;,...\r\n    {&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;581c22a19a1dc02c460541df&quot;,&quot;user_id&quot;:&quot;1o3helrdv58cxm7jf&quot;,...\r\n\r\npresumably the script that reads the output from jq could capture the first line for use in the `curl` invocation and put the rest of the data into the file you load.   \r\n\r\nHope this helps.",
                "title": "Parsing Filter Needed For Newline Delimited JSON format"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1597209436,
        "creation_date": 1479404807,
        "last_edit_date": 1597209436,
        "question_id": 40661704,
        "body_markdown": "I&#39;m running into a problem as I attempt to automate an API process into BigQuery.\r\n\r\nThe issue is that I need the data to be in a newline delimited JSON format to go into my BigQuery database but the data I&#39;m pulling does not do that, so I need to parse it out.\r\n\r\n[Here is a link to pastebin so you can get an idea of what the data looks like][1], but also, here it is just because:\r\n\r\n    {&quot;type&quot;:&quot;user.list&quot;,&quot;users&quot;:[{&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;581c13632f25960e6e3dc89a&quot;,&quot;user_id&quot;:&quot;ieo2e6dtsqhiyhtr&quot;,&quot;anonymous&quot;:false,&quot;email&quot;:&quot;test@gmail.com&quot;,&quot;name&quot;:&quot;Joe Martinez&quot;,&quot;pseudonym&quot;:null,&quot;avatar&quot;:{&quot;type&quot;:&quot;avatar&quot;,&quot;image_url&quot;:null},&quot;app_id&quot;:&quot;b5vkxvop&quot;,&quot;companies&quot;:{&quot;type&quot;:&quot;company.list&quot;,&quot;companies&quot;:[]},&quot;location_data&quot;:{&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;Houston&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:29.7633,&quot;longitude&quot;:-95.3633,&quot;postal_code&quot;:&quot;77002&quot;,&quot;region_name&quot;:&quot;Texas&quot;,&quot;timezone&quot;:&quot;America/Chicago&quot;,&quot;country_code&quot;:&quot;USA&quot;},&quot;last_request_at&quot;:1478235114,&quot;last_seen_ip&quot;:&quot;66.87.120.30&quot;,&quot;created_at&quot;:1478234979,&quot;remote_created_at&quot;:1478234944,&quot;signed_up_at&quot;:1478234944,&quot;updated_at&quot;:1478235145,&quot;session_count&quot;:1,&quot;social_profiles&quot;:{&quot;type&quot;:&quot;social_profile.list&quot;,&quot;social_profiles&quot;:[]},&quot;unsubscribed_from_emails&quot;:false,&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Linux; Android 6.0.1; SM-G920P Build/MMB29K) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.68 Mobile Safari/537.36&quot;,&quot;tags&quot;:{&quot;type&quot;:&quot;tag.list&quot;,&quot;tags&quot;:[]},&quot;segments&quot;:{&quot;type&quot;:&quot;segment.list&quot;,&quot;segments&quot;:[{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea275bfcebabd516d963&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea265bfcebabd516d962&quot;}]},&quot;custom_attributes&quot;:{&quot;claimCount&quot;:&quot;1&quot;,&quot;memberType&quot;:&quot;claimant&quot;}},{&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;581c22a19a1dc02c460541df&quot;,&quot;user_id&quot;:&quot;1o3helrdv58cxm7jf&quot;,&quot;anonymous&quot;:false,&quot;email&quot;:&quot;test@mail.com&quot;,&quot;name&quot;:&quot;Joe Coleman&quot;,&quot;pseudonym&quot;:null,&quot;avatar&quot;:{&quot;type&quot;:&quot;avatar&quot;,&quot;image_url&quot;:null},&quot;app_id&quot;:&quot;b5vkxvop&quot;,&quot;companies&quot;:{&quot;type&quot;:&quot;company.list&quot;,&quot;companies&quot;:[]},&quot;location_data&quot;:{&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;San Jose&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:37.3394,&quot;longitude&quot;:-121.895,&quot;postal_code&quot;:&quot;95141&quot;,&quot;region_name&quot;:&quot;California&quot;,&quot;timezone&quot;:&quot;America/Los_Angeles&quot;,&quot;country_code&quot;:&quot;USA&quot;},&quot;last_request_at&quot;:1478239113,&quot;last_seen_ip&quot;:&quot;216.151.183.47&quot;,&quot;created_at&quot;:1478238881,&quot;remote_created_at&quot;:1478238744,&quot;signed_up_at&quot;:1478238744,&quot;updated_at&quot;:1478239113,&quot;session_count&quot;:1,&quot;social_profiles&quot;:{&quot;type&quot;:&quot;social_profile.list&quot;,&quot;social_profiles&quot;:[]},&quot;unsubscribed_from_emails&quot;:false,&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Windows NT 6.3; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0&quot;,&quot;tags&quot;:{&quot;type&quot;:&quot;tag.list&quot;,&quot;tags&quot;:[]},&quot;segments&quot;:{&quot;type&quot;:&quot;segment.list&quot;,&quot;segments&quot;:[{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea275bfcebabd516d963&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea265bfcebabd516d962&quot;}]},&quot;custom_attributes&quot;:{&quot;claimCount&quot;:&quot;2&quot;,&quot;memberType&quot;:&quot;claimant&quot;}}],&quot;scroll_param&quot;:&quot;24ba0fac-b8f9-46b2-944a-9bb523dcd1b1&quot;}\r\n\r\nThe two problems are the first line:\r\n\r\n    {&quot;type&quot;:&quot;user.list&quot;,&quot;users&quot;:\r\n\r\nAnd the final piece at the bottom:\r\n\r\n    ,&quot;scroll_param&quot;:&quot;24bd0rac-b2f9-46b2-944a-9zz543dcd1b1&quot;}\r\n\r\nIf you eliminate those two, you are simply left with the necessary data needed, and I know what filter is needed to parse it out to put it in newline delimited format.\r\n\r\n[You can see for yourself by playing around with this tool][2], but if you only copy and paste everything from that first open bracket to the close bracket on the final line, set it to &quot;Compact Output&quot; and apply the filter:\r\n\r\n    .[]\r\n\r\nThe result will be like what you see here, [in a nice and neat newline delimited format like you see here.][3], also here it is not in the link:\r\n\r\n    {&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;581c13632f25960e6e3dc89a&quot;,&quot;user_id&quot;:&quot;ieo2e6dtsqhiyhtr&quot;,&quot;anonymous&quot;:false,&quot;email&quot;:&quot;test@gmail.com&quot;,&quot;name&quot;:&quot;Joe Martinez&quot;,&quot;pseudonym&quot;:null,&quot;avatar&quot;:{&quot;type&quot;:&quot;avatar&quot;,&quot;image_url&quot;:null},&quot;app_id&quot;:&quot;b5vkxvop&quot;,&quot;companies&quot;:{&quot;type&quot;:&quot;company.list&quot;,&quot;companies&quot;:[]},&quot;location_data&quot;:{&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;Houston&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:29.7633,&quot;longitude&quot;:-95.3633,&quot;postal_code&quot;:&quot;77002&quot;,&quot;region_name&quot;:&quot;Texas&quot;,&quot;timezone&quot;:&quot;America/Chicago&quot;,&quot;country_code&quot;:&quot;USA&quot;},&quot;last_request_at&quot;:1478235114,&quot;last_seen_ip&quot;:&quot;66.87.120.30&quot;,&quot;created_at&quot;:1478234979,&quot;remote_created_at&quot;:1478234944,&quot;signed_up_at&quot;:1478234944,&quot;updated_at&quot;:1478235145,&quot;session_count&quot;:1,&quot;social_profiles&quot;:{&quot;type&quot;:&quot;social_profile.list&quot;,&quot;social_profiles&quot;:[]},&quot;unsubscribed_from_emails&quot;:false,&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Linux; Android 6.0.1; SM-G920P Build/MMB29K) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.68 Mobile Safari/537.36&quot;,&quot;tags&quot;:{&quot;type&quot;:&quot;tag.list&quot;,&quot;tags&quot;:[]},&quot;segments&quot;:{&quot;type&quot;:&quot;segment.list&quot;,&quot;segments&quot;:[{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea275bfcebabd516d963&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea265bfcebabd516d962&quot;}]},&quot;custom_attributes&quot;:{&quot;claimCount&quot;:&quot;1&quot;,&quot;memberType&quot;:&quot;claimant&quot;}}\r\n    {&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;581c22a19a1dc02c460541df&quot;,&quot;user_id&quot;:&quot;1o3helrdv58cxm7jf&quot;,&quot;anonymous&quot;:false,&quot;email&quot;:&quot;test@mail.com&quot;,&quot;name&quot;:&quot;Joe Coleman&quot;,&quot;pseudonym&quot;:null,&quot;avatar&quot;:{&quot;type&quot;:&quot;avatar&quot;,&quot;image_url&quot;:null},&quot;app_id&quot;:&quot;b5vkxvop&quot;,&quot;companies&quot;:{&quot;type&quot;:&quot;company.list&quot;,&quot;companies&quot;:[]},&quot;location_data&quot;:{&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;San Jose&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:37.3394,&quot;longitude&quot;:-121.895,&quot;postal_code&quot;:&quot;95141&quot;,&quot;region_name&quot;:&quot;California&quot;,&quot;timezone&quot;:&quot;America/Los_Angeles&quot;,&quot;country_code&quot;:&quot;USA&quot;},&quot;last_request_at&quot;:1478239113,&quot;last_seen_ip&quot;:&quot;216.151.183.47&quot;,&quot;created_at&quot;:1478238881,&quot;remote_created_at&quot;:1478238744,&quot;signed_up_at&quot;:1478238744,&quot;updated_at&quot;:1478239113,&quot;session_count&quot;:1,&quot;social_profiles&quot;:{&quot;type&quot;:&quot;social_profile.list&quot;,&quot;social_profiles&quot;:[]},&quot;unsubscribed_from_emails&quot;:false,&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Windows NT 6.3; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0&quot;,&quot;tags&quot;:{&quot;type&quot;:&quot;tag.list&quot;,&quot;tags&quot;:[]},&quot;segments&quot;:{&quot;type&quot;:&quot;segment.list&quot;,&quot;segments&quot;:[{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea275bfcebabd516d963&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;57d2ea265bfcebabd516d962&quot;}]},&quot;custom_attributes&quot;:{&quot;claimCount&quot;:&quot;2&quot;,&quot;memberType&quot;:&quot;claimant&quot;}}\r\n\r\nSo what I need is a filter I can apply in the same manner I used .[] that pull out all the text prior to the first open bracket (as I highlighted above) as well as all the text prior to the closed bracket at the end.\r\n\r\nBut here&#39;s where the final problem comes in. While I need that final piece of text out of the equation, I still do need that string of letters and numbers known as the scroll paramater. This is because in order to fully capture all the data I need in the API, I need to continuously use the new scroll paramater it generates from the command line call until all the data is in.\r\n\r\nThe initial call looks as such:\r\n\r\n    $ curl -s https://api.program.io/users/scroll -u &#39;dG9rOmU5NGFjYTkwXzliNDFfNGIyMF9iYzA0XzU0NDg3MjE5ZWJkZDoxOjA=&#39;: -H &#39;Accept:application/json&#39;\r\n\r\nBut in ordere to get all the info in, I need that scroll parameter for a seperate call that looks like:\r\n\r\n    curl -s https://api.intercom.io/users/scroll?scroll_param=foo -u &#39;dG9rOmU5NGFjYTkwXzliNDFfNGIyMF9iYzA0XzU0NDg3MjE5ZWJkZDoxOjA=&#39;: -H &#39;Accept:application/json&#39; &gt;scroll.json\r\n \r\nSo while I need to get rid of the text in the blob that contains the paramater in order to put it in newline delimited format, I still need to extract whatever that paramater is to loop back into another script that will continue to run until it is empty.\r\n\r\nWould love to hear any advice in working around this!\r\n\r\n  [1]: http://pastebin.com/d64nDAdz\r\n  [2]: https://jqplay.org/#\r\n  [3]: http://pastebin.com/Dy27itgD\r\n",
        "link": "https://stackoverflow.com/questions/40661704/parsing-filter-needed-for-newline-delimited-json-format",
        "title": "Parsing Filter Needed For Newline Delimited JSON format"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1479745849,
                "last_edit_date": 1495541623,
                "creation_date": 1479741136,
                "answer_id": 40723367,
                "question_id": 40722754,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Update: see [@peak&#39;s answer](https://stackoverflow.com/a/40724176/1126841) for the generalization I couldn&#39;t quite get to.\r\n\r\n---\r\n\r\nThis is far from the best solution, but demonstrates that it is possible to generate some JSON from arbitrary text.\r\n\r\n    jq -Rrn &#39;inputs | match(&quot;\\\\[(.*)\\\\] (.*)&quot;) | .captures[]|.string &#39; tmp.txt |\r\n      jq -Rn &#39;{\r\n        payment_test: {\r\n          service1: {\r\n            api: {\r\n              &quot;\\(input)&quot;: input,\r\n              &quot;\\(input)&quot;: input,\r\n              &quot;\\(input)&quot;: input\r\n            }\r\n          }\r\n        }\r\n      }\r\n    &#39;\r\n\r\nHere&#39;s a breakdown of each command: \r\n\r\n 1. The first one reads the input as raw text (`-R`), line-by-line inside the filter (`-n` along with the `inputs` function), and outputs raw text (`-r`) corresponding to the text in brackets and the rest of the line following the brackets.\r\n\r\n  It is instructive to run the first command on your input one filter at a time to see how the full filter works. (That is, run each of the following in order:\r\n   1. `jq -Rrn &#39;inputs&#39; tmp.txt`\r\n   2. `jq -Rrn &#39;inputs | match(...)&#39; tmp.txt`\r\n   3. `jq -Rrn &#39;inputs | match(...) | .captures&#39; tmp.txt`\r\n   4. `jq -Rrn &#39;inputs | match(...) | .captures[] | .string&#39; tmp.txt`\r\n\r\n  )\r\n\r\n\r\n 2. The second command simply reads each line, again as raw text and explicitly using `input`, and builds the desired object from each piece.\r\n\r\nIt should be possible to combine this into one call to `jq`; my skills at more complex commands are limited, but this demonstrates that you can cobble together a solution using simple pieces.",
                "title": "How to use jq to convert this string to JSON?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1525368194,
                "last_edit_date": 1525368194,
                "creation_date": 1479743579,
                "answer_id": 40724176,
                "question_id": 40722754,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is more general than @chepner&#39;s solution (it uses `add` and therefore is not restricted to three key-value pairs) and perhaps slightly simpler:\r\n\r\n    $ jq -Rn &#39;inputs | match(&quot;\\\\[(.*)\\\\] (.*)&quot;)\r\n        | .captures | {(.[0].string): (.[1].string)} &#39; tmp.txt |\r\n      jq -s &#39;{payment_test: { service1: { api: add }}} &#39;\r\n\r\nNow it&#39;s easy to see how to eliminate the second call to jq:\r\n\r\n    jq -Rn &#39;[ inputs | match(&quot;\\\\[(.*)\\\\] (.*)&quot;)\r\n              | .captures | {(.[0].string): (.[1].string)}]\r\n            | {payment_test: { service1: { api: add }}} &#39; tmp.txt\r\n\r\n### Using named capture variables\r\nAn improvement would be to use named capture variables. jq provides a filter, `capture`, for creating an object from the capture variables; it can be used in conjunction with `from_entries` like so:\r\n\r\n    [inputs | capture(&quot;\\\\[(?&lt;key&gt;.*)\\\\] (?&lt;value&gt;.*)&quot;)]\r\n    | from_entries\r\n    | {payment_test: { service1: { api: . }}} \r\n\r\n\r\nUsing such techniques, the string &quot;payment_test_service1_api&quot; could also be parsed, but the OP expectations regarding this are unclear, so maybe that&#39;s best left for another Q&amp;A.\r\n",
                "title": "How to use jq to convert this string to JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1479764163,
                "creation_date": 1479764163,
                "answer_id": 40729827,
                "question_id": 40722754,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The first parts of each line resembles the object structure in your results. If you could come up with a scheme to parse that out in an unambiguous way, you could treat them as paths to then set the values directly.\r\n\r\nAssuming there are only three segments where only the first may contain underscores, you could do this:\r\n\r\n    $ jq -Rn &#39;reduce (inputs\r\n            | [match(&quot;(\\\\S+)_([^_]+)_([^_]+)\\\\[([^\\\\]]+)\\\\] (\\\\S+)&quot;).captures[].string]\r\n        ) as $p\r\n        ({}; setpath($p[:-1]; $p[-1]))&#39; input.txt",
                "title": "How to use jq to convert this string to JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1525368194,
        "creation_date": 1479739260,
        "last_edit_date": 1479747719,
        "question_id": 40722754,
        "body_markdown": "How can I use jq to convert the following lines to a JSON format?\r\n\r\n    payment_test_service1_api[host] HOST1\r\n    payment_test_service1_api[username] USERNAME1\r\n    payment_test_service1_api[password] PASSWORD1\r\n\r\nTo this JSON format:    \r\n    \r\n    &quot;payment_test&quot; {\r\n    \t&quot;service1&quot; : \r\n    \t{\r\n    \t  &quot;api&quot;: {\r\n    \t    &quot;host&quot;: &quot;HOST1&quot;,\r\n    \t    &quot;username&quot;: &quot;USERNAME1&quot;,\r\n    \t    &quot;password&quot;: &quot;PASSWORD1&quot;\r\n    \t  }\r\n    \t}\r\n    }",
        "link": "https://stackoverflow.com/questions/40722754/how-to-use-jq-to-convert-this-string-to-json",
        "title": "How to use jq to convert this string to JSON?"
    },
    {
        "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": 0,
                "creation_date": 1479784305,
                "post_id": 40732976,
                "comment_id": 68693100,
                "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": 1,
                "creation_date": 1479785266,
                "post_id": 40732976,
                "comment_id": 68693305,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1479786183,
                "last_edit_date": 1479786183,
                "creation_date": 1479783217,
                "answer_id": 40733044,
                "question_id": 40732976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq &#39;.[] | .name + &quot;, &quot; + (.tags[] | select(.key == &quot;environment&quot;).value)&#39; f.json",
                "title": "How to get a flat output based on conditional jq query?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1479785403,
                "creation_date": 1479785403,
                "answer_id": 40733321,
                "question_id": 40732976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes.\r\n\r\nFor example:\r\n\r\n    $ jq &#39;.[] | &quot;\\(.name), \\(.tags | from_entries | .environment)&quot;&#39; input.json\r\n\r\nOutput:\r\n\r\n    &quot;InstanceA, production&quot;\r\n    &quot;InstanceB, staging&quot;",
                "title": "How to get a flat output based on conditional jq query?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502081569,
                "creation_date": 1502081569,
                "answer_id": 45539618,
                "question_id": 40732976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **join**\r\n\r\n      .[]\r\n    | [.name, (.tags[] | if .key == &quot;environment&quot; then .value else empty end)]\r\n    | join(&quot;, &quot;)",
                "title": "How to get a flat output based on conditional jq query?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1502081569,
        "creation_date": 1479782719,
        "last_edit_date": 1479787062,
        "question_id": 40732976,
        "body_markdown": "I have the following JSON:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;InstanceA&quot;,\r\n        &quot;tags&quot;: [\r\n          {\r\n            &quot;key&quot;: &quot;environment&quot;,\r\n            &quot;value&quot;: &quot;production&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;group&quot;,\r\n            &quot;value&quot;: &quot;group1&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;InstanceB&quot;,\r\n        &quot;tags&quot;: [\r\n          {\r\n            &quot;key&quot;: &quot;group&quot;,\r\n            &quot;value&quot;: &quot;group2&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;environment&quot;,\r\n            &quot;value&quot;: &quot;staging&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;m trying to get a flat output of `value` based on the condition `key == &#39;environment&#39;`. I already tried [`select(boolean_expression)`][1], but I cannot get the desired output, like:\r\n\r\n&lt;pre&gt;\r\n&quot;InstanceA, production&quot;\r\n&quot;InstanceB, staging&quot;\r\n&lt;/pre&gt;\r\n\r\nDoes `jq` support this kind of output? If so, how to do it?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#ConditionalsandComparisons",
        "link": "https://stackoverflow.com/questions/40732976/how-to-get-a-flat-output-based-on-conditional-jq-query",
        "title": "How to get a flat output based on conditional jq query?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "flatten"
        ],
        "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": 1479833005,
                "post_id": 40746437,
                "comment_id": 68720238,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2738153,
                    "reputation": 101,
                    "user_id": 7195397,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FI8SA.jpg?s=256",
                    "display_name": "Dennis Olvany",
                    "link": "https://stackoverflow.com/users/7195397/dennis-olvany"
                },
                "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": 1479848395,
                "post_id": 40746437,
                "comment_id": 68729133,
                "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": 1479848540,
                "post_id": 40746437,
                "comment_id": 68729211,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1486181282,
                "last_edit_date": 1486181282,
                "creation_date": 1486164746,
                "answer_id": 42034667,
                "question_id": 40746437,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a programmatic way to expand all array-valued keys of an arbitrary JSON object:\r\n\r\n    def blowup(a): \r\n      def b(f): {(f): (.[f] | if type == &quot;array&quot; then .[] else . end)};\r\n\r\n      if a|length == 0 then {} else b(a[0]) + blowup(a[1:]) end;\r\n\r\n    blowup(keys)\r\n\r\nExample:\r\n\r\nInput: {a:0, b: [1,2], c: [3,4]}\r\n\r\nOutput: \r\n\r\n    {&quot;a&quot;:0,&quot;b&quot;:1,&quot;c&quot;:3}\r\n    {&quot;a&quot;:0,&quot;b&quot;:2,&quot;c&quot;:3}\r\n    {&quot;a&quot;:0,&quot;b&quot;:1,&quot;c&quot;:4}\r\n    {&quot;a&quot;:0,&quot;b&quot;:2,&quot;c&quot;:4}",
                "title": "Flatten Array In Object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1486207880,
        "creation_date": 1479830537,
        "last_edit_date": 1486207880,
        "question_id": 40746437,
        "body_markdown": "Is there an elegant way to replicate an object for each array item within?\r\n\r\n    printf &#39;{&quot;a&quot;:&quot;&quot;,&quot;b&quot;:[{},{}]}&#39; | jq &#39;{a:.a,b:.b[]}&#39;\r\n    {&quot;a&quot;:&quot;&quot;,&quot;b&quot;:{}}\r\n    {&quot;a&quot;:&quot;&quot;,&quot;b&quot;:{}}",
        "link": "https://stackoverflow.com/questions/40746437/flatten-array-in-object",
        "title": "Flatten Array In Object"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2173298,
                    "reputation": 13912,
                    "user_id": 1924666,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/5sYpF.jpg?s=256",
                    "display_name": "Shahriar",
                    "link": "https://stackoverflow.com/users/1924666/shahriar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1479898087,
                "post_id": 40762235,
                "comment_id": 68749033,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1479898559,
                "creation_date": 1479898559,
                "answer_id": 40762500,
                "question_id": 40762235,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `map(select(...))`:\r\n\r\n    jq &#39;.items|map(select(.metadata.name == &quot;127.0.0.1&quot;))|.[].status.capacity&#39; items \r\n    {\r\n      &quot;cpu&quot;: 3\r\n    }\r\n",
                "title": "How to skip iteration in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1480004033,
                "last_edit_date": 1480004033,
                "creation_date": 1479999734,
                "answer_id": 40789551,
                "question_id": 40762235,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@aerofile-kite - Your first instinct is right.  There is no need to use `map` and in your case, it is probably more efficient not to use it.  Following your line of thought, you could write:\r\n\r\n    .items[]\r\n    | if .metadata.name==&quot;127.0.0.1&quot;\r\n      then {cpu: .status.capacity.cpu}\r\n      else empty\r\n      end\r\n\r\nor more succinctly:\r\n\r\n      .items[]\r\n      | select(.metadata.name==&quot;127.0.0.1&quot;)\r\n      | { cpu: .status.capacity.cpu } \r\n\r\n",
                "title": "How to skip iteration in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1480004033,
        "creation_date": 1479897888,
        "question_id": 40762235,
        "body_markdown": "    {   &quot;items&quot;:[\r\n        {\r\n          &quot;metadata&quot;:{&quot;name&quot;:&quot;127.0.0.1&quot;},\r\n          &quot;status&quot;:{\r\n            &quot;capacity&quot;:{&quot;cpu&quot;:3}\r\n          }\r\n        },\r\n        {\r\n          &quot;metadata&quot;:{&quot;name&quot;:&quot;127.0.0.2&quot;},\r\n          &quot;status&quot;:{\r\n            &quot;capacity&quot;:{&quot;cpu&quot;:8}\r\n          }\r\n        }   ] }\r\n\r\nI want to do following:\r\n\r\n    .items[] | if .metadata.name==&quot;127.0.0.1&quot; then {cpu: .status.capacity.cpu} else &lt;&lt;I want to skip&gt;&gt; end\r\n\r\nI want skip if 1st continue is false\r\n\r\nRequired Output:\r\n\r\n    {&quot;cpu&quot;:3}",
        "link": "https://stackoverflow.com/questions/40762235/how-to-skip-iteration-in-jq",
        "title": "How to skip iteration in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1480044957,
                "creation_date": 1480044957,
                "answer_id": 40797328,
                "question_id": 40794182,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your jq has `any/2`, I&#39;d recommend using the following definition of `intersectq/2`:\r\n\r\n    def intersectq(a;b): any(a[]; . as $x | any( b[]; . == $x) );\r\n\r\nThe filter to use is then simply:\r\n\r\n    .[] | select( intersectq(.hosts; $array)) | .hostName\r\n\r\nas in:\r\n\r\n    jq --argjson array &#39;[&quot;darwin&quot;,&quot;intel&quot;]&#39; -r -f program.jq hosts.json\r\n\r\n\r\n\r\n",
                "title": "jq - select contains array or/and"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1480044957,
        "creation_date": 1480019811,
        "question_id": 40794182,
        "body_markdown": "Currently this works: \r\n\r\n    jq -r &#39;.[] | select(.hosts | contains(&#39;$array&#39;)).hostName&#39;)\r\n\r\nIf `array = [&quot;darwin&quot;,&quot;intel&quot;]`it returns objects containing both darwin &quot;and&quot; intel.\r\nHow can I make it return objects containing darwin &quot;and/or&quot; intel?",
        "link": "https://stackoverflow.com/questions/40794182/jq-select-contains-array-or-and",
        "title": "jq - select contains array or/and"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "fastcgi",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3309071,
                    "reputation": 8395,
                    "user_id": 2782989,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/mewYT.jpg?s=256",
                    "display_name": "pradeep1991singh",
                    "link": "https://stackoverflow.com/users/2782989/pradeep1991singh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1480058044,
                "post_id": 40799242,
                "comment_id": 68820478,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3269099,
                    "reputation": 917,
                    "user_id": 2752862,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/yWdHu.jpg?s=256",
                    "display_name": "Shashank Shekher",
                    "link": "https://stackoverflow.com/users/2752862/shashank-shekher"
                },
                "reply_to_user": {
                    "account_id": 3309071,
                    "reputation": 8395,
                    "user_id": 2782989,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/mewYT.jpg?s=256",
                    "display_name": "pradeep1991singh",
                    "link": "https://stackoverflow.com/users/2782989/pradeep1991singh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1480063719,
                "post_id": 40799242,
                "comment_id": 68823021,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1810057,
                    "reputation": 21707,
                    "user_id": 1646322,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/d9fd7a75e0d8ace7bb3276476786c2c0?s=256&d=identicon&r=PG",
                    "display_name": "Ruslan Osmanov",
                    "link": "https://stackoverflow.com/users/1646322/ruslan-osmanov"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1480065629,
                "post_id": 40799242,
                "comment_id": 68824000,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3269099,
                    "reputation": 917,
                    "user_id": 2752862,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/yWdHu.jpg?s=256",
                    "display_name": "Shashank Shekher",
                    "link": "https://stackoverflow.com/users/2752862/shashank-shekher"
                },
                "reply_to_user": {
                    "account_id": 1810057,
                    "reputation": 21707,
                    "user_id": 1646322,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/d9fd7a75e0d8ace7bb3276476786c2c0?s=256&d=identicon&r=PG",
                    "display_name": "Ruslan Osmanov",
                    "link": "https://stackoverflow.com/users/1646322/ruslan-osmanov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1480074822,
                "post_id": 40799242,
                "comment_id": 68829603,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1810057,
                    "reputation": 21707,
                    "user_id": 1646322,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/d9fd7a75e0d8ace7bb3276476786c2c0?s=256&d=identicon&r=PG",
                    "display_name": "Ruslan Osmanov",
                    "link": "https://stackoverflow.com/users/1646322/ruslan-osmanov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1480074898,
                "post_id": 40799242,
                "comment_id": 68829650,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1480308625,
                "last_edit_date": 1480308625,
                "creation_date": 1480308212,
                "answer_id": 40837304,
                "question_id": 40799242,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There was no configuration issue. The problem was caused because there was no response from the script for the POST request.",
                "title": "Print a string in JSON format in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1480308625,
        "creation_date": 1480056689,
        "question_id": 40799242,
        "body_markdown": "I am using below statement in my CGI bash scrip, which is returning me error `[error] 1705#0: *105 upstream prematurely closed FastCGI stdout while reading response header from upstream [...]`. Is this a correct way to use it?\r\n\r\n    echo &quot;{\\&quot;meta\\&quot;: {\\&quot;link\\&quot;: {\\&quot;upload\\&quot;: { \\&quot;href\\&quot;: \\&quot;http://${ip}${target}\\&quot;}}}, \\&quot;status\\&quot;: \\&quot;empty\\&quot;}&quot; | jq .\r\n\r\nMy expected output is as below.\r\n\r\n    {\r\n      &quot;meta&quot;: {\r\n      &quot;link&quot;: {\r\n      &quot;upload&quot;: { &quot;href&quot;: &quot;http://fileserver.example.com/upload/content/{id}&quot; }\r\n      }\r\n    },&quot;status&quot;: &quot;empty&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/40799242/print-a-string-in-json-format-in-bash",
        "title": "Print a string in JSON format in bash"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1480066258,
                "creation_date": 1480066258,
                "answer_id": 40801610,
                "question_id": 40801525,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could put your code in a function and run it in the background, with something like this:\r\n\r\n        runCurl() {\r\n    \t    md5_checksum=$(md5sum $1|cut -d&#39; &#39; -f 1)\r\n    \t    sha1_checksum=$(sha1sum $1|cut -d&#39; &#39; -f 1)\r\n    \t    sha256_checksum=$(sha256sum $1|cut -d&#39; &#39; -f 1)\r\n    \t    json_result=&quot;$(curl --silent -H &#39;Authorization:Basic XXXX&#39; &#39;https://XXXXX.com/api/databrowser/malware_presence/query/sha1/&#39;$sha1_checksum&#39;?format=json&amp;extended=true&#39;| jq -r &#39;.rl.malware_presence.name,.rl.malware_presence.level&#39; | awk -vORS=, &#39;{print $1}&#39; |sed &#39;s/,$/\\n/&#39;)&quot;\r\n    \t    echo &quot;$md5_checksum,$sha1_checksum,$sha256_checksum,$json_result&quot;\r\n    \t}\r\n    \r\n    \tfor i in $(find $1 -type f);do\r\n    \t\trunCurl $i &amp;\r\n    \tdone",
                "title": "Rate Limiting the Number of cURL request given from a bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1480076594,
        "creation_date": 1480065971,
        "last_edit_date": 1480076594,
        "question_id": 40801525,
        "body_markdown": "I wrote bash script to calculate the hashes of a files, when it&#39;s file path given and queries one among the file hash to get the result of that hash from a API service ( Parsing using `jq` ) .\r\n\r\n    #Scanner.sh\r\n\r\n    #!/bin/bash\r\n    \r\n    for i in $(find $1 -type f);do\r\n        md5_checksum=$(md5sum $i|cut -d&#39; &#39; -f 1)\r\n        sha1_checksum=$(sha1sum $i|cut -d&#39; &#39; -f 1)\r\n        sha256_checksum=$(sha256sum $i|cut -d&#39; &#39; -f 1)\r\n        json_result=&quot;$(curl --silent -H &#39;Authorization:Basic XXXX&#39; &#39;https://XXXXX.com/api/databrowser/malware_presence/query/sha1/&#39;$sha1_checksum&#39;?format=json&amp;extended=true&#39;| jq -r &#39;.rl.malware_presence.name,.rl.malware_presence.level&#39; | awk -vORS=, &#39;{print $1}&#39; |sed &#39;s/,$/\\n/&#39;)&quot;\r\n        echo &quot;$md5_checksum,$sha1_checksum,$sha256_checksum,$json_result&quot;\r\n    done\r\n\r\n\r\n    #Result : \r\n    c63a1576e4b416e6944a1c39dbdfc3b4,fd55dfdd9a432e34ce6c593cd09a48f457f7aab6,e2d1c1975c2406f60f1c0fe5255560c2cd06434e669933536a86296a2eb70020,Malware,5\r\n\r\nNow, it&#39;s taking too much time to process one and get results for one file hash ( 10 Sec ). How can i send 5 request per second and get the results faster ? \r\n\r\nAny suggestions please ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40801525/rate-limiting-the-number-of-curl-request-given-from-a-bash-script",
        "title": "Rate Limiting the Number of cURL request given from a bash script"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "parsing",
            "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": 1480101733,
                "post_id": 40810498,
                "comment_id": 68842879,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1480108644,
                "last_edit_date": 1480108644,
                "creation_date": 1480108156,
                "answer_id": 40812309,
                "question_id": 40810498,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Objects with duplicate keys can be handled in jq using the --stream option, e.g.:\r\n\r\n    $ jq -s --stream &#39;.[length-2] | { (.[0][0]): (.[1]) }&#39; input.json\r\n    {\r\n      &quot;error.content&quot;: &quot;{custom.error.content}&quot;\r\n    }\r\n\r\nFor large files, the following would probably be better as it avoids &quot;slurping&quot; the input file:\r\n\r\n    $ jq &#39;first(tostream) | {(.[0][0]): .[1]} &#39; input.json",
                "title": "Get the last element in JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1480108644,
        "creation_date": 1480097519,
        "last_edit_date": 1480099435,
        "question_id": 40810498,
        "body_markdown": "I have this JSON file:\r\n\r\n        \r\n    {\r\n          &quot;system.timestamp&quot;: &quot;{system.timestamp}&quot;,\r\n          &quot;error.state&quot;: &quot;{error.state}&quot;,\r\n          &quot;system.timestamp&quot;: &quot;{system.timestamp}&quot;,\r\n          &quot;error.state&quot;: &quot;{error.state}&quot;,\r\n           &quot;system.timestamp&quot;: &quot;{system.timestamp}&quot;,\r\n          &quot;error.state&quot;: &quot;{error.state}&quot;,\r\n          &quot;error.content&quot;: &quot;{custom.error.content}&quot;\r\n    }\r\n        \r\nI would like to get only the last object of the JSON file as I need to check that in every case, the last object is `error.content`. Attached part of code is just a sample file, every file that will be generated in reality will contain at least around 40 to 50 objects, so in every case I need to check that the last object is `error.content`.\r\n    \r\nI have calculated the length by using `jq &#39;. | length&#39;`. How do I do it using the `jq` command in Linux?\r\n        \r\nNote: it&#39;s a plain JSON file without any arrays.",
        "link": "https://stackoverflow.com/questions/40810498/get-the-last-element-in-json-file",
        "title": "Get the last element in JSON file"
    },
    {
        "tags": [
            "json",
            "sed",
            "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": 1480137307,
                "post_id": 40814863,
                "comment_id": 68850276,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1480138507,
                "post_id": 40814863,
                "comment_id": 68850493,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9724451,
                    "reputation": 31,
                    "user_id": 7211976,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8343be27da73a22a886eff53966def7d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ApG",
                    "link": "https://stackoverflow.com/users/7211976/apg"
                },
                "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": 1480151489,
                "post_id": 40814863,
                "comment_id": 68853188,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1480185709,
                "last_edit_date": 1480185709,
                "creation_date": 1480184714,
                "answer_id": 40821617,
                "question_id": 40814863,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should get you started:\r\n\r\n    $ jq --arg tag &quot;tag1&quot; &#39;\r\n      .paths |= with_entries(.value.get.tags[] = $tag)&#39; Example1.json\r\n\r\n\r\nOr on a slightly different tack, you could use this filter:\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n    walk(if type==&quot;object&quot; and has(&quot;tags&quot;) then .tags[] |= $tag else . end)\r\n\r\nIn both cases, the output would be as shown below.  You could of course also change &quot;exampleN&quot; to &quot;tagN&quot; programmatically within the jq program (e.g. using `sub/2`), if that&#39;s what you want.  The important point is that jq alone can do the job.\r\n\r\n    {\r\n      &quot;info&quot;: {\r\n        &quot;title&quot;: &quot;My example swagger 1&quot;,\r\n        &quot;version&quot;: &quot;1.0&quot;\r\n      },\r\n      &quot;paths&quot;: {\r\n        &quot;/v1/resource1&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;description&quot;: &quot;This is the example1&quot;,\r\n            &quot;tags&quot;: [\r\n              &quot;tag1&quot;\r\n            ],\r\n            &quot;consumes&quot;: [\r\n              &quot;*/*&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;/v1/resource2&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;tags&quot;: [\r\n              &quot;tag1&quot;\r\n            ],\r\n            &quot;consumes&quot;: [\r\n              &quot;*/*&quot;\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n    ",
                "title": "Need to Replace tags field in json with new value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1480186046,
                "creation_date": 1480186046,
                "answer_id": 40821840,
                "question_id": 40814863,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So if I understand correctly, you want to replace tags that have the file&#39;s name and replace it with a tag of your choosing.  Here&#39;s one way you could do it:\r\n\r\n    $ jq --arg newtag &#39;tag1&#39; &#39;(input_filename | sub(&quot;\\\\.json$&quot;; &quot;&quot;)) as $oldtag\r\n        | .paths[][].tags |= map(if . == $oldtag then $newtag else . end)&#39; example1.json\r\n\r\nIf you wanted to replace arbitrary tags and not just the one that matches the file name, just add another parameter:\r\n\r\n    $ jq --arg oldtag &#39;example1&#39; --arg newtag &#39;tag1&#39; \\\r\n        &#39;.paths[][].tags |= map(if . == $oldtag then $newtag else . end)&#39; example1.json\r\n\r\nIf you wanted to be able to replace multiple different tags, you can create an object mapping old tags to new tags and build off that.\r\n\r\n    $ jq --argjson tagmap &#39;{&quot;example1&quot;:&quot;tag1&quot;,&quot;example2&quot;:&quot;tag2&quot;}&#39; \\\r\n        &#39;.paths[][].tags |= map($tagmap[.] // .)&#39; example1.json",
                "title": "Need to Replace tags field in json with new value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1480186046,
        "creation_date": 1480133811,
        "last_edit_date": 1480160352,
        "question_id": 40814863,
        "body_markdown": "I am trying to write a batch script to change the value of &quot;tags&quot; key for below 2 jsons named example1.json and example2.json.\r\n\r\ninput example1.json \r\n    \r\n    {\r\n\t  &quot;info&quot;: {\r\n\t\t&quot;title&quot;: &quot;My example swagger 1&quot;,\r\n\t\t&quot;version&quot;: &quot;1.0&quot;\r\n\t  },\r\n\t  &quot;paths&quot;: {\r\n\t\t&quot;/v1/resource1&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;description&quot;: &quot;This is the example1&quot;,\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;example1&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;/v1/resource2&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;example1&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t  }\r\n    }\r\n\r\nInput example2.json\r\n\r\n    {\r\n\t &quot;info&quot;: {\r\n\t\t&quot;title&quot;: &quot;My example swagger 2&quot;,\r\n\t\t&quot;version&quot;: &quot;1.0&quot;\r\n\t  },\r\n\t  &quot;paths&quot;: {\r\n\t\t&quot;/v1/resource3&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;description&quot;: &quot;This is the example2&quot;,\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;example2&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;/v1/resource4&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;example2&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t  }\r\n    }\r\n\r\n\r\nExpected Output is two jsons with same name but the tags value is now changed.\r\n\r\nExample1.json : \r\n\r\n input tags value - example1 (which is json file name)\r\n\r\n output tags value - tags1   (as per requirement)\r\n\r\nExample2.json\r\n\r\n input tags value - example2 (which is json file name)\r\n\r\n output tags value - tags2  (as per requirement)\r\n\r\n\r\nOutput Example1.json\r\n\r\n    {\r\n\t  &quot;info&quot;: {\r\n\t\t&quot;title&quot;: &quot;My example swagger 1&quot;,\r\n\t\t&quot;version&quot;: &quot;1.0&quot;\r\n\t  },\r\n\t  &quot;paths&quot;: {\r\n\t\t&quot;/v1/resource1&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;description&quot;: &quot;This is the example1&quot;,\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;tag1&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;/v1/resource2&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;tag1&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t  }\r\n    }\r\n\r\nOuput Example2.json\r\n\r\n    {\r\n\t  &quot;info&quot;: {\r\n\t\t&quot;title&quot;: &quot;My example swagger 2&quot;,\r\n\t\t&quot;version&quot;: &quot;1.0&quot;\r\n\t  },\r\n\t  &quot;paths&quot;: {\r\n\t\t&quot;/v1/resource3&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;description&quot;: &quot;This is the example2&quot;,\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;tag2&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;/v1/resource4&quot;: {\r\n\t\t\t&quot;get&quot;: {\r\n\t\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t\t&quot;tag2&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;consumes&quot;: [\r\n\t\t\t\t\t&quot;*/*&quot;\r\n\t\t\t\t]\r\n\t\t   }\r\n\t\t}\r\n\t  }\r\n    }\r\n\r\n\r\nI wrote below commands in batch script but it is not working\r\n\r\n    sed -i &quot;s/$/ #removenewlines#/&quot; %1 \r\n    sed -i &quot;:a;N;$!ba;s/\\n//g&quot; %1\r\n    sed -i &quot;s/\\&quot;tags\\&quot;:\\(.*\\) \\&quot;%oldtagvalue%\\&quot;/\\&quot;tags\\&quot;:\\1 \\&quot;%newtagvalue%\\&quot;/g&quot; %1\r\n    sed -i &quot;s/ #removenewlines#/\\n/g&quot; %1\r\n\r\nAs sed don&#39;t work for multiple lines, I changed the newline to #removenewlines# and moving everything to single line(line 1 and 2) . In line 3, I am trying to find key tags using wildcard `\\(.*\\)` and variable `%oldtagvalue%`and then substituting it with `%newtagvalue%` . In line 4, I am formatting the json back.\r\nThe above code runs in loop, so for first loop values of variables will be\r\n\r\n    $ echo %1 \r\n    $ example1.json\r\n    $ echo %oldtagvalue%\r\n    $ example1\r\n    $ echo %newtagvalue%\r\n    $ tag1\r\n\r\nFor the second loop values will be \r\n\r\n    $ echo %1 \r\n    $ example2.json\r\n    $ echo %oldtagvalue%\r\n    $ example2\r\n    $ echo %newtagvalue%\r\n    $ tag2\r\n\r\nBut it is not working. Please advice. I also tried to achieve it using jq command but it didn&#39;t worked as well.",
        "link": "https://stackoverflow.com/questions/40814863/need-to-replace-tags-field-in-json-with-new-value",
        "title": "Need to Replace tags field in json with new value"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1480163312,
                "creation_date": 1480163312,
                "answer_id": 40818324,
                "question_id": 40817623,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thanks &#39;Goldfish&#39; from #jq irc channel. Here&#39;s the command that &#39;Goldfish&#39; shared and working like a charm for me:\r\n\r\n    .machines | to_entries[] | select(.value.&quot;instance-id&quot; == &quot;wdc7ae&quot;).key",
                "title": "Extracting key from a json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1480287753,
        "creation_date": 1480157875,
        "last_edit_date": 1480287753,
        "question_id": 40817623,
        "body_markdown": "Given this JSON snippet, I&#39;m trying to figure out to extract the name of the key corresponding to a specific &quot;instance-id&quot; using jq.\r\n\r\nI&#39;m trying this:\r\n\r\n    jq &#39;.machines | keys as $x | if .[].&quot;instance-id&quot;==&quot;wdc7ae&quot; then &lt;some-code-to-get-the-key&gt;  else empty end&#39;\r\n\r\nwhere $x has all machine numbers. and &quot;wdc7ae&quot; is the specific &quot;instance-id&quot; value\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    {\r\n      &quot;model&quot;: {\r\n        &quot;name&quot;: &quot;maas2&quot;,\r\n        &quot;controller&quot;: &quot;ctr-xenial&quot;,\r\n        &quot;cloud&quot;: &quot;maas&quot;,\r\n        &quot;version&quot;: &quot;2.0.1&quot;\r\n      },\r\n      &quot;machines&quot;: {\r\n        &quot;1&quot;: {\r\n          &quot;dns-name&quot;: &quot;10.4.0.181&quot;,\r\n          &quot;instance-id&quot;: &quot;wdc7ae&quot;,\r\n          &quot;series&quot;: &quot;xenial&quot;\r\n        },\r\n        &quot;2&quot;: {\r\n          &quot;dns-name&quot;: &quot;10.4.0.182&quot;,\r\n          &quot;instance-id&quot;: &quot;7mx74d&quot;,\r\n          &quot;series&quot;: &quot;xenial&quot;\r\n        },\r\n        &quot;3&quot;: {\r\n          &quot;dns-name&quot;: &quot;10.4.0.183&quot;,\r\n          &quot;instance-id&quot;: &quot;rgn3ca&quot;,\r\n          &quot;series&quot;: &quot;xenial&quot;\r\n        },\r\n        &quot;4&quot;: {\r\n          &quot;dns-name&quot;: &quot;10.4.0.184&quot;,\r\n          &quot;instance-id&quot;: &quot;kmy4bh&quot;,\r\n          &quot;series&quot;: &quot;xenial&quot;\r\n        },\r\n        &quot;5&quot;: {\r\n          &quot;dns-name&quot;: &quot;10.4.0.185&quot;,\r\n          &quot;instance-id&quot;: &quot;eb38c7&quot;,\r\n          &quot;series&quot;: &quot;xenial&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nAny help is much appreciated.",
        "link": "https://stackoverflow.com/questions/40817623/extracting-key-from-a-json",
        "title": "Extracting key from a json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1480344034,
                "last_edit_date": 1495540798,
                "creation_date": 1480343952,
                "answer_id": 40846880,
                "question_id": 40845789,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[This question is similar][1] I took the best answer from there a tweaked it a little bit to get the following.\r\n\r\n    $ jq &#39;to_entries[]| {(.key): .value.name}&#39; &lt; /tmp/filter.json\r\n    {\r\n      &quot;123&quot;: &quot;Horst&quot;\r\n    }\r\n    {\r\n      &quot;789&quot;: &quot;Bob&quot;\r\n    }\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/34226370/jq-print-key-and-value-for-each-entry-in-an-object\r\n",
                "title": "How to select key and sub-object property via jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1480351967,
                "creation_date": 1480351967,
                "answer_id": 40849534,
                "question_id": 40845789,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq -r &#39;keys[] as $key | &quot;\\&quot;\\($key)\\&quot;: \\&quot;\\(.[$key].name)\\&quot;&quot;\r\n\r\nproduces:\r\n\r\n    &quot;123&quot;: &quot;Horst&quot;\r\n    &quot;789&quot;: &quot;Bob&quot;",
                "title": "How to select key and sub-object property via jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1480351967,
        "creation_date": 1480340691,
        "question_id": 40845789,
        "body_markdown": "Given the json `filter.json`:\r\n\r\n    {\r\n        &quot;123&quot;: {\r\n            &quot;name&quot;: &quot;Horst&quot;\r\n        },\r\n        &quot;789&quot;: {\r\n            &quot;name&quot;: &quot;Bob&quot;\r\n        }\r\n    }\r\n\r\nI want to filter for each key and the name, wanting an output like:\r\n\r\n    &quot;123&quot;: &quot;Horst&quot;\r\n    &quot;789&quot;: &quot;Bob&quot;\r\n\r\nI tried:\r\n\r\n    jq .[].name,keys &lt; filter.json \r\n\r\nYet it gives me faulty output of:\r\n\r\n    &quot;Horst&quot;\r\n    &quot;Bob&quot;\r\n    [\r\n      &quot;123&quot;,\r\n      &quot;789&quot;\r\n    ]\r\n\r\nyet I don&#39;t know how to &quot;merge&quot; these two outputs to one. Where am I going wrong?",
        "link": "https://stackoverflow.com/questions/40845789/how-to-select-key-and-sub-object-property-via-jq",
        "title": "How to select key and sub-object property via jq?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1607551741,
                "last_edit_date": 1607551741,
                "creation_date": 1480350710,
                "answer_id": 40849180,
                "question_id": 40847936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your particular case:\r\n\r\n    to_entries | map( {(.value) : .key } ) | add\r\n\r\nMore robustly:\r\n\r\n    to_entries | map( {(.value|tostring) : .key } ) | add\r\n\r\nOr if you prefer:\r\n\r\n    with_entries( .key as $k | .key = (.value|tostring) | .value = $k )\r\n\r\nCaveat: all these are potentially lossy.",
                "title": "How to swap key and value of an object using jq?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1548359098,
                "creation_date": 1548359098,
                "answer_id": 54354245,
                "question_id": 40847936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If some keys have equal values then probably you would like to get an array of keys as value:\r\n\r\n    to_entries\r\n    | map( {(.value) : {(.key):null} } )\r\n    | reduce .[] as $item ({}; . * $item)\r\n    | to_entries\r\n    | map({key:.key, value:(.value|keys)})\r\n    | from_entries\r\n\r\ninput:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;val0&quot;,\r\n      &quot;key2&quot;: &quot;val1&quot;,\r\n      &quot;key3&quot;: &quot;val1&quot;\r\n    }\r\n\r\noutput:\r\n\r\n    {\r\n      &quot;val0&quot;: [&quot;key1&quot;],\r\n      &quot;val1&quot;: [&quot;key2&quot;, &quot;key3&quot;]\r\n    }",
                "title": "How to swap key and value of an object using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1576575816,
                "creation_date": 1576575816,
                "answer_id": 59371425,
                "question_id": 40847936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use an approach similar to @peak&#39;s answer but without using the `add` method\r\n\r\nFirst use `to_entries` to get an output like this:\r\n```\r\n-&gt; to_entries\r\nOutput:\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;123&quot;,\r\n    &quot;value&quot;: &quot;Foobar&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;567&quot;,\r\n    &quot;value&quot;: &quot;Poit&quot;\r\n  }\r\n]\r\n```\r\n\r\nThen use `map` to swap the keys with values:\r\n```\r\n-&gt; to_entries | map({key: .value|tostring, value: .key})  ###**tostring** method converts a number to string since keys can&#39;t be numbers\r\nOutput:\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;Foobar&quot;,\r\n    &quot;value&quot;: &quot;123&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;Poit&quot;,\r\n    &quot;value&quot;: &quot;567&quot;\r\n  }\r\n]\r\n\r\n```\r\nFinally use `from_entries` to remove the `key/value` and return back to the original format:\r\n```\r\n-&gt; to_entries | map({key: .value|tostring, value: .key}) | from_entries\r\nOutput:\r\n{\r\n  &quot;Foobar&quot;: &quot;123&quot;,\r\n  &quot;Poit&quot;: &quot;567&quot;\r\n}\r\n\r\n```",
                "title": "How to swap key and value of an object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 18,
        "last_activity_date": 1607551741,
        "creation_date": 1480346961,
        "last_edit_date": 1480385190,
        "question_id": 40847936,
        "body_markdown": "Using jq I would like to inverse a json object so that the property becomes the value and the value becomes the key.\r\n\r\nSource:\r\n\r\n    { \r\n        &quot;123&quot;: &quot;Foobar&quot;\r\n        &quot;567&quot;: &quot;Poit&quot;\r\n    } \r\n\r\nGoal:\r\n\r\n    { \r\n        &quot;Foobar&quot;: &quot;123&quot;\r\n        &quot;Poit&quot;: &quot;567&quot;\r\n    } \r\n\r\nHow can I achieve that?",
        "link": "https://stackoverflow.com/questions/40847936/how-to-swap-key-and-value-of-an-object-using-jq",
        "title": "How to swap key and value of an object using jq?"
    },
    {
        "tags": [
            "json",
            "key",
            "counter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1480440562,
                "creation_date": 1480440562,
                "answer_id": 40872101,
                "question_id": 40871001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So if your goal is to reseed the ids, you could do this:\r\n\r\n    $ jq -n &#39;[ foreach inputs[] as $i (0; .+1; $i*{id:(.-1)}) ]&#39; file_?.json\r\n\r\nI find using `inputs` instead of slurping easier to work with multiple inputs.\r\n\r\nThe idea is to take each of the items from input and update the id (by merging with an object with the desired id).",
                "title": "Trying to merge two JSON file and reset ID values replace it with new incrementing values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1480446344,
                "last_edit_date": 1480446344,
                "creation_date": 1480440762,
                "answer_id": 40872156,
                "question_id": 40871001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First slurp, then concatenate (`add`), and finally adjust the &quot;id&quot; values:\r\n\r\n    $ jq -s &#39;add | reduce range(0;length) as $n (.; .[$n].id = $n)&#39; file_?.json\r\n\r\nThis approach will work using version 1.3 of jq or later (and possibly earlier).\r\n",
                "title": "Trying to merge two JSON file and reset ID values replace it with new incrementing values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1480446344,
        "creation_date": 1480437272,
        "last_edit_date": 1495540378,
        "question_id": 40871001,
        "body_markdown": "I&#39;ve been playing around with jq (https://stedolan.github.io/jq/) but I can&#39;t seem to make it work the way I want it to.\r\n\r\nI was able to merge the two JSON file using this command `jq -s &#39;[.[][]]&#39; file*.json &gt;  combined_file.json` Now,  I can&#39;t figure out how to go about in incrementing the &#39;**id**&#39; value since when I merge it there will be duplicating id values.\r\n\r\nMy json files looks something like this:\r\n\r\n**file_a.json**\r\n\r\n    [  {\r\n        &quot;id&quot;: 0,\r\n        &quot;fruit_name&quot;: &quot;Apple&quot;,\r\n        &quot;fruit_category&quot;: &quot;category 1&quot;,\r\n        &quot;fruit_count&quot;: 1\r\n      },\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;fruit_name&quot;: &quot;Apricot&quot;,\r\n        &quot;fruit_category&quot;: &quot;category 2&quot;,\r\n        &quot;fruit_count&quot;: 1\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;fruit_name&quot;: &quot;Avocado&quot;,\r\n        &quot;fruit_category&quot;: &quot;category 3&quot;,\r\n        &quot;fruit_count&quot;: 2\r\n      }\r\n    ]\r\n\r\n\r\n**file_b.json**\r\n\r\n    [  {\r\n        &quot;id&quot;: 0,\r\n        &quot;fruit_name&quot;: &quot;Banana&quot;,\r\n        &quot;fruit_category&quot;: &quot;category 4&quot;,\r\n        &quot;fruit_count&quot;: 1\r\n      },\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;fruit_name&quot;: &quot;Bilberry&quot;,\r\n        &quot;fruit_category&quot;: &quot;category 5&quot;,\r\n        &quot;fruit_count&quot;: 1\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;fruit_name&quot;: &quot;Blackberry&quot;,\r\n        &quot;fruit_category&quot;: &quot;category 6&quot;,\r\n        &quot;fruit_count&quot;: 2\r\n      }\r\n    ]\r\n\r\nI&#39;ve been exploring this answer (https://stackoverflow.com/questions/34510742/how-do-i-create-an-incremental-index-with-jq) but I was not able to figure out how to make it work.",
        "link": "https://stackoverflow.com/questions/40871001/trying-to-merge-two-json-file-and-reset-id-values-replace-it-with-new-incrementi",
        "title": "Trying to merge two JSON file and reset ID values replace it with new incrementing values"
    },
    {
        "tags": [
            "unique",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1480536099,
                "last_edit_date": 1480536099,
                "creation_date": 1480465905,
                "answer_id": 40878289,
                "question_id": 40877513,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Maybe your version of jq is not sufficiently recent.  Using jq 1.5:\r\n\r\n    unique_by( .reference_key ) \r\n\r\nyields\r\n\r\n    [{&quot;reference_key&quot;:&quot;200&quot;,&quot;id&quot;:&quot;1&quot;},{&quot;reference_key&quot;:&quot;201&quot;,&quot;id&quot;:&quot;4&quot;}]\r\n\r\n(As of January 18, 2016 (7835a72), the builtin `sort` filter is stable; prior to that, stability was platform-dependent.)\r\n\r\nIf you don&#39;t have access to a sufficiently recent version of jq, then consider the following, which has been tested with jq 1.3, 1.4 and 1.5:\r\n\r\n\r\n    def bucketize(f):\r\n      reduce .[] as $x ({}; .[$x|f] += [$x] );\r\n\r\n    bucketize(.reference_key) | .[][0]\r\n\r\nOr much more economically:\r\n\r\n    reduce .[] as $x ({};\r\n      $x.reference_key as $key \r\n      | if .[$key] then . else .[$key] = $x end)\r\n    | .[]\r\n\r\n\r\n",
                "title": "jq unique_by - Choose remaining element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1480536099,
        "creation_date": 1480461197,
        "last_edit_date": 1480466086,
        "question_id": 40877513,
        "body_markdown": "I&#39;m currently trying to get a list of incidents from PagerDuty via the REST api, [which returns them in JSON array][1].  I want to remove any duplicate events by using unique_by() on the incident_key. However, I want the first occurrence of the incident_key, and unique_by() is removing all but the last. Right now, if I have incident_number 849, 850, and 851, all with the same incident_key, unique_by() will return 851.\r\n\r\n\r\nSimple example:\r\n\r\n    [\r\n    { &quot;reference_key&quot;:&quot;200&quot;, &quot;id&quot;:&quot;1&quot; },\r\n    { &quot;reference_key&quot;:&quot;200&quot;, &quot;id&quot;:&quot;2&quot; },\r\n    { &quot;reference_key&quot;:&quot;200&quot;, &quot;id&quot;:&quot;3&quot; },\r\n    { &quot;reference_key&quot;:&quot;201&quot;, &quot;id&quot;:&quot;4&quot; },\r\n    { &quot;reference_key&quot;:&quot;201&quot;, &quot;id&quot;:&quot;5&quot; },\r\n    { &quot;reference_key&quot;:&quot;201&quot;, &quot;id&quot;:&quot;6&quot; }\r\n    ]\r\n\r\nWhat I&#39;m trying to do is use unique_by() to get the first occurrence of reference_key, based on the id. So in this case, I&#39;d want the output to be\r\n\r\n    [\r\n    { &quot;reference_key&quot;:&quot;200&quot;, &quot;id&quot;:&quot;1&quot; },\r\n    { &quot;reference_key&quot;:&quot;201&quot;, &quot;id&quot;:&quot;4&quot; }\r\n    ]\r\n\r\nThe problem is that I have no control over this, and with the data I&#39;m currently trying to do this with, it is returning the last occurrence instead of the first, like so.\r\n\r\n    [\r\n    { &quot;reference_key&quot;:&quot;200&quot;, &quot;id&quot;:&quot;3&quot; },\r\n    { &quot;reference_key&quot;:&quot;201&quot;, &quot;id&quot;:&quot;6&quot; }\r\n    ]\r\n\r\nI have tried using reverse and then calling unique_by(), but I am getting the same results. Is there any way to have some control over this?\r\n\r\n  [1]: https://v1.developer.pagerduty.com/documentation/rest/incidents/list",
        "link": "https://stackoverflow.com/questions/40877513/jq-unique-by-choose-remaining-element",
        "title": "jq unique_by - Choose remaining element"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1706200782,
                "last_edit_date": 1706200782,
                "creation_date": 1480601327,
                "answer_id": 40912740,
                "question_id": 40912672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to quote the JQ expression, e.g.:\r\n\r\n    curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq &#39;.data[] | select(.name==&quot;TestAccount&quot;).id&#39;\r\n\r\nwhen on Windows you&#39;ll need to use double quotes and escaped double quotes as in:\r\n\r\n    curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq &quot;.data[] | select(.name==\\&quot;TestAccount\\&quot;).id&quot;",
                "title": "select is not recognized as an internal or external command - jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1706200782,
        "creation_date": 1480601114,
        "last_edit_date": 1480602146,
        "question_id": 40912672,
        "body_markdown": "I had downloaded jq and trying to get a hang of it on Windows.\r\nI am able to run some basic queries in jq but when I am trying to use `select` with jq  I am getting the below mentioned message.\r\n\r\nBelow is the command which I am executing.\r\n\r\n&lt;s&gt;`curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq .data[] | select(.name==&quot;TestAccount&quot;).id`&lt;/s&gt;\r\n\r\n`curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq .data[] | select(.name==\\&quot;TestAccount\\&quot;).id`\r\n\r\n**Output**\r\n\r\n`select is not recognized as an internal or external command`\r\n\r\nI have jq in my path but not sure what I have to add in my path so that it can recognize `select as a command.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40912672/select-is-not-recognized-as-an-internal-or-external-command-jq",
        "title": "select is not recognized as an internal or external command - jq"
    },
    {
        "tags": [
            "json",
            "key",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 32,
                "is_accepted": true,
                "score": 32,
                "last_activity_date": 1731954729,
                "last_edit_date": 1731954729,
                "creation_date": 1480648303,
                "answer_id": 40924154,
                "question_id": 40923539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter [`with_entries/1`][1] is your friend, e.g.:\r\n\r\n    .activities | with_entries( select(.value | has(&quot;stop_time_utc&quot;) ) )\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;-KSndgjqvmQkWVKHCpLh&quot;: {\r\n        &quot;create_device&quot;: &quot;...&quot;,\r\n        &quot;stop_time_utc&quot;: &quot;2016-11-01T23:08:08Z&quot;\r\n      },\r\n      &quot;-KSptboGjo8g4bieUbGM&quot;: {\r\n        &quot;create_device&quot;: &quot;...&quot;,\r\n        &quot;stop_time_utc&quot;: &quot;2017-01-17T23:08:08Z&quot;\r\n      }\r\n    \r\n\r\nIt&#39;s now easy to add additional selection criteria, extract the key names of interest, etc.  For example:\r\n\r\n    .activities\r\n    | with_entries( select( (.value.stop_time_utc? | fromdateiso8601?) &lt; now ) )\r\n    | keys\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries",
                "title": "JQ: Filtering for keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 21,
        "last_activity_date": 1731954729,
        "creation_date": 1480643708,
        "last_edit_date": 1641437574,
        "question_id": 40923539,
        "body_markdown": "I&#39;m trying to use the JQ command to filter a json object to selectively extract keys.  Here&#39;s a sample object that I&#39;ve placed in file x.txt:\r\n\r\n    {\r\n      &quot;activities&quot; : {\r\n    \r\n        &quot;-KSndgjqvmQkWVKHCpLh&quot; : {\r\n          &quot;create_device&quot; : &quot;...&quot;,\r\n          &quot;stop_time_utc&quot; : &quot;2016-11-01T23:08:08Z&quot;\r\n        },\r\n    \r\n        &quot;-KSoBSrBh6PZcjRocGD7&quot; : {\r\n          &quot;create_device&quot; : &quot;...&quot;\r\n        },\r\n    \r\n        &quot;-KSptboGjo8g4bieUbGM&quot; : {\r\n          &quot;create_device&quot; : &quot;...&quot;,\r\n          &quot;stop_time_utc&quot; : &quot;2017-01-17T23:08:08Z&quot;\r\n        }\r\n    \r\n      }\r\n    }\r\n\r\nThe following command can extract all of the activity keys:\r\n\r\n    cat x.txt | jq &#39;.activities | keys&#39;\r\n    [\r\n      &quot;-KSndgjqvmQkWVKHCpLh&quot;,\r\n      &quot;-KSoBSrBh6PZcjRocGD7&quot;,\r\n      &quot;-KSptboGjo8g4bieUbGM&quot;\r\n    ]\r\n\r\nI&#39;ve been googling and experimenting for a few hours trying to filter the object to select only the activity entries that have a stop_time_utc value, and use something like a &quot;select(.stop_time_utc | fromdateiso8601 &gt; now)&quot; to only pick activities that have expired. For example, I&#39;d like to use filters to create an array from the sample object with only the one relevant entry:\r\n\r\n    [\r\n      &quot;-KSndgjqvmQkWVKHCpLh&quot;\r\n    ]\r\n\r\nIs attempting this with the keys option the wrong route?  Any ideas or suggestions would be much appreciated.",
        "link": "https://stackoverflow.com/questions/40923539/jq-filtering-for-keys",
        "title": "JQ: Filtering for keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1481009328,
                "creation_date": 1481009328,
                "answer_id": 40989990,
                "question_id": 40989786,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Read `logg.json` as an argument file. You could then access its values to make changes to the other.\r\n\r\n    $ jq --argfile logg logg.json &#39;.version.number = $logg.version.number + 1&#39; 1.json\r\n\r\nOf course you&#39;ll need to use double quotes to work in the Windows Command prompt.\r\n\r\n    &gt; jq --argfile logg logg.json &quot;.version.number = $logg.version.number + 1&quot; 1.json\r\n\r\nAlthough the documentation says to use `--slurpfile` instead, we only have a single object in the file so it would be totally appropriate to use `--argfile` instead.",
                "title": "Get field from another json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1481009638,
        "creation_date": 1481008461,
        "question_id": 40989786,
        "body_markdown": "I have two .json-files. \r\nThe first is 1.json\r\n\r\n    {\r\n    \t&quot;id&quot;: &quot;107709375&quot;,\r\n    \t&quot;type&quot;: &quot;page&quot;,\r\n    \t&quot;title&quot;: &quot;SomeTitle&quot;,\r\n    \t&quot;space&quot;: {\r\n    \t\t&quot;key&quot;: &quot;BUSINT&quot;\r\n    \t},\r\n    \t&quot;version&quot;: {\r\n    \t\t&quot;number&quot;: 62\r\n    \t}\r\n    }\r\nAnd the second one logg.json:\r\n\r\n    {\r\n    \t&quot;id&quot;: &quot;228204270&quot;,\r\n    \t&quot;type&quot;: &quot;page&quot;,\r\n    \t&quot;status&quot;: &quot;current&quot;,\r\n    \t&quot;title&quot;: &quot;test-test&quot;,\r\n    \t&quot;version&quot;: {\r\n    \t\t&quot;when&quot;: &quot;2016-11-23T16:54:18.313+07:00&quot;,\r\n    \t\t&quot;number&quot;: 17,\r\n    \t\t&quot;minorEdit&quot;: false\r\n    \t},\r\n    \t&quot;extensions&quot;: {\r\n    \t\t&quot;position&quot;: &quot;none&quot;\r\n    \t}\r\n    }\r\nCan I paste version.number from logg.json into version.number 1.json using jq? I need something like that (it&#39;s absolutely wrong):\r\n\r\n    jq-win64 &quot;.version.number 1.json&quot; = &quot;.version.number +1&quot; logg.json",
        "link": "https://stackoverflow.com/questions/40989786/get-field-from-another-json-using-jq",
        "title": "Get field from another json using jq"
    },
    {
        "tags": [
            "java",
            "spring",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1799577,
                    "reputation": 5443,
                    "user_id": 1638237,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/f04a6b7e3f9b34fef4941ae00f04009a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nafas",
                    "link": "https://stackoverflow.com/users/1638237/nafas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481020338,
                "post_id": 40992970,
                "comment_id": 69194943,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user5177570"
                },
                "reply_to_user": {
                    "account_id": 1799577,
                    "reputation": 5443,
                    "user_id": 1638237,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/f04a6b7e3f9b34fef4941ae00f04009a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nafas",
                    "link": "https://stackoverflow.com/users/1638237/nafas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481020394,
                "post_id": 40992970,
                "comment_id": 69194977,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1799577,
                    "reputation": 5443,
                    "user_id": 1638237,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/f04a6b7e3f9b34fef4941ae00f04009a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nafas",
                    "link": "https://stackoverflow.com/users/1638237/nafas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481021438,
                "post_id": 40992970,
                "comment_id": 69195610,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1481022404,
                "last_edit_date": 1481022404,
                "creation_date": 1481021167,
                "answer_id": 40993449,
                "question_id": 40992970,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think you need to try like this:\r\n\r\n    curl localhost:9200/dewikiquote/_search -d &#39;{&quot;query&quot;: {&quot;match_all&quot;:{}}}&#39; \\\r\n    | jq &#39;.[] | {title: .title, description: .description, languageKey: &quot;ja&quot;} \\\r\n    | curl -H &#39;Content-Type: application/json&#39;  -XPUT &#39;http://localhost:11223/context/api/add&#39; -d @-\r\n\r\nyou are missing the &#39;.[]&#39; array operation operator on the returned json list",
                "title": "how to split jq output at every json object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1481022450,
                "last_edit_date": 1481022450,
                "creation_date": 1481021834,
                "answer_id": 40993654,
                "question_id": 40992970,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an alternative, which loops through the results and send each individually: \r\n\r\nPlease Note the `-c` to print each output without indent.\r\n\r\n\r\n    curl localhost:9200/dewikiquote/_search -d &#39;{&quot;query&quot;: {&quot;match_all&quot;:{}}}&#39; \\\r\n    | jq &#39;.hits.hits[] | ._source&#39; \\\r\n    | jq -c &#39;{title: .heading[0], description: .text, languageKey: &quot;ja&quot;} \\\r\n    | while read next; do curl -H &#39;Content-Type: application/json&#39;  -XPUT &#39;http://localhost:11223/context/api/add&#39; -d $next; done",
                "title": "how to split jq output at every json object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1481022450,
        "creation_date": 1481019782,
        "last_edit_date": 1481020241,
        "question_id": 40992970,
        "body_markdown": "    {\r\n      &quot;title&quot;: &quot;...&quot;,\r\n      &quot;description&quot;: &quot;...&quot;,\r\n      &quot;languageKey&quot;: &quot;ja&quot;\r\n    }    {\r\n      &quot;title&quot;: &quot;...&quot;,\r\n      &quot;description&quot;: &quot;...&quot;,\r\n      &quot;languageKey&quot;: &quot;ja&quot;\r\n    }    {\r\n      &quot;title&quot;: &quot;...&quot;,\r\n      &quot;description&quot;: &quot;...&quot;,\r\n      &quot;languageKey&quot;: &quot;ja&quot;\r\n    }\r\n\r\nThis output is fed to a curl request\r\n\r\nref: https://www.elastic.co/blog/loading-wikipedia\r\n\r\n    curl localhost:9200/dewikiquote/_search -d &#39;{&quot;query&quot;: {&quot;match_all&quot;:{}}}&#39; \\\r\n    | jq &#39;.hits.hits[] | ._source&#39; \\\r\n    | jq &#39;{title: .heading[0], description: .text, languageKey: &quot;ja&quot;} \\\r\n    | curl -H &#39;Content-Type: application/json&#39;  -XPUT &#39;http://localhost:11223/context/api/add&#39; -d @-\r\n\r\nBut below java endpoint is hit only once and the map `data` has only one title, description and languagekey. Why are the other json items lost?\r\n\r\n\t@RequestMapping(path = &quot;/api/add&quot;, method = RequestMethod.PUT)\r\n\tpublic void add(@RequestBody Map&lt;String, String&gt; data)\r\n\t{ \r\n    ...\r\n\r\nIs that because the jq output is not split at every json object? if yes how do I do that with jq?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/40992970/how-to-split-jq-output-at-every-json-object",
        "title": "how to split jq output at every json object"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1481157456,
                "creation_date": 1481157456,
                "answer_id": 41029839,
                "question_id": 41029693,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not a jq expert, but conceptually what you are after is `reduce`.\r\n\r\nHere is my best guess given how I expect things to work...\r\n\r\n    reduce .[] as $item ({}; .[$item.name] = {&quot;cpu&quot; : $item.monit.cpu, &quot;memory&quot; : $item.monit.memory, &quot;pid&quot; : $item.pid})\r\n\r\nFor what it is worth, jqplay.org produces the following output for your input and that above filter:\r\n\r\n    {\r\n      &quot;myapp&quot;: {\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 13795328,\r\n        &quot;pid&quot;: 1419\r\n      },\r\n      &quot;calendar-viewer&quot;: {\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 22761472,\r\n        &quot;pid&quot;: 1425\r\n      }\r\n    }",
                "title": "How to transform a JSON array to a JSON map: one specific array element attribute value becomes the key of each map"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1481162143,
                "creation_date": 1481162143,
                "answer_id": 41030529,
                "question_id": 41029693,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your input, the filter:\r\n\r\n    map( { (.name): (.monit + {pid} ) } ) | add\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;myapp&quot;: {\r\n        &quot;memory&quot;: 13795328,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;pid&quot;: 1419\r\n      },\r\n      &quot;calendar-viewer&quot;: {\r\n        &quot;memory&quot;: 22761472,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;pid&quot;: 1425\r\n      }\r\n    }\r\n    ",
                "title": "How to transform a JSON array to a JSON map: one specific array element attribute value becomes the key of each map"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1481166380,
        "creation_date": 1481156428,
        "last_edit_date": 1481166380,
        "question_id": 41029693,
        "body_markdown": "I would like to transform the JSON of the Node.js pm2 process listing (`pm2 jlist &gt; pm2-jlist.json`) in order to feed it in a slightly different format into collectd (telemetry).\r\n\r\nInput JSON:\r\n\r\n    [\r\n        {\r\n            &quot;pid&quot;: 1419,\r\n            &quot;name&quot;: &quot;myapp&quot;,\r\n            &quot;pm_id&quot;: 0,\r\n            &quot;monit&quot;: {\r\n                &quot;memory&quot;: 13795328,\r\n                &quot;cpu&quot;: 0\r\n            }\r\n        },\r\n        {\r\n            &quot;pid&quot;: 1425,\r\n            &quot;name&quot;: &quot;calendar-viewer&quot;,\r\n            &quot;pm_id&quot;: 1,\r\n            &quot;monit&quot;: {\r\n                &quot;memory&quot;: 22761472,\r\n                &quot;cpu&quot;: 0\r\n            }\r\n        }\r\n    ]\r\n\r\nExpected Output:\r\n\r\n    {\r\n        &quot;myapp&quot;: {\r\n            &quot;cpu&quot;: 0,\r\n            &quot;memory&quot;: 14548992,\r\n            &quot;pid&quot;: 1419\r\n        },\r\n        &quot;calendar-viewer&quot;: {\r\n            &quot;cpu&quot;: 0,\r\n            &quot;memory&quot;: 16957440,\r\n            &quot;pid&quot;: 1425\r\n        }\r\n    }\r\n\r\n\r\nSo I want to convert each array element of the Input JSON array to a JSON map element as follows:\r\n\r\n1. The attribute value with the key &quot;name&quot; gets promoted to the key of that map element.\r\n\r\n2. The attributes under the &quot;monit&quot; subtree are consolidated under the key of that map (this part works already).\r\n\r\n\r\nI cannot get the desired output if the array contains more than one element.\r\n\r\nTry#1: this is almost correct but the output contains 2 json objects (invalid syntax) instead of 1 json object...\r\n\r\n    cat pm2-jlist.json | jq &#39;.[] | {(.name): {pid: .pid,cpu: .monit.cpu, memory: .monit.memory}}&#39;\r\n\r\n    {\r\n      &quot;myapp&quot;: {\r\n        &quot;pid&quot;: 1419,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 14548992\r\n      }\r\n    }\r\n    {\r\n      &quot;calendar-viewer&quot;: {\r\n        &quot;pid&quot;: 1425,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 16957440\r\n      }\r\n    }\r\n\r\n\r\nTry#2: I can filter out just 1 json object but I want all items in 1 json object...\r\n\r\n    cat pm2-jlist.json | jq &#39;.[] | select(.name == &quot;calendar-viewer&quot;)| {(.name): {pid: .pid, cpu: .monit.cpu, memory: .monit.memory}}&#39;\r\n\r\n    {\r\n      &quot;calendar-viewer&quot;: {\r\n        &quot;pid&quot;: 1425,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 16957440\r\n      }\r\n    }\r\n\r\n\r\nThanks for your time.\r\n",
        "link": "https://stackoverflow.com/questions/41029693/how-to-transform-a-json-array-to-a-json-map-one-specific-array-element-attribut",
        "title": "How to transform a JSON array to a JSON map: one specific array element attribute value becomes the key of each map"
    },
    {
        "tags": [
            "linux",
            "bash",
            "parsing",
            "jq",
            "error-suppression"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4203120,
                    "reputation": 11256,
                    "user_id": 4923629,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/2abZO.png?s=256",
                    "display_name": "123",
                    "link": "https://stackoverflow.com/users/4923629/123"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481188221,
                "post_id": 41035458,
                "comment_id": 69278415,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1810057,
                    "reputation": 21707,
                    "user_id": 1646322,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/d9fd7a75e0d8ace7bb3276476786c2c0?s=256&d=identicon&r=PG",
                    "display_name": "Ruslan Osmanov",
                    "link": "https://stackoverflow.com/users/1646322/ruslan-osmanov"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1481188228,
                "post_id": 41035458,
                "comment_id": 69278421,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1528727292,
                "last_edit_date": 1528727292,
                "creation_date": 1481190231,
                "answer_id": 41036229,
                "question_id": 41035458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want jq to ignore errors, then consider handling the error programmatically within jq, e.g.\r\n\r\n    $ jq -n &#39;try inputs catch &quot;The end&quot;&#39; &lt;&lt;&lt; &#39;silly&#39;\r\n    &quot;The end&quot;\r\n\r\n(Note the use of the -n option.)",
                "title": "Suppress JQ parse error messages in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1528727292,
        "creation_date": 1481187722,
        "question_id": 41035458,
        "body_markdown": "I am looking to parse the json file using JQ utility in bash script , though i am able to parse it correctly , whenever there&#39;s invalid json content we get parse error message on the cmd line . So Question is how do we suppress that parse error message from the screen .\r\n\r\nWhy do i want to suppress the parse error messsage ?\r\nI am running through loop for evaluating certain conditions in json file , for which i need to parse it first using jq. So whenever the script runs and it encounters invalid json which it is not able to parse we get series of parse error message on the screen , which is something i want to suppress .\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/41035458/suppress-jq-parse-error-messages-in-linux",
        "title": "Suppress JQ parse error messages in linux"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1481255281,
                "last_edit_date": 1481255281,
                "creation_date": 1481191963,
                "answer_id": 41036842,
                "question_id": 41036841,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "After doing lots of search get the best result which is given below \r\n\r\n    echo `cat $curFileName | jq &#39;.[&quot;home&quot;][][&quot;pageid&quot;]&#39; | wc -l `\r\n\r\nWhere is:\r\n\r\n- `$curFileName` = {{Path_of_json_file.json}}\r\n- `.[&quot;home&quot;][][&quot;pageid&quot;]` = target Json Object\r\n\r\njson_file.json :\r\n \r\n    {\r\n      &quot;home&quot;: [\r\n        {\r\n          &quot;pageid&quot;: &quot;about yft&quot;,\r\n          &quot;pageData&quot;: &quot;0908782&quot;\r\n        },\r\n        {\r\n          &quot;pageData&quot;: &quot;09897&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nfor more \r\nhttp://www.compciv.org/recipes/cli/jq-for-parsing-json/\r\n",
                "title": "How do I count specific JSON items in Bash, or another shell?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1481270292,
                "last_edit_date": 1481270292,
                "creation_date": 1481194428,
                "answer_id": 41037688,
                "question_id": 41036841,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Collect the `pageid` items of `&quot;string&quot;` type into an array, then return the length of the array:\r\n\r\n    n=$(jq &#39;[.home[].pageid | select(type == &quot;string&quot;)] | length&#39; &lt; file.json)\r\n\r\nAlternatively, check if the items in the `home` array have `pageid`. If the item has the property, put `1` into the result array, otherwise put zero. Finally sum the zeroes and ones with `add` function:\r\n\r\n    n=$(jq &#39;[.home[] | if has(&quot;pageid&quot;) then 1 else 0 end] | add&#39; &lt; file.json)\r\n\r\nHere is how you should print the number:\r\n\r\n    printf &#39;%d\\n&#39; &quot;$n&quot;\r\n\r\n*Sample Output*\r\n\r\n    3\r\n\r\n  [1]: http://pubs.opengroup.org/onlinepubs/007904875/utilities/xcu_chap02.html#tag_02_06_03\r\n",
                "title": "How do I count specific JSON items in Bash, or another shell?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1481353657,
                "last_edit_date": 1481353657,
                "creation_date": 1481196519,
                "answer_id": 41038384,
                "question_id": 41036841,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The input as originally given by the OP was invalid, and also didn&#39;t include an object without .pageid.  In this response, the following JSON will be used:\r\n\r\n    {\r\n      &quot;home&quot;: [\r\n        {\r\n          &quot;pageid&quot;: &quot;about yft&quot;,\r\n          &quot;pageData&quot;: &quot;0908782&quot;\r\n        },\r\n        {\r\n          &quot;pageData&quot;: &quot;09897&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nConsider now these two filters, both of which yield 1 for the above JSON:\r\n\r\n\r\n    [.home[] | select(has(&quot;pageid&quot;)) ] | length\r\n\r\n\r\n    [.home[] | .pageid//empty ] | length\r\n\r\nIf .home was huge, then a more efficient approach would be as follows:\r\n\r\n    def count(s): reduce s as $i(0; .+1);\r\n    count(.home[] | select(has(&quot;pageid&quot;)))\r\n\r\nAnd here&#39;s an efficient, one-line variant:\r\n\r\n    reduce (.home[].pageid?//empty) as $x (0; .+1)\r\n\r\n### Counting the number of distinct items\r\nTo obtain the number of **distinct** `home-&gt;pageid` items, the simplest would be to use `unique|length` rather than `length`, e.g. in either of the first two solutions above. \r\n",
                "title": "How do I count specific JSON items in Bash, or another shell?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1481353657,
        "creation_date": 1481191963,
        "last_edit_date": 1481207073,
        "question_id": 41036841,
        "body_markdown": "I have JSON data in the following form:\r\n\r\n    {\r\n    &quot;home&quot;: [{\r\n      &quot;pageid&quot;: &quot;about yft&quot;,\r\n      &quot;pageData&quot;: &quot;0908782&quot;\r\n    },\r\n\r\n    {\r\n      &quot;pageData&quot;: &quot;09897&quot;\r\n    }]}\r\n\r\n  \r\n\r\nHow do I get the total number of `home-&gt;pageid` items?\r\n\r\nHere is what I have tried so far:\r\n\r\n    $curFileName ={{Path_of_json_file.json}}\r\n    appName0=$(cat $curFileName | jq -c &#39;.[&quot;home&quot;][][&quot;pageid&quot;]&#39;  | sed &#39;s/&quot;//g&#39;);\r\n    ${#appName0[@]} # to get the length of pageid but didn&#39;t success..\r\n\r\n\r\nBut it didn&#39;t return the desired results.",
        "link": "https://stackoverflow.com/questions/41036841/how-do-i-count-specific-json-items-in-bash-or-another-shell",
        "title": "How do I count specific JSON items in Bash, or another shell?"
    },
    {
        "tags": [
            "json",
            "merge",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1481223710,
                "last_edit_date": 1481223710,
                "creation_date": 1481222896,
                "answer_id": 41046715,
                "question_id": 41045659,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes, `map` is a good way to go.  The key here is to use it with `transpose/0`, which can be used as though it were a &quot;zip&quot; function:\r\n\r\n     [.time.startPeriodName, .data.weather]\r\n     | transpose\r\n     | map( {(.[0]): .[1]})\r\n\r\nThe output begins as follows:\r\n\r\n    [\r\n      {\r\n        &quot;Today&quot;: &quot;Mostly Sunny&quot;\r\n      },\r\n      {\r\n        &quot;Tonight&quot;: &quot;Mostly Cloudy&quot;\r\n      },\r\n      ...\r\n\r\nSo, to produce a single JSON object, simply add the `add` filter to the pipeline.",
                "title": "Merge two arrays into a single object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 14,
        "last_activity_date": 1481228303,
        "creation_date": 1481219126,
        "last_edit_date": 1481228303,
        "question_id": 41045659,
        "body_markdown": "I&#39;m trying to use jq to parse a NOAA data feed into just the values I need: \r\n\r\nhttp://forecast.weather.gov/MapClick.php?FcstType=json&amp;lat=39.56&amp;lon=-104.85\r\n\r\nI&#39;m able to (separately) extract the two arrays I&#39;m looking to combine:\r\n\r\n    $ cat noaa.json | jq .time.startPeriodName\r\n    [\r\n      &quot;Today&quot;,\r\n      &quot;Tonight&quot;,\r\n      &quot;Friday&quot;,\r\n      &quot;Friday Night&quot;,\r\n      &quot;Saturday&quot;,\r\n      &quot;Saturday Night&quot;,\r\n      &quot;Sunday&quot;,\r\n      &quot;Sunday Night&quot;,\r\n      &quot;Monday&quot;,\r\n      &quot;Monday Night&quot;,\r\n      &quot;Tuesday&quot;,\r\n      &quot;Tuesday Night&quot;,\r\n      &quot;Wednesday&quot;\r\n    ]\r\n\r\n    $ cat noaa.json | jq .data.weather\r\n    [\r\n      &quot;Mostly Sunny&quot;,\r\n      &quot;Mostly Cloudy&quot;,\r\n      &quot;Mostly Sunny&quot;,\r\n      &quot;Partly Cloudy&quot;,\r\n      &quot;Slight Chance Showers&quot;,\r\n      &quot;Slight Chance Snow Showers&quot;,\r\n      &quot;Slight Chance Snow Showers then Mostly Sunny&quot;,\r\n      &quot;Mostly Clear&quot;,\r\n      &quot;Mostly Sunny&quot;,\r\n      &quot;Partly Cloudy&quot;,\r\n      &quot;Mostly Sunny&quot;,\r\n      &quot;Partly Cloudy&quot;,\r\n      &quot;Mostly Sunny&quot;\r\n    ]\r\n\r\nI&#39;d like to combine the two arrays together into a single object like this:\r\n\r\n    { \r\n       &quot;Today&quot;: &quot;Mostly Sunny&quot;,\r\n       &quot;Tonight&quot;: &quot;Mostly Cloudy&quot;,\r\n       ...\r\n       &quot;Wednesday&quot;: &quot;Mostly Sunny&quot;\r\n    }\r\n\r\nI&#39;d be grateful if someone could point me in the right direction. I feel like the answer is probably in the `map` operator, but I haven&#39;t been able to figure it out.\r\n",
        "link": "https://stackoverflow.com/questions/41045659/merge-two-arrays-into-a-single-object-with-jq",
        "title": "Merge two arrays into a single object with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1481249853,
                "post_id": 41051322,
                "comment_id": 69311626,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481269656,
                "post_id": 41051322,
                "comment_id": 69317700,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481269731,
                "post_id": 41051322,
                "comment_id": 69317730,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1481269555,
                "last_edit_date": 1481269555,
                "creation_date": 1481269179,
                "answer_id": 41055362,
                "question_id": 41051322,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq 1.3 does not always respect the ordering of keys within JSON objects.  Assuming you are using jq 1.3 (or earlier), the solution would be to upgrade to a later version (1.4, 1.5, or the &quot;master&quot; version). ",
                "title": "jq is reordering keys within my JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1481269843,
        "creation_date": 1481244024,
        "last_edit_date": 1481269843,
        "question_id": 41051322,
        "body_markdown": "For some reason, and I have no idea why, when I test out formatting of the following lines on [jqplay][1] it comes out looking different than when I run it on the command line.\r\n\r\n[My original data looks as such:][2]\r\n\r\n    {&quot;type&quot;:&quot;user.list&quot;,&quot;users&quot;:[{&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;57db1b1b9jdjd84f99b977785ba&quot;,&quot;user_id&quot;:&quot;janwjf3sqdditwn7c7&quot;,&quot;anonymous&quot;:false,&quot;email&quot;:&quot;test@diversifiedventures.net&quot;,&quot;phone&quot;:null,&quot;name&quot;:&quot;Joe Smith&quot;,&quot;pseudonym&quot;:null,&quot;avatar&quot;:{&quot;type&quot;:&quot;avatar&quot;,&quot;image_url&quot;:null},&quot;app_id&quot;:&quot;b5vkddxvop&quot;,&quot;companies&quot;:{&quot;type&quot;:&quot;company.list&quot;,&quot;companies&quot;:[]},&quot;location_data&quot;:{&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;Murfreesboro&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:35.8896,&quot;longitude&quot;:-86.3166,&quot;postal_code&quot;:&quot;37130&quot;,&quot;region_name&quot;:&quot;Tennessee&quot;,&quot;timezone&quot;:&quot;America/Chicago&quot;,&quot;country_code&quot;:&quot;USA&quot;},&quot;last_request_at&quot;:1478624249,&quot;last_seen_ip&quot;:&quot;69.139.122.123&quot;,&quot;created_at&quot;:1473977115,&quot;remote_created_at&quot;:1466313380,&quot;signed_up_at&quot;:1466313380,&quot;updated_at&quot;:1480970142,&quot;session_count&quot;:1,&quot;social_profiles&quot;:{&quot;type&quot;:&quot;social_profile.list&quot;,&quot;social_profiles&quot;:[]},&quot;unsubscribed_from_emails&quot;:false,&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko&quot;,&quot;tags&quot;:{&quot;type&quot;:&quot;tag.list&quot;,&quot;tags&quot;:[{&quot;type&quot;:&quot;tag&quot;,&quot;id&quot;:&quot;587061&quot;,&quot;name&quot;:&quot;Mixpanel Import - 2016-09-15 21:25:08 UTC&quot;}]},&quot;segments&quot;:{&quot;type&quot;:&quot;segment.list&quot;,&quot;segments&quot;:[{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;581a048c4ad88d6b458198d7&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;5845cd57c91b1fe3e440032b&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;5845cab9d951b43e7d33d2f7&quot;}]},&quot;custom_attributes&quot;:{&quot;mixpanel_id&quot;:&quot;1556710d919339-0beb72f2966b408-69581467-cff8c-1556710d91a54b&quot;,&quot;claimCount&quot;:&quot;2&quot;,&quot;memberType&quot;:&quot;claimant&quot;}}],&quot;scroll_param&quot;:&quot;56386a4d-743b-470a-ae9f-848b991e0ccc&quot;}\r\n\r\nIf you dump that into the [jq playground,][1] it formats it exactly how it should be and how I want it, [which looks like this][3]:\r\n\r\n    {&quot;type&quot;:&quot;user&quot;,&quot;id&quot;:&quot;57db1b1b9jdjd84f99b977785ba&quot;,&quot;user_id&quot;:&quot;janwjf3sqdditwn7c7&quot;,&quot;anonymous&quot;:false,&quot;email&quot;:&quot;test@diversifiedventures.net&quot;,&quot;phone&quot;:null,&quot;name&quot;:&quot;Joe Smith&quot;,&quot;pseudonym&quot;:null,&quot;avatar&quot;:{&quot;type&quot;:&quot;avatar&quot;,&quot;image_url&quot;:null},&quot;app_id&quot;:&quot;b5vkddxvop&quot;,&quot;companies&quot;:{&quot;type&quot;:&quot;company.list&quot;,&quot;companies&quot;:[]},&quot;location_data&quot;:{&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;Murfreesboro&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:35.8896,&quot;longitude&quot;:-86.3166,&quot;postal_code&quot;:&quot;37130&quot;,&quot;region_name&quot;:&quot;Tennessee&quot;,&quot;timezone&quot;:&quot;America/Chicago&quot;,&quot;country_code&quot;:&quot;USA&quot;},&quot;last_request_at&quot;:1478624249,&quot;last_seen_ip&quot;:&quot;69.139.122.123&quot;,&quot;created_at&quot;:1473977115,&quot;remote_created_at&quot;:1466313380,&quot;signed_up_at&quot;:1466313380,&quot;updated_at&quot;:1480970142,&quot;session_count&quot;:1,&quot;social_profiles&quot;:{&quot;type&quot;:&quot;social_profile.list&quot;,&quot;social_profiles&quot;:[]},&quot;unsubscribed_from_emails&quot;:false,&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko&quot;,&quot;tags&quot;:{&quot;type&quot;:&quot;tag.list&quot;,&quot;tags&quot;:[{&quot;type&quot;:&quot;tag&quot;,&quot;id&quot;:&quot;587061&quot;,&quot;name&quot;:&quot;Mixpanel Import - 2016-09-15 21:25:08 UTC&quot;}]},&quot;segments&quot;:{&quot;type&quot;:&quot;segment.list&quot;,&quot;segments&quot;:[{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;581a048c4ad88d6b458198d7&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;5845cd57c91b1fe3e440032b&quot;},{&quot;type&quot;:&quot;segment&quot;,&quot;id&quot;:&quot;5845cab9d951b43e7d33d2f7&quot;}]},&quot;custom_attributes&quot;:{&quot;mixpanel_id&quot;:&quot;1556710d919339-0beb72f2966b408-69581467-cff8c-1556710d91a54b&quot;,&quot;claimCount&quot;:&quot;2&quot;,&quot;memberType&quot;:&quot;claimant&quot;}}\r\n\r\nThat is precisely how I want the data to be restructured.\r\n\r\nGo to the link for jqplay and see for yourselft, by simply typing this into the filter and clicking the compact output:\r\n\r\n    .users[] \r\n\r\nBut for some reason when I run this in the command line:\r\n\r\n    curl https://api.example.com/users/scroll -u &#39;dG9rOjg4YmUxMzr4XzJmNzZfNDkwY3934jU2X2mrM2MxZGEzYWI2MzoxOjA=&#39;: -H &#39;Accept:application/json&#39;| jq -c &#39;.users[]&#39;\r\n\r\n[It spits out a result that is totally not formmated how it is suppose to come out, despite using the exact same filter][4]:\r\n\r\n    {&quot;custom_attributes&quot;:{&quot;memberType&quot;:&quot;claimant&quot;,&quot;claimCount&quot;:&quot;2&quot;,&quot;mixpanel_id&quot;:&quot;1556710d919339-0beb72f2966b408-69581467-cff8c-1556710d91a54b&quot;},&quot;segments&quot;:{&quot;segments&quot;:[{&quot;id&quot;:&quot;581a048c4ad88d6b458198d7&quot;,&quot;type&quot;:&quot;segment&quot;},{&quot;id&quot;:&quot;5845cd57c91b1fe3e440032b&quot;,&quot;type&quot;:&quot;segment&quot;},{&quot;id&quot;:&quot;5845cab9d951b43e7d33d2f7&quot;,&quot;type&quot;:&quot;segment&quot;}],&quot;type&quot;:&quot;segment.list&quot;},&quot;tags&quot;:{&quot;tags&quot;:[{&quot;name&quot;:&quot;Mixpanel Import - 2016-09-15 21:25:08 UTC&quot;,&quot;id&quot;:&quot;587061&quot;,&quot;type&quot;:&quot;tag&quot;}],&quot;type&quot;:&quot;tag.list&quot;},&quot;user_agent_data&quot;:&quot;Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko&quot;,&quot;unsubscribed_from_emails&quot;:false,&quot;social_profiles&quot;:{&quot;social_profiles&quot;:[],&quot;type&quot;:&quot;social_profile.list&quot;},&quot;session_count&quot;:1,&quot;updated_at&quot;:1480970142,&quot;signed_up_at&quot;:1466313380,&quot;pseudonym&quot;:null,&quot;name&quot;:&quot;Joe Smith&quot;,&quot;phone&quot;:null,&quot;email&quot;:&quot;test@diversifiedventures.net&quot;,&quot;anonymous&quot;:false,&quot;user_id&quot;:&quot;janwjf3sqdditwn7c7&quot;,&quot;id&quot;:&quot;57db1b1b9jdjd84f99b977785ba&quot;,&quot;type&quot;:&quot;user&quot;,&quot;avatar&quot;:{&quot;image_url&quot;:null,&quot;type&quot;:&quot;avatar&quot;},&quot;app_id&quot;:&quot;b5vkddxvop&quot;,&quot;companies&quot;:{&quot;companies&quot;:[],&quot;type&quot;:&quot;company.list&quot;},&quot;location_data&quot;:{&quot;country_code&quot;:&quot;USA&quot;,&quot;timezone&quot;:&quot;America/Chicago&quot;,&quot;type&quot;:&quot;location_data&quot;,&quot;city_name&quot;:&quot;Murfreesboro&quot;,&quot;continent_code&quot;:&quot;NA&quot;,&quot;country_name&quot;:&quot;United States&quot;,&quot;latitude&quot;:35.8896,&quot;longitude&quot;:-86.3166,&quot;postal_code&quot;:&quot;37130&quot;,&quot;region_name&quot;:&quot;Tennessee&quot;},&quot;last_request_at&quot;:1478624249,&quot;last_seen_ip&quot;:&quot;69.139.122.123&quot;,&quot;created_at&quot;:1473977115,&quot;remote_created_at&quot;:1466313380}\r\n\r\nWhich as you can tell, is nothing like how it turns out in the jqplayground feature. To make matters even more confusing, someone else ran it and it formatted it correctly. On top of that, about a week ago, it worked fine for me.\r\n\r\nI&#39;ve also tried removing jq and reinstalling it with no success. I&#39;m running it on Ubuntu 14.04.2 LTS (GNU/Linux 3.13.0-51-generic x86_64) if that somehow helps.\r\n\r\nAny help would be greatly appreciated!\r\n\r\n  [1]: https://jqplay.org/#\r\n  [2]: http://pastebin.com/ew4AAkrY\r\n  [3]: http://pastebin.com/en8gSXbs\r\n  [4]: http://pastebin.com/Bhqt9wQJ",
        "link": "https://stackoverflow.com/questions/41051322/jq-is-reordering-keys-within-my-json",
        "title": "jq is reordering keys within my JSON"
    },
    {
        "tags": [
            "json",
            "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": 1,
                "creation_date": 1481473205,
                "post_id": 41082241,
                "comment_id": 69381376,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1481426536,
                "creation_date": 1481426536,
                "answer_id": 41082653,
                "question_id": 41082241,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With jq:\r\n\r\n    $ jq -nR &#39;[inputs | split(&quot; &quot;) | {&quot;From&quot;: .[0], &quot;To&quot;: .[1]}]&#39; &lt;&lt;EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n    \r\n    [\r\n      {\r\n        &quot;From&quot;: &quot;foo&quot;,\r\n        &quot;To&quot;: &quot;bar&quot;\r\n      },\r\n      {\r\n        &quot;From&quot;: &quot;what&quot;,\r\n        &quot;To&quot;: &quot;ever&quot;\r\n      }\r\n    ]\r\n\r\n`-n` tells jq to not read any input; `-R` is for raw input so it doesn&#39;t expect JSON.\r\n\r\nThe input is read with `inputs`, resulting in one string per input line:\r\n\r\n    $ jq -nR &#39;inputs&#39; &lt;&lt;EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n    &quot;foo bar&quot;\r\n    &quot;what ever&quot;\r\n\r\nThese are then split into arrays of words:\r\n\r\n    $ jq -nR &#39;inputs | split(&quot; &quot;)&#39; &lt;&lt;EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n    [\r\n      &quot;what&quot;,\r\n      &quot;ever&quot;\r\n    ]\r\n\r\nFrom this, we construct the objects:\r\n\r\n    $ jq -nR &#39;inputs | split(&quot; &quot;) | {&quot;From&quot;: .[0], &quot;To&quot;: .[1]}&#39; &lt;&lt;EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n    \r\n    {\r\n      &quot;From&quot;: &quot;foo&quot;,\r\n      &quot;To&quot;: &quot;bar&quot;\r\n    }\r\n    {\r\n      &quot;From&quot;: &quot;what&quot;,\r\n      &quot;To&quot;: &quot;ever&quot;\r\n    }\r\n\r\nAnd finally, we wrap everything in `[]` to get the final output shown first.\r\n\r\nThe more intuitive approach of splitting input directly fails because wrapping everything in `[]` results in one array per input line:\r\n\r\n    $ jq -R &#39;[split(&quot; &quot;) | { &quot;From&quot;: .[0], &quot;To&quot;: .[1] }]&#39; &lt;&lt;EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n    \r\n    [\r\n      {\r\n        &quot;From&quot;: &quot;foo&quot;,\r\n        &quot;To&quot;: &quot;bar&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;From&quot;: &quot;what&quot;,\r\n        &quot;To&quot;: &quot;ever&quot;\r\n      }\r\n    ]\r\n\r\nHence the somewhat cumbersome `-n`/`inputs`. Notice that `inputs` requires jq version 1.5.",
                "title": "Shell while loop to JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1481428386,
                "last_edit_date": 1481428386,
                "creation_date": 1481426969,
                "answer_id": 41082697,
                "question_id": 41082241,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s an all-jq solution that assumes the &quot;From&quot; and &quot;To&quot; values are presented exactly as in your example:\r\n\r\n    jq -R -n &#39;[inputs | split(&quot; &quot;) | {From: .[0], To: .[1]}]&#39;\r\n\r\nYou might want to handle additional spaces using `gsub/2`.\r\n\r\nIf your jq does not have `inputs` then you can use this incantation:\r\n\r\n\r\n    jq -R -s &#39;split(&quot;\\n&quot;)\r\n      | map(select(length&gt;1) | split(&quot; &quot;) | {From: .[0], To: .[1]})&#39;\r\n\r\nOr you could just pipe the output from your while-loop into `jq -s`.  \r\n\r\n\r\n",
                "title": "Shell while loop to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1481428386,
        "creation_date": 1481421246,
        "last_edit_date": 1495541633,
        "question_id": 41082241,
        "body_markdown": "I have a while loop with two variables I have to merge into a single piece of JSON, like so:\r\n\r\n    #!/bin/bash\r\n    while read -r from to\r\n    do\r\n        # BONUS: Solution would ideally require no quoting at this point\r\n    \techo { \\&quot;From\\&quot;: \\&quot;$from\\&quot;, \\&quot;To\\&quot;: \\&quot;$to\\&quot; } \r\n    done &lt;&lt; EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n\r\nWhich currently outputs invalid JSON:\r\n\r\n    { &quot;From&quot;: &quot;foo&quot;, &quot;To&quot;: &quot;bar&quot; }\r\n    { &quot;From&quot;: &quot;what&quot;, &quot;To&quot;: &quot;ever&quot; }\r\n\r\nWhat&#39;s the simplest I can create valid JSON like:\r\n\r\n    [\r\n    { &quot;From&quot;: &quot;foo&quot;, &quot;To&quot;: &quot;bar&quot; },\r\n    { &quot;From&quot;: &quot;what&quot;, &quot;To&quot;: &quot;ever&quot; }\r\n    ]\r\n\r\nI looked at `jq` but I couldn&#39;t figure out how to do it. I&#39;m not [looking to do it in shell](https://stackoverflow.com/a/30923164/4534) ideally because I feel adding commas and such is a bit ugly.",
        "link": "https://stackoverflow.com/questions/41082241/shell-while-loop-to-json",
        "title": "Shell while loop to JSON"
    },
    {
        "tags": [
            "amazon-s3",
            "amazon-redshift",
            "jq",
            "array-merge"
        ],
        "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": 1481506497,
                "post_id": 41092891,
                "comment_id": 69390978,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1481506279,
                "creation_date": 1481506279,
                "answer_id": 41093053,
                "question_id": 41092891,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So if by &quot;merge&quot; you mean to combine the `&quot;entries&quot;` arrays into a single array by concatenating them, you could do this:\r\n\r\n    $ jq &#39;reduce inputs as $i (.; .entries += $i.entries)&#39; manifest_file{1,2}.json\r\n\r\nWhich yields:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;url&quot;: &quot;DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz&quot;\r\n        },\r\n        {\r\n          &quot;url&quot;: &quot;DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "merging s3 manifest files using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1481514346,
                "last_edit_date": 1481514346,
                "creation_date": 1481511174,
                "answer_id": 41093549,
                "question_id": 41092891,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Or, without resorting to `reduce`:\r\n\r\n    $ jq -n &#39;{entries: [inputs.entries[]]}&#39; manifest_file_{1,2}.json\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;url&quot;: &quot;DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz&quot;\r\n        },\r\n        {\r\n          &quot;url&quot;: &quot;DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz&quot;\r\n        }\r\n     ]\r\n    }\r\n\r\nNote that `inputs` was introduced in jq version 1.5.  If your jq does not have `inputs`, you can use `jq -s` as follows:\r\n\r\n    $ jq -s &#39;{entries: [.[].entries[]]}&#39; manifest_file_{1,2}.json\r\n",
                "title": "merging s3 manifest files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1481581386,
        "creation_date": 1481504572,
        "last_edit_date": 1481581386,
        "question_id": 41092891,
        "body_markdown": "I have multiple s3 manifest files each corresponding to a date for a given date range. I am looking to merge all of the manifest files to generate a single manifest file, thus allowing me to perform a single Redshift copy.\r\n\r\n**manifest file 1:**\r\n\r\n    {\r\n        &quot;entries&quot;: [\r\n            {\r\n                &quot;url&quot;: &quot;DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n**manifest file 2:**\r\n\r\n    {\r\n        &quot;entries&quot;: [\r\n            {\r\n                &quot;url&quot;: &quot;DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI am looking for an output like:- \r\n\r\n    {\r\n        &quot;entries&quot;: [\r\n             {\r\n                &quot;url&quot;: &quot;DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz&quot;\r\n             },\r\n             {\r\n                &quot;url&quot;: &quot;DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz&quot;\r\n             }\r\n        ]\r\n    }\r\n\r\nI did try \r\n\r\n    jq -s &#39;.[]&#39; &quot;manifest_file1.json&quot; &quot;manifest_file2.json&quot; \r\n\r\nand other suggestions posted in Stackoverflow but couldn&#39;t make it work.",
        "link": "https://stackoverflow.com/questions/41092891/merging-s3-manifest-files-using-jq",
        "title": "merging s3 manifest files using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1481586137,
                "creation_date": 1481586137,
                "answer_id": 41111516,
                "question_id": 41111477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The top-level object in your json is an object, not an array.  So `.[]` would only yield its values and discard the keys. Use [`with_entries/1`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) to filter that object.  This converts an object to an array of key/value pairs and back with which you can apply filters to.\r\n\r\n    $ jq --arg key &#39;svc&#39; &#39;with_entries(select(any(.value[]; . == $key)))&#39; list.json\r\n\r\nAlso, you should avoid using `contains/1` here.  It&#39;s applied recursively so it will also match strings that contain the substring `svc`.  i.e., `&quot;Foosvcbar&quot;` will be matched.",
                "title": "jq find keys whose value is an array containing a specific element"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1481604535,
                "last_edit_date": 1481604535,
                "creation_date": 1481600077,
                "answer_id": 41113328,
                "question_id": 41111477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your input, the following filter yields the output as shown:\r\n\r\n    to_entries[] | select( .value | index(&quot;svc&quot;) ) | .key\r\n\r\nOutput:\r\n\r\n    &quot;ContentKey--4-0-47--zjOkiQ&quot;\r\n    &quot;IdGenService--2001-4-22--CJUFaMQ&quot;\r\n    &quot;IdGenService--2001-4-22--Uhf9CTQ&quot;\r\n\r\nIn cases like this, using `index/1` is both simpler and (potentially much) faster than using `any/2`.",
                "title": "jq find keys whose value is an array containing a specific element"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1481604732,
        "creation_date": 1481585825,
        "last_edit_date": 1481604732,
        "question_id": 41111477,
        "body_markdown": "the file is\r\n\r\n    {\r\n    \t&quot;ContentKey--4-0-47--Vovb1BQ&quot;: [&quot;infra&quot;, &quot;qa&quot;, &quot;qa-ContentKey-4-0-47-Vovb1BQ&quot;, &quot;internal-qa-Conten-WebServi-19E4PUWHRGD44-460820639.us-east-1.elb.amazonaws.com&quot;, &quot;plan--default&quot;],\r\n    \t&quot;ContentKey--4-0-47--zjOkiQ&quot;: [&quot;svc&quot;, &quot;dev&quot;, &quot;dev-ContentKey-4-0-47-zjOkiQ&quot;, &quot;dev-Conte-WebServi-KXJXZBDY113W-2116785917.us-east-1.elb.amazonaws.com&quot;, &quot;plan--default&quot;],\r\n    \t&quot;IdGenService--2001-4-22--CJUFaMQ&quot;: [&quot;svc&quot;, &quot;dev&quot;, &quot;dev-IdGenService-2001-4-22-CJUFaMQ&quot;, &quot;dev-IdGen-WebServi-R7RVXSYAV92W-304073075.us-east-1.elb.amazonaws.com&quot;],\r\n    \t&quot;IdGenService--2001-4-22--Uhf9CTQ&quot;: [&quot;svc&quot;, &quot;qa&quot;, &quot;qa-IdGenService-2001-4-22-Uhf9CTQ&quot;, &quot;internal-qa-IdGenS-WebServi-RT5BI5EEVZP3-665537643.us-east-1.elb.amazonaws.com&quot;]\r\n    }\r\n\r\nI want to find the list of keys whose array value have the entry `svc`\r\n\r\ni could get the following to work\r\n\r\n    cat list.json | jq &#39;. | map(select (. | contains([&quot;svc&quot;])))&#39;\r\n\r\nBut the output is the value array and not the key itself\r\n\r\n    [\r\n      [\r\n        &quot;svc&quot;,\r\n        &quot;dev&quot;,\r\n        &quot;dev-ContentKey-4-0-47-zjOkiQ&quot;,\r\n        &quot;dev-Conte-WebServi-KXJXZBDY113W-2116785917.us-east-1.elb.amazonaws.com&quot;,\r\n        &quot;plan--default&quot;\r\n      ],\r\n      [\r\n        &quot;svc&quot;,\r\n        &quot;dev&quot;,\r\n        &quot;dev-IdGenService-2001-4-22-CJUFaMQ&quot;,\r\n        &quot;dev-IdGen-WebServi-R7RVXSYAV92W-304073075.us-east-1.elb.amazonaws.com&quot;\r\n      ],\r\n      [\r\n        &quot;svc&quot;,\r\n        &quot;qa&quot;,\r\n        &quot;qa-IdGenService-2001-4-22-Uhf9CTQ&quot;,\r\n        &quot;internal-qa-IdGenS-WebServi-RT5BI5EEVZP3-665537643.us-east-1.elb.amazonaws.com&quot;\r\n      ]\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41111477/jq-find-keys-whose-value-is-an-array-containing-a-specific-element",
        "title": "jq find keys whose value is an array containing a specific element"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "return-code"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481644660,
                "post_id": 41124355,
                "comment_id": 69454521,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481646154,
                "post_id": 41124355,
                "comment_id": 69455498,
                "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": 1481646973,
                "post_id": 41124355,
                "comment_id": 69456063,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "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": 1481647118,
                "post_id": 41124355,
                "comment_id": 69456156,
                "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": 1481647215,
                "post_id": 41124355,
                "comment_id": 69456227,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 46,
                "is_accepted": false,
                "score": 45,
                "last_activity_date": 1481645252,
                "last_edit_date": 1481645252,
                "creation_date": 1481644452,
                "answer_id": 41125261,
                "question_id": 41124355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `-e / --exit-status` flag from the [`jq Manual`](https://stedolan.github.io/jq/manual/), which says\r\n\r\n&gt;Sets the exit status of jq to 0 if the last output values was neither false nor null, 1 if the last output value was either false or null, or 4 if no valid result was ever produced. Normally jq exits with 2 if there was any usage problem or system error, 3 if there was a jq program compile error, or 0 if the jq program ran.\r\n\r\nI can demonstrate the usage with a basic filter as below, as your given example is not working for me.\r\n\r\nFor a successful query,\r\n\r\n    dudeOnMac:~$ jq -e &#39;.foo?&#39; &lt;&lt;&lt; &#39;{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}&#39;\r\n    42\r\n    dudeOnMac:~$ echo $?\r\n    0\r\n\r\nFor an invalid query, done with a non-existent entity `zoo`, \r\n\r\n    dudeOnMac:~$ jq -e &#39;.zoo?&#39; &lt;&lt;&lt; &#39;{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}&#39;\r\n    null\r\n    dudeOnMac:~$ echo $?\r\n    1\r\n\r\nFor an error scenario, returning code `2` which I created by double-quoting the `jq` input stream.\r\n\r\n    dudeOnMac:~$ jq -e &#39;.zoo?&#39; &lt;&lt;&lt; &quot;{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}&quot;\r\n    jq: error: Could not open file interesting: No such file or directory\r\n    jq: error: Could not open file data}: No such file or directory\r\n    dudeOnMac:~$ echo $?\r\n    2",
                "title": "How can I tell if a jq filter successfully pulls data from a JSON data structure?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1481654613,
                "last_edit_date": 1481654613,
                "creation_date": 1481651622,
                "answer_id": 41127561,
                "question_id": 41124355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;ve found a solution that meets all of my requirements!  Please let me know what you think!\r\n\r\nThe idea is use `jq -e &quot;$Filter&quot;` as a first-pass check. Then for the return code of 1, do a `jq &quot;path($Filter)&quot;` check. The latter will only succeed if, in fact, there is a path into the JSON data.\r\n\r\n**Select.sh**\r\n\r\n    #!/bin/bash\r\n    \r\n    Select()\r\n    {\r\n       local Name=&quot;$1&quot;\r\n       local Filter=&quot;$2&quot;\r\n       local Input=&quot;$3&quot;\r\n       local Result Status\r\n    \r\n       Result=&quot;$(jq -e --arg Name &quot;$Name&quot; &quot;$Filter&quot; &lt;&lt;&lt;&quot;$Input&quot;)&quot;\r\n       Status=$?\r\n    \r\n       case $Status in\r\n       1) jq --arg Name &quot;$Name&quot; &quot;path($Filter)&quot; &lt;&lt;&lt;&quot;$Input&quot; &gt;/dev/null 2&gt;&amp;1\r\n          Status=$?\r\n          ;;\r\n       *) ;;\r\n       esac\r\n    \r\n       [[ $Status -eq 0 ]] || Result=&quot;***ERROR***&quot;\r\n       echo &quot;$Status $Result&quot;\r\n    }\r\n    \r\n    Filter=&#39;.[]|select(.user == $Name)|.value&#39;\r\n    Input=&#39;[\r\n       {&quot;user&quot;:&quot;steve&quot;, &quot;value&quot;:false},\r\n       {&quot;user&quot;:&quot;tom&quot;, &quot;value&quot;:true},\r\n       {&quot;user&quot;:&quot;pat&quot;, &quot;value&quot;:null},\r\n       {&quot;user&quot;:&quot;jane&quot;, &quot;value&quot;:&quot;&quot;}\r\n    ]&#39;\r\n     \r\n    Select steve &quot;$Filter&quot; &quot;$Input&quot;\r\n    Select tom   &quot;$Filter&quot; &quot;$Input&quot;\r\n    Select pat   &quot;$Filter&quot; &quot;$Input&quot;\r\n    Select jane  &quot;$Filter&quot; &quot;$Input&quot;\r\n    Select mary  &quot;$Filter&quot; &quot;$Input&quot;\r\n\r\nAnd the execution of the above:\r\n\r\n    % ./Select.sh\r\n    0 false\r\n    0 true\r\n    0 null\r\n    0 &quot;&quot;\r\n    4 ***ERROR***\r\n",
                "title": "How can I tell if a jq filter successfully pulls data from a JSON data structure?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1481661917,
                "last_edit_date": 1481661917,
                "creation_date": 1481656490,
                "answer_id": 41128855,
                "question_id": 41124355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given that jq is the way it is, and in particular that it is stream-oriented, I&#39;m inclined to think that a better approach would be to define and use one or more filters that make the distinctions you want. Thus rather than writing `.a` to access the value of a field, you&#39;d write `get(&quot;a&quot;)` assuming that get/1 is defined as follows:\r\n\r\n    def get(f): if has(f) then .[f] else error(&quot;\\(type) is not defined at \\(f)&quot;) end;\r\n\r\nNow you can easily tell whether or not an object has a key, and you&#39;re all set to go.  This definition of `get` can also be used with arrays.",
                "title": "How can I tell if a jq filter successfully pulls data from a JSON data structure?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1481922975,
                "last_edit_date": 1481922975,
                "creation_date": 1481658018,
                "answer_id": 41129248,
                "question_id": 41124355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "_**I&#39;ve added an updated solution below**_\r\n\r\nThe fundamental problem here is that when try to retrieve a value from an object using the `.key` or `.[key]` syntax, `jq` — by [definition](https://stedolan.github.io/jq/manual/#.foo,.foo.bar) — can&#39;t distinguish a missing key from a key with a value of `null`.\r\n\r\nYou can instead define your own lookup function:\r\n\r\n    def lookup(k):if has(k) then .[k] else error(&quot;invalid key&quot;) end;\r\n\r\nThen use it like so:\r\n\r\n    $ jq &#39;lookup(&quot;a&quot;)&#39; &lt;&lt;&lt;&#39;{}&#39; ; echo $?\r\n    jq: error (at &lt;stdin&gt;:1): invalid key\r\n    5\r\n    \r\n    $ jq &#39;lookup(&quot;a&quot;)&#39; &lt;&lt;&lt;&#39;{&quot;a&quot;:null}&#39; ; echo $?\r\n    null\r\n    0\r\n\r\nIf you then use `lookup` consistently instead of the builtin method, I think that will give you the behaviour you want.\r\n\r\n---\r\n\r\nHere&#39;s another way to go about it, with less `bash` and more `jq`.\r\n\r\n\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    #!/bin/bash\r\n    \r\n    lib=&#39;def value(f):((f|tojson)//error(&quot;no such value&quot;))|fromjson;&#39;\r\n    \r\n    users=( steve tom pat jane mary )\r\n    \r\n    Select () {\r\n      local name=$1 filter=$2 input=$3\r\n      local -i status=0\r\n      result=$( jq --arg name &quot;$name&quot; &quot;${lib}value(${filter})&quot; &lt;&lt;&lt;$input  2&gt;/dev/null )\r\n      status=$? \r\n      (( status )) &amp;&amp; result=&quot;***ERROR***&quot;\r\n      printf &#39;%s\\t%d %s\\n&#39; &quot;$name&quot; $status &quot;$result&quot;\r\n    }\r\n    \r\n    filter=&#39;.[]|select(.user == $name)|.value&#39;\r\n    \r\n    input=&#39;[{&quot;user&quot;:&quot;steve&quot;,&quot;value&quot;:false},\r\n            {&quot;user&quot;:&quot;tom&quot;,&quot;value&quot;:true},\r\n            {&quot;user&quot;:&quot;pat&quot;,&quot;value&quot;:null},\r\n            {&quot;user&quot;:&quot;jane&quot;,&quot;value&quot;:&quot;&quot;}]&#39;\r\n    \r\n    for name in &quot;${users[@]}&quot;\r\n    do\r\n      Select &quot;$name&quot; &quot;$filter&quot; &quot;$input&quot;\r\n    done\r\n\r\nThis produces the output:\r\n\r\n    steve   0 false\r\n    tom     0 true\r\n    pat     0 null\r\n    jane    0 &quot;&quot;\r\n    mary    5 ***ERROR***\r\n   \r\nThis takes advantage of the fact the absence of input to a filter acts like `empty`, and empty will trigger the alternative of `//`, but a string — like `&quot;null&quot;` or `&quot;false&quot;` — will not.\r\n   \r\nIt should be noted that `value/1` will not work for filters that are simple key/index\r\nlookups on objects/arrays, but neither will your solution. I&#39;m reasonably sure that to\r\n cover all the cases, you&#39;d need something like this (or yours) **_and_** something\r\n like `get` or `lookup`.\r\n\r\n",
                "title": "How can I tell if a jq filter successfully pulls data from a JSON data structure?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 32,
        "last_activity_date": 1481922975,
        "creation_date": 1481641638,
        "last_edit_date": 1481673456,
        "question_id": 41124355,
        "body_markdown": "I want to know if a given filter succeeds in pulling data from a JSON data structure.  For example:\r\n\r\n    ###### For the user steve...\r\n\r\n    % Name=steve\r\n    % jq -j --arg Name &quot;$Name&quot; &#39;.[]|select(.user == $Name)|.value&#39; &lt;&lt;&lt;&#39;\r\n    [\r\n       {&quot;user&quot;:&quot;steve&quot;, &quot;value&quot;:false},\r\n       {&quot;user&quot;:&quot;tom&quot;, &quot;value&quot;:true},\r\n       {&quot;user&quot;:&quot;pat&quot;, &quot;value&quot;:null},\r\n       {&quot;user&quot;:&quot;jane&quot;, &quot;value&quot;:&quot;&quot;}\r\n    ]&#39;\r\n    false\r\n    % echo $?\r\n    0\r\n\r\n**Note:** successful results can include boolean values, `null`, and even the empty string.\r\n\r\n    ###### Now for user not in the JSON data...\r\n\r\n    % Name=mary\r\n    % jq -j --arg Name &quot;$Name&quot; &#39;.[]|select(.user == $Name)|.value&#39; &lt;&lt;&lt;&#39;\r\n    [\r\n       {&quot;user&quot;:&quot;steve&quot;, &quot;value&quot;:false},\r\n       {&quot;user&quot;:&quot;tom&quot;, &quot;value&quot;:true},\r\n       {&quot;user&quot;:&quot;pat&quot;, &quot;value&quot;:null},\r\n       {&quot;user&quot;:&quot;jane&quot;, &quot;value&quot;:&quot;&quot;}\r\n    ]&#39;\r\n    % echo $?\r\n    0\r\n\r\nIf the filter does not pull data from the JSON data structure, I need to know this. I would prefer the filter to return a non-zero return code. \r\n\r\nHow would I go about determining if a selector successfully pulls data from a JSON data structure vs. fails to pull data?\r\n\r\n**Important:** The above filter is just an example, the solution needs to work for any jq filter.\r\n\r\n**Note:** the evaluation environment is Bash 4.2+.",
        "link": "https://stackoverflow.com/questions/41124355/how-can-i-tell-if-a-jq-filter-successfully-pulls-data-from-a-json-data-structure",
        "title": "How can I tell if a jq filter successfully pulls data from a JSON data structure?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1481745844,
                "creation_date": 1481745844,
                "answer_id": 41151246,
                "question_id": 41150539,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I don&#39;t think this is the simplest way to do it, but it seems to work:\r\n\r\n    $ jq -r &#39;.blockdevices[] | .. | objects | select(has(&quot;children&quot;)|not)| .name&#39; tmp.json\r\n    sda1\r\n    sda2_mapper\r\n    sda3\r\n    sda4\r\n    sdb1\r\n    sdb2\r\n    sdc\r\n\r\nIt recursively outputs each value found in the JSON, filtering out first anything that is not an object, then any object that has a `children` key. Finally, you can select the `name` value from each remaining object.\r\n",
                "title": "Parsing JSON format with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1481745872,
                "creation_date": 1481745872,
                "answer_id": 41151256,
                "question_id": 41150539,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your JSON input, the following command:\r\n\r\n    jq &#39;.. | scalars&#39; \r\n\r\nemits the &quot;leaves&quot;, beginning:\r\n\r\n    &quot;sda&quot;\r\n    &quot;sda1&quot;\r\n    &quot;/sda1/mountpoint&quot;\r\n\r\nUse the -r (raw output) to strip the quotation marks from strings.\r\n",
                "title": "Parsing JSON format with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1481745872,
        "creation_date": 1481743320,
        "question_id": 41150539,
        "body_markdown": "I need to parse the output from `lsblk`. Since I am doing this from within a script I need the output in a standardized format. Therefore I chose the JSON format as output. Here is the command with some sample output:\r\n\r\n    # lsblk -o NAME,MOUNTPOINT -J\r\n    {\r\n       &quot;blockdevices&quot;: [\r\n          {&quot;name&quot;: &quot;sda&quot;, &quot;mountpoint&quot;: null,\r\n             &quot;children&quot;: [\r\n                {&quot;name&quot;: &quot;sda1&quot;, &quot;mountpoint&quot;: &quot;/sda1/mountpoint&quot;},\r\n                {&quot;name&quot;: &quot;sda2&quot;, &quot;mountpoint&quot;: null,\r\n                   &quot;children&quot;: [\r\n                      {&quot;name&quot;: &quot;sda2_mapper&quot;, &quot;mountpoint&quot;: &quot;/sda2/mountpoint&quot;}\r\n                   ]\r\n                },\r\n                {&quot;name&quot;: &quot;sda3&quot;, &quot;mountpoint&quot;: null},\r\n                {&quot;name&quot;: &quot;sda4&quot;, &quot;mountpoint&quot;: null}\r\n             ]\r\n          },\r\n          {&quot;name&quot;: &quot;sdb&quot;, &quot;mountpoint&quot;: null,\r\n             &quot;children&quot;: [\r\n                {&quot;name&quot;: &quot;sdb1&quot;, &quot;mountpoint&quot;: &quot;/sdb1/mountpoint&quot;},\r\n                {&quot;name&quot;: &quot;sdb2&quot;, &quot;mountpoint&quot;: null}\r\n             ]\r\n          },\r\n          {&quot;name&quot;: &quot;sdc&quot;, &quot;mountpoint&quot;: null}\r\n       ]\r\n    }\r\n\r\nI want to extract the names of all *innermost* nodes, i.e., the name of all nodes that do not have children. The desired output for the above sample would be:\r\n\r\n    sda1\r\n    sda2_mapper\r\n    sda3\r\n    sda4\r\n    sdb1\r\n    sdb2\r\n    sdc\r\n\r\nMy tool of choice is `jq` which I have only recently discovered. I have tried\r\n\r\n    # jq &#39;.blockdevices[].children[]?.name?&#39;\r\n\r\nBut this only filters the first level of names. I also tried with\r\n\r\n    # jq &#39;recurse(.name?)&#39;\r\n\r\nbut this returns the entire file.\r\n\r\nIs there a way to return only nodes that do not have children, no matter how deep they are nested?\r\n\r\n\r\nPS: I am capable of implementing the requirement in `bash` or `awk`. I would, however, prefer a solution with a tool like `jq`, which specific purpose is to parse json files.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41150539/parsing-json-format-with-jq",
        "title": "Parsing JSON format with jq"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1481776134,
                "creation_date": 1481776134,
                "answer_id": 41156445,
                "question_id": 41156118,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Read the other file in as an argument file, then assign the new message value from the file.  You can obtain a stringified version of the current object using `tojson` (or `@json`).\r\n\r\n    $ jq --argfile file file.json &#39;.Records[0].Sns.Message = ($file | tojson)&#39; input.json",
                "title": "How to JSON.stringify insert a file into a JSON message?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1481790888,
                "creation_date": 1481790888,
                "answer_id": 41159668,
                "question_id": 41156118,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a slightly different approach that is also more general.\r\n\r\nSuppose we want to assign a value to the &quot;Message&quot; field, wherever it occurs (and no matter how often it occurs), without having to worry about the details.  \r\n\r\nTo do this with complete generality, here&#39;s a function that takes a field name (a JSON string) and the desired value:\r\n\r\n    def setall(key; value):\r\n      walk(if type == &quot;object&quot; and has(key) then .[key] = value else . end);\r\n\r\n(In case your jq does not have `walk/1`, its definition, as given in jq&#39;s builtin.jq, is included below.)\r\n\r\nTo solve the original problem, the filter to use would be:\r\n\r\n    setall( &quot;Message&quot;; $file|tojson )\r\n\r\nwhere $file can be defined on the command line as follows:\r\n\r\n    $ jq --argfile file file.json -f setall.jq input.json\r\n\r\nHere it has been assumed that all the jq bits have been placed in a file named setall.jq.\r\n\r\n\r\n### walk/1\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n    \r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "How to JSON.stringify insert a file into a JSON message?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1481790888,
        "creation_date": 1481773694,
        "question_id": 41156118,
        "body_markdown": "I have a SNS JSON message here: https://s.natalian.org/2016-12-15/sns-event.json\r\n\r\nHowever I need to use the Message field as a payload for a JSON data structure. How do I quickly get a piece of JSON inserted so the final JSON looks like: https://s.natalian.org/2016-12-15/sns-event-stringified-message.json\r\n\r\n    &quot;Message&quot;: &quot;[{\\&quot;From\\&quot;: \\&quot;foo\\&quot;,\\&quot;To\\&quot;: \\&quot;bar\\&quot;}]&quot;,\r\n\r\nFor the sake of this example, file.json to be inserted has the contents:\r\n\r\n    [\r\n      {\r\n        &quot;From&quot;: &quot;foo&quot;,\r\n        &quot;To&quot;: &quot;bar&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m doing it by hand currently with `JSON.stringify` which error prone with a large structure.",
        "link": "https://stackoverflow.com/questions/41156118/how-to-json-stringify-insert-a-file-into-a-json-message",
        "title": "How to JSON.stringify insert a file into a JSON message?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1481813398,
                "creation_date": 1481813398,
                "answer_id": 41167027,
                "question_id": 41166330,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Manage to do it \r\n\r\n    jq &#39;.items[0].properties.&quot;hfile.block.cache.size&quot;=&quot;0.2&quot;&#39; initial.json &gt; 1.json",
                "title": "Manipulate JSON with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1481843840,
                "last_edit_date": 1481843840,
                "creation_date": 1481827515,
                "answer_id": 41171245,
                "question_id": 41166330,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The original question asks how to alter more than one of the &quot;properties&quot;.  The key to doing so without being repetitive is `|=`.  Here&#39;s an illustration:\r\n\r\n    .items[0].properties |=\r\n      ( .[&quot;hfile.block.cache.size&quot;] = &quot;newvalue1&quot;\r\n      | .[&quot;hbase.hregion.max.filesize&quot;] = &quot;newvalue2&quot; )\r\n\r\n\r\n### In-place updates\r\nThe original question also mentioned updating properties within a file. One possibility that avoids having to create an explicit temporary file is to use `sponge` (e.g. `brew install moreutils`), along the lines of:\r\n\r\n    $ jq .... input.json | sponge input.json \r\n\r\n",
                "title": "Manipulate JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1481843840,
        "creation_date": 1481811346,
        "last_edit_date": 1481811594,
        "question_id": 41166330,
        "body_markdown": "I have following the json file. I am trying to update a couple of properties in this file using `jq`\r\n\r\n    {\r\n      &quot;href&quot; : &quot;http://localhost:8080/api/v1/clusters/ambarihbase/configurations?type=hbase-site&amp;tag=TOPOLOGY_RESOLVED&quot;,\r\n      &quot;items&quot; : [\r\n      {\r\n      &quot;href&quot; : &quot;http://localhost:8080/api/v1/clusters/ambarihbase/configurations?type=hbase-site&amp;tag=TOPOLOGY_RESOLVED&quot;,\r\n      &quot;tag&quot; : &quot;TOPOLOGY_RESOLVED&quot;,\r\n      &quot;type&quot; : &quot;hbase-site&quot;,\r\n      &quot;version&quot; : 2,\r\n      &quot;Config&quot; : {\r\n        &quot;cluster_name&quot; : &quot;ambarihbase&quot;,\r\n        &quot;stack_id&quot; : &quot;HDP-2.5&quot;\r\n      },\r\n      &quot;properties&quot; : {\r\n        &quot;dfs.domain.socket.path&quot; : &quot;/var/lib/hadoop-hdfs/dn_socket&quot;,\r\n        &quot;dfs.support.append&quot; : &quot;false&quot;,\r\n        &quot;hbase.bucketcache.combinedcache.enabled&quot; : &quot;true&quot;,\r\n        &quot;hbase.bucketcache.ioengine&quot; : &quot;file:/mnt/hbase/cache.data&quot;,\r\n        &quot;hbase.bucketcache.percentage.in.combinedcache&quot; : &quot;&quot;,\r\n        &quot;hbase.bucketcache.size&quot; : &quot;81920&quot;,\r\n        &quot;hbase.bulkload.staging.dir&quot; : &quot;/apps/hbase/staging&quot;,\r\n        &quot;hbase.client.keyvalue.maxsize&quot; : &quot;1048576&quot;,\r\n        &quot;hbase.client.retries.number&quot; : &quot;35&quot;,\r\n        &quot;hbase.client.scanner.caching&quot; : &quot;100&quot;,\r\n        &quot;hbase.cluster.distributed&quot; : &quot;true&quot;,\r\n        &quot;hbase.coprocessor.master.classes&quot; : &quot;&quot;,\r\n        &quot;hbase.coprocessor.region.classes&quot; : &quot;org.apache.hadoop.hbase.security.access.SecureBulkLoadEndpoint&quot;,\r\n        &quot;hbase.defaults.for.version.skip&quot; : &quot;true&quot;,\r\n        &quot;hbase.fs.shutdown.hook.wait&quot; : &quot;600000&quot;,\r\n        &quot;hbase.hregion.majorcompaction&quot; : &quot;0&quot;,\r\n        &quot;hbase.hregion.majorcompaction.jitter&quot; : &quot;0.50&quot;,\r\n        &quot;hbase.hregion.max.filesize&quot; : &quot;3221225472&quot;,\r\n        &quot;hbase.hregion.memstore.block.multiplier&quot; : &quot;4&quot;,\r\n        &quot;hbase.hregion.memstore.flush.size&quot; : &quot;134217728&quot;,\r\n        &quot;hbase.hregion.memstore.mslab.enabled&quot; : &quot;true&quot;,\r\n        &quot;hbase.hstore.blockingStoreFiles&quot; : &quot;100&quot;,\r\n        &quot;hbase.hstore.compaction.max&quot; : &quot;10&quot;,\r\n        &quot;hbase.hstore.compaction.max.size&quot; : &quot;10737418240&quot;,\r\n        &quot;hbase.hstore.compactionThreshold&quot; : &quot;3&quot;,\r\n        &quot;hbase.local.dir&quot; : &quot;${hbase.tmp.dir}/local&quot;,\r\n        &quot;hbase.master.distributed.log.splitting&quot; : &quot;true&quot;,\r\n        &quot;hbase.master.info.bindAddress&quot; : &quot;0.0.0.0&quot;,\r\n        &quot;hbase.master.info.port&quot; : &quot;16010&quot;,\r\n        &quot;hbase.master.port&quot; : &quot;16000&quot;,\r\n        &quot;hbase.master.ui.readonly&quot; : &quot;false&quot;,\r\n        &quot;hbase.region.server.rpc.scheduler.factory.class&quot; : &quot;org.apache.hadoop.hbase.ipc.PhoenixRpcSchedulerFactory&quot;,\r\n        &quot;hbase.regionserver.global.memstore.size&quot; : &quot;0.4&quot;,\r\n        &quot;hbase.regionserver.handler.count&quot; : &quot;100&quot;,\r\n        &quot;hbase.regionserver.hlog.blocksize&quot; : &quot;134217728&quot;,\r\n        &quot;hbase.regionserver.info.port&quot; : &quot;16030&quot;,\r\n        &quot;hbase.regionserver.optionalcacheflushinterval&quot; : &quot;0&quot;,\r\n        &quot;hbase.regionserver.port&quot; : &quot;16020&quot;,\r\n        &quot;hbase.regionserver.wal.codec&quot; : &quot;org.apache.hadoop.hbase.regionserver.wal.IndexedWALEditCodec&quot;,\r\n        &quot;hbase.rest.port&quot; : &quot;8090&quot;,\r\n        &quot;hbase.rootdir&quot; : &quot;/hbase&quot;,\r\n        &quot;hbase.rpc.protection&quot; : &quot;authentication&quot;,\r\n        &quot;hbase.rpc.timeout&quot; : &quot;90000&quot;,\r\n        &quot;hbase.rs.cacheblocksonwrite&quot; : &quot;true&quot;,\r\n        &quot;hbase.security.authentication&quot; : &quot;simple&quot;,\r\n        &quot;hbase.security.authorization&quot; : &quot;false&quot;,\r\n        &quot;hbase.shutdown.hook&quot; : &quot;true&quot;,\r\n        &quot;hbase.superuser&quot; : &quot;hbase&quot;,\r\n        &quot;hbase.tmp.dir&quot; : &quot;/tmp/hbase-${user.name}&quot;,\r\n        &quot;hbase.zookeeper.property.clientPort&quot; : &quot;2181&quot;,\r\n        &quot;hbase.zookeeper.useMulti&quot; : &quot;true&quot;,\r\n        &quot;hfile.block.cache.size&quot; : &quot;0.40&quot;,\r\n        &quot;hfile.index.block.max.size&quot; : &quot;131072&quot;,\r\n        &quot;io.storefile.bloom.block.size&quot; : &quot;131072&quot;,\r\n        &quot;phoenix.functions.allowUserDefinedFunctions&quot; : &quot;true&quot;,\r\n        &quot;phoenix.query.timeoutMs&quot; : &quot;60000&quot;,\r\n        &quot;zookeeper.recovery.retry&quot; : &quot;6&quot;,\r\n        &quot;zookeeper.session.timeout&quot; : &quot;120000&quot;,\r\n        &quot;zookeeper.znode.parent&quot; : &quot;/hbase-unsecure&quot;\r\n      }\r\n     }\r\n    ]\r\n    }\r\n\r\nI want to update `hbase.hregion.max.filesize` so I tried the following \r\n\r\n    cat initial.json | \r\n          jq &#39;to_entries | \r\n               map(if .items[0].properties.key == &quot;hfile.block.cache.size&quot; \r\n                  then . + {&quot;value&quot;:&quot;0.20&quot;} \r\n                  else . \r\n                  end\r\n                 ) | \r\n              from_entries&#39;\r\n\r\nWhich outputs the original file but not with updated `hfile.block.cache.size`\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/41166330/manipulate-json-with-jq",
        "title": "Manipulate JSON with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "set-intersection",
            "set-difference"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1481895456,
                "post_id": 41185194,
                "comment_id": 69570954,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1481908146,
                "creation_date": 1481908146,
                "answer_id": 41189232,
                "question_id": 41185194,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To find items common between two arrays, just perform a set intersection between the two.  There&#39;s no intersection function available but it should be simple enough to define on your own.  Take the unique items of each array, group them up by value, then take the items where there are more than 1 in a group.\r\n\r\n    def intersect($a; $b): [($a | unique)[], ($b | unique)[]]\r\n        | [group_by(.)[] | select(length &gt; 1)[0]];\r\n\r\nUsing this, to find the common elements (assuming your input is actually a valid json object):\r\n\r\n    $ jq &#39;def intersect($a; $b): [($a | unique)[], ($b | unique)[]]\r\n        | [group_by(.)[] | select(length &gt; 1)[0]];\r\n    intersect(.tag_aws_autoscaling_groupName_asg_test;\r\n              .tag_aws_autoscaling_groupName_asg_unknown)&#39; &lt; input.json\r\n    [\r\n      &quot;aa.b.bb.55&quot;\r\n    ]\r\n\r\nTo find items unique to an array, just perform the set difference.\r\n\r\n    $ jq &#39;def difference($a; $b): ($a | unique) - ($b | unique);\r\n    difference(.tag_aws_autoscaling_groupName_asg_test;\r\n               .tag_aws_autoscaling_groupName_asg_unknown)&#39; &lt; input.json\r\n    [\r\n      &quot;1b.b.c.d&quot;\r\n    ]\r\n\r\n",
                "title": "Find common and unique items between two arrays"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1495806371,
                "last_edit_date": 1495806371,
                "creation_date": 1481931016,
                "answer_id": 41193864,
                "question_id": 41185194,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### difference/2\r\nBecause of the way jq&#39;s &quot;-&quot; operator is defined on arrays, one invocation of `unique` is sufficient to produce a &quot;uniquified&quot; answer:\r\n\r\n    def difference($a; $b): ($a | unique) - $b;\r\n\r\nSimilarly, for the symmetric difference, a single sorting operation is sufficient to produce a &quot;uniquified&quot; value:\r\n\r\n    def sdiff($a; $b): (($a-$b) + ($b-$a)) | unique;\r\n\r\n### intersect/2\r\nHere is a faster version of `intersect/2` that should work with all versions of jq -- it eliminates `group_by` in favor of `sort`:\r\n\r\n    def intersect(x;y):\r\n      ( (x|unique) + (y|unique) | sort) as $sorted\r\n      | reduce range(1; $sorted|length) as $i\r\n          ([];\r\n           if $sorted[$i] == $sorted[$i-1] then . + [$sorted[$i]] else . end) ;\r\n\r\n### intersection/2\r\n\r\nIf you have jq 1.5, then here&#39;s a similar but still measurably faster set-intersection function: it produces a stream of the elements in the set-intersection of the two arrays:\r\n\r\n    def intersection(x;y):\r\n      (x|unique) as $x | (y|unique) as $y\r\n      | ($x|length) as $m\r\n      | ($y|length) as $n\r\n      | if $m == 0 or $n == 0 then empty\r\n        else { i:-1, j:-1, ans:false }\r\n        | while(  .i &lt; $m and .j &lt; $n;\r\n            $x[.i+1] as $nextx\r\n            | if $nextx == $y[.j+1] then {i:(.i+1), j:(.j+1), ans: true, value: $nextx}\r\n              elif  $nextx &lt; $y[.j+1] then .i += 1 | .ans = false\r\n              else  .j += 1 | .ans = false\r\n              end )\r\n        end\r\n      | if .ans then .value else empty end ;\r\n",
                "title": "Find common and unique items between two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1495806371,
        "creation_date": 1481893901,
        "last_edit_date": 1482217171,
        "question_id": 41185194,
        "body_markdown": "I use ec2.py dynamic inventory script with ansible to extract a list of ec2 hosts and their tag names. It returns me a list of JSON as below, \r\n\r\n      &quot;tag_aws_autoscaling_groupName_asg_test&quot;: [\r\n        &quot;aa.b.bb.55&quot;,\r\n        &quot;1b.b.c.d&quot;\r\n      ],\r\n    \r\n      &quot;tag_aws_autoscaling_groupName_asg_unknown&quot;: [\r\n        &quot;aa.b.bb.55&quot;,\r\n        &quot;1b.b.c.e&quot;\r\n      ],\r\n\r\nI&#39;m using jq for parsing this output. \r\n\r\n1. How can I extract only fields common to both these ASG?\r\n2. How can I extract only fields unique to both these ASG?",
        "link": "https://stackoverflow.com/questions/41185194/find-common-and-unique-items-between-two-arrays",
        "title": "Find common and unique items between two arrays"
    },
    {
        "tags": [
            "filter",
            "nested",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 184870,
                    "reputation": 122434,
                    "user_id": 421195,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/9a9793fdeb3b94e185c8c99c0238372f?s=256&d=identicon&r=PG",
                    "display_name": "paulsm4",
                    "link": "https://stackoverflow.com/users/421195/paulsm4"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1481955586,
                "post_id": 41195915,
                "comment_id": 69591526,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2295369,
                    "reputation": 117,
                    "user_id": 2016930,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/874fa17381ffc739c0cbcb9005a5988a?s=256&d=identicon&r=PG",
                    "display_name": "Garrett Boatman",
                    "link": "https://stackoverflow.com/users/2016930/garrett-boatman"
                },
                "reply_to_user": {
                    "account_id": 184870,
                    "reputation": 122434,
                    "user_id": 421195,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/9a9793fdeb3b94e185c8c99c0238372f?s=256&d=identicon&r=PG",
                    "display_name": "paulsm4",
                    "link": "https://stackoverflow.com/users/421195/paulsm4"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1482011769,
                "post_id": 41195915,
                "comment_id": 69606022,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1481989037,
                "last_edit_date": 1481989037,
                "creation_date": 1481987878,
                "answer_id": 41200053,
                "question_id": 41195915,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is a good example of the convenience of `with_entries/1` and of the brevity that&#39;s possible with jq:\r\n\r\n    with_entries( select(.value.show_id != 1641788 ))\r\n\r\n`with_entries/1` converts an object into an explicit .key/.value representation.  Please see the [jq manual][1] for details.\r\n\r\nAlternatively and with even greater brevity, one can in this case also use `del/1`:\r\n\r\n    del( .[] | select( .show_id == 1641788 ) )\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Looking for a jq filter to exclude nested objects based on the value of a nested property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1482910116,
        "creation_date": 1481955451,
        "last_edit_date": 1482910116,
        "question_id": 41195915,
        "body_markdown": "Given this input:\r\n\r\n    {\r\n      &quot;10000703&quot;: {\r\n        &quot;show_id&quot;: 1641788,\r\n      },\r\n      &quot;10000838&quot;: {\r\n        &quot;show_id&quot;: 1517903,\r\n      },\r\n      &quot;10001325&quot;: {\r\n        &quot;show_id&quot;: 1641788,\r\n      },\r\n    }\r\n\r\nI&#39;m looking for a filter to say &quot;return all objects where `show_id` does not equal `1641788`&quot;\r\n\r\nThe expected output would be:\r\n\r\n    {\r\n      &quot;10000838&quot;: {\r\n        &quot;show_id&quot;: 1517903,\r\n      },\r\n    }\r\nHaven&#39;t been able to exclude nested objects :(",
        "link": "https://stackoverflow.com/questions/41195915/looking-for-a-jq-filter-to-exclude-nested-objects-based-on-the-value-of-a-nested",
        "title": "Looking for a jq filter to exclude nested objects based on the value of a nested property"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1482130491,
                "creation_date": 1482130491,
                "answer_id": 41217217,
                "question_id": 41216894,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You don&#39;t need a &quot;final&quot; array. You can process the individual JSON output of each `curl` call, and parse each with the same `jq` script, converting JSON input to CSV output. Something along the lines of:\r\n\r\n    for url; do\r\n        curl &quot;$url&quot; | jq &#39;filter-and-extract-csv-columns&#39;\r\n    done &gt; output.csv\r\n\r\nNotice the redirection of the entire loop to `output.csv`.\r\n\r\nThis kind of streamlined processing is possible thanks to the CVS format being flat without a surrounding context as in XML or JSON. The output of multiple computations can be simply concatenated.",
                "title": "jq - create empty array and add objects to it"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1482131851,
                "last_edit_date": 1482131851,
                "creation_date": 1482131388,
                "answer_id": 41217443,
                "question_id": 41216894,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` can deal with multiple input arrays. You can pipe the whole output of the loop to it:\r\n\r\n    for service in &quot;$services&quot; ; do\r\n        curl &quot;$service/path&quot;\r\n    done | jq -r &#39;.[]|[.id,.startDate,.calls]|@csv&#39;\r\n\r\nNote that the csv transformation can be done by `@csv`",
                "title": "jq - create empty array and add objects to it"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1482160997,
                "last_edit_date": 1482160997,
                "creation_date": 1482135073,
                "answer_id": 41218259,
                "question_id": 41216894,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As @hek2mlg pointed out, it should be possible to invoke jq just once. If the input is sufficiently uniform (admittedly, maybe a big &quot;if&quot;), you could even avoid having to name the fields explicitly, e.g.:\r\n\r\n    $ for service in &quot;$services&quot; ; do\r\n        curl &quot;$service/path&quot;\r\n      done | jq -sr &#39;add[] | [.[]] | @csv&#39;\r\n\r\nOutput:\r\n\r\n    &quot;123&quot;,&quot;2016-12-09T00:00:00Z&quot;,4\r\n    &quot;456&quot;,&quot;2016-12-09T00:00:00Z&quot;,22\r\n    &quot;789&quot;,&quot;2016-12-09T00:00:00Z&quot;,8\r\n    &quot;147&quot;,&quot;2016-12-09T00:00:00Z&quot;,10\r\n\r\nNote that using -s allows you to perform arbitrary computations on all the inputs, e.g. counting them.",
                "title": "jq - create empty array and add objects to it"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1482160997,
        "creation_date": 1482128968,
        "last_edit_date": 1482130837,
        "question_id": 41216894,
        "body_markdown": "I am working on a bash script (using jq for JSON parsing) \r\n\r\n 1. that needs to make multiple CURL calls (response has same structure but different values), apply some logic/filters and then collate all the responses in one final JSON array of objects. \r\n 2. Loop through this final JSON array and write into a CSV in a predefined format.\r\n\r\nSearched for a bit for both the requirements but could not find anything concrete. Please advice. The highlighted steps below (in ***) are the points where I need help.\r\n\r\n**Sample Flow :**\r\n\r\n    create empty FINAL array\r\n\r\n    for(eachService is serviceList)\r\n           a. CURL &lt;service_response&gt; returning JSON array of objects\r\n           b. use jq filters to parse JSON response, apply some logic and modify elements in response as needed\r\n           c. ***add this JSON array to FINAL array***\r\n\r\n    ***LOOP through FINAL array, one object at a time a write to CSV.***\r\n\r\n**Sample Data :** \r\n\r\n    CURL Response 1 (ex: $curl1):\r\n    [\r\n      {\r\n        &quot;id&quot;:&quot;123&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:4\r\n      },\r\n      {\r\n        &quot;id&quot;:&quot;456&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:22\r\n      }\r\n    ]\r\n    \r\n    CURL Response 2 (ex : $curl2): \r\n    [\r\n      {\r\n        &quot;id&quot;:&quot;789&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:8\r\n      },\r\n      {\r\n        &quot;id&quot;:&quot;147&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:10\r\n      }\r\n    ]\r\n\r\n    NEEDED OUTPUT ($final): \r\n    [\r\n    {\r\n        &quot;id&quot;:&quot;123&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:4\r\n      },\r\n      {\r\n        &quot;id&quot;:&quot;456&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:22\r\n      },\r\n      {\r\n        &quot;id&quot;:&quot;789&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:8\r\n      },\r\n      {\r\n        &quot;id&quot;:&quot;147&quot;,\r\n        &quot;startDate&quot;: &quot;2016-12-09T00:00:00Z&quot;,\r\n        &quot;calls&quot;:10\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/41216894/jq-create-empty-array-and-add-objects-to-it",
        "title": "jq - create empty array and add objects to it"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8358547,
                    "reputation": 39,
                    "user_id": 6277847,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/30ae4b80633082dc5a48e04dcfbc1d16?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Moshe Saada",
                    "link": "https://stackoverflow.com/users/6277847/moshe-saada"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1482756230,
                "post_id": 41222293,
                "comment_id": 69865769,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1482256598,
                "last_edit_date": 1482256598,
                "creation_date": 1482161892,
                "answer_id": 41226156,
                "question_id": 41222293,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1) Use |= rather than just |\r\n\r\n2) One way to transform the fragment:\r\n\r\n    {\r\n      &quot;Headers&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Host&quot;,\r\n          &quot;Value&quot;: &quot;static.tiza.com&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;User-Agent&quot;,\r\n          &quot;Value&quot;: &quot;Faraday v0.9.2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nas required would be using the filter:\r\n\r\n    .Headers[] | { (&quot;Headers.&quot; + .Name): .Value }\r\n\r\nIn your case, you could therefore use the following filter for (2):\r\n\r\n    .SampledRequests[].Request.Headers[] |=\r\n        { (&quot;Headers.&quot; + .Name): .Value }\r\n\r\nI&#39;ll leave it to you to put all the pieces together :-)\r\n",
                "title": "jq json parsing - replace timestamp to date using todate, and flat an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1482421620,
        "creation_date": 1482149424,
        "last_edit_date": 1482421620,
        "question_id": 41222293,
        "body_markdown": "**2 Questions:** \r\n\r\n1) I want to keep the json as is but change the Timestamp to human readable date like &quot;2016-12-19T09:21:35Z&quot;\r\n\r\n\r\n    {\r\n      &quot;Action&quot;: &quot;ALLOW&quot;,\r\n      &quot;Timestamp&quot;: 1482139256.274,\r\n      &quot;Request&quot;: {\r\n        &quot;Country&quot;: &quot;US&quot;,\r\n        &quot;URI&quot;: &quot;/version/moot/beta.json&quot;,\r\n        &quot;Headers&quot;: [\r\n          {\r\n            &quot;Name&quot;: &quot;Host&quot;,\r\n            &quot;Value&quot;: &quot;static.tiza.com&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;User-Agent&quot;,\r\n            &quot;Value&quot;: &quot;Faraday v0.9.2&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Accept-Encoding&quot;,\r\n            &quot;Value&quot;: &quot;gzip;q=1.0,deflate;q=0.6,identity;q=0.3&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Accept&quot;,\r\n            &quot;Value&quot;: &quot;*/*&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;X-Newrelic-Id&quot;,\r\n            &quot;Value&quot;: &quot;Vgcs5gbFU123dFBWGwIdAVFdrXBwc=&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;X-Newrelic-Transaction&quot;,\r\n            &quot;Value&quot;: &quot;PxQDQVlzZVUd3NKQcrEwWwU&quot;\r\n          }\r\n        ],\r\n        &quot;ClientIP&quot;: &quot;107.22.17.51&quot;,\r\n        &quot;Method&quot;: &quot;GET&quot;,\r\n        &quot;HTTPVersion&quot;: &quot;HTTP/1.1&quot;\r\n      },\r\n      &quot;Weight&quot;: 1\r\n    }\r\n\r\n\r\nI know I can do it using &#39;todate&#39; jq feature but I lose all other data \r\n\r\n    sh# cat temp.json | jq -r &#39;.SampledRequests[].Timestamp | todate&#39;\r\n    2016-12-19T09:21:44Z\r\n\r\n--------- Updated --------\r\n\r\nsecond question:\r\n2)How do I take the content of .Headers[] out of the array under the &quot;Request{}&quot; level.\r\n\r\nfrom:\r\n\r\n    {\r\n      &quot;TimeWindow&quot;: {\r\n        &quot;EndTime&quot;: 1482156660,\r\n        &quot;StartTime&quot;: 1482156420\r\n      },\r\n      &quot;SampledRequests&quot;: [\r\n        {\r\n          &quot;Action&quot;: &quot;ALLOW&quot;,\r\n          &quot;Timestamp&quot;: 1482139256.274,\r\n          &quot;Request&quot;: {\r\n            &quot;Country&quot;: &quot;US&quot;,\r\n            &quot;URI&quot;: &quot;/version/moot/beta.json&quot;,\r\n            &quot;Headers&quot;: [\r\n              {\r\n                &quot;Name&quot;: &quot;Host&quot;,\r\n                &quot;Value&quot;: &quot;static.tiza.com&quot;\r\n              },\r\n              {\r\n                &quot;Name&quot;: &quot;X-Newrelic-Transaction&quot;,\r\n                &quot;Value&quot;: &quot;PxQDQVlzZVUd3NKQcrEwWwU&quot;\r\n              }\r\n            ],\r\n            &quot;ClientIP&quot;: &quot;107.22.17.51&quot;,\r\n            &quot;Method&quot;: &quot;GET&quot;,\r\n            &quot;HTTPVersion&quot;: &quot;HTTP/1.1&quot;\r\n          },\r\n          &quot;Weight&quot;: 1\r\n        }\r\n      ],\r\n      &quot;PopulationSize&quot;: 89\r\n    }\r\n\r\nTo:\r\n\r\n    {\r\n        &quot;TimeWindow.EndTime&quot;: 1482156660,\r\n        &quot;TimeWindow.StartTime&quot;: 1482156420,\r\n        &quot;Action&quot;: &quot;ALLOW&quot;,\r\n        &quot;Timestamp&quot;: 1482139256.274,\r\n        &quot;Request.Country&quot;: &quot;US&quot;,\r\n        &quot;Request.URI&quot;: &quot;/version/moot/beta.json&quot;,\r\n        &quot;Headers.Host&quot;: &quot;static.tiza.com&quot;,\r\n        &quot;Headers.X-Newrelic-Transaction&quot;: &quot;PxQDQVlzZVUd3NKQcrEwWwU&quot;,\r\n        &quot;ClientIP&quot;: &quot;107.22.17.51&quot;,\r\n        &quot;Method&quot;: &quot;GET&quot;,\r\n        &quot;HTTPVersion&quot;: &quot;HTTP/1.1&quot;,\r\n        &quot;Weight&quot;: 1,\r\n        &quot;PopulationSize&quot;: 89\r\n    }\r\n\r\nThanks a lot,\r\n\r\nMoshe\r\n",
        "link": "https://stackoverflow.com/questions/41222293/jq-json-parsing-replace-timestamp-to-date-using-todate-and-flat-an-array",
        "title": "jq json parsing - replace timestamp to date using todate, and flat an array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "apache-zeppelin"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4881680,
                    "reputation": 6921,
                    "user_id": 3935325,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/jjwPe.jpg?s=256",
                    "display_name": "villasv",
                    "link": "https://stackoverflow.com/users/3935325/villasv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1482174977,
                "post_id": 41229477,
                "comment_id": 69658093,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4881680,
                    "reputation": 6921,
                    "user_id": 3935325,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/jjwPe.jpg?s=256",
                    "display_name": "villasv",
                    "link": "https://stackoverflow.com/users/3935325/villasv"
                },
                "reply_to_user": {
                    "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1482176702,
                "post_id": 41229477,
                "comment_id": 69658911,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1482182004,
                "last_edit_date": 1482182004,
                "creation_date": 1482176292,
                "answer_id": 41229799,
                "question_id": 41229477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "## Git Filter\r\n\r\nThe best solution (thanks to @steven-penny) is to run this:\r\n\r\n`git config filter.znbstripout.clean &quot;jq &#39;.paragraphs[].result.msg = \\&quot;\\&quot;&#39;&quot;`\r\n\r\nwhich will setup a filter called `znbstripout` that invokes the `jq` tool. Then, in your `.gitattributes` file you can just put:\r\n\r\n`*.json filter=znbstripout`\r\n\r\n## Python Script (usable with Git Hooks)\r\n\r\nThe following can be used as a git hook:\r\n\r\n    #!/usr/bin/env python3\r\n    \r\n    from glob import glob\r\n    import json\r\n    \r\n    files = glob(&#39;**/note.json&#39;, recursive=True)\r\n    for file in files:\r\n        with open(file, &#39;r&#39;) as fp:\r\n            nb = json.load(fp)\r\n        for p in nb[&#39;paragraphs&#39;]:\r\n            if &#39;result&#39; in p:\r\n                p[&#39;result&#39;][&#39;msg&#39;] = &quot;&quot;\r\n        with open(file, &#39;w&#39;) as fp:\r\n            json.dump(nb, fp, sort_keys=True, indent=2)\r\n",
                "title": "Simple command line JSON tool equivalent of nbstripout for Zeppelin notebooks"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1482177015,
                "creation_date": 1482177015,
                "answer_id": 41229983,
                "question_id": 41229477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "JQ can do this:\r\n\r\n    jq .paragraphs[].result.msg file\r\n\r\nhttp://stedolan.github.io/jq",
                "title": "Simple command line JSON tool equivalent of nbstripout for Zeppelin notebooks"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1482185795,
                "last_edit_date": 1482185795,
                "creation_date": 1482185044,
                "answer_id": 41231759,
                "question_id": 41229477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In (1) and (2) below, I&#39;ll assume that the incoming JSON looks like this:\r\n\r\n    {\r\n      &quot;paragraphs&quot;: [\r\n        {\r\n          &quot;result&quot;: {\r\n            &quot;msg&quot;: &quot;msg1&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;result&quot;: {\r\n            &quot;msg&quot;: &quot;msg2&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n    \r\n\r\n### 1. To set the .result.msg values to &quot;&quot;\r\n    .paragraphs[].result.msg = &quot;&quot;\r\n\r\n### 2. To remove the .result.msg fields altogether:\r\n\r\n    del(.paragraphs[].result.msg)\r\n\r\n### 3. To remove &quot;msg&quot; fields in all objects, wherever they occur:\r\n\r\n    walk(if type == &quot;object&quot; then del(.msg) else . end)\r\n\r\n(If your jq does not have `walk`, google: jq faq walk)\r\n\r\n### 4. To remove &quot;msg&quot; fields wherever they occur in a .result object in a  .paragraphs array:\r\n\r\n     walk(if type == &quot;object&quot; and (.paragraphs|type) == &quot;array&quot;\r\n          then del(.paragraphs[].result?.msg?) else . end)\r\n\r\n",
                "title": "Simple command line JSON tool equivalent of nbstripout for Zeppelin notebooks"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1482185795,
        "creation_date": 1482174870,
        "last_edit_date": 1482183690,
        "question_id": 41229477,
        "body_markdown": "**Some background**\r\n\r\nVersioning notebooks can become very inefficient if the output is expected to vary a lot. I solved this problem with my Jupyter notebooks using [`nbstripout`][1], but so far I&#39;ve found no alternative for Zeppelin notebooks.\r\n\r\nBecause `nbstripout` uses `nbformat` to parse `ipynb` files, it&#39;s not an easy patch to make it support Zeppelin. On the other hand, the goal is not that complex: simply empty out all the `&quot;msg&quot;: &quot;...&quot;`.\r\n\r\n**Goal**\r\n\r\nGiven a JSON file, empty out all `&#39;paragraphs.result.msg&#39;` fields.\r\n\r\n**Sample** (schema):\r\n\r\n    {&quot;paragraps&quot;: [{&quot;result&quot;: {&quot;msg&quot;: &quot;Very long output...&quot;}}]}\r\n\r\n  [1]: https://github.com/kynan/nbstripout",
        "link": "https://stackoverflow.com/questions/41229477/simple-command-line-json-tool-equivalent-of-nbstripout-for-zeppelin-notebooks",
        "title": "Simple command line JSON tool equivalent of nbstripout for Zeppelin notebooks"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1482201483,
                "creation_date": 1482201483,
                "answer_id": 41234038,
                "question_id": 41233816,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could convert the array to entries to access the index and the value.  Then you can build out the CSV rows.\r\n\r\n    $ jq -r &#39;[.foo] + (.bar | to_entries[] | [.key+1,.value.key,.value.val]) | @csv&#39; input.json\r\n    &quot;hello&quot;,1,&quot;k1&quot;,&quot;v1&quot;\r\n    &quot;hello&quot;,2,&quot;k2&quot;,&quot;v2&quot;\r\n    &quot;hello&quot;,3,&quot;k3&quot;,&quot;v3&quot;\r\n",
                "title": "Get the index of the array element in JSON with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1482268624,
                "last_edit_date": 1482268624,
                "creation_date": 1482201834,
                "answer_id": 41234078,
                "question_id": 41233816,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you have access to jq 1.5 and that the key/val keys are presented in that order:\r\n\r\n    jq -r &#39;.foo as $foo \r\n      | foreach .bar[] as $i (0; .+1; [$foo, .] + [$i[]])\r\n      | @csv&#39;\r\n\r\nwould produce:\r\n\r\n    &quot;hello&quot;,1,&quot;k1&quot;,&quot;v1&quot;\r\n    &quot;hello&quot;,2,&quot;k2&quot;,&quot;v2&quot;\r\n    &quot;hello&quot;,3,&quot;k3&quot;,&quot;v3&quot;\r\n\r\nThe -r option is often used with @csv to convert the JSON string that would otherwise be produced by @csv into a comma-separated list of values.\r\n\r\nIf you really want to join with &quot;, &quot;, then it&#39;s a bit messier, but if you&#39;re not worried about the functionality that @csv provides, here&#39;s one way:\r\n\r\n    $ jq -r &#39;&quot;\\&quot;\\(.foo)\\&quot;&quot; as $foo\r\n        | foreach .bar[] as $i\r\n            (0; .+1; &quot;\\($foo), \\(.), \\($i | map(&quot;\\&quot;\\(.)\\&quot;&quot;)|join(&quot;, &quot;))&quot;)&#39; \r\n\r\nThis produces:\r\n\r\n    &quot;hello&quot;, 1, &quot;k1&quot;, &quot;v1&quot;\r\n    &quot;hello&quot;, 2, &quot;k2&quot;, &quot;v2&quot;\r\n    &quot;hello&quot;, 3, &quot;k3&quot;, &quot;v3&quot;\r\n\r\n\r\nIf your jq does not have `foreach` then you could similarly use `reduce`, but it might be easier to upgrade.\r\n",
                "title": "Get the index of the array element in JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1482268624,
        "creation_date": 1482199329,
        "last_edit_date": 1482204853,
        "question_id": 41233816,
        "body_markdown": "I have the following type of json:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;hello&quot;,\r\n      &quot;bar&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;k1&quot;,\r\n          &quot;val&quot;: &quot;v1&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;k2&quot;,\r\n          &quot;val&quot;: &quot;v2&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;k3&quot;,\r\n          &quot;val&quot;: &quot;v3&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI want to output the following:\r\n\r\n    &quot;hello&quot;, 1, &quot;k1&quot;, &quot;v1&quot;\r\n    &quot;hello&quot;, 2, &quot;k2&quot;, &quot;v2&quot;\r\n    &quot;hello&quot;, 3, &quot;k3&quot;, &quot;v3&quot;\r\n\r\nI am using jq to tranform this and the answer should also be with a jq transformation.\r\n\r\nI am currently at:\r\n\r\n    echo &#39;{&quot;foo&quot;: &quot;hello&quot;,&quot;bar&quot;: [{&quot;key&quot;: &quot;k1&quot;,&quot;val&quot;: &quot;v1&quot;},{&quot;key&quot;: &quot;k2&quot;,&quot;val&quot;: &quot;v2&quot;},{&quot;key&quot;: &quot;k3&quot;,&quot;val&quot;: &quot;v3&quot;} ]}&#39; | jq -c -r &#39;.bar[] as $b | [.foo, ($b | .key, .val)] | @csv&#39;\r\n\r\nWhich gives me:\r\n\r\n    &quot;hello&quot;,&quot;k1&quot;,&quot;v1&quot;\r\n    &quot;hello&quot;,&quot;k2&quot;,&quot;v2&quot;\r\n    &quot;hello&quot;,&quot;k3&quot;,&quot;v3&quot;\r\n\r\nHow can I also get the index to show of the array element being parsed?",
        "link": "https://stackoverflow.com/questions/41233816/get-the-index-of-the-array-element-in-json-with-jq",
        "title": "Get the index of the array element in JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1482278991,
                "creation_date": 1482278991,
                "answer_id": 41253218,
                "question_id": 41252971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Whenever you use the assignment operators (`=`, `|=`, `+=`, etc.), the context of the expression is kept unchanged.  So as long as your top-level filter(s) are assignments, in the end, you&#39;ll get the rest of the data (with your changes applied).\r\n\r\nIn this case, you&#39;re just sorting the `array1` array so you could just update the array.\r\n\r\n    .array1 |= sort_by(.name)",
                "title": "How to use jq to reconstruct complete contents of json file, operating only on part of interest?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1482278991,
        "creation_date": 1482277253,
        "last_edit_date": 1482278798,
        "question_id": 41252971,
        "body_markdown": "All the examples I&#39;ve seen so far &quot;reduce&quot; the output (filter out) some part. I understand how to operate on the part of the input I want to, but I haven&#39;t figured out how to output the rest of the content &quot;untouched&quot;.\r\n\r\nThe particular example would be an input file with several high level entries &quot;array1&quot;, &quot;field1&quot;, &quot;array2&quot;, &quot;array3&quot; say. Each array contents is different. The specific processing I want to do is to sort &quot;array1&quot; entries by a &quot;name&quot; field which is doable by:\r\n\r\n    jq &#39;.array1 | sort_by(.name)&#39; test.json\r\n\r\nbut I also want this output as &quot;array1&quot; as well as all the other data to be preserved.\r\n\r\nExample input:\r\n\r\n    {\r\n        &quot;field1&quot;: &quot;value1&quot;,\r\n        &quot;array1&quot;:\r\n            [\r\n                { &quot;name&quot;: &quot;B&quot;, &quot;otherdata&quot;: &quot;Bstuff&quot; },\r\n                { &quot;name&quot;: &quot;A&quot;, &quot;otherdata&quot;: &quot;Astuff&quot; }\r\n            ],\r\n        &quot;array2&quot; :\r\n            [\r\n                array2 stuff\r\n            ],\r\n        &quot;array3&quot; :\r\n            [\r\n                array3 stuff\r\n            ]\r\n    }\r\n    \r\nExpected output:\r\n\r\n    {\r\n        &quot;field1&quot;: &quot;value1&quot;,\r\n        &quot;array1&quot;:\r\n            [\r\n                { &quot;name&quot;: &quot;A&quot;, &quot;otherdata&quot;: &quot;Astuff&quot; },\r\n                { &quot;name&quot;: &quot;B&quot;, &quot;otherdata&quot;: &quot;Bstuff&quot; }\r\n            ],\r\n        &quot;array2&quot; :\r\n            [\r\n                array2 stuff\r\n            ],\r\n        &quot;array3&quot; :\r\n            [\r\n                array3 stuff\r\n            ]\r\n    }\r\n\r\nI&#39;ve tried using map but I can&#39;t seem to get the syntax correct to be able to handle any type of input other than the array I want to be sorted by name.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41252971/how-to-use-jq-to-reconstruct-complete-contents-of-json-file-operating-only-on-p",
        "title": "How to use jq to reconstruct complete contents of json file, operating only on part of interest?"
    },
    {
        "tags": [
            "json",
            "types",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1482500274,
                "creation_date": 1482500274,
                "answer_id": 41302477,
                "question_id": 41301988,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq &#39;first(path(.[] | select(type == &quot;array&quot;))[0])&#39; &lt; data.json\r\n\r\nThe top-level items `.[]` are filtered out with `select(type == &quot;array&quot;)` which selects only items of array type; `path()` returns array representation of the path in `.`, i.e. the key names of the array items; `first()` extracts the first path.\r\n\r\nSo the result of the command is key name of the first top-level array item. \r\n\r\n\r\n\r\n*Sample Output*\r\n\r\n    &quot;dataset&quot;\r\n\r\n\r\n----\r\n\r\n&gt; How to you determine the type of a key (e.g., I would send &quot;dataset&quot; to jq in some form and would get &quot;array&quot; in return).\r\n\r\nYou probably mean &quot;the type of a value&quot;, because the keys must be strings in JSON. If the path is known (e.g. `.dataset`), then the type of the object can be fetched with the `type` function:\r\n\r\n    jq &#39;.dataset | type&#39; &lt; data.json\r\n\r\n*Sample Output*\r\n\r\n    &quot;array&quot;\r\n\r\n",
                "title": "How to get root keys and key types using jq"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1482505963,
                "creation_date": 1482505963,
                "answer_id": 41303819,
                "question_id": 41301988,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The simplest approach to writing queries that depend on both key names and values is to use one of the &quot;*_entries&quot; family of filters.  In your case:\r\n\r\n    $ jq -c &#39;to_entries[] | [.key, (.value|type)]&#39; data.json\r\n\r\n    [&quot;@context&quot;,&quot;string&quot;]\r\n    [&quot;@id&quot;,&quot;string&quot;]\r\n    [&quot;@type&quot;,&quot;string&quot;]\r\n    [&quot;conformsTo&quot;,&quot;string&quot;]\r\n    [&quot;describedBy&quot;,&quot;string&quot;]\r\n    [&quot;dataset&quot;,&quot;array&quot;]    \r\n\r\nIf you wanted this presented in a more human-readable fashion, consider using @csv or @tsv, e.g.\r\n\r\n    $ jq -r &#39;to_entries[] | [.key, (.value|type)] | @csv&#39; data.json\r\n    &quot;@context&quot;,&quot;string&quot;\r\n    &quot;@id&quot;,&quot;string&quot;\r\n    &quot;@type&quot;,&quot;string&quot;\r\n    &quot;conformsTo&quot;,&quot;string&quot;\r\n    &quot;describedBy&quot;,&quot;string&quot;\r\n    &quot;dataset&quot;,&quot;array&quot;\r\n\r\nOr with less noise:\r\n\r\n    $ jq -r &#39;to_entries[] | &quot;\\(.key) \\(.value|type)&quot;&#39; data.json\r\n    @context string\r\n    @id string\r\n    @type string\r\n    conformsTo string\r\n    describedBy string\r\n    dataset array\r\n    \r\n\r\n### Bonus question\r\n\r\nHere&#39;s a parametric approach to the second question. Let the file query.jq contain:\r\n\r\n    .[$key]|type\r\n\r\nThen:\r\n\r\n    $ jq -r --arg key dataset -f query.jq data.json\r\n    array\r\n",
                "title": "How to get root keys and key types using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1501716821,
        "creation_date": 1482498013,
        "last_edit_date": 1501716821,
        "question_id": 41301988,
        "body_markdown": "Let&#39;s take this simple data file: http://data.cdc.gov/data.json\r\n\r\nI know how to get the root key names:\r\n\r\n    jq keys_unsorted[] -r data.json\r\n\r\nwhich produces:\r\n\r\n    @context\r\n    @id\r\n    @type\r\n    conformsTo\r\n    describedBy\r\n    dataset\r\n\r\nAnd I know how to get the key types:\r\n\r\n    jq &#39;map(type)&#39; data.json\r\n\r\nWhich produces:\r\n\r\n    [\r\n      &quot;string&quot;,\r\n      &quot;string&quot;,\r\n      &quot;string&quot;,\r\n      &quot;string&quot;,\r\n      &quot;string&quot;,\r\n      &quot;array&quot;\r\n    ]\r\n\r\nIs there not some way of combining this in returning pairs? (what I am really trying to do is find the key name of the first root level array, if any). I can write a routine to figure it out, but this seem inelegant. \r\n\r\nBonus side question: How to you determine the type of a key (e.g., I would send &quot;dataset&quot; to jq in some form and would get &quot;array&quot; in return)?",
        "link": "https://stackoverflow.com/questions/41301988/how-to-get-root-keys-and-key-types-using-jq",
        "title": "How to get root keys and key types using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1482978814,
                "last_edit_date": 1495540911,
                "creation_date": 1482978814,
                "answer_id": 41372393,
                "question_id": 41345239,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When you write your result to your csv file your are using `echo $csvOutput &gt;&gt; out.csv` instead of :\r\n\r\n    echo &quot;$csvOutput&quot; &gt;&gt; out.csv \r\n\r\nThe double quotes will preserve newlines, see [this post][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/613572/capturing-multiple-line-output-to-a-bash-variable",
                "title": "jq - Extra space when outputting to CSV after jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1482978814,
        "creation_date": 1482841736,
        "question_id": 41345239,
        "body_markdown": "Facing an issue with a simple requirement.\r\n\r\n 1. Make a CURL request and store in a variable\r\n 2. Parse JSON from variable using JQ and output into CSV file.\r\n\r\nWhen I try to do it, I am getting extra leading space in the file from the second line for some reason. Is there a way to configure jq to not do this ?\r\n\r\n**Code :** \r\n\r\n    output=`curl -v -k -H &#39;Content-Type: application/json&#39; &#39;&lt;&lt;URL&gt;&gt;&#39; -d &#39;&lt;&lt;PARAMS&gt;&gt;&#39;`\r\n    csvOutput=`echo $output | jq --raw-output &#39;.result .items[]|[.name,.key,.created,.updated]|@csv&#39;`\r\n    echo $csvOutput &gt;&gt; out.csv\r\n\r\nThe following code (all in one line) does not have the issue. But I need the curl output in a variable to perform some checks ,so this option does not help.\r\n\r\n    echo &quot;$(curl -v -k -H &#39;Content-Type: application/json&#39; &#39;&lt;&lt;URL&gt;&gt;&#39; -d &#39;&lt;&lt;PARAMS&gt;&gt;&quot; | jq -r &#39;.result .items[]|[.name,.key,.created,.updated]|@csv&#39; &gt;&gt; out.csv\r\n\r\nStrangely, when I read the json output (taken from curl response) from a file and then apply jq filters, I don&#39;t see the issue.\r\n\r\n    cat response.json | jq -r &#39;.result .items[]|[.name,.key,.created,.updated]|@csv&#39; &gt; out.csv\r\n\r\n**response.json (formatted)** :\r\n\r\n    {\r\n      &quot;result&quot;: {\r\n        &quot;total_items&quot;: 22,\r\n        &quot;total_pages&quot;: 1,\r\n        &quot;items_per_page&quot;: 1000,\r\n        &quot;current_page&quot;: 1,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;key&quot;: &quot;1&quot;,\r\n            &quot;name&quot;: &quot;Name 1&quot;,\r\n            &quot;created&quot;: &quot;2016-12-20T08:51:13Z&quot;,\r\n            &quot;updated&quot;: &quot;2016-12-20T09:29:08Z&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;2&quot;,\r\n            &quot;name&quot;: &quot;Name 2&quot;,\r\n            &quot;created&quot;: &quot;2016-12-20T08:51:13Z&quot;,\r\n            &quot;updated&quot;: &quot;2016-12-20T09:29:08Z&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;3&quot;,\r\n            &quot;name&quot;: &quot;Name 3&quot;,\r\n            &quot;created&quot;: &quot;2016-12-20T08:51:13Z&quot;,\r\n            &quot;updated&quot;: &quot;2016-12-20T09:29:08Z&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;id&quot;: 1\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41345239/jq-extra-space-when-outputting-to-csv-after-jq-filter",
        "title": "jq - Extra space when outputting to CSV after jq filter"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "updates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1482876013,
                "last_edit_date": 1482876013,
                "creation_date": 1482869132,
                "answer_id": 41351530,
                "question_id": 41350839,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If it is acceptable to change the &quot;name&quot; field wherever it occurs, you could use `walk/1`:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;name&quot;) then .name = &quot;something&quot; else . end)\r\n\r\nPlease note that `walk/1` was only included with jq after jq 1.5 was released.  If your jq does not have it, then you can find its definition on the [jq FAQ][1], for example.\r\n\r\nIf you only want to modify the &quot;name&quot; field in the &quot;z&quot; context, then consider:\r\n\r\n    .z |= with_entries(if .value.name?\r\n                       then .value.name = &quot;something&quot; \r\n                       else . end)\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "Replace subkey without exact path in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1482875508,
                "creation_date": 1482875508,
                "answer_id": 41352631,
                "question_id": 41350839,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming every value within `z` has a name property, you could do this:\r\n\r\n    $ jq --arg newname &#39;something&#39; &#39;.z[].name = $newname&#39; input.json\r\n\r\nUsing `[]` on an object will yield all the values contained in that object.  And for each of those values, we were simply setting the `name` to the new name.\r\n\r\n&lt;hr&gt;\r\n\r\nIf you needed to be more selective with what gets updated, you&#39;ll have to add more conditions to what objects to update.  In general, I&#39;d use peak&#39;s approach, but here&#39;s another way it could be achieved using a structure similar to the first approach, assuming we only want to update objects that already have a `name` property:\r\n\r\n    $ jq --arg newname &#39;something&#39; &#39;(.z[] | select(has(&quot;name&quot;)).name) = $newname&#39; input.json\r\n\r\nIt&#39;s important to wrap the LHS of the assignment in parentheses, we don&#39;t want to change the context prior to the assignment, otherwise we won&#39;t see the rest of the results.",
                "title": "Replace subkey without exact path in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1482876216,
        "creation_date": 1482865802,
        "last_edit_date": 1482876216,
        "question_id": 41350839,
        "body_markdown": "Example JSON file:\r\n\r\n    {\r\n      &quot;u&quot;: &quot;stuff&quot;,\r\n      &quot;x&quot;: [1,2,3],\r\n      &quot;y&quot;: {\r\n        &quot;field&quot;: &quot;value&quot;\r\n      },\r\n      &quot;z&quot;: {\r\n        &quot;zz&quot;: {\r\n           &quot;name&quot;: &quot;change me&quot;,\r\n           &quot;more&quot;: &quot;stuff&quot;\r\n        },\r\n        &quot;randomKey&quot;:  {\r\n           &quot;name&quot;: &quot;change me&quot;,\r\n           &quot;random&quot;: &quot;more stuff&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nHow can I update all the name fields to &quot;something&quot;, maintaining the rest of the JSON file the same?\r\n\r\n\r\n    {\r\n      &quot;u&quot;: &quot;stuff&quot;,\r\n      &quot;x&quot;: [1,2,3],\r\n      &quot;y&quot;: {\r\n        &quot;field&quot;: &quot;value&quot;\r\n      },\r\n      &quot;z&quot;: {\r\n        &quot;zz&quot;: {\r\n           &quot;name&quot;: &quot;something&quot;,\r\n           &quot;more&quot;: &quot;stuff&quot;\r\n        },\r\n        &quot;randomKey&quot;:  {\r\n           &quot;name&quot;: &quot;something&quot;,\r\n           &quot;random&quot;: &quot;more stuff&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nWith a direct path, this would be easy, but the parent keys (z and randomKey in these case) varies.\r\n\r\nI tried something like:\r\n\r\n    jq &#39;.z | .. | .name? |= &quot;something&quot;&#39; file.json\r\n\r\nAnd it&#39;s updating the names, but putting also all the recursive stuff..",
        "link": "https://stackoverflow.com/questions/41350839/replace-subkey-without-exact-path-in-jq",
        "title": "Replace subkey without exact path in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "artifactory",
            "jq",
            "skip"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 386425,
                    "reputation": 57870,
                    "user_id": 744178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3193139ea494c45e63752504f5ff1f2?s=256&d=identicon&r=PG",
                    "display_name": "jwodder",
                    "link": "https://stackoverflow.com/users/744178/jwodder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1482945481,
                "post_id": 41366699,
                "comment_id": 69934893,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 32607,
                    "reputation": 7055,
                    "user_id": 90608,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/TwKto.jpg?s=256",
                    "display_name": "Oscar Foley",
                    "link": "https://stackoverflow.com/users/90608/oscar-foley"
                },
                "reply_to_user": {
                    "account_id": 386425,
                    "reputation": 57870,
                    "user_id": 744178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3193139ea494c45e63752504f5ff1f2?s=256&d=identicon&r=PG",
                    "display_name": "jwodder",
                    "link": "https://stackoverflow.com/users/744178/jwodder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1482945671,
                "post_id": 41366699,
                "comment_id": 69935002,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 32607,
                    "reputation": 7055,
                    "user_id": 90608,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/TwKto.jpg?s=256",
                    "display_name": "Oscar Foley",
                    "link": "https://stackoverflow.com/users/90608/oscar-foley"
                },
                "reply_to_user": {
                    "account_id": 386425,
                    "reputation": 57870,
                    "user_id": 744178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3193139ea494c45e63752504f5ff1f2?s=256&d=identicon&r=PG",
                    "display_name": "jwodder",
                    "link": "https://stackoverflow.com/users/744178/jwodder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1482945810,
                "post_id": 41366699,
                "comment_id": 69935057,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1482947031,
                "creation_date": 1482947031,
                "answer_id": 41367121,
                "question_id": 41366699,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your Artifactory output isn&#39;t pure json... you need to remove those non-json parts.  Assuming we will only need to skip the first two lines, we could just use tail to skip em.\r\n\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip | tail -n +3 | jq &#39;.[-1].path&#39;",
                "title": "Unable to parse json output of artifactory with jq in linux"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1482949726,
                "creation_date": 1482949726,
                "answer_id": 41367732,
                "question_id": 41366699,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For the record, here&#39;s a jq-only solution that assumes there are exactly two lines of non-JSON prolog: \r\n\r\n    ... | jq -n -R -r &#39;[inputs][2:] | join(&quot;&quot;) | fromjson[-1]&#39; \r\n    {\r\n      &quot;path&quot;: &quot;foo/01_Develop/01_CI/HPCC-Package-72.zip&quot;\r\n    }",
                "title": "Unable to parse json output of artifactory with jq in linux"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1483001773,
                "creation_date": 1483001773,
                "answer_id": 41376201,
                "question_id": 41366699,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As mentioned in previous answers, this error occurred because the output of JFrog CLI is not pure JSON.&lt;br/&gt;\r\nYou may want to set the JFROG_CLI_LOG_LEVEL environment variable to ERROR, so that additional messages will not be prompted by the command.&lt;br/&gt;\r\nFor more details you can read [JFrog CLI wiki.][1] \r\n\r\n\r\n  [1]: https://www.jfrog.com/confluence/display/CLI/Welcome+to+JFrog+CLI#WelcometoJFrogCLI-EnvironmentVariables",
                "title": "Unable to parse json output of artifactory with jq in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1483001773,
        "creation_date": 1482945099,
        "last_edit_date": 1495542825,
        "question_id": 41366699,
        "body_markdown": "After executing this query in Artifactory\r\n\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip\r\n\r\nI have this output:\r\n\r\n    [Info] Searching artifacts...\r\n    [Info] Found 3 artifacts.\r\n    [\r\n      {\r\n        &quot;path&quot;: &quot;foo/01_Develop/01_CI/HPCC-Package-47.zip&quot;\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;foo/01_Develop/01_CI/HPCC-Package-48.zip&quot;\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;foo/01_Develop/01_CI/HPCC-Package-72.zip&quot;\r\n      }\r\n    ]\r\n\r\n\r\nI want to get the last path in json array with this command as suggested [here][1]:\r\n\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip | jq .[-1].path\r\n\r\nBut fails with\r\n\r\n&gt; parse error: Invalid numeric literal at line 1, column 6\r\n\r\nI cannot change json as it is the output from artifactory jfrog tool\r\n\r\n - How can I fix JQ query?\r\n - Is there any other way to get the last path?\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/41362345/how-can-i-download-last-artifact-in-artifactory\r\n\r\nNOTE: I have jq version 1.5\r\n\r\nUPDATE:\r\n\r\nUsing quotes I have the exact same error:\r\n\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip | jq &#39;.[-1].path&#39;\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip | jq &quot;.[-1].path&quot;",
        "link": "https://stackoverflow.com/questions/41366699/unable-to-parse-json-output-of-artifactory-with-jq-in-linux",
        "title": "Unable to parse json output of artifactory with jq in linux"
    }
]