[
    {
        "tags": [
            "syntax",
            "key",
            "expression",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1537596171,
                "last_edit_date": 1537596171,
                "creation_date": 1537586066,
                "answer_id": 52453181,
                "question_id": 52452705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @JeffMercado suggested, the problem goes away if you enclose `$authorizer_name` in parentheses:\r\n\r\n    { ($authorizer_name) : &quot;stuff&quot; }\r\n\r\nThe point is that when using the object construction syntax as here, each expression specifying a key name must be enclosed in parentheses unless it is a JSON string.",
                "title": "How can I use a parameter as key in a new object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1537596171,
        "creation_date": 1537579390,
        "last_edit_date": 1537586196,
        "question_id": 52452705,
        "body_markdown": "I&#39;m modifying some swagger to add aws api gateway integrations and am currently stuck on this problem.\r\n\r\nUsing this code, I&#39;m unable to generate the security object.\r\n\r\nI&#39;m getting the error:\r\n\r\n`jq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 6:\r\n      .value.security |= [ { $authorizer_name : map(.) }]`\r\n\r\nThis is driving me bonkers today.\r\n\r\nCan anyone shed a light on this?\r\n\r\nhere&#39;s a small repro.\r\n\r\n    INPUT=&#39;{\r\n      &quot;swagger&quot;: &quot;2.0&quot;,\r\n      &quot;paths&quot;: {\r\n        &quot;integrations/systems/{system_id}/configurations&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;security&quot;: [\r\n              &quot;https://api.com/internal-api&quot;\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }&#39;\r\n    \r\n    AUTHORIZER_NAME=&quot;cognito_user_pool&quot;\r\n    \r\n    jq --arg authorizer_name &quot;${AUTHORIZER_NAME}&quot; \\\r\n    &#39;.info.title |= &quot;API&quot; \r\n    | .info.description |= &quot;REST API&quot; \r\n    | .paths |= with_entries(\r\n        .value |= with_entries(\r\n          .value.security |= [ { $authorizer_name : &quot;stuff&quot; }]\r\n        )\r\n      )&#39; &lt;&lt;&lt; &quot;${INPUT}&quot;\r\n\r\nEDIT:\r\n\r\nThe solution is to surround the argument with `()` ie. `.value.security |= [ { ($authorizer_name) : &quot;stuff&quot; }]`",
        "link": "https://stackoverflow.com/questions/52452705/how-can-i-use-a-parameter-as-key-in-a-new-object",
        "title": "How can I use a parameter as key in a new object?"
    },
    {
        "tags": [
            "syntax",
            "jq",
            "invocation"
        ],
        "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": 1537650241,
                "post_id": 52460453,
                "comment_id": 91863741,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1537650326,
                "creation_date": 1537650326,
                "answer_id": 52460866,
                "question_id": 52460453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Immediate Answer: Use More Quotes\r\n\r\nIn `jq .[&quot;20&quot;]`, the double quotes are parsed as shell syntax, not `jq` syntax (shell quoting is character-by-character: One can switch quoting types within a larger string). Use single quotes to protect that entire string from modification by the shell:\r\n\r\n    $ echo &#39;{&quot;20&quot;:&quot;twenty&quot;}&#39; | jq &#39;.[&quot;20&quot;]&#39;\r\n    &quot;twenty&quot;\r\n\r\n---\r\n\r\n### Finding The Problem Yourself\r\n\r\nOne approach to diagnosing this kind of problem is using the shell&#39;s `xtrace` facility, to tell the shell to echo back to you the command lines it&#39;s running:\r\n\r\n    $ set -x\r\n    $ echo &#39;{&quot;20&quot;:&quot;twenty&quot;}&#39; | jq .[&quot;20&quot;]\r\n    + echo &#39;{&quot;20&quot;:&quot;twenty&quot;}&#39;\r\n    + jq &#39;.[20]&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index object with number\r\n\r\nAs you can see, `jq .[&quot;20&quot;]` was parsed as being identical to `jq &#39;.[20]&#39;`",
                "title": "How to use jq for a query where key is a numeric string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1537667251,
        "creation_date": 1537646804,
        "last_edit_date": 1537667251,
        "question_id": 52460453,
        "body_markdown": "Recently discovered `jq` and am using it to format some data.\r\n\r\nHow do I use it to access fields of a json object that happen to be numeric strings?\r\n\r\nFor example, the following fails for me with an error:\r\n\r\n```echo &#39;{&quot;20&quot;:&quot;twenty&quot;}&#39; | jq .[&quot;20&quot;]\r\n```\r\n\r\nWhat&#39;s the right way to do this?",
        "link": "https://stackoverflow.com/questions/52460453/how-to-use-jq-for-a-query-where-key-is-a-numeric-string",
        "title": "How to use jq for a query where key is a numeric string"
    },
    {
        "tags": [
            "bash",
            "geometry",
            "geojson",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2267004,
                    "reputation": 111,
                    "user_id": 1995398,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f01bab60aee60023d26aef5508e6fbc2?s=256&d=identicon&r=PG",
                    "display_name": "categulario",
                    "link": "https://stackoverflow.com/users/1995398/categulario"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537716524,
                "post_id": 52467305,
                "comment_id": 91876912,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1440074,
                    "reputation": 1787,
                    "user_id": 1360476,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/f0ba0ae461e07eeef3edcd43c003cbf2?s=256&d=identicon&r=PG",
                    "display_name": "Michel Hua",
                    "link": "https://stackoverflow.com/users/1360476/michel-hua"
                },
                "reply_to_user": {
                    "account_id": 2267004,
                    "reputation": 111,
                    "user_id": 1995398,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f01bab60aee60023d26aef5508e6fbc2?s=256&d=identicon&r=PG",
                    "display_name": "categulario",
                    "link": "https://stackoverflow.com/users/1995398/categulario"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537716604,
                "post_id": 52467305,
                "comment_id": 91876934,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537769148,
                "post_id": 52467305,
                "comment_id": 91888606,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1440074,
                    "reputation": 1787,
                    "user_id": 1360476,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/f0ba0ae461e07eeef3edcd43c003cbf2?s=256&d=identicon&r=PG",
                    "display_name": "Michel Hua",
                    "link": "https://stackoverflow.com/users/1360476/michel-hua"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537773952,
                "post_id": 52467305,
                "comment_id": 91890427,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1537744643,
                "last_edit_date": 1537744643,
                "creation_date": 1537720508,
                "answer_id": 52468129,
                "question_id": 52467305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Warning\r\nThe &quot;center of gravity&quot; of a polygon is in general not the same as the point defined in terms of the averages of the x and y co-ordinates of its vertices.  See e.g. https://math.stackexchange.com/questions/3177/why-doesnt-a-simple-mean-give-the-position-of-a-centroid-in-a-polygon\r\n\r\n## The averages of the latitudes and of the longitudes\r\n\r\nHere is a jq filter that will,\r\nwith a single invocation of jq and without redundancy, compute the averages of the latitudes and of the longitudes of each &quot;feature&quot;:\r\n\r\n    .features[].geometry.coordinates[0]\r\n    | [ [.[][0]], [.[][1]] ]\r\n    | map(add/length)\r\n\r\nWith the `-c` command-line option, this produces a stream of arrays, one array for each &quot;feature&quot;.  The stream begins:\r\n\r\n    [2.4206944444444445,48.724651111111115]\r\n    [2.407614,48.82250133333333]\r\n    ...\r\n\r\nOf course there are other alternatives but note that there is no need to use string interpolation to perform grouping, so there is usually no need for `tr` as your first version did.\r\n\r\n",
                "title": "Computing the center of gravity of a geoJSON Polygon using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537803054,
                "creation_date": 1537803054,
                "answer_id": 52482712,
                "question_id": 52467305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So if I understood correctly, you&#39;re trying to get the averages of the first set of coordinates, then updating the properties to store the result.\r\n\r\n    .features[] |= (\r\n        (.geometry.coordinates[0] | length as $len | reduce .[] as [$x, $y] ([0,0];\r\n            [.[0] + $x, .[1] + $y]\r\n        ) | map(. / $len)) as $barrycenter |\r\n        .properties.barycenter = $barrycenter\r\n    )",
                "title": "Computing the center of gravity of a geoJSON Polygon using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537803054,
        "creation_date": 1537714482,
        "last_edit_date": 1537783300,
        "question_id": 52467305,
        "body_markdown": "I have a list of cities described by their polygon in geoJSON files.\r\n\r\nI would like to get a sample inside point of the polygon.\r\n\r\nBasic maths says the center of gravity is inside the polygon and it suffices to sum all longitudes and all latitudes together then divide it by the number of points.\r\n\r\n[Full file to process][1] (visualization is available on GitHub)\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;coordinates&quot;: [[[2.41101, 48.72605], [2.41554, 48.72656], [2.41718, 48.72791], [2.4211, 48.72953], [2.42603, 48.72824], [2.42756, 48.72865], [2.42922, 48.72723], [2.43133, 48.72646], [2.43404, 48.72665], [2.43513, 48.72409], [2.42554, 48.7227], [2.42072, 48.72105], [2.41426, 48.71782], [2.41327, 48.71869], [2.41582, 48.72086], [2.41238, 48.72193], [2.41136, 48.72325], [2.41101, 48.72605]]]\r\n        },\r\n        &quot;properties&quot;: {\r\n          &quot;code&quot;: &quot;94001&quot;,\r\n          &quot;nom&quot;: &quot;Ablon-sur-Seine&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;coordinates&quot;: [[[2.41959, 48.81691], [2.4159, 48.81633], [2.40936, 48.81667], [2.40787, 48.81746\r\n        },\r\n        &quot;properties&quot;: {\r\n          &quot;code&quot;: &quot;94018&quot;,\r\n          &quot;nom&quot;: &quot;Charenton-le-Pont&quot;\r\n        }\r\n      },\r\n      ...\r\n      ]\r\n    }\r\n\r\n\r\nI already have a command that computes the length of the polygon vertices.\r\n\r\n    $ curl -s https://raw.githubusercontent.com/gregoiredavid/france-geojson/master/departements/94-val-de-marne/communes-94-val-de-marne.geojson \\\r\n    &gt; | jq &#39;.features[0].geometry.coordinates[0][][0]&#39; \\\r\n    &gt; | jq -s &#39;add/length&#39;\r\n    2.4206944444444445\r\n\r\nSee https://unix.stackexchange.com/questions/13731/\r\n\r\nUsing `jq` and simple bash commands, how can I compute the sum of the longitudes and sum of the latitudes as well, and reinject the barycenter in `properties` field in another geoJSON file?\r\n\r\nThank you.\r\n\r\n\r\n  [1]: https://github.com/gregoiredavid/france-geojson/blob/master/departements/94-val-de-marne/communes-94-val-de-marne.geojson",
        "link": "https://stackoverflow.com/questions/52467305/computing-the-center-of-gravity-of-a-geojson-polygon-using-jq",
        "title": "Computing the center of gravity of a geoJSON Polygon using jq"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537816269,
                "last_edit_date": 1537816269,
                "creation_date": 1537814374,
                "answer_id": 52485450,
                "question_id": 52485114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Version 1 is missing the `-s` command-line option.\r\n\r\nAnother way to skip the header row is to use `inputs` without the `-n` command-line option, as follows.  Using `inputs` is also much more efficient than using the `-s` command-line option.\r\n\r\n    &lt; source.csv sed &#39;s/[\\&quot;&lt;&gt;]//g&#39; |\r\n    jq -cR &#39;inputs \r\n          | split(&quot;,&quot;)\r\n          | {&quot;phone_number&quot;:.[0],&quot;opt_in&quot;:&quot;yes&quot;}&#39;\r\n\r\n# Robustness\r\n\r\nUsing jq to parse a CSV file is fraught with potential difficulties.  In general, it would be better to use a &quot;csv2tsv&quot; tool to convert the CSV to TSV, which jq can easily handle.\r\n\r\n\r\n",
                "title": "JQ to Parse CSV - How to Skip Headers"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1537816269,
        "creation_date": 1537812830,
        "question_id": 52485114,
        "body_markdown": "I have a CSV that needs to be converted to a simple new-line separated format to be fed into another script, but running into a weird issue.\r\n\r\nContents of CSV:\r\n\r\n    &quot;1. ID&quot;,&quot;2. Height&quot;,&quot;3. Gender&quot;,&quot;4. Age&quot;\r\n    &quot;&lt;1111111111&gt;&quot;,&quot;5ft. 10.0in.&quot;,&quot;M&quot;,&quot; 15.0&quot;\r\n    &quot;&lt;2222222222&gt;&quot;,&quot;6ft. 0in.&quot;,&quot;M&quot;,&quot; 22.0&quot;\r\n\r\nVersion 1 of CLI command:\r\n\r\n    cat source.csv | sed &#39;s/[\\&quot;&lt;&gt;]//g&#39; | ~/projects/dp/vendor/jq/1.5/jq --raw-input --compact-output &#39;split(&quot;\\n&quot;) | .[1:] | map(split(&quot;,&quot;)) | map({&quot;phone_number&quot;:.[0],&quot;opt_in&quot;:&quot;yes&quot;}) | .[]&#39;\r\n\r\nVersion 1 output: None\r\n\r\nVersion 2 of CLI command:\r\n\r\n    cat source.csv | sed &#39;s/[\\&quot;&lt;&gt;]//g&#39; | ~/projects/dp/vendor/jq/1.5/jq --raw-input --compact-output &#39;split(&quot;\\n&quot;) | .[0:] | map(split(&quot;,&quot;)) | map({&quot;phone_number&quot;:.[0],&quot;opt_in&quot;:&quot;yes&quot;}) | .[]&#39;\r\n\r\nVersion 2 output:\r\n\r\n    {&quot;phone_number&quot;:&quot;1. ID&quot;,&quot;opt_in&quot;:&quot;yes&quot;}\r\n    {&quot;phone_number&quot;:&quot;1111111111&quot;,&quot;opt_in&quot;:&quot;yes&quot;}\r\n    {&quot;phone_number&quot;:&quot;2222222222&quot;,&quot;opt_in&quot;:&quot;yes&quot;}\r\n\r\nIt&#39;s my understanding that the .[1:] tells JQ to only parse rows (separated by new line) past row #1, however row #1 will dictate references (being able to reference phone_number).\r\n\r\nSo why is version 1 not outputting anything?",
        "link": "https://stackoverflow.com/questions/52485114/jq-to-parse-csv-how-to-skip-headers",
        "title": "JQ to Parse CSV - How to Skip Headers"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537834095,
                "creation_date": 1537834095,
                "answer_id": 52488864,
                "question_id": 52488495,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want both filenames:\r\n\r\n    .[].fileName\r\n\r\nBut there are many other possibilities ...\r\n\r\n",
                "title": "jq select value from array where json does not have any root element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1537834095,
        "creation_date": 1537830574,
        "question_id": 52488495,
        "body_markdown": "jq select value from array\r\n\r\n    [\r\n    {\r\n            &quot;fileName&quot;: &quot;FOO&quot;,\r\n            &quot;md5&quot;: &quot;blablabla&quot;\r\n        }, \r\n    {\r\n            &quot;fileName&quot;: &quot;BAR&quot;,\r\n            &quot;md5&quot;: &quot;alaldlafj&quot;\r\n    }\r\n    ]\r\n\r\nHow to use JQ to select filename ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52488495/jq-select-value-from-array-where-json-does-not-have-any-root-element",
        "title": "jq select value from array where json does not have any root element"
    },
    {
        "tags": [
            "json",
            "diff",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 156429,
                    "reputation": 3686,
                    "user_id": 373710,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/9827ddb7c8cb132375cf55bf7e624250?s=256&d=identicon&r=PG",
                    "display_name": "Jakob",
                    "link": "https://stackoverflow.com/users/373710/jakob"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1556485034,
                "post_id": 52488950,
                "comment_id": 98445435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1537836446,
                "creation_date": 1537836446,
                "answer_id": 52489112,
                "question_id": 52488950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would probably be simplest to use the `--argjson` command-line option, e.g.\r\n\r\n    jq -n --argjson a &quot;$a&quot; --argjson b &quot;$b&quot; &#39;$a == $b&#39;\r\n\r\nOf course there are alternatives, e.g. using `jq -s` ...",
                "title": "jq to diff json in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1537836446,
        "creation_date": 1537834872,
        "question_id": 52488950,
        "body_markdown": "I have 2 json objects comming from a rest api. I want to compare if they are the same object.\r\nobjectA:\r\n\r\n    {\r\n      &quot;type&quot;: {\r\n        &quot;S&quot;: &quot;equal&quot;\r\n      },\r\n      &quot;preFilter&quot;: {\r\n        &quot;BOOL&quot;: true\r\n      }\r\n    }\r\n\r\nobjectB:\r\n\r\n    {\r\n      &quot;preFilter&quot;: {\r\n        &quot;BOOL&quot;: true\r\n      },\r\n      &quot;type&quot;: {\r\n        &quot;S&quot;: &quot;equal&quot;\r\n      }\r\n    }\r\n\r\nThey are the same, but an md5sum will see them as different. I tried inserting them in 2 different files, and compare the files using something proposed\r\n[here:](https://stackoverflow.com/questions/31930041/using-jq-or-alternative-command-line-tools-to-diff-json-files) but I would like to know if it&#39;s possible to use jq on the fly to compare variables.\r\n\r\nI&#39;ve been trying to change \r\n\r\n    --argfile a a.json\r\nfor\r\n\r\n    --arg a $a\r\n(being $a a json string) with no luck. Any idea how to approach strings, not files?\r\n",
        "link": "https://stackoverflow.com/questions/52488950/jq-to-diff-json-in-bash",
        "title": "jq to diff json in bash"
    },
    {
        "tags": [
            "json",
            "stream",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1537882235,
                "creation_date": 1537882235,
                "answer_id": 52499470,
                "question_id": 52497587,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your input file is:\r\n\r\n    cat file\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:20:00 +0000 2018&quot;,&quot;object_id&quot;:1,&quot;class_id&quot;:&quot;C&quot;}\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:23:00 +0000 2018&quot;,&quot;object_id&quot;:2,&quot;class_id&quot;:&quot;A&quot;}\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:21:00 +0000 2018&quot;,&quot;object_id&quot;:3,&quot;class_id&quot;:&quot;B&quot;}\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:22:00 +0000 2018&quot;,&quot;object_id&quot;:4,&quot;class_id&quot;:&quot;A&quot;}\r\n\r\n\r\nYou can try the following:\r\n\r\n    &lt;file jq -s &#39;\r\n       [ .[] | \r\n         (.modified |= (strptime(&quot;%a %b %d %H:%M:%S +0000 %Y&quot;) | mktime)) \r\n       ] | \r\n       sort_by(.modified) |              # sort using converted time\r\n       .[-3:] |                          # take the last 3\r\n       group_by(.class_id) |             # group ids together\r\n       .[] |                             \r\n       {(.[0].class_id): length}&#39;        # create the object using the id name and table length\r\n    {\r\n       &quot;A&quot;: 2\r\n    }\r\n    {\r\n      &quot;B&quot;: 1\r\n    }\r\n\r\nNote that on my system, the option `%z` of `strptime` isn&#39;t working. So I replaced it with `+0000` (which is anyway not used in the time conversion).",
                "title": "JQ: count number of objects per group, for a subset of input"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1538397705,
                "last_edit_date": 1538397705,
                "creation_date": 1537902732,
                "answer_id": 52505271,
                "question_id": 52497587,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [accepted answer](https://stackoverflow.com/a/52499470/10085368) uses the `-s` command-line option, which requires that the entire input data fit into memory.  For very large data sets, this may not be possible. \r\n\r\nSince the release of jq 1.5 (in 2015), an alternative is available. Here, therefore, a memory-efficient solution using `inputs` is presented.\r\n\r\nThe key functionality is encapsulated in the following jq filter:\r\n\r\n    # Return an array of n items as if by \r\n    # [stream] | sort_by(filter) | .[-n:]\r\n    def maxn(stream; filter; n):\r\n      def maxn:\r\n        sort_by(filter) | .[-n :];\r\n      reduce stream as $x ([]; . + [$x] | maxn);\r\n\r\nA solution to the problem at hand (with N==3) can now be obtained in just three additional lines:\r\n\r\n    maxn(inputs; .modified | strptime(&quot;%a %b %d %H:%M:%S +0000 %Y&quot;) | mktime; 3)\r\n    | group_by(.class_id)[]\r\n    | {(.[0].class_id): length}\r\n\r\nNote that this assumes the -n command-line option is used.  If it is omitted, the first line of input will be ignored.\r\n\r\n## Large N\r\n\r\nFor large datasets, if the value of N is also large, it would probably be worth the trouble to tweak the above to use jq’s support fot binary search (`bsearch`) instead of `sort_by`. It might similarly be worthwhile cacheing the `mktime` values.",
                "title": "JQ: count number of objects per group, for a subset of input"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1538397705,
        "creation_date": 1537876363,
        "last_edit_date": 1537911417,
        "question_id": 52497587,
        "body_markdown": "I need to count number of objects in each group with JQ, but only for N most recent objects.\r\n\r\nSample input, for N=3:\r\n\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:20:00 +0000 2018&quot;,&quot;object_id&quot;:1,&quot;group_id&quot;:&quot;C&quot;}\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:23:00 +0000 2018&quot;,&quot;object_id&quot;:2,&quot;group_id&quot;:&quot;A&quot;}\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:21:00 +0000 2018&quot;,&quot;object_id&quot;:3,&quot;group_id&quot;:&quot;B&quot;}\r\n    {&quot;modified&quot;:&quot;Mon Sep 25 14:22:00 +0000 2018&quot;,&quot;object_id&quot;:4,&quot;group_id&quot;:&quot;A&quot;}\r\n\r\nExpected output:\r\n\r\n    {&quot;A&quot;,2}\r\n    {&quot;B&quot;,1}\r\n\r\n----\r\nI&#39;m failing even to select a date-based subset which will preserve the structure of the objects: this is the best I managed to achieve:\r\n\r\n     [\r\n       .modified |= strptime(&quot;%a %b %d %H:%M:%S %z %Y&quot;) |\r\n       .modified |= mktime |\r\n       .modified |= strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)\r\n     ]  |\r\n     sort_by(.modified) |\r\n     .[] |\r\n     {modified, object_id, group_id}\r\n\r\nFor some reason, results are still unsorted.\r\n\r\nI&#39;m also failing to convert such a list to an array to select only N most recent entries.\r\n\r\nAnd after that I will need to count number of objects per group in some way.\r\n\r\n----\r\nOverall, looks like I need an extremely intuitive explanation on how arrays and lists of objects convert to each other, and how to modify some of their fields and, after that, to extract only fields required. The tutorials I&#39;ve found so far did not help, unfortunately.",
        "link": "https://stackoverflow.com/questions/52497587/jq-count-number-of-objects-per-group-for-a-subset-of-input",
        "title": "JQ: count number of objects per group, for a subset of input"
    },
    {
        "tags": [
            "json",
            "bash",
            "ssh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1537907374,
                "post_id": 52506148,
                "comment_id": 91952879,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2514230,
                    "reputation": 1068,
                    "user_id": 2186005,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/06d651c89e760499cf5c5da286bd5192?s=256&d=identicon&r=PG",
                    "display_name": "Vituvo",
                    "link": "https://stackoverflow.com/users/2186005/vituvo"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537912655,
                "post_id": 52506148,
                "comment_id": 91954877,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1537907651,
                "creation_date": 1537907651,
                "answer_id": 52506284,
                "question_id": 52506148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to quote the whole command, it&#39;s OK to provide multiple arguments. I&#39;d do this:\r\n\r\n    file=/home/systems/clients/000002/production.json\r\n    ...\r\n    ssh user@&quot;$cbserver&quot; jq -r &#39;.client.service_name&#39; &quot;$file&quot; | perl -lnE &#39;s/\\s+/-/g; say lc&#39; &gt; &quot;$tmp_input3&quot;\r\n\r\nNotes:\r\n\r\n* The `perl` command will run on your local system.  \r\n* I use of `jq -r` to avoid the quotes in the first place.\r\n",
                "title": "Retrieving the value from a json file from a remote server then use sed to replace upper case, double quotes and spaces"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537908060,
                "creation_date": 1537908060,
                "answer_id": 52506380,
                "question_id": 52506148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do all of this in `jq` itself:\r\n\r\n    $ jq -r &#39;.client.service_name | ascii_downcase | split(&quot; &quot;) | join(&quot;-&quot;)&#39; &lt;&lt;EOF\r\n    {\r\n        &quot;port&quot;: 5000,\r\n        &quot;machine&quot;: &quot;102&quot;,\r\n        &quot;ip&quot;: &quot;xxx.xxx.xxx.xxx&quot;,\r\n        &quot;drum_id&quot;: &quot;1305145216186552&quot;,\r\n        &quot;client&quot;: {\r\n            &quot;service_name&quot;: &quot;Two Men And A Truck&quot;,\r\n            &quot;vendor&quot;: &quot;default&quot;\r\n        }\r\n    }\r\n    EOF\r\n    two-men-and-a-truck",
                "title": "Retrieving the value from a json file from a remote server then use sed to replace upper case, double quotes and spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1538900605,
        "creation_date": 1537907073,
        "last_edit_date": 1538900605,
        "question_id": 52506148,
        "body_markdown": "I have to query a jason file to retrieve the value of service_name, then take the value, remove the double quotes, convert spaces to dashes, and then uppercase to lower case.\r\n\r\n\r\nHere is my json production.json file\r\n\r\n    {\r\n        &quot;port&quot;: 5000,\r\n        &quot;machine&quot;: &quot;102&quot;,\r\n        &quot;ip&quot;: &quot;xxx.xxx.xxx.xxx&quot;,\r\n        &quot;drum_id&quot;: &quot;1305145216186552&quot;,\r\n        &quot;client&quot;: {\r\n            &quot;service_name&quot;: &quot;Two Men And A Truck&quot;,\r\n            &quot;vendor&quot;: &quot;default&quot;\r\n        }\r\n    }\r\n\r\n\r\nand this is my command\r\n\r\n```\r\njq &#39;&quot;\\(.client.service_name)&quot;&#39; /home/systems/clients/000002/production.json | sed &#39;s/&quot;//g;s/ /-/g;s/\\(.*\\)/\\L\\1/&#39;\r\n```\r\n\r\nand this works just fine.\r\n\r\n    root@0200 ~ # cat /home/systems/clients/000002/production.json\r\n    {\r\n        &quot;port&quot;: 5000,\r\n        &quot;machine&quot;: &quot;102&quot;,\r\n        &quot;ip&quot;: &quot;xxx.xxx.xxx.xxx&quot;,\r\n        &quot;drum_id&quot;: &quot;1305145216186552&quot;,\r\n        &quot;client&quot;: {\r\n            &quot;service_name&quot;: &quot;Two Men And A Truck&quot;,\r\n            &quot;vendor&quot;: &quot;default&quot;\r\n        }\r\n    }\r\n    root@0200 ~ # jq &#39;&quot;\\(.client.service_name)&quot;&#39; /home/systems/clients/000002/production.json | sed &#39;s/&quot;//g;s/ /-/g;s/\\(.*\\)/\\L\\1/&#39;\r\n    two-men-and-a-truck\r\n\r\n\r\nNow here is my initial script. It&#39;s all going vlan atm and I&#39;ll eventually run it through an ssh tunnel.\r\n\r\n\r\n    #!/bin/bash\r\n    #\r\n    \r\n    #-- tmp files\r\n    tmp_dir=&quot;$(mktemp -d -t &#39;text.XXXXX&#39; || mktemp -d 2&gt;/dev/null)&quot;\r\n    tmp_input1=&quot;${tmp_dir}/temp_input1.txt&quot;\r\n    tmp_input2=&quot;${tmp_dir}/temp_input2.txt&quot;\r\n    tmp_input3=&quot;${tmp_dir}/temp_input3.txt&quot;\r\n    \r\n    #- servers\r\n    cbservers=( &quot;xxx.xxx.xxx.xxx&quot; &quot;xxx.xxx.xxx.xxx&quot; )\r\n    \r\n    for cbserver in &quot;${cbservers[*]}&quot;; do\r\n      ssh user@&quot;$cbserver&quot; &quot;ls /home/systems/clients | grep &#39;^[0-9]&#39;&quot; &gt; &quot;$tmp_input1&quot;\r\n      while read client; do\r\n        ssh user@&quot;$cbserver&quot; &quot;jq &#39;&quot;\\(.client.service_name)&quot;&#39; /home/systems/clients/000002/production.json | sed &#39;s/&quot;//g;s/ /-/g;s/\\(.*\\)/\\L\\1/&#39;&quot; &gt; &quot;$tmp_input3&quot;\r\n      done&lt;&quot;$tmp_input1&quot;\r\n    done\r\n    \r\n    rm -rf &quot;$tmp_dir&quot;\r\n\r\n\r\nI am having a hell of a time trying to wrap the command being sent over ssh.\r\n\r\n```\r\nssh user@&quot;$cbserver&quot; &quot;jq &#39;&quot;\\(.client.service_name)&quot;&#39; /home/systems/clients/000002/production.json | sed &#39;s/&quot;//g;s/ /-/g;s/\\(.*\\)/\\L\\1/&#39;&quot; &gt; &quot;$tmp_input3&quot;\r\n```\r\n\r\nIf there is an easier way to do this, please enlighten me.\r\n\r\n\r\n**Update**\r\n\r\n\r\nI followed everyone&#39;s advice below\r\n\r\n    #!/bin/bash\r\n    #\r\n    \r\n    #-- tmp files\r\n    tmp_dir=&quot;$(mktemp -d -t &#39;text.XXXXX&#39; || mktemp -d 2&gt;/dev/null)&quot;\r\n    tmp_input1=&quot;${tmp_dir}/temp_input1.txt&quot;\r\n    tmp_input2=&quot;${tmp_dir}/temp_input2.txt&quot;\r\n    \r\n    #- servers\r\n    cbservers=( &quot;xxx.xxx.xxx.xxx&quot; &quot;xxx.xxx.xxx.xxx&quot; )\r\n    \r\n    for cbserver in &quot;${cbservers[*]}&quot;; do\r\n      ssh user@&quot;$cbserver&quot; &quot;ls /home/systems/clients | grep &#39;^[0-9]&#39;&quot; &gt; &quot;$tmp_input1&quot;\r\n      while read client; do\r\n        file=&quot;/home/systems/clients/${client}/production.json &quot;\r\n        ssh user@&quot;$cbserver&quot; jq --raw-output &#39;.client.service_name&#39; &quot;$file&quot; | sed &#39;s/ /-/g;s/\\(.*\\)/\\L\\1/&#39; &gt; &quot;$tmp_input2&quot;\r\n      done&lt;&quot;$tmp_input1&quot;\r\n    done\r\n    \r\n    rm -rf &quot;$tmp_dir&quot;\r\n\r\nthe &quot;while read client&quot; loop only runs once and it should run 12 times.",
        "link": "https://stackoverflow.com/questions/52506148/retrieving-the-value-from-a-json-file-from-a-remote-server-then-use-sed-to-repla",
        "title": "Retrieving the value from a json file from a remote server then use sed to replace upper case, double quotes and spaces"
    },
    {
        "tags": [
            "json",
            "linux",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1537913737,
                "creation_date": 1537913737,
                "answer_id": 52507350,
                "question_id": 52507077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a little messy. Because you are piping twice and concatenating you are ending up with a cartesian product. \r\n\r\nInstead pipe `.[]` once to two different parentheticals:\r\n\r\n    ~$ jq -r &#39;.[] | (.id | tostring) + &quot;,&quot; + (.product | tostring)&#39; ver.json\r\n    123,13038\r\n    456,1212\r\n\r\n",
                "title": "BASH JQ command"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1537918731,
                "creation_date": 1537918731,
                "answer_id": 52507968,
                "question_id": 52507077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or more compactly:\r\n \r\n    $ jq -r &#39;.[] | &quot;\\(.id),\\(.product)&quot;&#39;\r\n    123,13038\r\n    456,1212\r\n\r\nIt may also be worth noting that `@csv` retains the types:\r\n\r\n    $ jq -r &#39;.[] | [.id,.product] | @csv&#39;\r\n    &quot;123&quot;,13038\r\n    &quot;456&quot;,1212",
                "title": "BASH JQ command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1537940357,
        "creation_date": 1537911789,
        "last_edit_date": 1537940357,
        "question_id": 52507077,
        "body_markdown": "Suppose I have the following json in the file ver.json:\r\n\r\n    [{&quot;id&quot;:&quot;123&quot;,&quot;product&quot;:13038},{&quot;id&quot;:&quot;456&quot;,&quot;product&quot;:1212}]\r\n\r\nWhy when I apply the &quot;jq&quot; command I get this result?\r\n\r\n    jq -r &#39;(.[].id|tostring) + &quot;,&quot; + (.[].product|tostring)&#39; ver.json\r\n    \r\n    123,13038\r\n    456,13038\r\n    123,1212\r\n    456,1212\r\n\r\nThis would be the correct answer:\r\n\r\n    123,13038\r\n    456,1212\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52507077/bash-jq-command",
        "title": "BASH JQ command"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1537954014,
                "creation_date": 1537954014,
                "answer_id": 52514366,
                "question_id": 52512687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `del` operator to delete the node you want:\r\n\r\n    &lt;file jq &#39;del(.bar[] | select(.v==2))&#39;",
                "title": "How can a sub-object be pruned from a json object using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1537958440,
                "last_edit_date": 1537958440,
                "creation_date": 1537956624,
                "answer_id": 52515247,
                "question_id": 52512687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Along the lines of the given attempt, namely:\r\n\r\n&gt;    .bar[] | select(.v ==2 | not)\r\n\r\nyou would use the `|=` operator, e.g.:\r\n\r\n    .bar |= map(select(.v ==2 | not))\r\n\r\nOr simply:\r\n\r\n     .bar |= map(select(.v != 2))\r\n\r\nIf you only wanted to delete the first match, you could write:\r\n\r\n    .bar |= (index({v:2}) as $i| .[:$i] + .[$i+1:])\r\n\r\nor more robustly:\r\n\r\n    .bar |= (index({v:2}) as $i\r\n      | if $i then .[:$i] + .[$i+1:] else . end)\r\n    \r\nor if you prefer:\r\n\r\n    .bar |= ( ([.[].v]|index(2)) as $i\r\n      | if $i then del(.[$i]) else . end)",
                "title": "How can a sub-object be pruned from a json object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537965254,
        "creation_date": 1537948471,
        "last_edit_date": 1537965254,
        "question_id": 52512687,
        "body_markdown": "In the following, I am trying to delete one of the two objects in the &quot;bar&quot; array, the one where &quot;v&quot; == 2:\r\n\r\n    {\r\n      &quot;foo&quot;: {},\r\n      &quot;bar&quot;: [\r\n        {\r\n          &quot;v&quot;: 2\r\n        },\r\n        {\r\n          &quot;v&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n\r\nI am able to first only keep the list, then delete the matching object:\r\n\r\n    .bar[] | select(.v ==2 | not)\r\n\r\nreturns:\r\n\r\n    {\r\n      &quot;v&quot;: 1\r\n    }\r\n\r\nIs there a way to delete a sub-object to keep the enclosing object:\r\n\r\n    {\r\n      &quot;foo&quot;: {},\r\n      &quot;bar&quot;: [\r\n        {\r\n          &quot;v&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/52512687/how-can-a-sub-object-be-pruned-from-a-json-object-using-jq",
        "title": "How can a sub-object be pruned from a json object using jq?"
    },
    {
        "tags": [
            "json",
            "object",
            "parent",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1537959658,
                "post_id": 52515945,
                "comment_id": 91971867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4438039,
                    "reputation": 121,
                    "user_id": 3613331,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/11ecb612d14e2ec6431b3fd9ffd544d6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3613331",
                    "link": "https://stackoverflow.com/users/3613331/user3613331"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537974419,
                "post_id": 52515945,
                "comment_id": 91981377,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537959814,
                "creation_date": 1537959814,
                "answer_id": 52516262,
                "question_id": 52515945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this jq command:\r\n\r\n     &lt;file jq &#39;select(.[].behaviors[].name==&quot;redirect&quot;)&#39;\r\n\r\n",
                "title": "How to get entire parent node using jq json parser?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1537981157,
                "last_edit_date": 1537981157,
                "creation_date": 1537960699,
                "answer_id": 52516505,
                "question_id": 52515945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid unwanted duplication:\r\n\r\n    .[]\r\n    | first(select(.behaviors[].name == &quot;redirect&quot;))\r\n   \r\n\r\nEquivalently:\r\n\r\n    .[]\r\n    | select(any(.behaviors[]; .name == &quot;redirect&quot;))",
                "title": "How to get entire parent node using jq json parser?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537981157,
        "creation_date": 1537958849,
        "last_edit_date": 1537964221,
        "question_id": 52515945,
        "body_markdown": "I am trying to find a value in the json file and based on that I need to get the entire json data instead of that particular block.\r\n\r\nHere is my sample json\r\n\r\n    [{\r\n          &quot;name&quot; : &quot;Redirect to Website 1&quot;,\r\n          \r\n          &quot;behaviors&quot; : [ {\r\n            &quot;name&quot; : &quot;redirect&quot;,\r\n            &quot;options&quot; : {\r\n              &quot;mobileDefaultChoice&quot; : &quot;DEFAULT&quot;,\r\n              &quot;destinationProtocol&quot; : &quot;HTTPS&quot;,\r\n              &quot;destinationHostname&quot; : &quot;SAME_AS_REQUEST&quot;,\r\n              &quot;responseCode&quot; : 302\r\n            }\r\n          } ],\r\n          &quot;criteria&quot; : [ {\r\n            &quot;name&quot; : &quot;requestProtocol&quot;,\r\n            &quot;options&quot; : {\r\n              &quot;value&quot; : &quot;HTTP&quot;\r\n            }\r\n          } ],\r\n          &quot;criteriaMustSatisfy&quot; : &quot;all&quot;\r\n    },\r\n    {\r\n          &quot;name&quot; : &quot;Redirect to Website 2&quot;,\r\n          \r\n          &quot;behaviors&quot; : [ {\r\n            &quot;name&quot; : &quot;redirect&quot;,\r\n            &quot;options&quot; : {\r\n              &quot;mobileDefaultChoice&quot; : &quot;DEFAULT&quot;,\r\n              &quot;destinationProtocol&quot; : &quot;HTTPS&quot;,\r\n              &quot;destinationHostname&quot; : &quot;SAME_AS_REQUEST&quot;,\r\n              &quot;responseCode&quot; : 301\r\n            }\r\n          } ],\r\n          &quot;criteria&quot; : [ {\r\n            &quot;name&quot; : &quot;contentType&quot;,\r\n            &quot;options&quot; : {\r\n              &quot;matchOperator&quot; : &quot;IS_ONE_OF&quot;,\r\n              &quot;values&quot; : [ &quot;text/html*&quot;, &quot;text/css*&quot;, &quot;application/x-javascript*&quot; ],\r\n            }\r\n          } ],\r\n          &quot;criteriaMustSatisfy&quot; : &quot;all&quot;\r\n    }]\r\n\r\nI am trying to match for `&quot;name&quot; : &quot;redirect&quot;` inside each `behaviors` array and if it matches then I need the entire block including the &quot;criteria&quot; section, as you can see its under same block `{}`\r\n\r\nI managed to find the values using select methods but not able to get the parent section. \r\n\r\nhttps://jqplay.org/s/BWJwVdO3Zv\r\n\r\nAny help is much appreciated!\r\n",
        "link": "https://stackoverflow.com/questions/52515945/how-to-get-entire-parent-node-using-jq-json-parser",
        "title": "How to get entire parent node using jq json parser?"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "extract",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 205662,
                    "reputation": 192281,
                    "user_id": 454533,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/c7715e765817254e0534f89a4092c0aa?s=256&d=identicon&r=PG",
                    "display_name": "Explosion Pills",
                    "link": "https://stackoverflow.com/users/454533/explosion-pills"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1537971234,
                "post_id": 52519743,
                "comment_id": 91979175,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1537972218,
                "creation_date": 1537972218,
                "answer_id": 52520155,
                "question_id": 52519743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your JSON object has a top-level field &quot;stream&quot; You need to access &quot;stream&quot; to access the other sub-properties, e.g. `channel`:\r\n\r\n    jq &#39;.stream.channel.status&#39; parse.json\r\n\r\nYou can also do `cat parse.json | jq &#39;.stream.channel.status&#39;`.\r\n\r\nYour example JSON is also invalid because the `stream.preview.small` property has a trailing comma. Simply removing that comma will make it valid, though.",
                "title": "why parsing with jq returns null?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1537984211,
                "creation_date": 1537984211,
                "answer_id": 52523516,
                "question_id": 52519743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To deal with the invalid JSON, you could use a JSON rectifier such as `hjson`; to avoid any hassles associated with identifying the relevant paths, you could use `..|objects`.  Thus for example:\r\n\r\n\r\n    $ hjson -j parse.json | jq &#39;..|objects|select(.status) | .status, ._id, .name&#39;\r\n    &quot;status&quot;\r\n    218025408945123440000000\r\n    &quot;djvbsdhvsdvasdv&quot;\r\n\r\n",
                "title": "why parsing with jq returns null?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1537984211,
        "creation_date": 1537971008,
        "question_id": 52519743,
        "body_markdown": "i am trying to extract values of 3 fields (status, id, name) from my json file by using jq tool, here is my json:\r\n\r\ncat parse.json\r\n\r\n    {\r\n      &quot;stream&quot;: {\r\n        &quot;_id&quot;: 65675798730520654496,\r\n        &quot;broadcast_platform&quot;: &quot;live&quot;,\r\n        &quot;community_id&quot;: &quot;&quot;,\r\n        &quot;community_ids&quot;: [],\r\n        &quot;average_fps&quot;: 60.0247524752,\r\n        &quot;delay&quot;: 0,\r\n        &quot;created_at&quot;: &quot;2018-09-26T07:25:38Z&quot;,\r\n        &quot;is_playlist&quot;: false,\r\n        &quot;stream_type&quot;: &quot;live&quot;,\r\n        &quot;preview&quot;: {\r\n          &quot;small&quot;: &quot;https://static-cdn.jtvnw.net/previews-ttv/live_user_versuta-80x4512wdfqf.jpg&quot;,\r\n        },\r\n        &quot;channel&quot;: {\r\n          &quot;mature&quot;: true,\r\n          &quot;status&quot;: &quot;status&quot;,\r\n          &quot;broadcaster_language&quot;: &quot;ru&quot;,\r\n          &quot;broadcaster_software&quot;: &quot;&quot;,\r\n          &quot;_id&quot;: 218025408945123423423445,\r\n          &quot;name&quot;: &quot;djvbsdhvsdvasdv&quot;,\r\n          &quot;created_at&quot;: &quot;2011-04-17T17:31:36.091604Z&quot;,\r\n          &quot;updated_at&quot;: &quot;2018-09-26T09:49:04.434245Z&quot;,\r\n          &quot;partner&quot;: true,\r\n          &quot;video_banner&quot;: null,\r\n          &quot;profile_banner&quot;: &quot;https://static-cdn.jtvnw.net/jtv_user_pictures/25c2bec3-95b8-4347-aba0-128b3b913b0d-profile_banner-480.png&quot;,\r\n          &quot;profile_banner_background_color&quot;: &quot;&quot;,\r\n          &quot;views&quot;: 103911737,\r\n          &quot;followers&quot;: 446198,\r\n          &quot;broadcaster_type&quot;: &quot;&quot;,\r\n          &quot;description&quot;: &quot;&quot;,\r\n          &quot;private_video&quot;: false,\r\n          &quot;privacy_options_enabled&quot;: false\r\n        }\r\n      }\r\n    }\r\n\r\nonline json validators say that it is valid, when i try to get some field it return `null`\r\n\r\ncat parse.json | jq &#39;.channel&#39;\r\n\r\n    null\r\n\r\ncat parse.json | jq &#39;.channel.status&#39;\r\n\r\n    null\r\n\r\nwhat am i doing wrong guys ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52519743/why-parsing-with-jq-returns-null",
        "title": "why parsing with jq returns null?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1537998315,
                "creation_date": 1537998315,
                "answer_id": 52526434,
                "question_id": 52523718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is probably not exactly what you want but should get you on your way:\r\n\r\n    def parsePathname: split(&quot;\\\\&quot;) | {path: .[0:length-1], file: .[-1]};\r\n    \r\n    # skip over lines that only specify directories\r\n    def pathnames:\r\n      foreach inputs as $x (null;\r\n        if . == null\r\n        then if ($x|length) == 0 then 0 else . end\r\n        else .+1\r\n        end;\r\n        select(. and . &gt; 0)|$x)\r\n        | parsePathname ;\r\n    \r\n    reduce pathnames as $pn ({};\r\n      getpath($pn.path + [&quot;children&quot;]) as $children\r\n      | setpath($pn.path + [&quot;children&quot;]; $children + [$pn.file]) )\r\n\r\n## Output\r\nWith your listing trimmed of the indicative lines, running the following command:\r\n\r\n    jq -R -n -f dirtree.jq dirtree.txt\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;C:&quot;: {\r\n        &quot;Program Files&quot;: {\r\n          &quot;children&quot;: [\r\n            &quot;desktop.ini&quot;\r\n          ],\r\n          &quot;7-Zip&quot;: {\r\n            &quot;children&quot;: [\r\n              &quot;7-zip.chm&quot;,\r\n              &quot;7-zip.dll&quot;,\r\n              &quot;7-zip32.dll&quot;,\r\n              &quot;7z.dll&quot;,\r\n              &quot;7z.exe&quot;,\r\n              &quot;7z.sfx&quot;,\r\n              &quot;7zCon.sfx&quot;,\r\n              &quot;7zFM.exe&quot;,\r\n              &quot;7zG.exe&quot;,\r\n              &quot;descript.ion&quot;\r\n            ]\r\n          },\r\n          &quot;WindowsPowerShell&quot;: {\r\n            &quot;Modules&quot;: {\r\n              &quot;PSReadline&quot;: {\r\n                &quot;1.2&quot;: {\r\n                  &quot;children&quot;: [\r\n                    &quot;Microsoft.PowerShell.PSReadline.dll&quot;,\r\n                    &quot;PSReadline.psd1&quot;,\r\n                    &quot;PSReadline.psm1&quot;\r\n                  ],\r\n                  &quot;en&quot;: {\r\n                    &quot;children&quot;: [\r\n                      &quot;Microsoft.PowerShell.PSReadline.Resources.dll&quot;\r\n                    ]\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n",
                "title": "Building a JSON of a directory tree using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1537998315,
        "creation_date": 1537985008,
        "question_id": 52523718,
        "body_markdown": "I&#39;m trying to building a JSON of a directory tree using [jq][1]. I&#39;m half way there but the directory tree is flat and I need to put every directory into it&#39;s parents `children` array.\r\n\r\n\r\n\r\nThe code I have so far is `dirtree.jq`:\r\n\r\n    [\r\n        split(&quot;\\n\\n&quot;) as $list\r\n        \r\n        | $list\r\n        | .[0]\r\n        | split(&quot;\\n&quot;)\r\n        | .  + [  .[0] | split(&quot;\\\\&quot;) | .[0:-1] | join(&quot;\\\\&quot;)  ] # add root folder\r\n        | sort\r\n        | . as $folders\r\n        \r\n        | $list\r\n        | .[1]\r\n        | split(&quot;\\n&quot;) as $files\r\n    \r\n        | $folders [] as $parent\r\n    \r\n    \r\n        | {\r\n            path: $parent,\r\n            children: (\r\n                $files\r\n                | map({\r\n                    path: select(\r\n                        . | (split(&quot;\\\\&quot;) | .[0:-1] | join(&quot;\\\\&quot;)) as $fileParent # get parent path\r\n                          | $fileParent == $parent\r\n                    )\r\n                })\r\n            )\r\n        }\r\n        \r\n        \r\n        \r\n    ] as $flatTree\r\n    | $flatTree\r\n\r\nThe [input][2] file is a **raw** plain text file in the format listing:\r\n\r\n - first all **directories** of a given folder\r\n\r\n - **then** an empty line\r\n\r\n - **then** a list of all **files**:\r\n\r\n\r\n----------\r\n\r\n\r\n    C:\\Program Files\\7-Zip\r\n    C:\\Program Files\\ASUS\r\n    C:\\Program Files\\Common Files\r\n    C:\\Program Files\\Intel\r\n    C:\\Program Files\\Internet Explorer\r\n    C:\\Program Files\\Mozilla Firefox\r\n    C:\\Program Files\\MSBuild\r\n    C:\\Program Files\\NVIDIA Corporation\r\n    C:\\Program Files\\Realtek\r\n    .\r\n    .\r\n    .\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PowerShellGet\\1.0.0.1\\en-US\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PSReadline\\1.2\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PSReadline\\1.2\\en\r\n                    &lt;-- NOTE THIS EMPTY LINE (\\n\\n) that separates folders from files\r\n    C:\\Program Files\\desktop.ini\r\n    C:\\Program Files\\7-Zip\\7-zip.chm\r\n    C:\\Program Files\\7-Zip\\7-zip.dll\r\n    C:\\Program Files\\7-Zip\\7-zip32.dll\r\n    C:\\Program Files\\7-Zip\\7z.dll\r\n    C:\\Program Files\\7-Zip\\7z.exe\r\n    C:\\Program Files\\7-Zip\\7z.sfx\r\n    C:\\Program Files\\7-Zip\\7zCon.sfx\r\n    C:\\Program Files\\7-Zip\\7zFM.exe\r\n    C:\\Program Files\\7-Zip\\7zG.exe\r\n    C:\\Program Files\\7-Zip\\descript.ion\r\n    .\r\n    .\r\n    .\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PSReadline\\1.2\\Microsoft.PowerShell.PSReadline.dll\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PSReadline\\1.2\\PSReadline.psd1\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PSReadline\\1.2\\PSReadline.psm1\r\n    C:\\Program Files\\WindowsPowerShell\\Modules\\PSReadline\\1.2\\en\\Microsoft.PowerShell.PSReadline.Resources.dll\r\n\r\n\r\nThe [resulting json][3] have all the files added to their respective parents but now I need to **move every folder to it&#39;s `parent`&#39;s `children` array**:\r\n\r\n\r\n----------\r\n[![enter image description here][4]][4]\r\n\r\nCommand line:\r\n\r\n`jq -R --slurp -s -f dirtree.jq input.txt &gt; dirtree.json`\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://pastebin.com/raw/N78kT3iY\r\n  [3]: https://pastebin.com/B7UKKpti\r\n  [4]: https://i.sstatic.net/EFEuI.png",
        "link": "https://stackoverflow.com/questions/52523718/building-a-json-of-a-directory-tree-using-jq",
        "title": "Building a JSON of a directory tree using JQ"
    },
    {
        "tags": [
            "json",
            "sum",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537991271,
                "last_edit_date": 1537991271,
                "creation_date": 1537990817,
                "answer_id": 52524995,
                "question_id": 52524416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input (rendered into valid JSON), the filter:\r\n\r\n    .data.stations\r\n    | { bikes: map(.num_bikes_available) | add,\r\n        ebikes: map(.num_ebikes_available) | add }\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;bikes&quot;: 22,\r\n      &quot;ebikes&quot;: 0\r\n    }\r\n\r\nA more efficient solution would use `sigma`, e.g. as follows:\r\n\r\n    def sigma(s): reduce s as $x (0; .+$x);\r\n\r\n    .data.stations\r\n    | [sigma(.[] | .num_bikes_available),\r\n       sigma(.[] | .num_ebikes_available)]",
                "title": "Summing nested values in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1538061236,
        "creation_date": 1537988313,
        "last_edit_date": 1538061236,
        "question_id": 52524416,
        "body_markdown": "I&#39;ve produced a json file from a public API with a curl request: \r\n\r\n    curl &quot;https://gbfs.citibikenyc.com/gbfs/es/station_status.json&quot; &gt; citibike.json\r\n\r\nThis pretty prints in `jq` as: \r\n\r\n    $ jq . citibike.json\r\n    {\r\n      &quot;last_updated&quot;: 1537986541,\r\n      &quot;ttl&quot;: 10,\r\n      &quot;data&quot;: {\r\n        &quot;stations&quot;: [\r\n          {\r\n            &quot;station_id&quot;: &quot;304&quot;,\r\n            &quot;num_bikes_available&quot;: 22,\r\n            &quot;num_ebikes_available&quot;: 0,\r\n            &quot;num_bikes_disabled&quot;: 4,\r\n            &quot;num_docks_available&quot;: 7,\r\n            &quot;num_docks_disabled&quot;: 0,\r\n            &quot;is_installed&quot;: 1,\r\n            &quot;is_renting&quot;: 1,\r\n            &quot;is_returning&quot;: 0,\r\n            &quot;last_reported&quot;: 1537986269,\r\n            &quot;eightd_has_available_keys&quot;: true,\r\n            &quot;eightd_active_station_services&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;a58d9e34-2f28-40eb-b4a6-c8c01375657a&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;station_id&quot;: &quot;359&quot;,\r\n            &quot;num_bikes_available&quot;: 0,\r\n            &quot;num_ebikes_available&quot;: 0,\r\n            &quot;num_bikes_disabled&quot;: 2,\r\n            &quot;num_docks_available&quot;: 50,\r\n            &quot;num_docks_disabled&quot;: 1,\r\n            &quot;is_installed&quot;: 1,\r\n            &quot;is_renting&quot;: 1,\r\n            &quot;is_returning&quot;: 0,\r\n            &quot;last_reported&quot;: 1537986120,\r\n            &quot;eightd_has_available_keys&quot;: false,\r\n            &quot;eightd_active_station_services&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;2e104e31-606a-44af-8b25-ceaffc338489&quot;\r\n              }\r\n            ]\r\n          },...\r\n\r\n\r\nMy objective is get two numbers - the sum of all values contained in `num_bikes_available` and `num_ebikes_available` with one jq query. \r\n\r\nThe following attempts throw an error: \r\n\r\n    jq -n &#39;reduce (inputs | .data.stations[] ) as $i ({}; .[$i.num_bikes_available] += $i.value)&#39; citibike.json\r\n\r\n    jq &#39;reduce .data.stations[] as $num_bikes_available (0; . + $num_bikes_available)&#39; citibike.json\r\n\r\nAny idea as to why and how to produce the desired result? \r\n",
        "link": "https://stackoverflow.com/questions/52524416/summing-nested-values-in-jq",
        "title": "Summing nested values in jq"
    },
    {
        "tags": [
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1537990476,
                "creation_date": 1537990476,
                "answer_id": 52524917,
                "question_id": 52524449,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Neither jq function names nor module names can be specified as jq variables, and so to achieve what you seem to want, you would have to resort to shell string-interpolation, or lookup expressions.\r\n\r\nIt is worth noting, however, that jq supports array-based path expressions, and so certain kinds of lookups can be supported using jq variables.",
                "title": "JQ: How to specify function name and include file as input arguments?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1537990476,
        "creation_date": 1537988438,
        "question_id": 52524449,
        "body_markdown": "I want to create generic SH script which will be called with a specified function to be used in the middle of JQ query.\r\n\r\n**1. How can I call a function by name specified as command-line argument?**\r\n\r\nThe straightforward way do so generates string with function name instead of invoking such a function:\r\n\r\n    jq --arg query_function &quot;foo_function&quot; &#39;\r\n      include &quot;foo_function&quot;;\r\n      . |\r\n      ($query_function)&#39; \\\r\n    input.txt\r\n\r\n----\r\n**2. Is it possible to also specify a file to include with a command-line argument to JQ?**\r\n\r\nI also tried to do it in a straightforward manner, but it didn&#39;t work.",
        "link": "https://stackoverflow.com/questions/52524449/jq-how-to-specify-function-name-and-include-file-as-input-arguments",
        "title": "JQ: How to specify function name and include file as input arguments?"
    },
    {
        "tags": [
            "shell",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1538058064,
                "last_edit_date": 1538058064,
                "creation_date": 1538056575,
                "answer_id": 52538743,
                "question_id": 52537826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not a `jq` problem, it&#39;s a shell quoting issue:\r\n\r\n    mytest(){\r\n      json=&#39;[{&quot;id&quot;:1,&quot;name&quot;:&quot;jdjson&quot;},{&quot;id&quot;:2,&quot;name&quot;:&quot;imagetookit&quot;}]&#39;\r\n      detail=$(echo &quot;$json&quot; | jq &#39;.[]|select(.id==2)&#39;)\r\n      echo &quot;$detail&quot;\r\n    }\r\n    mytest\r\n    {\r\n       &quot;id&quot;: 2,\r\n       &quot;name&quot;: &quot;imagetookit&quot;\r\n    }\r\n\r\nNotice the single quote `&#39;` around the `jq` command and so no need for backslash `\\`.  \r\nAlso prefer the `$(...)` instead of the old backtick notation.",
                "title": "jq built-in method select(): command not found"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1538068987,
        "creation_date": 1538053899,
        "last_edit_date": 1538068987,
        "question_id": 52537826,
        "body_markdown": "I used the jq built-in method `select` to parse the json string in shell script, and got an error: `command not found`.\r\n\r\nHere is my shell script: `test.sh`\r\n\r\n    #!/bin/bash\r\n\r\n    function test(){\r\n\r\n       json=&#39;[{&quot;id&quot;:1,&quot;name&quot;:&quot;jdjson&quot;},{&quot;id&quot;:2,&quot;name&quot;:&quot;imagetookit&quot;}]&#39;\r\n\r\n       detail=`echo $json | jq .[]|select\\(.id==2\\)`\r\n    }\r\n\r\n    test\r\n\r\n\r\nI just ran the script on the command line and got the following error:\r\n\r\n    $ bash test.sh\r\n    test.sh:行5: select(.id==2): 未找到命令 (means &quot;command not found&quot;) \r\n\r\n\r\nthe `select` is built-in method of jq command, and I don&#39;t know why\r\n\r\nDoes the function need to be imported? How to import method of jq?",
        "link": "https://stackoverflow.com/questions/52537826/jq-built-in-method-select-command-not-found",
        "title": "jq built-in method select(): command not found"
    },
    {
        "tags": [
            "windows",
            "jq",
            "pathname"
        ],
        "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": 1538121132,
                "post_id": 52546719,
                "comment_id": 92040333,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14433945,
                    "reputation": 21,
                    "user_id": 10426485,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-JqjUwXNYxlk/AAAAAAAAAAI/AAAAAAAAAAA/AAN31DWcovS5n92MTzmcTfI0GrGURUOTqA/mo/s256-rj/photo.jpg",
                    "display_name": "AKAAkira",
                    "link": "https://stackoverflow.com/users/10426485/akaakira"
                },
                "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": 1538139728,
                "post_id": 52546719,
                "comment_id": 92050456,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1605653282,
                "last_edit_date": 1605653282,
                "creation_date": 1538098375,
                "answer_id": 52547119,
                "question_id": 52546719,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There was a Windows-specific bug in jq 1.5 (see e.g. https://github.com/stedolan/jq/issues/1094).  It was fixed shortly after the release of jq 1.5. \r\n\r\nTo obtain a post-1.5 .exe for Windows, see any of:\r\n\r\n* https://chocolatey.org/packages?q=jq\r\n* https://stedolan.github.io/jq/download\r\n* https://github.com/stedolan/jq/wiki/Installation#windows-using-appveyor",
                "title": "Does jq have a filepath length limit?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1605653282,
        "creation_date": 1538094300,
        "last_edit_date": 1538140039,
        "question_id": 52546719,
        "body_markdown": "(OS is Windows 7 Professional. jq is version 1.5.)\r\n\r\nI&#39;ve been using jq to automate prettifying some JSON files (with Python). It seems to me after some time trying to determine why it wasn&#39;t working that jq fails silently when working with a file path string that&#39;s length 28, or simply stops working if the file path string is length 29 or more.\r\n\r\nE.g. on `cmd` (and it&#39;s worth pointing out that I made a kind of shortcut so that `jq` calls `jq-win64.exe`, and tested the latter directly as well, so that&#39;s not the source of the issue):\r\n\r\n    C:\\jq&gt;jq . 123456789012345678901234567\r\n\r\ndisplays prettified content of the file;\r\n\r\n    C:\\jq&gt;jq . 1234567890123456789012345678\r\n\r\ndisplays nothing; and\r\n\r\n    C:\\jq&gt;jq . 12345678901234567890123456789\r\n\r\ncauses a &quot;jq-win64.exe has stopped working&quot; window.\r\n\r\n(I also tested this on JSON files within folders; the common point was that the input string be of length 28 or more including slashes to fail.)\r\n\r\nIs this a bug? If it&#39;s not, &lt;strike&gt;what can I do to work around it&lt;/strike&gt; Okay, I admit that was a stupid question, I can work around it by copying content into a temp file in the base folder, prettify it, and then save it back to wherever I want it to be. More on-point question: is this the best workaround available for me to take?",
        "link": "https://stackoverflow.com/questions/52546719/does-jq-have-a-filepath-length-limit",
        "title": "Does jq have a filepath length limit?"
    },
    {
        "tags": [
            "json",
            "windows",
            "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": 1538101521,
                "post_id": 52547351,
                "comment_id": 92034336,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4521018,
                    "reputation": 1954,
                    "user_id": 3674263,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/bbr1E.jpg?s=256",
                    "display_name": "CodeSpent",
                    "link": "https://stackoverflow.com/users/3674263/codespent"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538102061,
                "post_id": 52547351,
                "comment_id": 92034427,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24564,
                    "reputation": 126055,
                    "user_id": 62576,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/15264f7bf48e10ce32dfa4865a13763c?s=256&d=identicon&r=PG",
                    "display_name": "Ken White",
                    "link": "https://stackoverflow.com/users/62576/ken-white"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538102244,
                "post_id": 52547351,
                "comment_id": 92034458,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14434837,
                    "reputation": 33,
                    "user_id": 10427084,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6625f938fe773e90fe5b7aad7fc0118?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Z. Kettell",
                    "link": "https://stackoverflow.com/users/10427084/z-kettell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538104392,
                "post_id": 52547351,
                "comment_id": 92034840,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14434837,
                    "reputation": 33,
                    "user_id": 10427084,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6625f938fe773e90fe5b7aad7fc0118?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Z. Kettell",
                    "link": "https://stackoverflow.com/users/10427084/z-kettell"
                },
                "reply_to_user": {
                    "account_id": 4521018,
                    "reputation": 1954,
                    "user_id": 3674263,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/bbr1E.jpg?s=256",
                    "display_name": "CodeSpent",
                    "link": "https://stackoverflow.com/users/3674263/codespent"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538111556,
                "post_id": 52547351,
                "comment_id": 92036564,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 515705,
                    "reputation": 4093,
                    "user_id": 3160967,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/1d5285da7116b41a824dd9cf0e77e4ea?s=256&d=identicon&r=PG",
                    "display_name": "mwag",
                    "link": "https://stackoverflow.com/users/3160967/mwag"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581554693,
                "post_id": 52547351,
                "comment_id": 106477845,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538113419,
                "last_edit_date": 1538113419,
                "creation_date": 1538102386,
                "answer_id": 52547543,
                "question_id": 52547351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could start with the following command-line invocation:\r\n\r\n    jq -n &quot;[inputs | .messages] | add&quot; *.json \r\n\r\nThis has a number of assumptions. If your windows shell does not support wildcard expansion, see https://stackoverflow.com/questions/45062501/passing-multiple-wildcard-filenames-to-a-command-in-windows and/or https://superuser.com/questions/460598/is-there-any-way-to-get-the-windows-cmd-shell-to-expand-wildcard-paths/460648#460648\r\n\r\nOther assumptions are that you are using jq 1.5 or later, and of course that all the *.json files in the current directory are relevant and that *.json lists them in the desired order.  \r\n\r\nIf the ordering of the JSON files is best determined by explicitly listing them, then you will probably want to create a batch file.  If their ordering is determined by their contents, then you could use jq to order them for you, but the details of how to do will depend on the details about the sorting criteria.\r\n\r\n",
                "title": "Combine all JSON files in a directory into one file - Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1538113419,
        "creation_date": 1538100688,
        "last_edit_date": 1538104328,
        "question_id": 52547351,
        "body_markdown": "I&#39;m fairly new to JSON and I currently have a list of ~130 JSON files that I received by downloading my Facebook message data. I&#39;m currently attempting to use JQ To concatenate them all into a single json file while keeping the existing message order intact however I&#39;m running into errors when I attempt to enter commands on Windows. I have attempted to follow their suggestions for Windows within the FAQ and am still running into issues.\r\n\r\nAll files have the same layout\r\n\r\n    {\r\n      &quot;participants&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Participant One&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Participant Two&quot;\r\n        }\r\n      ],\r\n      &quot;messages&quot;: [\r\n        {\r\n          &quot;sender_name&quot;: &quot;Participant One&quot;,\r\n          &quot;timestamp_ms&quot;: 99999999999,\r\n          &quot;content&quot;: &quot;message content&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Participant Two&quot;,\r\n          &quot;timestamp_ms&quot;: 9999999999,\r\n          &quot;content&quot;: &quot;message content&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;chat title&quot;,\r\n      &quot;is_still_participant&quot;: true,\r\n      &quot;thread_type&quot;: &quot;Regular&quot;,\r\n      &quot;thread_path&quot;: &quot;thread path&quot;\r\n    }\r\nIf possible with JQ, I&#39;d like to combine only the &quot;messages&quot; into a single JSON file while keeping them in the existing order. The messages are the only data in these files that I care about for my purposes.\r\n\r\n--Edit--\r\nVery sorry for the lack of details in the original post. I&#39;ve attempted several commands that I&#39;ve found both on here and elsewhere:\r\n\r\n    jq -s &quot;[.[][]]&quot; a-*.json &gt; output.json\r\n\r\n    jq -s &quot;{ attributes: map(.attributes[0]) }&quot; file*.json &gt; output.json\r\n\r\n    jq -s &quot;*&quot; *.json &gt; output.json\r\n\r\nI&#39;ve also attempted to put this code into a text file and rune it using:\r\n    jq -f filename\r\nBut am also receiving errors\r\n\r\nThe errors I&#39;ve been getting are either:\r\n\r\n    jq: error: Could not open file *.json: Invalid argument\r\n\r\nor\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;\r\n\r\nAs for more specifics on the output I&#39;m trying to achieve: I am using JQ 1.5. I don&#39;t care about the order that the JSON files get added to one another as long as the messages remain in the correct order so that I can get clear defined message/response pairs. I also don&#39;t care if it all gets combined and I have to separate out the messages in a different way. Something along the lines of this would be my ideal output:\r\n\r\n    &quot;messages&quot;: [\r\n        {\r\n          &quot;sender_name&quot;: &quot;Participant One&quot;,\r\n          &quot;timestamp_ms&quot;: 99999999999,\r\n          &quot;content&quot;: &quot;message content&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Participant Two&quot;,\r\n          &quot;timestamp_ms&quot;: 9999999999,\r\n          &quot;content&quot;: &quot;message content&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Participant Three&quot;,\r\n          &quot;timestamp_ms&quot;: 9999999999,\r\n          &quot;content&quot;: &quot;message content&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Participant Two&quot;,\r\n          &quot;timestamp_ms&quot;: 9999999999,\r\n          &quot;content&quot;: &quot;message content&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        }\r\n      ]\r\n\r\nWhere participant two represents my responses to messages and other participants are the people I am having conversations with (Which is how it is in the original JSON output from Facebook)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52547351/combine-all-json-files-in-a-directory-into-one-file-windows",
        "title": "Combine all JSON files in a directory into one file - Windows"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538106234,
                "creation_date": 1538106234,
                "answer_id": 52547978,
                "question_id": 52547428,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One possibility:\r\n\r\n    [.[] | { (.module) : (.deps | join(&quot;,&quot;)) }] | add",
                "title": "Combining outputs into single hash/dictionary JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607353151,
                "creation_date": 1607353151,
                "answer_id": 65184091,
                "question_id": 52547428,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another possibility (sort of functional approach):\r\n\r\n```\r\nreduce .[] as $elem ({}; . + { ($elem.module): $elem.deps | join(&quot;,&quot;) })\r\n```\r\nThe general syntax is:\r\n```\r\nreduce inputs as $elem (INIT; REDUCER)\r\n```\r\n\r\n - `INIT` initial value of the output variable could be e.g. `[]` or `{}`\r\n - `REDUCER` code that is executed on each element `. +` makes sure it gets appended to the intermediate result (the output) \r\n\r\n",
                "title": "Combining outputs into single hash/dictionary JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1607353151,
        "creation_date": 1538101480,
        "last_edit_date": 1538115461,
        "question_id": 52547428,
        "body_markdown": "So I&#39;ve got a json object that looks like this : \r\n\r\n\r\n\r\n    [{\r\n    \t&quot;size&quot;: &quot;77824&quot;,\r\n    \t&quot;module&quot;: &quot;rfcomm&quot;,\r\n    \t&quot;depcount&quot;: &quot;4&quot;,\r\n    \t&quot;deps&quot;: []\r\n    }, {\r\n    \t&quot;size&quot;: &quot;98304&quot;,\r\n    \t&quot;module&quot;: &quot;scsi_transport_iscsi&quot;,\r\n    \t&quot;depcount&quot;: &quot;4&quot;,\r\n    \t&quot;deps&quot;: []\r\n    }, {\r\n    \t&quot;size&quot;: &quot;16384&quot;,\r\n    \t&quot;module&quot;: &quot;xt_conntrack&quot;,\r\n    \t&quot;depcount&quot;: &quot;1&quot;,\r\n    \t&quot;deps&quot;: [&quot;nouveau&quot;, &quot;i915&quot;]\r\n    }]\r\n\r\n\r\n\r\nAnd I can use the following jq rule `.[] | { (.module) : (.deps | join(&quot;,&quot;)) }` into a series of objects that look like this \r\n\r\n\r\n    {\r\n      &quot;rfcomm&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;scsi_transport_iscsi&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;xt_conntrack&quot;: &quot;nouveau,i915&quot;\r\n    }\r\n\r\n\r\nI&#39;ve added a [jq play example](https://jqplay.org/s/8cXYKv2qlU) of what I see. \r\n\r\nWhat I&#39;d like it to get output that combines those objects. So something like : \r\n\r\n\r\n    {\r\n      &quot;rfcomm&quot;: &quot;&quot;,\r\n      &quot;scsi_transport_iscsi&quot;: &quot;&quot;,\r\n      &quot;xt_conntrack&quot;: &quot;nouveau,i915&quot;\r\n    }\r\n\r\n\r\nI&#39;m a bit of a jq novice so I&#39;m sure there&#39;s a way to do it I just don&#39;t know how. ",
        "link": "https://stackoverflow.com/questions/52547428/combining-outputs-into-single-hash-dictionary-jq",
        "title": "Combining outputs into single hash/dictionary JQ"
    },
    {
        "tags": [
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538182075,
                "last_edit_date": 1538182075,
                "creation_date": 1538154355,
                "answer_id": 52559900,
                "question_id": 52557156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To pass in a path as a parameter, you have to use the array-path notation (i.e., an array of strings and/or integers):\r\n\r\n    jq -s --argjson group_by_field &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; &#39;\r\n      group_by( getpath($group_by_field) )\r\n      | .[]\r\n      | [ .[0] | getpath($group_by_field)  ]\r\n    &#39; jq_group_on_test.json\r\n\r\nNote the use of the command-line option `--argjson`.",
                "title": "jq: Using nested field name as a command-line argument for group_by statement"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1538182075,
        "creation_date": 1538143749,
        "question_id": 52557156,
        "body_markdown": "I&#39;m building a generic group-by JQ script (as detailed [in another question](https://stackoverflow.com/questions/52497587/jq-count-number-of-objects-per-group-for-a-subset-of-input)) which accepts a field to be grouped as a command-line argument.\r\n\r\nIt works fine when I group by top-level field; it doesn&#39;t when I need to group by a field deep in an hierarchy of objects:\r\n\r\njq_group_on_test.json:\r\n\r\n    {\r\n        &quot;a&quot;: {\r\n          &quot;b&quot;: {\r\n            &quot;c&quot;: &quot;EFG&quot;\r\n          }\r\n        },\r\n        &quot;d&quot;: &quot;HIJ&quot;\r\n      }\r\n\r\nTop-level field:\r\n\r\n    jq -s --arg group_by_field &quot;d&quot; &#39;\r\n      group_by(.[$group_by_field])\r\n      | .[]\r\n      | [ (.[0][$group_by_field] ) ]&#39; \\\r\n    jq_group_on_test.json \r\n\r\n    [\r\n      &quot;HIJ&quot;\r\n    ]\r\n\r\nField from the nested object:\r\n\r\n    jq -s --arg group_by_field &quot;a.b.c&quot; &#39;\r\n      group_by(.[$group_by_field])\r\n      | .[]\r\n      | [ (.[0][$group_by_field] ) ]&#39; \\\r\n    jq_group_on_test.json\r\n\r\n    [\r\n      null\r\n    ]\r\n\r\nSame filter works if no variables used:\r\n\r\n    jq -s &#39;\r\n      group_by(.a.b.c)\r\n      | .[]\r\n      | [ (.[0].a.b.c ) ]&#39; \\\r\n    jq_group_on_test.json\r\n\r\n    [\r\n      &quot;DEF&quot;\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52557156/jq-using-nested-field-name-as-a-command-line-argument-for-group-by-statement",
        "title": "jq: Using nested field name as a command-line argument for group_by statement"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "categorization"
        ],
        "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": 1538148186,
                "post_id": 52558120,
                "comment_id": 92055337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538148295,
                "post_id": 52558120,
                "comment_id": 92055411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538150526,
                "post_id": 52558120,
                "comment_id": 92056573,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538150608,
                "post_id": 52558120,
                "comment_id": 92056604,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1865496,
                    "reputation": 3519,
                    "user_id": 1689179,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/o7925.png?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/1689179/dan"
                },
                "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": 1538150750,
                "post_id": 52558120,
                "comment_id": 92056670,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1865496,
                    "reputation": 3519,
                    "user_id": 1689179,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/o7925.png?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/1689179/dan"
                },
                "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": 1538150846,
                "post_id": 52558120,
                "comment_id": 92056716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538150985,
                "post_id": 52558120,
                "comment_id": 92056786,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1865496,
                    "reputation": 3519,
                    "user_id": 1689179,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/o7925.png?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/1689179/dan"
                },
                "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": 1538151357,
                "post_id": 52558120,
                "comment_id": 92056972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538151796,
                "post_id": 52558120,
                "comment_id": 92057203,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1865496,
                    "reputation": 3519,
                    "user_id": 1689179,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/o7925.png?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/1689179/dan"
                },
                "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": 1538153371,
                "post_id": 52558120,
                "comment_id": 92057896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1865496,
                    "reputation": 3519,
                    "user_id": 1689179,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://i.sstatic.net/o7925.png?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/1689179/dan"
                },
                "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": 1538155496,
                "post_id": 52558120,
                "comment_id": 92058797,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1538151553,
                "last_edit_date": 1538151553,
                "creation_date": 1538147659,
                "answer_id": 52558265,
                "question_id": 52558120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "*For others with related questions, but not sharing the OP&#39;s specific requirements: See edit history! There are several other relevant proposals, including `group_by` use, in prior iterations of this answer.*\r\n\r\n---\r\n\r\nIf you need entries for *all* values, even ones which have no occurrence, you might consider:\r\n\r\n&lt;!-- language: shell --&gt;\r\n\r\n    jq -r &#39;\r\n      def filterStates($stateMap):\r\n        if $stateMap[.] then $stateMap[.] else . end;\r\n    \r\n      def errorLevel:\r\n        if (.[&quot;error&quot;] &gt; 0) then 2 else\r\n          if (.[&quot;stalled&quot;] &gt; 0) then 1 else\r\n            0\r\n          end\r\n        end;\r\n    \r\n      {&quot;queuedDL&quot;: &quot;downloading&quot;, \r\n       &quot;checkingDL&quot;: &quot;downloading&quot;,\r\n       &quot;queuedUP&quot;: &quot;uploading&quot;, \r\n       &quot;checkingUP&quot;: &quot;uploading&quot;,\r\n       &quot;pausedUP&quot;: &quot;pause&quot;, \r\n       &quot;pausedDL&quot;: &quot;pause&quot;,\r\n       &quot;stalledUP&quot;: &quot;stalled&quot;, \r\n       &quot;stalledDL&quot;: &quot;stalled&quot;, \r\n       &quot;metaDL&quot;: &quot;stalled&quot;} as $stateMap |\r\n    \r\n      # initialize an output array since we want 0 outputs for everything\r\n      {&quot;pause&quot;: 0,  &quot;stalled&quot;: 0, &quot;error&quot;: 0, &quot;downloading&quot;: 0, &quot;uploading&quot;: 0} as $counts |\r\n    \r\n      # count number of items which filter to each value\r\n      reduce (.[].state | filterStates($stateMap)) as $state ($counts; .[$state]+=1) |\r\n    \r\n      # actually format an output string\r\n      &quot;\\(. | errorLevel) qbt_Nb_torrents - \\(values | add) total, \\(.[&quot;downloading&quot;]) downloading, \\(.[&quot;uploading&quot;]) seeding, \\(.[&quot;pause&quot;]) on pause, \\(.[&quot;stalled&quot;]) stalled, \\(.[&quot;error&quot;]) error&quot;\r\n    &#39; /tmp/torrents.json\r\n\r\n",
                "title": "Getting per-category counts of list items with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538171419,
                "last_edit_date": 1538171419,
                "creation_date": 1538155317,
                "answer_id": 52560093,
                "question_id": 52558120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just in case anyone is wondering what I exactly ended up using following Charles Duffy&#39;s excellent answer, here is the full `/usr/lib/check_mk_agent/local/qbittorrent` shell script that allows Check_MK (1.5.0 raw) to get what I think is the most relevant information about my qBittorrent application (qBittorrent v3.3.7 Web UI) running in a dedicated VM on my server:\r\n\r\n&lt;!-- language: shell --&gt;\r\n\r\n    #!/bin/sh\r\n    curl -s http://localhost:8080/query/transferInfo -o /tmp/transferInfo.json\r\n    curl -s http://localhost:8080/query/torrents -o /tmp/torrents.json\r\n    \r\n    if [ -e /tmp/transferInfo.json ]\r\n    then\r\n     dwl=$(jq .dl_info_speed /tmp/transferInfo.json)\r\n     dwl_MB=$(bc &lt;&lt;&lt; &quot;scale=2;$dwl/1048576&quot;)\r\n     upl=$(jq .up_info_speed /tmp/transferInfo.json)\r\n     upl_MB=$(bc &lt;&lt;&lt; &quot;scale=2;$upl/1048576&quot;)\r\n     echo &quot;0 qbt_Global_speed download=$dwl_MB|upload=$upl_MB Download: $dwl_MB MB/s, Upload: $upl_MB MB/s&quot;\r\n     rm -f /tmp/transferInfo.json\r\n    else\r\n     echo &quot;3 qbt_Global_speed download=0|upload=0 Can&#39;t get the information from qBittorrent WebUI API&quot;\r\n    fi\r\n    \r\n    if [ -e /tmp/torrents.json ]\r\n    then    \r\n     jq -r &#39;\r\n       def filterStates($stateMap):\r\n        if $stateMap[.] then $stateMap[.] else . end;\r\n    \r\n       {&quot;queuedDL&quot;: &quot;downloading&quot;,\r\n       &quot;checkingDL&quot;: &quot;downloading&quot;,\r\n       &quot;queuedUP&quot;: &quot;uploading&quot;,\r\n       &quot;checkingUP&quot;: &quot;uploading&quot;,\r\n       &quot;pausedUP&quot;: &quot;pause&quot;,\r\n       &quot;pausedDL&quot;: &quot;pause&quot;,\r\n       &quot;stalledUP&quot;: &quot;stalled&quot;,\r\n       &quot;stalledDL&quot;: &quot;stalled&quot;,\r\n       &quot;metaDL&quot;: &quot;stalled&quot;} as $stateMap |\r\n    \r\n       # initialize an output array since we want 0 outputs for everything\r\n       {&quot;pause&quot;: 0,  &quot;stalled&quot;: 0, &quot;error&quot;: 0, &quot;downloading&quot;: 0, &quot;uploading&quot;: 0} as $counts |\r\n    \r\n       # count number of items which filter to each value\r\n       reduce (.[].state | filterStates($stateMap)) as $state ($counts; .[$state]+=1) |\r\n    \r\n       # output string\r\n       &quot;P qbt_Nb_torrents total=\\(values|add)|downloading=\\(.[&quot;downloading&quot;])|seeding=\\(.[&quot;uploading&quot;])|pause=\\(.[&quot;pause&quot;])|stalled=\\(.[&quot;stalled&quot;]);0|error=\\(.[&quot;error&quot;]);0;0 total is \\(values|add), downloading is \\(.[&quot;downloading&quot;]), seeding is \\(.[&quot;uploading&quot;]), pause is \\(.[&quot;pause&quot;])&quot;\r\n    &#39; /tmp/torrents.json\r\n    \r\n     rm -f /tmp/torrents.json\r\n    else\r\n     echo &quot;3 qbt_Nb_torrents total=0|downloading=0|seeding=0|pause=0|stalled=0;0|error=0;0;0 Can&#39;t get the information from qBittorrent WebUI API&quot;\r\n    fi\r\n\r\nHere is the output with 1 stalled torrent:\r\n\r\n    0 qbt_Global_speed download=0|upload=0 Download: 0 MB/s, Upload: 0 MB/s\r\n    P qbt_Nb_torrents total=1|downloading=0|seeding=0|pause=0|stalled=1;0|error=0;0;0 total is 1, downloading is 0, seeding is 0, pause is 0\r\n\r\nThe `errorLevel` that I thought I needed (see Charles&#39;s answer) isn&#39;t required because of how Check_MK works; it handles the thresholds itself through [the metric parameter][1] when warning and critical values are specified.\r\n\r\nHere is what it looks like in Check_MK:\r\n\r\n[![Check_MK view][2]][2]\r\n\r\nNotice how Check_MK automatically added stalled and errored torrents. This is because of the warning and/or critical thresholds being specified. The metrics in general (with or without thresholds) are important to have the detailed relevant charts available.\r\n\r\n  [1]: https://mathias-kettner.com/cms_localchecks.html#perfdata\r\n  [2]: https://i.sstatic.net/RFp1q.png",
                "title": "Getting per-category counts of list items with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538182353,
                "last_edit_date": 1538182353,
                "creation_date": 1538166017,
                "answer_id": 52562184,
                "question_id": 52558120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a slightly more modularized version of @CharlesDuffy&#39;s solution. The main point of interest is perhaps the generic &quot;bag of words&quot; filter:\r\n\r\n    # bag of words\r\n    def bow(init; s): reduce s as $word (init; .[$word] += 1) ;\r\n\r\nNote also the initialization function:\r\n\r\n    # initialize an output object since we minimally want 0s\r\n    def init:\r\n      {} | {pause,stalled,error,downloading,uploading} | map_values(0);\r\n\r\nWith these additional abstractions, the &quot;main&quot; program becomes just two lines of code.\r\n\r\n      def filterStates($stateMap):\r\n        if $stateMap[.] then $stateMap[.] else . end ;\r\n    \r\n      def errorLevel:\r\n        if .error &gt; 0 then 2\r\n        elif .stalled &gt; 0 then 1\r\n        else 0\r\n        end ;\r\n    \r\n      def stateMap:\r\n        {&quot;queuedDL&quot;: &quot;downloading&quot;, \r\n         &quot;checkingDL&quot;: &quot;downloading&quot;,\r\n         &quot;queuedUP&quot;: &quot;uploading&quot;, \r\n         &quot;checkingUP&quot;: &quot;uploading&quot;,\r\n         &quot;pausedUP&quot;: &quot;pause&quot;, \r\n         &quot;pausedDL&quot;: &quot;pause&quot;,\r\n         &quot;stalledUP&quot;: &quot;stalled&quot;, \r\n         &quot;stalledDL&quot;: &quot;stalled&quot;, \r\n         &quot;metaDL&quot;: &quot;stalled&quot;} ;\r\n    \r\n## &quot;Main&quot;\r\n        \r\n      \r\n      # count number of items which map to each value\r\n      bow(init; .[].state | filterStates(stateMap))\r\n      # format an output string\r\n      | &quot;\\(errorLevel) qbt_Nb_torrents - \\(values | add) total, \\(.downloading) downloading, \\(.uploading) seeding, \\(.pause) on pause, \\(.stalled) stalled, \\(.error) error&quot;\r\n\r\n",
                "title": "Getting per-category counts of list items with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1538355891,
        "creation_date": 1538147150,
        "last_edit_date": 1538355891,
        "question_id": 52558120,
        "body_markdown": "I&#39;m currently learning how to use jq with shell in Linux since I&#39;m developing custom checks for Check_MK (formerly known as Nagios) and my application (qBittorrent with their [WebUI API][1]) returns JSON strings.\r\n\r\nCurrently, I&#39;m already able to count the total number of torrents just by using a simple `jq length`. Now, I would like to count the number of torrents that are currently dowloading, seeding or on pause. I&#39;m only interested by the `state`, so if I have 6 torrents, my JSON could look like that:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;state&quot;: &quot;uploading&quot;\r\n      },\r\n      {\r\n        &quot;state&quot;: &quot;downloading&quot;\r\n      },\r\n      {\r\n        &quot;state&quot;: &quot;downloading&quot;\r\n      },\r\n      {\r\n        &quot;state&quot;: &quot;downloading&quot;\r\n      },\r\n      {\r\n        &quot;state&quot;: &quot;pauseDL&quot;\r\n      },\r\n      {\r\n        &quot;state&quot;: &quot;pauseUP&quot;\r\n      }\r\n    ]\r\n\r\nHere, `jq length` returns 6. What do I need to do to get the details such as 3 are downloading, 1 is uploading, 2 are paused and 0 are in error?\r\n\r\nHere is my actual script:\r\n\r\n&lt;!-- language: sh --&gt;\r\n\r\n    #!/bin/sh\r\n    curl -s http://localhost:8080/query/torrents -o /tmp/torrents.json\r\n    count=$(jq length /tmp/torrents.json)\r\n    echo &quot;0 qbt_Nb_torrents - $count&quot;\r\n\r\nThe syntax for the `echo` is required by Check_MK (as explained [here][2]).\r\n\r\nI&#39;ve read multiple examples on filters but they all seem to be working when we&#39;re filtering through the top-level attributes. Here, my top level is basically just [0], ..., [5], so it doesn&#39;t work with the examples I&#39;ve found in the manual.\r\n\r\n**Additional information**\r\n\r\nThe WebUI API says there are 12 different possible states. That&#39;s how I intend to split them up:\r\n\r\n    downloading: queuedDL, checkingDL, downloading \r\n    uploading: queuedUP, checkingUP, uploading \r\n    pause: pausedUP, pausedDL \r\n    error: error \r\n    stalled: stalledUP, stalledDL, metaDL\r\n\r\nAs per the CheckMK syntax, I need to basically output something like:\r\n\r\n&gt; 0 qbt_Nb_torrents - 6 total, 3 downloading, 1 seeding, 2 on pause, 0 stalled, 0 error\r\n\r\nThe first 0 at the beginning means an OK status for CheckMK. If there are any stalled torrents, I want that status to become 1, and if there is any torrent in error, the status becomes 2. Example:\r\n\r\n&gt; 2 qbt_Nb_torrents - 8 total, 3 downloading, 1 seeding, 2 on pause, 1 stalled, 1 error\r\n\r\n  [1]: https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-Documentation\r\n  [2]: https://mathias-kettner.com/cms_localchecks.html#syntax",
        "link": "https://stackoverflow.com/questions/52558120/getting-per-category-counts-of-list-items-with-jq",
        "title": "Getting per-category counts of list items with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538169793,
                "post_id": 52562653,
                "comment_id": 92064091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2514230,
                    "reputation": 1068,
                    "user_id": 2186005,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/06d651c89e760499cf5c5da286bd5192?s=256&d=identicon&r=PG",
                    "display_name": "Vituvo",
                    "link": "https://stackoverflow.com/users/2186005/vituvo"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538170349,
                "post_id": 52562653,
                "comment_id": 92064260,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1538170142,
                "last_edit_date": 1538170142,
                "creation_date": 1538169233,
                "answer_id": 52562738,
                "question_id": 52562653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As for the immediate issue: `.key` works with `{ &quot;foo&quot;: &quot;value&quot; }`, but `.100` doesn&#39;t work with `{ &quot;100&quot;: &quot;value&quot; }`; the syntax you&#39;re relying is sugar, only available for a limited subset of keys. `.[&quot;100&quot;]` would work, but generating that by expanding shell variables into strings parsed as code is fragile (`jq` isn&#39;t a side-effecting language as of current releases, but in languages that *do* support I/O operations, such substitutions can be leveraged for injection attacks). To do things the Right Way, pass your variables out-of-band from your code, and use them for lookups in a manner that doesn&#39;t rely on what they contain.\r\n\r\n---\r\n\r\nThe `jq` equivalent to awk&#39;s `-v var=&quot;$value&quot;` is `--arg var &quot;$value&quot;`, used thusly:\r\n\r\n    jq --arg pgid &quot;$pgid&quot; \\\r\n       --arg tpogo &quot;$tpogo&quot; \\\r\n       &#39;.[$pgid].pogo = $tpogo&#39;\r\n\r\n---\r\n\r\nTesting this with your data:\r\n\r\n    json=&#39;{&quot;0000000&quot;:{&quot;pogo&quot;:&quot;AJHVUYKJBOIHKNNLNM&quot;},&quot;7000000&quot;:{&quot;pogo&quot;:&quot;PPPVUYKJBOIHKNNLNM&quot;}}&#39;\r\n    pgid=&quot;0000000&quot;\r\n    tpogo=&quot;XXXXXXX&quot;\r\n\r\n    jq --arg pgid &quot;$pgid&quot; --arg tpogo &quot;$tpogo&quot; \\\r\n       &#39;.[$pgid].pogo = $tpogo&#39; &lt;&lt;&lt;&quot;$json&quot;\r\n\r\n...emits as output:\r\n\r\n    {\r\n      &quot;0000000&quot;: {\r\n        &quot;pogo&quot;: &quot;XXXXXXX&quot;\r\n      },\r\n      &quot;7000000&quot;: {\r\n        &quot;pogo&quot;: &quot;PPPVUYKJBOIHKNNLNM&quot;\r\n      }\r\n    }",
                "title": "&quot;Invalid numeric literal&quot; error from jq trying to modify JSON with variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1622081304,
        "creation_date": 1538168658,
        "last_edit_date": 1538171295,
        "question_id": 52562653,
        "body_markdown": "I am wanting to pipe values into a bash script that will change values in a json file using jq. I&#39;ve been working on this for a while now and I can&#39;t get past the first set of errors.\r\n\r\nHere is my simple json file:\r\n\r\n    {\r\n    \t&quot;0000000&quot;: {\r\n    \t\t&quot;pogo&quot;: &quot;AJHVUYKJBOIHKNNLNM&quot;\r\n    \t},\r\n    \t&quot;7000000&quot;: {\r\n    \t\t&quot;pogo&quot;: &quot;PPPVUYKJBOIHKNNLNM&quot;\r\n    \t}\r\n    }\r\n\r\nHere is my script   \r\n\r\n    #!/bin/bash\r\n        \r\n    #-- pass into script\r\n    pgid=&quot;${1}&quot;\r\n    tpogo=&quot;${2}&quot;\r\n    file=&quot;file.json&quot;\r\n        \r\n    #-- tmp files\r\n    tmp_dir=&quot;$(mktemp -d -t &#39;text.XXXXX&#39; || mktemp -d 2&gt;/dev/null)&quot;\r\n    tmp_input1=&quot;${tmp_dir}/temp_input1.txt&quot;\r\n    \r\n    if [ ! -n &quot;$2&quot; ]; then\r\n       { echo &quot;Check your command as you are missing a variable ...&quot;; echo &quot;Example: script.sh &quot;00000001&quot; &quot;jvkkjbkjbd&quot; ...&quot;; }\r\n       exit 1;\r\n    fi\r\n        \r\n    jq -r &quot;.${pgid}.pogo = \\&quot;${tpogo}\\&quot;&quot; &quot;$file&quot; &gt; &quot;$tmp_input1&quot;\r\n    cat &quot;$tmp_input1&quot;\r\n    rm -rf &quot;$tmp_dir&quot;\r\n\r\n\r\nHere are the errors:\r\n\r\n    jq: error: Invalid numeric literal at EOF at line 1, column 9 (while parsing &#39;.0000000.&#39;) at &lt;top-level&gt;, line 1:\r\n    .0000000.pogo = &quot;XXXXXXX&quot;\r\n    jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .0000000.pogo = &quot;XXXXXXX&quot;\r\n    jq: 2 compile errors\r\n\r\n\r\nI have tried so many variations from stack and most of them look similar to what I am doing now.",
        "link": "https://stackoverflow.com/questions/52562653/invalid-numeric-literal-error-from-jq-trying-to-modify-json-with-variable",
        "title": "&quot;Invalid numeric literal&quot; error from jq trying to modify JSON with variable"
    },
    {
        "tags": [
            "select",
            "syntax",
            "jq",
            "tacit-programming"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1538183685,
                "creation_date": 1538183685,
                "answer_id": 52564235,
                "question_id": 52562979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `.`.  \r\n\r\nIf you want to retain the array structure, you could use `map(select(_))`, e.g.\r\n\r\n    jq -n &#39;[2, 4, 3] | map(select(. &gt;= 3))&#39;\r\n\r\nIf you just want the values, you could consider:\r\n\r\n    jq &#39;.[] | select(. &gt;= 3)&#39; &lt;&lt;&lt; &#39;[2, 4, 3]&#39;\r\n\r\n",
                "title": "How to select with jq in an array of values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1538337024,
        "creation_date": 1538171020,
        "last_edit_date": 1538337024,
        "question_id": 52562979,
        "body_markdown": "I want to select elements &gt;= 3 in an array like `[2, 4, 3]` with `jq`, how do I do it?\r\n\r\nI have found answers when the array contains objects (e.g `[{Name:&quot;a&quot;, Age:2} ...]}`) with things like `select (.Age &gt;= 2)` but I don&#39;t know how to refer to values",
        "link": "https://stackoverflow.com/questions/52562979/how-to-select-with-jq-in-an-array-of-values",
        "title": "How to select with jq in an array of values?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538391600,
                "creation_date": 1538391600,
                "answer_id": 52589687,
                "question_id": 52588489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To change all `x` values to `97`, you can try this jq command:\r\n\r\n    &lt;file jq &#39;.a.b.c as $in | .a.b.c=[ $in[] | .[].x=97 ]&#39;\r\n\r\nThe command stores the parent of the object in the variable `$in` such that you can modify one of its sub element.",
                "title": "Modify keys in multiple nested objects/arrays"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1538398502,
                "creation_date": 1538398502,
                "answer_id": 52591654,
                "question_id": 52588489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `|=` one can simply perform the update by writing:\r\n\r\n    .a.b.c |= [.[]|.[].x=97]\r\n\r\nor perhaps more clearly:\r\n\r\n    .a.b.c |= map(.[].x=97)\r\n\r\nIf you really do want to &quot;modify the value of all x keys&quot;, then you could use `walk`:\r\n\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;x&quot;) then .x=97 else . end)\r\n\r\n(If your jq does not have `walk`, then you can snarf its def from the web, e.g. from [builtin.jq](https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq) )",
                "title": "Modify keys in multiple nested objects/arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1538398502,
        "creation_date": 1538387418,
        "question_id": 52588489,
        "body_markdown": "I want to modify the value of all `x` keys in a json that looks like:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: {\r\n          &quot;c&quot;: [\r\n            {\r\n              &quot;0&quot;: {\r\n                &quot;x&quot;: 23,\r\n                &quot;name&quot;: &quot;AS&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;1&quot;: {\r\n                &quot;x&quot;: 23,\r\n                &quot;name&quot;: &quot;AS&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;2&quot;: {\r\n                &quot;x&quot;: 23,\r\n                &quot;name&quot;: &quot;Fe&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;3&quot;: {\r\n                &quot;x&quot;: 23,\r\n                &quot;name&quot;: &quot;Pl&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nI have tried multiple approaches, but I can&#39;t modify the value of `x` and obtain the full json as a result. All I managed to do is modify the value of `x` and obtain the last array as a result.\r\n\r\nHere is the closest I have been to achieve the result: https://jqplay.org/s/Wx741btZOg",
        "link": "https://stackoverflow.com/questions/52588489/modify-keys-in-multiple-nested-objects-arrays",
        "title": "Modify keys in multiple nested objects/arrays"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2756623,
                    "reputation": 25897,
                    "user_id": 7553525,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ua0kY.png?s=256",
                    "display_name": "zwer",
                    "link": "https://stackoverflow.com/users/7553525/zwer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538388596,
                "post_id": 52588722,
                "comment_id": 92112441,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6896529,
                    "reputation": 703,
                    "user_id": 8230132,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2d92ea3c4311567a524d8b751de051ea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rio",
                    "link": "https://stackoverflow.com/users/8230132/rio"
                },
                "reply_to_user": {
                    "account_id": 2756623,
                    "reputation": 25897,
                    "user_id": 7553525,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ua0kY.png?s=256",
                    "display_name": "zwer",
                    "link": "https://stackoverflow.com/users/7553525/zwer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538389000,
                "post_id": 52588722,
                "comment_id": 92112653,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6896529,
                    "reputation": 703,
                    "user_id": 8230132,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2d92ea3c4311567a524d8b751de051ea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rio",
                    "link": "https://stackoverflow.com/users/8230132/rio"
                },
                "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": 1538399212,
                "post_id": 52588722,
                "comment_id": 92118298,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538392790,
                "creation_date": 1538392790,
                "answer_id": 52589969,
                "question_id": 52588722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s rather unclear what you expect as output, but given your last example and using `jq` you can concatenate both service names together:\r\n\r\n    &lt;file jq &#39;[.group[].group[].service[].name] | join(&quot;,&quot;)&#39;\r\n\r\nNote that `join` expects an array, so the `name`s need to be inside an array `[ ... ]`.\r\n\r\nIf you need to add this string within the object itself, you might do something like:\r\n\r\n    &lt;file jq &#39;.service.name=([.group[].group[].service[].name] | join(&quot;,&quot;))&#39;\r\n\r\n\r\n",
                "title": "python combine values for a specific key separated by comma"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538400802,
                "creation_date": 1538400802,
                "answer_id": 52592341,
                "question_id": 52588722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your second JSON text, the following filter:\r\n\r\n    .group[].group[]\r\n    | { &quot;number&quot;: .number, &quot;service name&quot;: ([.service[].name]|join(&quot;, &quot;)) }\r\n\r\nproduces the output that you&#39;ve indicated you expected (including the space after the comma):\r\n\r\n    {\r\n      &quot;number&quot;: 1,\r\n      &quot;service name&quot;: &quot;FTP-Server, SSH-Server&quot;\r\n    }\r\n\r\n",
                "title": "python combine values for a specific key separated by comma"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1538400802,
        "creation_date": 1538388163,
        "last_edit_date": 1538394091,
        "question_id": 52588722,
        "body_markdown": "Is there a way to combine multiple values for a specific key separated by comma. In my case i am trying to print multiple `service.names` values so they can be printed in a single line separated by comma.\r\n\r\nHow can i combine the `service.name` values separated by comma so they print like below:\r\n\r\n    {\r\n      &quot;number&quot;: 1,\r\n      &quot;service name&quot;: &quot;FTP-Server, SSH-Server&quot;\r\n    }\r\n\r\nI tried below in pyjq but it separates values by a complete separate block.\r\n\r\n    .group[].group[] | { &quot;number&quot;: .number, &quot;service name&quot;: .service[].name }\r\n\r\nHere is the output i am getting\r\n\r\n    {\r\n      &quot;number&quot;: 1,\r\n      &quot;service name&quot;: &quot;FTP-Server&quot;\r\n    }\r\n    {\r\n      &quot;number&quot;: 1,\r\n      &quot;service name&quot;: &quot;SSH-Server&quot;\r\n    }\r\n\r\nGiven below same data with/without object-dictionary. I am ok with any format.\r\n\r\nJSON file with object-dictionary enabled\r\n\r\n\t{\r\n\t\t&quot;objects-dictionary&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;FTP-Server&quot;, \r\n\t\t\t\t&quot;port&quot;: &quot;21&quot;, \r\n\t\t\t\t&quot;type&quot;: &quot;service-tcp&quot;, \r\n\t\t\t\t&quot;uid&quot;: &quot;ef245528-9a3d-11d6-9eaa-3e5a6fdd6a6a&quot;\r\n\t\t\t}, \r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;SSH-Server&quot;, \r\n\t\t\t\t&quot;port&quot;: &quot;22&quot;, \r\n\t\t\t\t&quot;type&quot;: &quot;service-tcp&quot;, \r\n\t\t\t\t&quot;uid&quot;: &quot;dff4f7ba-9a3d-11d6-91c1-3e5a6fdd5151&quot;\r\n\t\t\t}\r\n\t\t], \r\n\t\t&quot;base&quot;: [\r\n\t\t\t{\r\n\t\t\t   &quot;number&quot;: 1, \r\n\t\t\t\t&quot;service&quot;: [\r\n\t\t\t\t\t&quot;ef245528-9a3d-11d6-9eaa-3e5a6fdd6a6a&quot;,\r\n\t\t\t\t\t&quot;dff4f7ba-9a3d-11d6-91c1-3e5a6fdd5151&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;uid&quot;: &quot;90088436-ac42-4363-84a6-3dbebf3c11f0&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\nJSON file without object-dictionary\r\n\r\n\t{\r\n\t\t&quot;group&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;group&quot;: [\r\n\t\t\t\t\t{ \r\n\t\t\t\t\t\t&quot;number&quot;: 1, \r\n\t\t\t\t\t\t&quot;service&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;FTP-Server&quot;, \r\n\t\t\t\t\t\t\t\t&quot;port&quot;: &quot;21&quot;, \r\n\t\t\t\t\t\t\t\t&quot;type&quot;: &quot;service-tcp&quot;, \r\n\t\t\t\t\t\t\t\t&quot;uid&quot;: &quot;ef245528-9a3d-11d6-9eaa-3e5a6fdd6a6a&quot;\r\n\t\t\t\t\t\t\t}, \r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;SSH-Server&quot;, \r\n\t\t\t\t\t\t\t\t&quot;port&quot;: &quot;22&quot;, \r\n\t\t\t\t\t\t\t\t&quot;type&quot;: &quot;service-tcp&quot;, \r\n\t\t\t\t\t\t\t\t&quot;uid&quot;: &quot;dff4f7ba-9a3d-11d6-91c1-3e5a6fdd5151&quot;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t], \r\n\t\t\t\t\t\t&quot;uid&quot;: &quot;90088436-ac42-4363-84a6-3dbebf3c11f0&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}",
        "link": "https://stackoverflow.com/questions/52588722/python-combine-values-for-a-specific-key-separated-by-comma",
        "title": "python combine values for a specific key separated by comma"
    },
    {
        "tags": [
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538465306,
                "last_edit_date": 1538465306,
                "creation_date": 1538448194,
                "answer_id": 52601330,
                "question_id": 52601262,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Does jq --stream run in background by default?\r\n\r\nNo. \r\n\r\nThe --stream option is usually only used for very large JSON texts, so if that is the case here, then it might take a long while for the job to finish. If you want to verify that progress is being made, consider adding one or more `debug` statements: each `debug` is like `.` but copies its input value to STDERR before passing the value along.\r\n\r\nSometimes it pays to be a bit devious with `debug`, as illustrated in this variant of your program:\r\n\r\n    jq -cn --stream &#39;\r\n      fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;userActivities&quot;) | del(.[0][0])))\r\n      | (.localDate|debug) as $debug\r\n      | select(.localDate[0:7] == &quot;2018-10&quot;)\r\n    &#39; 2018-10-01T21_45_56Z_triplem-baas_data.json &gt; October_2018_triplem_events.json\r\n\r\n",
                "title": "does jq --stream run in background?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1538465306,
        "creation_date": 1538447464,
        "last_edit_date": 1538459435,
        "question_id": 52601262,
        "body_markdown": "I ran the below-mentioned jq command and my putty session became inactive. however, I can still see the process running using the &quot;top&quot; command.\r\n\r\nDoes jq --stream run in background by default?\r\n\r\n    jq -cn --stream &#39;\r\n      fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;userActivities&quot;) | del(.[0][0])))\r\n      | select(.localDate[0:7] == &quot;2018-10&quot;)\r\n    &#39; 2018-10-01T21_45_56Z_triplem-baas_data.json &gt; October_2018_triplem_events.json",
        "link": "https://stackoverflow.com/questions/52601262/does-jq-stream-run-in-background",
        "title": "does jq --stream run in background?"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1538496007,
                "last_edit_date": 1538496007,
                "creation_date": 1538486894,
                "answer_id": 52609377,
                "question_id": 52609226,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have jq 1.4 or older, you could use the [`tonumber`][1] function:\r\n\r\n    jq --arg index 1 &#39;.[$index | tonumber]&#39;\r\n\r\nFor more recent versions, refer to [oliv&#39;s answer](https://stackoverflow.com/a/52609445/3266847).\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#tonumber",
                "title": "How I pass argument as index to jq?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1538487124,
                "creation_date": 1538487124,
                "answer_id": 52609445,
                "question_id": 52609226,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--argjson` option:\r\n\r\n    jq --argjson index 1 &#39;.[$index]&#39;\r\n\r\nAs mentioned in the `jq --help`:\r\n\r\n&gt; `--argjson a v`  set variable `$a` to JSON **value** `&lt;v&gt;`;",
                "title": "How I pass argument as index to jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1538496007,
        "creation_date": 1538486452,
        "last_edit_date": 1538486638,
        "question_id": 52609226,
        "body_markdown": "Hi I would like to access a given element in the json array as below:\r\n\r\n    $ echo &#39;[  { &quot;CT&quot; : &quot;OS1&quot;  , &quot;VERSION&quot; : &quot;3&quot; } , { &quot;CT&quot; : &quot;OS2&quot;  , &quot;VERSION&quot; : &quot;3&quot; } ]&#39;  | jq &#39;.[1]&#39;\r\n    {\r\n      &quot;CT&quot;: &quot;OS2&quot;,\r\n      &quot;VERSION&quot;: &quot;3&quot;\r\n    }\r\n\r\nHowever I would like to use a variable (from the environment in the future) replacing the index &#39;1&#39; in the command above but this produces an error.\r\n\r\n    echo &#39;[  { &quot;CT&quot; : &quot;OS1&quot;  , &quot;VERSION&quot; : &quot;3&quot; } , { &quot;CT&quot; : &quot;OS2&quot;  , &quot;VERSION&quot; : &quot;3&quot; } ]&#39;  | jq --arg index 1 &#39;.[$index]&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;1&quot;\r\n\r\nIt looks like it cannot parse this 1 as a numerical value once resolved like this. Is somebody able to help me?",
        "link": "https://stackoverflow.com/questions/52609226/how-i-pass-argument-as-index-to-jq",
        "title": "How I pass argument as index to jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538514319,
                "post_id": 52614115,
                "comment_id": 92166992,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1538504333,
                "creation_date": 1538504333,
                "answer_id": 52614154,
                "question_id": 52614115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well the data you&#39;re attempting to flatten is itself JSON so you have to parse it using `fromjson`. Once parsed, you could then generate the new objects.\r\n\r\n    map({id} + (.officers | fromjson[]))",
                "title": "Flatten nested JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1538504333,
        "creation_date": 1538504170,
        "question_id": 52614115,
        "body_markdown": "I&#39;m trying to flatten some nested JSON with jq. My first attempt was by looping over the JSON in bash with base64 [as per this article](https://starkandwayne.com/blog/bash-for-loop-over-json-array-using-jq/). It turned out to perform very slowly, so I&#39;m trying to figure out an alternative with just jq.\r\n\r\nI have some JSON like this:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;:117739,\r\n        &quot;officers&quot;: &quot;[{\\&quot;name\\&quot;:\\&quot;Alice\\&quot;},{\\&quot;name\\&quot;:\\&quot;Bob\\&quot;}]&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;:117740,\r\n        &quot;officers&quot;:&quot;[{\\&quot;name\\&quot;:\\&quot;Charlie\\&quot;}]&quot;\r\n      }\r\n    ]\r\n\r\n\r\nThe `officers` field holds a string which is JSON too. I&#39;d like to reduce this to:\r\n\r\n    [\r\n      { &quot;id&quot;:117739, &quot;name&quot;:&quot;Alice&quot; },\r\n      { &quot;id&quot;:117739, &quot;name&quot;:&quot;Bob&quot; },\r\n      { &quot;id&quot;:117740, &quot;name&quot;:&quot;Charlie&quot; }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52614115/flatten-nested-json-with-jq",
        "title": "Flatten nested JSON with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1538545631,
                "last_edit_date": 1538545631,
                "creation_date": 1538543992,
                "answer_id": 52620143,
                "question_id": 52620027,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Every line ends with a newline. Either remove the final newline, or omit the empty element at the end of the array.\r\n\r\n    vnix$ printf &#39;foo\\nbar\\n&#39; |\r\n    &gt; jq -R -s &#39;.[:-1] | split(&quot;\\n&quot;)&#39;\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n\r\n    vnix$ printf &#39;foo\\nbar\\n&#39; |\r\n    &gt; jq -R -s &#39;split(&quot;\\n&quot;)[:-1]&#39;\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n\r\nThe notation `x[:-1]` retrieves the value of a string or array `x` with the last element removed.  This is called [&quot;slice notation&quot;.](https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15])\r\n\r\nJust to spell this out, if you take the string `&quot;foo\\n&quot;` and split on newline, you get `&quot;foo&quot;` from before the newline and `&quot;&quot;` after it.\r\n\r\nTo make this really robust, maybe trim the last character only if it really is a newline.\r\n\r\n    vnix$ printf &#39;foo\\nbar\\n&#39; |\r\n    &gt; jq -R -s &#39;sub(&quot;\\n$&quot;;&quot;&quot;) | split(&quot;\\n&quot;)&#39;\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n\r\n    vnix$ printf &#39;foo\\nbar&#39; |\r\n    &gt; #  notice, no final ^ newine\r\n    &gt; jq -R -s &#39;sub(&quot;\\n$&quot;;&quot;&quot;) | split(&quot;\\n&quot;)&#39;\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]",
                "title": "jq raw json output carriage return?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1538545966,
                "creation_date": 1538545966,
                "answer_id": 52620490,
                "question_id": 52620027,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you have access to jq 1.5 or later, you can circumvent the problem entirely and economically using `inputs`:\r\n\r\n    jq -nR &#39;[inputs]&#39;\r\n\r\nJust be sure to include the -n option, otherwise the first line will go missing.",
                "title": "jq raw json output carriage return?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538546705,
                "creation_date": 1538546705,
                "answer_id": 52620643,
                "question_id": 52620027,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use\r\n\r\n    rpm -qa | grep kernel | jq -R . | jq -s .\r\n\r\nto get the desired result.\r\n\r\nPlease see https://github.com/stedolan/jq/issues/563",
                "title": "jq raw json output carriage return?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1538546705,
        "creation_date": 1538543267,
        "question_id": 52620027,
        "body_markdown": "Feel free to edit the title; not sure how to word it.  I&#39;m trying to turn shell output into JSON data for a reporting system I&#39;m writing for work.  Quick question, no matter what i do, when I take raw input in slurp mode and output the JSON, the last item in the array is blank (&quot;&quot;).  I feel like this is some sort of rookie `jq` issue I&#39;m running into, but can&#39;t figure out how to word the issue.  This seems to happen no matter what command I run on the shell and pipe to `jq`:\r\n\r\n    # rpm -qa | grep kernel | jq -R -s &#39;split(&quot;\\n&quot;)&#39;\r\n    [\r\n      &quot;kernel-2.6.32-504.8.1.el6.x86_64&quot;,\r\n      &quot;kernel-firmware-2.6.32-696.20.1.el6.noarch&quot;,\r\n      &quot;kernel-headers-2.6.32-696.20.1.el6.x86_64&quot;,\r\n      &quot;dracut-kernel-004-409.el6_8.2.noarch&quot;,\r\n      &quot;abrt-addon-kerneloops-2.0.8-43.el6.x86_64&quot;,\r\n      &quot;kernel-devel-2.6.32-358.11.1.el6.x86_64&quot;,\r\n      &quot;kernel-2.6.32-131.4.1.el6.x86_64&quot;,\r\n      &quot;kernel-devel-2.6.32-696.20.1.el6.x86_64&quot;,\r\n      &quot;kernel-2.6.32-696.20.1.el6.x86_64&quot;,\r\n      &quot;kernel-devel-2.6.32-504.8.1.el6.x86_64&quot;,\r\n      &quot;libreport-plugin-kerneloops-2.0.9-33.el6.x86_64&quot;,\r\n      &quot;&quot;\r\n    ]\r\n\r\nAny help is appreciated.",
        "link": "https://stackoverflow.com/questions/52620027/jq-raw-json-output-carriage-return",
        "title": "jq raw json output carriage return?"
    },
    {
        "tags": [
            "jenkins",
            "centos7",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538555740,
                "creation_date": 1538555740,
                "answer_id": 52622935,
                "question_id": 52621359,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you have is source RPM which isn&#39;t built software (binary). You have to build the rpm first.\r\n\r\n    rpmbuild --rebuild jq-1.5-1.el7.src.rpm\r\n\r\nIf things go right, you will end up with package like jq-1.5-1.el7.*.rpm file somewhere in ~/rpmbuild/RPMS/ *. You can then install that rpm.\r\n\r\nYou can refer to  \r\n\r\nhttps://wiki.centos.org/HowTos/RebuildSRPM    \r\n\r\nhttps://unix.stackexchange.com/a/110880",
                "title": "Jq offline install issue - Centos7"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1538555740,
        "creation_date": 1538549818,
        "question_id": 52621359,
        "body_markdown": "I am trying to install JQ on to a server that has no access to the internet.\r\n\r\nI downloaded the jq-1.5-1.el7.src.rpm file to a machine that is online and transferred it to the online machine.\r\n\r\nI then ran rpm -Uvh jq-1.5-1.el7.src.rpm on the offline machine. It says it installed 100% but when I try run jq --version, it says jq is no such file or directory.\r\n\r\nAny ideas why?\r\n\r\nOutput:\r\n\r\n* rpm -Uvh jq-1.5-1.el7.src.rpm\r\nwarning: jq-1.5-1.el7.src.rpm: Header V3 RSA/SHA256 Signature, key ID 352c64e5: NOKEY\r\nUpdating / installing...\r\n   1:jq-1.5-1.el7                     ################################# [100%]\r\nwarning: user mockbuild does not exist - using root\r\nwarning: group mockbuild does not exist - using root\r\nwarning: user mockbuild does not exist - using root\r\nwarning: group mockbuild does not exist - using root\r\n",
        "link": "https://stackoverflow.com/questions/52621359/jq-offline-install-issue-centos7",
        "title": "Jq offline install issue - Centos7"
    },
    {
        "tags": [
            "linux",
            "bash",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5370447,
                    "reputation": 17508,
                    "user_id": 4279155,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/Gve3F.png?s=256",
                    "display_name": "Dominique",
                    "link": "https://stackoverflow.com/users/4279155/dominique"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538568399,
                "post_id": 52626648,
                "comment_id": 92186544,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5453509,
                    "reputation": 182,
                    "user_id": 5786261,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1ca54247c5c9f3428cb10512c2487af8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "creed",
                    "link": "https://stackoverflow.com/users/5786261/creed"
                },
                "reply_to_user": {
                    "account_id": 5370447,
                    "reputation": 17508,
                    "user_id": 4279155,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/Gve3F.png?s=256",
                    "display_name": "Dominique",
                    "link": "https://stackoverflow.com/users/4279155/dominique"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538568506,
                "post_id": 52626648,
                "comment_id": 92186601,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538568564,
                "post_id": 52626648,
                "comment_id": 92186630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5453509,
                    "reputation": 182,
                    "user_id": 5786261,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1ca54247c5c9f3428cb10512c2487af8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "creed",
                    "link": "https://stackoverflow.com/users/5786261/creed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538568930,
                "post_id": 52626648,
                "comment_id": 92186868,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538569020,
                "post_id": 52626648,
                "comment_id": 92186916,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538585047,
                "post_id": 52626648,
                "comment_id": 92197077,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538596072,
                "last_edit_date": 1538596072,
                "creation_date": 1538568748,
                "answer_id": 52626789,
                "question_id": 52626648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the JSON structure matches roughly your example (e. g., there won&#39;t be any other whitespace characters between `&quot;timestamp&quot; `, the colon, and the value), then this awk should be ok. If available, using `jq` for JSON transformation is the better choice by far!\r\n\r\n    awk &#39;{print gensub(/(&quot;(timestamp|score)&quot;: )&quot;([0-9]+)&quot;/, &quot;\\\\1\\\\3&quot;, &quot;g&quot;)}&#39; file\r\n",
                "title": "Removing pattern from multiple lines using sed or awk in two places in the same line"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1538570552,
                "creation_date": 1538570552,
                "answer_id": 52627302,
                "question_id": 52626648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that you fix your JSON input file like this:\r\n\r\n    &lt;file jq .\r\n    [\r\n      {\r\n        &quot;title&quot;: &quot;DNS domain&quot;,\r\n        &quot;timestamp&quot;: &quot;1538564256&quot;,\r\n        &quot;domain&quot;: {\r\n          &quot;dns&quot;: [\r\n            &quot;www.google.com&quot;\r\n          ]\r\n        },\r\n        &quot;score&quot;: &quot;10&quot;,\r\n        &quot;link&quot;: &quot;www.bit.ky/sdasd/asddsa&quot;,\r\n        &quot;id&quot;: &quot;c-1eOWYB9XD0VZRJuWL6&quot;\r\n      },\r\n      {\r\n        &quot;title&quot;: &quot;DNS domain&quot;,\r\n        &quot;timestamp&quot;: &quot;1538564256&quot;,\r\n        &quot;domain&quot;: {\r\n          &quot;dns&quot;: [\r\n            &quot;google.de&quot;\r\n          ]\r\n        },\r\n        &quot;score&quot;: &quot;10&quot;,\r\n        &quot;link&quot;: &quot;www.bit.ky/sdasd/asddsa&quot;,\r\n        &quot;id&quot;: &quot;du1eOWYB9XD0VZRJuWL6&quot;\r\n      }\r\n    ]\r\n\r\nYou can use `jq` and its `tonumber` function to change the wanted strings to values:\r\n\r\n    &lt;file jq &#39;.[].timestamp |= tonumber | .[].score |= tonumber&#39;",
                "title": "Removing pattern from multiple lines using sed or awk in two places in the same line"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538895606,
                "last_edit_date": 1538895606,
                "creation_date": 1538597026,
                "answer_id": 52634856,
                "question_id": 52626648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Be warned that `tonumber` can lose precision.  If using `tonumber` is inadmissible, and if the output is produced by jq (or otherwise linearized vertically), then using awk as proposed elsewhere on this page is a good way to go.  (If your awk does not have gensub, then the awk program can be easily adapted.) Here is the same thing using `sed`, assuming its flag for extended regex processing is `-E`:\r\n\r\n    `sed -E -e &#39;s/&quot;(timestamp|score)&quot;: &quot;([0-9]+)&quot;/&quot;\\1&quot;: \\2/&#39;` \r\n\r\n\r\n2. For reference, if there&#39;s any doubt about where the relevant keys are located, here&#39;s a filter in jq that is agnostic about that:\r\n\r\n    `walk(if type == &quot;object&quot; \r\n         then if has(&quot;timestamp&quot;) then .timestamp|=tonumber else . end\r\n         | if has(&quot;score&quot;) then .score|=tonumber else end \r\n         else . end)`\r\n\r\nIf your jq does not have `walk/1`, then simply snarf its def from the web, e.g. from https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq\r\n\r\n3. If you wanted to convert all number-valued strings to numbers, you could write:\r\n\r\n    `walk(if type==&quot;object&quot; then map_values(tonumber? // .) else . end)`\r\n\r\n\r\n    ",
                "title": "Removing pattern from multiple lines using sed or awk in two places in the same line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538627948,
                "creation_date": 1538627948,
                "answer_id": 52639118,
                "question_id": 52626648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might work for you (GNU sed):\r\n\r\n    sed &#39;:a;/&quot;timestamp&quot;:\\s*&quot;1538564256&quot;,/{s/&quot;//3g;:b;n;/timestamp/ba;/&quot;score&quot;:\\s*&quot;10&quot;/s/&quot;//3g;Tb}&#39; file\r\nOn encountering a line that contains `&quot;timestamp&quot;: &quot;1538564256&quot;,` remove the 3rd or more `&quot;`&#39;s. Then read on until another line containing `timestamp` and repeat or a line containing `&quot;score&quot;: &quot;10` and remove the 3rd or more `&quot;`&#39;s.",
                "title": "Removing pattern from multiple lines using sed or awk in two places in the same line"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1538895606,
        "creation_date": 1538568237,
        "last_edit_date": 1538568303,
        "question_id": 52626648,
        "body_markdown": "I have a JSON file with 12,166,466 of lines. \r\nI want to remove quotes from values on keys: \r\n`&quot;timestamp&quot;: &quot;1538564256&quot;,`and `&quot;score&quot;: &quot;10&quot;,` to look like\r\n`&quot;timestamp&quot;: 1538564256,` and `&quot;score&quot;: 10,`.\r\n\r\n\r\nInput:\r\n\r\n    {\r\n    \t&quot;title&quot;: &quot;DNS domain&quot;, ,\r\n    \t&quot;timestamp&quot;: &quot;1538564256&quot;,\r\n    \t&quot;domain&quot;: {\r\n    \t\t&quot;dns&quot;: [\r\n    \t\t\t&quot;www.google.com&quot;\r\n    \t\t]\r\n    \t},\r\n    \t&quot;score&quot;: &quot;10&quot;,\r\n    \t&quot;link&quot;: &quot;www.bit.ky/sdasd/asddsa&quot;\r\n    \t&quot;id&quot;: &quot;c-1eOWYB9XD0VZRJuWL6&quot;\r\n    }, {\r\n    \t&quot;title&quot;: &quot;DNS domain&quot;,\r\n    \t&quot;timestamp&quot;: &quot;1538564256&quot;,\r\n    \t&quot;domain&quot;: {\r\n    \t\t&quot;dns&quot;: [\r\n    \t\t\t&quot;google.de&quot;\r\n    \t\t]\r\n    \t},\r\n    \t&quot;score&quot;: &quot;10&quot;,\r\n    \t&quot;link&quot;: &quot;www.bit.ky/sdasd/asddsa&quot;,\r\n    \t&quot;id&quot;: &quot;du1eOWYB9XD0VZRJuWL6&quot;\r\n    }\r\n    }\r\n\r\nExpected output:\r\n\r\n    {\r\n    \t&quot;title&quot;: &quot;DNS domain&quot;, ,\r\n    \t&quot;timestamp&quot;: 1538564256,\r\n    \t&quot;domain&quot;: {\r\n    \t\t&quot;dns&quot;: [\r\n    \t\t\t&quot;www.google.com&quot;\r\n    \t\t]\r\n    \t},\r\n    \t&quot;score&quot;: 10,\r\n    \t&quot;link&quot;: &quot;www.bit.ky/sdasd/asddsa&quot;\r\n    \t&quot;id&quot;: &quot;c-1eOWYB9XD0VZRJuWL6&quot;\r\n    }, {\r\n    \t&quot;title&quot;: &quot;DNS domain&quot;,\r\n    \t&quot;timestamp&quot;: 1538564256,\r\n    \t&quot;domain&quot;: {\r\n    \t\t&quot;dns&quot;: [\r\n    \t\t\t&quot;google.de&quot;\r\n    \t\t]\r\n    \t},\r\n    \t**&quot;score&quot;: 10,**\r\n    \t&quot;link&quot;: &quot;www.bit.ky/sdasd/asddsa&quot;,\r\n    \t&quot;id&quot;: &quot;du1eOWYB9XD0VZRJuWL6&quot;\r\n    }\r\n    }\r\n\r\nI have tried:\r\n\r\n    sed -E &#39;\r\n    s/&quot;timestamp&quot;: &quot;/&quot;timestamp&quot;: /g\r\n    s/&quot;score&quot;: &quot;/&quot;score&quot;: /g\r\n    &#39;\r\n\r\nthe first part is quite straightforward, but how to remove &quot;, at that the end of the line that contains &quot;timestamp&quot; and &quot;score&quot;? How do I access that using sed or even awk, or other tool with the mind that I have 12 million lines to process?",
        "link": "https://stackoverflow.com/questions/52626648/removing-pattern-from-multiple-lines-using-sed-or-awk-in-two-places-in-the-same",
        "title": "Removing pattern from multiple lines using sed or awk in two places in the same line"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2638245,
                    "reputation": 83,
                    "user_id": 2282432,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3965194f7f99d771da907bbf8810a7e2?s=256&d=identicon&r=PG",
                    "display_name": "chilukuridevbuzz",
                    "link": "https://stackoverflow.com/users/2282432/chilukuridevbuzz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538586260,
                "post_id": 52632140,
                "comment_id": 92197705,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538593941,
                "post_id": 52632140,
                "comment_id": 92201517,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538595259,
                "creation_date": 1538595259,
                "answer_id": 52634446,
                "question_id": 52632140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you&#39;re just updating a property by name somewhere in an object and how complex you expect to set the key, you could obtain all paths to values in your tree and compare to set your value.\r\n\r\n    $ jq --arg key &#39;somekey&#39; --arg value &#39;somevalue&#39; &#39;reduce (paths | select(.[-1] | tostring == $key)) as $i (.;\r\n        setpath($i; $value)\r\n    )&#39; input.json",
                "title": "jq update key and value with help of variables"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1538595259,
        "creation_date": 1538585906,
        "question_id": 52632140,
        "body_markdown": "I need to update JSON data with the given key and value. I tried passing this as variables for both key and value. \r\nI have JSON data, in my Unix method, I get key and value as parameters. I need to update the JSON data for that key with the given value.",
        "link": "https://stackoverflow.com/questions/52632140/jq-update-key-and-value-with-help-of-variables",
        "title": "jq update key and value with help of variables"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538652903,
                "creation_date": 1538652903,
                "answer_id": 52645700,
                "question_id": 52643251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this `jq` filter:\r\n\r\n    jq --slurpfile a a.json --slurpfile b b.json -n \\\r\n      &#39;$a[] | [.t] | if inside($b[] | [ range(.t1; .t2+1) ]) then {t:.[]} else empty end&#39;\r\n\r\nFor all values in `a.json`, look if that one is part of the range composed by the arrays of file `b.json`.\r\n",
                "title": "jq compare using values of same object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1538676493,
                "creation_date": 1538676493,
                "answer_id": 52652963,
                "question_id": 52643251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution is oriented to efficiency and also handles the case where the intervals defined by b.json overlap:\r\n\r\n    &lt; a.json jq --slurpfile b b.json &#39;\r\n      def check($value):\r\n        if any(.[]; .t1 &lt;= $value and $value &lt;= .t2) \r\n        then {t:$value} \r\n        else empty\r\n        end ;\r\n      . as $a | $b | check($a.t)\r\n    &#39; \r\n\r\n   \r\nSpecifically:\r\n\r\n* we use `any` so that the search for an applicable range stops as soon as possible;\r\n* we avoid &quot;slurping&quot; a.json to save RAM;\r\n* we avoid `range` in case any of the ranges is large.\r\n\r\n",
                "title": "jq compare using values of same object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1538676493,
        "creation_date": 1538644850,
        "question_id": 52643251,
        "body_markdown": "I have one json file\r\n\r\na.json:\r\n\r\n    {\r\n      &quot;t&quot;: 3\r\n    }\r\n    {\r\n      &quot;t&quot;: 6\r\n    }\r\n    {\r\n      &quot;t&quot;: 13\r\n    }\r\n\r\n\r\nAnd another file\r\n\r\nb.json:\r\n\r\n    {\r\n      &quot;t1&quot;: 1,\r\n      &quot;t2&quot;: 4\r\n    }\r\n    {\r\n      &quot;t1&quot;: 7,\r\n      &quot;t2&quot;: 8\r\n    }\r\n    {\r\n      &quot;t1&quot;: 11,\r\n      &quot;t2&quot;: 13\r\n    }\r\n\r\nI want to find the t values from a.json, which are between any single range t1, t2 of b.json objects.\r\n\r\nSo expected output is\r\n\r\n    {\r\n      &quot;t&quot;: 3\r\n    }\r\n    {\r\n      &quot;t&quot;: 13\r\n    }\r\n\r\nI have tried\r\n`jq --slurpfile a a.json --slurpfile b b.json -n &#39;$a[] | select(.t &gt;= $b[].t1 and .t &lt;= $b[].t2)&#39;` and\r\n`jq --slurpfile a a.json --slurpfile b b.json -n &#39;$a[] | select(.t == range($b[].t1, $b[].t2))&#39;`, but the comparison does not happen for same object of `$b` and I don&#39;t get the expected output.\r\n\r\n\r\nPlease help.",
        "link": "https://stackoverflow.com/questions/52643251/jq-compare-using-values-of-same-object",
        "title": "jq compare using values of same object"
    },
    {
        "tags": [
            "json",
            "openstreetmap",
            "geojson",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1538793511,
                "last_edit_date": 1538793511,
                "creation_date": 1538655827,
                "answer_id": 52646639,
                "question_id": 52645978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "found a satisfying solution while fiddling around on [jqplay][1]:\r\n\r\n    jq &#39;.features\r\n      | map(try(.properties.other_tags |=\r\n                (split(&quot;\\&quot;,\\&quot;&quot;)\r\n                 | join(&quot;\\&quot;##strsplit##\\&quot;&quot;)\r\n                 | split(&quot;##strsplit##&quot;)\r\n                 | .[] |= split(&quot;=&gt;&quot;) \r\n                 | .[] |= {(.[0][1:-1]): (.[1][1:-1])}\r\n                 | add)) // .)&#39;\r\n\r\nedit: changed the array index, thanks to peak for your comment\r\n\r\nedit2: comma tolerant and includes nodes w/o &#39;other_tags&#39;\r\n\r\n  [1]: http://jqplay.org",
                "title": "How to split a string value in json and convert to nested objects using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1538669323,
                "last_edit_date": 1538669323,
                "creation_date": 1538659242,
                "answer_id": 52647819,
                "question_id": 52645978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use this:\r\n\r\n    &lt;file jq &#39;[.[] | try(.properties.other_tags |= (&quot;{&quot; + gsub(&quot;=&gt;&quot;; &quot;:&quot;) + &quot;}&quot; | fromjson))//.]&#39;\r\n\r\nThis adds curly braces `{` and `}` to the wanted string and replace `=&gt;` by `:`. The string is then converted as a JSON object with the command `fromjson`. \r\n\r\nThe command doesn&#39;t change the JSON data if the `.properties.other_tags` isn&#39;t found.",
                "title": "How to split a string value in json and convert to nested objects using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538735359,
                "last_edit_date": 1538735359,
                "creation_date": 1538660310,
                "answer_id": 52648194,
                "question_id": 52645978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that assumes the input can be parsed into comma-separated segments matching the following regex (expressed as JSON):\r\n\r\n    &quot;\\&quot;(?&lt;key&gt;[^\\&quot;]+)\\&quot;=&gt;\\&quot;(?&lt;value&gt;[^\\&quot;]+)\\&quot;&quot;\r\n\r\n&lt;/p&gt;\r\n \r\n    # emit a stream\r\n    def unwrap:\r\n      . as $s\r\n      | if length==0 then empty\r\n        else match( &quot;\\&quot;(?&lt;key&gt;[^\\&quot;]+)\\&quot;=&gt;\\&quot;(?&lt;value&gt;[^\\&quot;]+)\\&quot;,?&quot; )\r\n        | (.captures|map({(.name): .string})|add), \r\n          ( $s[.length:]|unwrap)\r\n        end\r\n    ;\r\n    \r\n     map( .properties.other_tags |= ([unwrap]|from_entries) )\r\n\r\n\r\nThis approach has the (potential) advantage of allowing commas and occurrences of &quot;=&gt;&quot; within the keys and values.  Of course the implementation can be robustified (e.g. using `try` as you have done), but I&#39;ve kept it simple so you can easily make modifications to meet your more detailed requirements.",
                "title": "How to split a string value in json and convert to nested objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1538793511,
        "creation_date": 1538653849,
        "last_edit_date": 1538654656,
        "question_id": 52645978,
        "body_markdown": "I am trying to use jq to convert something like this:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;osm_id&quot;: &quot;172544&quot;,\r\n          &quot;highway&quot;: &quot;crossing&quot;,\r\n          &quot;other_tags&quot;: &quot;\\&quot;crossing\\&quot;=&gt;\\&quot;uncontrolled\\&quot;,\\&quot;tactile_paving\\&quot;=&gt;\\&quot;yes\\&quot;&quot;\r\n        },\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;Point&quot;,\r\n          &quot;coordinates&quot;: [\r\n            13.3432342,\r\n            52.5666157\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\ninto this:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;osm_id&quot;: &quot;172544&quot;,\r\n          &quot;highway&quot;: &quot;crossing&quot;,\r\n          &quot;other_tags&quot;: {\r\n            &quot;crossing&quot;: &quot;uncontrolled&quot;,\r\n            &quot;tactile_paving&quot;: &quot;yes&quot;\r\n          }\r\n        },\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;Point&quot;,\r\n          &quot;coordinates&quot;: [\r\n            13.3432342,\r\n            52.5666157\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nright now, this is my progress:\r\n\r\n    jq &#39;map(try(.properties.other_tags |= split(&quot;,&quot;) // .)) | map(try(.properties.other_tags[] |= split(&quot;=&gt;&quot;) // .)) | map(try(.properties.other_tags[] |= { (.[0]) : .[1] } // .))&#39; example.json\r\n\r\nbut the output of &quot;other_tags&quot; looks like this:\r\n\r\n      &quot;other_tags&quot;: [\r\n        {\r\n          &quot;\\&quot;crossing\\&quot;&quot;: &quot;\\&quot;uncontrolled\\&quot;&quot;\r\n        },\r\n        {\r\n          &quot;\\&quot;tactile_paving\\&quot;&quot;: &quot;\\&quot;yes\\&quot;&quot;\r\n        }\r\n      ]\r\n\r\nI am pretty sure this is not as performant as it could be.\r\n\r\nIt&#39;s used to transform osm exports, which are fairly big\r\n\r\nIs there a more elegant/shorter jq instruction i can use, also giving me the desired output as stated above?",
        "link": "https://stackoverflow.com/questions/52645978/how-to-split-a-string-value-in-json-and-convert-to-nested-objects-using-jq",
        "title": "How to split a string value in json and convert to nested objects using jq?"
    },
    {
        "tags": [
            "json",
            "command-line-arguments",
            "jq",
            "string-interpolation"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1538770232,
                "last_edit_date": 1538770232,
                "creation_date": 1538768333,
                "answer_id": 52672302,
                "question_id": 52672234,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq does support string interpolation, and in your case the string would be:\r\n\r\n    &quot;/bin/linux/\\($ARCH)/kubeadm&quot;\r\n\r\nNotice that this is not a JSON string: the occurrence of `&quot;\\(&quot;` signals that the string is subject to interpolation.  Very nifty.\r\n\r\n(Alternatively, you could of course use string concatenation: \r\n`&quot;/bin/linux/&quot; + $ARCH + &quot;/kubeadm&quot;`)\r\n\r\nBtw, you might wish to avoid `contains` here.  Its semantics is (are?) quite complex and perhaps counter-intuitive.  Consider using `startswith`, `index`, or (for regex matches) `test`.\r\n",
                "title": "jq --arg variable used in quoted string within select()"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1538771314,
        "creation_date": 1538767999,
        "last_edit_date": 1538771314,
        "question_id": 52672234,
        "body_markdown": "I want to `select()` an object based on a string containing a jq variable (`$ARCH`) using `-arg` jq argument. Here&#39;s the use-case while looking for &quot;`/bin/linux/$ARCH/kubeadm`&quot; from Google...\r\n\r\n    # You may need to install `xml2json` IE \r\n    # sudo gem install --no-rdoc --no-ri xml2json and run the script I wrote to do the xml2json:\r\n\r\n---------\r\n    #!/usr/bin/ruby\r\n\t# Written by Jim Conner\r\n\trequire &#39;xml2json&#39;\r\n\r\n\txml = ARGV[0]\r\n\r\n\tbegin\r\n\t  if xml == &#39;-&#39;\r\n\t    xdata = ARGF.read.chomp\r\n\t    puts XML2JSON.parse(xdata)\r\n\t  else\r\n\t    puts XML2JSON.parse(File.read(file2parse).chomp)\r\n\t  end\r\n\trescue =&gt; e\r\n\t  $stderr.puts &#39;Unable to comply: %s&#39; % [e.message]\r\n\tend\r\n\r\n-------------\r\n\r\nThen run the following:\r\n\r\n    curl -sSL https://storage.googleapis.com/kubernetes-release/ &gt; /var/tmp/k8s.xml | \\\r\n    xml2json - | \\\r\n    jq --arg ARCH amd64 &#39;[.ListBucketResult.Contents[] | select(.Key | contains(&quot;/bin/linux/$arch/kubeadm&quot;))]&#39;\r\n\r\n...which returns an empty set because `jq` doesn&#39;t transliterate inside quotes. I know I can get around this by using multiple select/contains() but I&#39;d prefer not to if possible.\r\n\r\n`jq` simply may not do it, but if someone knows a way to do it, I&#39;d much appreciate it.",
        "link": "https://stackoverflow.com/questions/52672234/jq-arg-variable-used-in-quoted-string-within-select",
        "title": "jq --arg variable used in quoted string within select()"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1538921787,
                "post_id": 52689219,
                "comment_id": 92305632,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1779,
                    "reputation": 4398,
                    "user_id": 2440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WHozO.jpg?s=256",
                    "display_name": "Sire",
                    "link": "https://stackoverflow.com/users/2440/sire"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633692380,
                "post_id": 52689219,
                "comment_id": 122833658,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1555063894,
                "last_edit_date": 1555063894,
                "creation_date": 1538921548,
                "answer_id": 52689319,
                "question_id": 52689219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq]:\r\n\r\n    jq --arg sub &quot;$sub&quot; &#39;.IntendedFor |= sub(&quot;(?&lt;=sub-)[^_]+&quot;; $sub)&#39; file\r\n\r\nSee [this online example](https://jqplay.org/s/_2xqFraagF)\r\n\r\nNote that your `jq` binary must be compiled with regex support in order to use `sub` function.  \r\n\r\nAnd, you can implement inline editing using a for loop and temporary files:\r\n\r\n    sub=03\r\n    \r\n    for jsonfile in *.json; do\r\n        tempfile=$(mktemp -u)\r\n        jq --arg sub &quot;$sub&quot; &#39;.IntendedFor|=sub(&quot;(?&lt;=sub-)[^_]+&quot;;$sub)&#39; &quot;$jsonfile&quot; &gt; &quot;$tempfile&quot;\r\n        mv &quot;$tempfile&quot; &quot;$jsonfile&quot;\r\n    done",
                "title": "find and replace a value in a json file using bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1539020298,
                "last_edit_date": 1539020298,
                "creation_date": 1538921780,
                "answer_id": 52689356,
                "question_id": 52689219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are better ways of doing this, but there is a bash-solution:\r\n\r\n    #!/bin/bash\r\n    fromstring=&quot;sub-02&quot;\r\n    tostring=&quot;sub-03&quot;\r\n\r\n    while read line; do\r\n        case &quot;$line&quot; in\r\n        (*IntendedFor*) echo $(line/$fromstring/$tostring) ;;\r\n        (*)  echo $line ;;\r\n        esac\r\n     done &lt; JSONfile\r\n\r\n",
                "title": "find and replace a value in a json file using bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1538923930,
                "last_edit_date": 1538923930,
                "creation_date": 1538922225,
                "answer_id": 52689419,
                "question_id": 52689219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq and bash:\r\n\r\n    value=$(jq -r &#39;.IntendedFor&#39; file)\r\n    new_value=&quot;${value/sub-02/sub-03}&quot;\r\n    jq --arg new &quot;$new_value&quot; &#39;.IntendedFor |= $new&#39; file\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;AcquisitionNumber&quot;: 1,\r\n      &quot;TotalReadoutTime&quot;: 0.035,\r\n      &quot;IntendedFor&quot;: &quot;func/sub-03_task-rest_run-01_bold.nii.gz&quot;\r\n    }",
                "title": "find and replace a value in a json file using bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538975121,
                "last_edit_date": 1538975121,
                "creation_date": 1538941887,
                "answer_id": 52692284,
                "question_id": 52689219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `sponge` (part of `moreutils`):\r\n\r\n    for f in *.json; do\r\n      jq --arg sub &quot;$sub&quot; &#39;.IntendedFor |= sub(&quot;/sub-[^_]+&quot;;&quot;/sub-&quot;+$sub)&#39; &quot;$f&quot; | sponge &quot;$f&quot;\r\n    done\r\n\r\nIn any case, a simple regex suffices.\r\n\r\n# sponge for Windows\r\nSee:\r\n\r\n* https://stackoverflow.com/questions/6604852/powershell-equivalent-to-sponge-in-moreutils\r\n* https://github.com/zetamatta/sponge",
                "title": "find and replace a value in a json file using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1666425146,
        "creation_date": 1538920804,
        "last_edit_date": 1666425146,
        "question_id": 52689219,
        "body_markdown": "I have several `.json` files similar to this.\r\n\r\n    {\r\n    \t&quot;AcquisitionNumber&quot;: 1,\r\n    \t&quot;TotalReadoutTime&quot;: 0.035,\r\n    \t&quot;IntendedFor&quot;: &quot;func/sub-02_task-rest_run-01_bold.nii.gz&quot;\r\n    }\r\n\r\nI want to change the sub number in the &quot;IntendedFor&quot; line using a bash variable, looping over different subs.For example if sub is 03:\r\n\r\n    sub=03\r\n    echo $sub\r\n    03\r\n\r\nHow can I change the value of `sub-02` to `sub-03` using this bash variable?\r\n",
        "link": "https://stackoverflow.com/questions/52689219/find-and-replace-a-value-in-a-json-file-using-bash",
        "title": "find and replace a value in a json file using bash"
    },
    {
        "tags": [
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538951828,
                "last_edit_date": 1538951828,
                "creation_date": 1538949831,
                "answer_id": 52693310,
                "question_id": 52692955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The trick is to &quot;pull&quot; the `.weeks[]` iterator forward, and to `map` over the `.matches` array:\r\n\r\n    .stage[]\r\n    |.weeks[]\r\n    | {matches:\r\n        (.matches\r\n         | map({team1:   .teams[0].name,\r\n                t1score: .teams[0].score,\r\n    \t        team2:   .teams[1].name, \r\n                t2score: .teams[1].score }) ) }\r\n\r\n# Output\r\n\r\n    {\r\n      &quot;matches&quot;: [\r\n        {\r\n          &quot;team1&quot;: &quot;San Francisco Shock&quot;,\r\n          &quot;t1score&quot;: &quot;0&quot;,\r\n          &quot;team2&quot;: &quot;Los Angeles Valiant&quot;,\r\n          &quot;t2score&quot;: &quot;4&quot;\r\n        },\r\n        {\r\n          &quot;team1&quot;: &quot;Shanghai Dragons&quot;,\r\n          &quot;t1score&quot;: &quot;0&quot;,\r\n          &quot;team2&quot;: &quot;Los Angeles Gladiators&quot;,\r\n          &quot;t2score&quot;: &quot;4&quot;\r\n        },\r\n        {\r\n          &quot;team1&quot;: &quot;Dallas Fuel&quot;,\r\n          &quot;t1score&quot;: &quot;1&quot;,\r\n          &quot;team2&quot;: &quot;Seoul Dynasty&quot;,\r\n          &quot;t2score&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "How to stop JQ filter from matching key to every permutation of the other keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1538951828,
        "creation_date": 1538946664,
        "last_edit_date": 1538949844,
        "question_id": 52692955,
        "body_markdown": "I&#39;m trying to parse a collection of JSON objects like this: \r\n\r\n    {\r\n    &quot;stage&quot;: [\r\n    {\r\n    &quot;name&quot;: &quot;Stage 1&quot;,\r\n    &quot;weeks&quot;: [\r\n    {\r\n     &quot;name&quot;: &quot;Week 1&quot;,\r\n     &quot;matches&quot;: [\r\n      {\r\n       &quot;teams&quot;: [\r\n        {\r\n         &quot;name&quot;: &quot;San Francisco Shock&quot;,\r\n         &quot;score&quot;: &quot;0&quot;,\r\n         &quot;score_url&quot;: &quot;https://overwatchleague.com/matches/10223&quot;\r\n        },\r\n        {\r\n         &quot;name&quot;: &quot;Los Angeles Valiant&quot;,\r\n         &quot;score&quot;: &quot;4&quot;,\r\n         &quot;score_url&quot;: &quot;https://overwatchleague.com/matches/10223&quot;\r\n        }\r\n       ]\r\n      },\r\n      {\r\n       &quot;teams&quot;: [\r\n        {\r\n         &quot;name&quot;: &quot;Shanghai Dragons&quot;,\r\n         &quot;score&quot;: &quot;0&quot;,\r\n         &quot;score_url&quot;: &quot;https://overwatchleague.com/matches/10224&quot;\r\n        },\r\n        {\r\n         &quot;name&quot;: &quot;Los Angeles Gladiators&quot;,\r\n         &quot;score&quot;: &quot;4&quot;,\r\n         &quot;score_url&quot;: &quot;https://overwatchleague.com/matches/10224&quot;\r\n        }\r\n       ]\r\n      },\r\n      {\r\n       &quot;teams&quot;: [\r\n        {\r\n         &quot;name&quot;: &quot;Dallas Fuel&quot;,\r\n         &quot;score&quot;: &quot;1&quot;,\r\n         &quot;score_url&quot;: &quot;https://overwatchleague.com/matches/10225&quot;\r\n        },\r\n        {\r\n         &quot;name&quot;: &quot;Seoul Dynasty&quot;,\r\n         &quot;score&quot;: &quot;2&quot;,\r\n         &quot;score_url&quot;: &quot;https://overwatchleague.com/matches/10225&quot;\r\n        }\r\n       ]\r\n      },\r\nEtc, etc.\r\n\r\nI&#39;m trying to get this into a format that another language that isn&#39;t super friendly to JSON can handle more easily by condensing it into something like this:\r\n\r\n   \r\n\r\n    {&quot;matches&quot;:\r\n        [\r\n         {\r\n          &quot;team1&quot;: &quot;San Francisco Shock&quot;,\r\n          &quot;t1score&quot;: &quot;0&quot;,\r\n          &quot;team2&quot;: &quot;Los Angeles Valiant&quot;,\r\n          &quot;t2score&quot;: &quot;4&quot;\r\n         },\r\n         { ... }\r\n        ]\r\n    }\r\n\r\nI&#39;m trying to use this jq filter to accomplish this:\r\n    \r\n    jq &#39;.stage[] | {matches: [{team1: .weeks[].matches[].teams[0].name, t1score: \r\n    .weeks[].matches[].teams[0].score, team2: .weeks[].matches[].teams[1].name, \r\n    t2score: .weeks[].matches[].teams[1].score}]}&#39;\r\n\r\nThe issue with this is that it matches every instance of, say, the &quot;name&quot; key with the value &quot;San Francisco Shock&quot; against all permutations of scores and names in the array &quot;matches&quot;. I&#39;m pretty new to jq, but I think that this is happening because I&#39;m simply telling it to map all of the elements in &quot;weeks&quot; and &quot;matches&quot; together through the filter. Is this correct? And what would a filter that actually did what I&#39;m looking to try and do look like? I haven&#39;t found an easy way to keep the filter from matching beyond the scope of the &quot;teams&quot; array.",
        "link": "https://stackoverflow.com/questions/52692955/how-to-stop-jq-filter-from-matching-key-to-every-permutation-of-the-other-keys",
        "title": "How to stop JQ filter from matching key to every permutation of the other keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22779,
                    "reputation": 132266,
                    "user_id": 56541,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Wm7Xg.png?s=256",
                    "display_name": "David Z",
                    "link": "https://stackoverflow.com/users/56541/david-z"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538971036,
                "post_id": 52695178,
                "comment_id": 92316849,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1538971626,
                "post_id": 52695178,
                "comment_id": 92316965,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12951196,
                    "reputation": 477,
                    "user_id": 9363455,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bf0c48c68e2d04ef6a3c4f8d1fd69b9b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sains",
                    "link": "https://stackoverflow.com/users/9363455/sains"
                },
                "reply_to_user": {
                    "account_id": 22779,
                    "reputation": 132266,
                    "user_id": 56541,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Wm7Xg.png?s=256",
                    "display_name": "David Z",
                    "link": "https://stackoverflow.com/users/56541/david-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538971805,
                "post_id": 52695178,
                "comment_id": 92317005,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22779,
                    "reputation": 132266,
                    "user_id": 56541,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Wm7Xg.png?s=256",
                    "display_name": "David Z",
                    "link": "https://stackoverflow.com/users/56541/david-z"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538972164,
                "post_id": 52695178,
                "comment_id": 92317075,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1539039401,
                "last_edit_date": 1539039401,
                "creation_date": 1538974758,
                "answer_id": 52695630,
                "question_id": 52695178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the problem description (and from the fact that the proposed awk solution has been accepted), it seems clear that although the file itself is large, each JSON document is relatively small, or at least small enough to fit in memory.  If that is indeed the case, then a straightforward solution using jq would have similar performance characteristics to a `sed` or `awk` solution, but without the potential complications.  Here therefore is such a solution:\r\n\r\n    jq &#39;.kruxSegmentIds |= with_entries(.key |= if .==&quot;0&quot; then &quot;zero&quot; elif .==&quot;1&quot; then &quot;one&quot; else . end)&#39;\r\n\r\nIf `jq empty hugefile` fails because of the file&#39;s size, then jq might still be useful because of its streaming parser, which is designed precisely for such cases.\r\n\r\n## Variations\r\n\r\nIn the comments, the OP posted another example, so it might be useful to define a filter for performing the key-to-key transformation:\r\n\r\n    def twiddle:\r\n      with_entries(.key |= if .==&quot;0&quot; then &quot;zero&quot; elif .==&quot;1&quot; then &quot;one&quot; else . end);\r\n\r\nWith this, the solution to the original problem is:\r\n\r\n     .kruxSegmentIds |= twiddle\r\n\r\nand the solution to the variant is:\r\n\r\n    (.users.L3AVIcqaDpZxLf6ispK.kruxSegmentIds) |= twiddle \r\n\r\nGeneralizing even further, if the task is to perform the transformation on all objects, wherever they occur, the solution is:\r\n\r\n    walk(if type == &quot;object&quot; then twiddle else . end)\r\n\r\nIf your jq does not have `walk` pre-defined, then you can snarf its def from https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq\r\n",
                "title": "find and replace nested JSON keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1539039401,
        "creation_date": 1538970846,
        "last_edit_date": 1539035197,
        "question_id": 52695178,
        "body_markdown": "I have a huge JSON file which contain records like this:\r\n\r\n    {&quot;callsign&quot;:&quot;abc&quot;,&quot;kruxSegmentIds&quot;:{&quot;0&quot;:&quot;q2d9nn1qv&quot;,&quot;1&quot;:&quot;rle4kfgsf&quot;},&quot;liveFlag&quot;:&quot;Y&quot;}}\r\n\r\nI need to replace the keys inside the nested JSON key &quot;kruxSegmentIds&quot; in such a way that 0 becomes &quot;zero&quot; and 1 as &quot;one&quot; like below:\r\n\r\n    {&quot;callsign&quot;:&quot;abc&quot;,&quot;kruxSegmentIds&quot;:{&quot;zero&quot;:&quot;q2d9nn1qv&quot;,&quot;one&quot;:&quot;rle4kfgsf&quot;},&quot;liveFlag&quot;:&quot;Y&quot;}}\r\n\r\nIs this possible using sed? I don&#39;t want to write a script as the file size is huge and it may not fit into memory.\r\n\r\nAny help/support is greatly appreciated.",
        "link": "https://stackoverflow.com/questions/52695178/find-and-replace-nested-json-keys",
        "title": "find and replace nested JSON keys"
    },
    {
        "tags": [
            "php",
            "arrays",
            "select",
            "multidimensional-array",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 45213,
                    "reputation": 27259,
                    "user_id": 133203,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://i.sstatic.net/Fp3hB.jpg?s=256",
                    "display_name": "Federico klez Culloca",
                    "link": "https://stackoverflow.com/users/133203/federico-klez-culloca"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1538987480,
                "post_id": 52698257,
                "comment_id": 92322988,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user8034901"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538987516,
                "post_id": 52698257,
                "comment_id": 92323009,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5944237,
                    "reputation": 3,
                    "user_id": 4674307,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/948720898471845/picture?type=large",
                    "display_name": "Balapradeep Gullapalli",
                    "link": "https://stackoverflow.com/users/4674307/balapradeep-gullapalli"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538987672,
                "post_id": 52698257,
                "comment_id": 92323091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6354467,
                    "reputation": 2142,
                    "user_id": 4932315,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c1d0412e518d26745f4b013207c3bbc8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Anthony",
                    "link": "https://stackoverflow.com/users/4932315/anthony"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1538987908,
                "post_id": 52698257,
                "comment_id": 92323226,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1538988737,
                "creation_date": 1538988737,
                "answer_id": 52698611,
                "question_id": 52698257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have a quote issue. Use baskslash before the single quote of the jq filter:\r\n\r\n    $cm_json = exec(&#39;curl -H &quot;Accept: application/vnd.pagerduty+json;version=2&quot; -H &quot;Authorization: Token token=&quot;XXXXXXX&quot; -X GET -G  &quot;https://api.pagerduty.com/users/&#39;.$user_id.&#39;/contact_methods/&quot; | jq \\&#39;.contact_methods[] | select(.label == &quot;Mobile&quot;) | .address\\&#39;&#39;);\r\n    \r\n\r\n    ",
                "title": "PHP Parse error: syntax error, unexpected &#39;[&#39; on line 56"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1538988737,
        "creation_date": 1538987404,
        "last_edit_date": 1538988131,
        "question_id": 52698257,
        "body_markdown": "    $cm_json = exec(&#39;curl -H &quot;Accept: application/vnd.pagerduty+json;version=2&quot; -H &quot;Authorization: Token token=&quot;XXXXXXX&quot; -X GET -G  &quot;https://api.pagerduty.com/users/&#39;.$user_id.&#39;/contact_methods/&quot; | jq &#39;.contact_methods[] | select(.label == &quot;Mobile&quot;) | .address&#39;&#39;);\r\n\r\n\r\n&gt; PHP Parse error: syntax error, unexpected &#39;[&#39; on line 56",
        "link": "https://stackoverflow.com/questions/52698257/php-parse-error-syntax-error-unexpected-on-line-56",
        "title": "PHP Parse error: syntax error, unexpected &#39;[&#39; on line 56"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10905924,
                    "reputation": 81723,
                    "user_id": 8016720,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bXsod.png?s=256",
                    "display_name": "John Hanley",
                    "link": "https://stackoverflow.com/users/8016720/john-hanley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539032700,
                "post_id": 52710050,
                "comment_id": 92346367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4005126,
                    "reputation": 3083,
                    "user_id": 3671801,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/0ad564cf9f9bc0b78a551fc78e64b161?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bill",
                    "link": "https://stackoverflow.com/users/3671801/bill"
                },
                "reply_to_user": {
                    "account_id": 10905924,
                    "reputation": 81723,
                    "user_id": 8016720,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bXsod.png?s=256",
                    "display_name": "John Hanley",
                    "link": "https://stackoverflow.com/users/8016720/john-hanley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539032845,
                "post_id": 52710050,
                "comment_id": 92346427,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10905924,
                    "reputation": 81723,
                    "user_id": 8016720,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bXsod.png?s=256",
                    "display_name": "John Hanley",
                    "link": "https://stackoverflow.com/users/8016720/john-hanley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539033095,
                "post_id": 52710050,
                "comment_id": 92346516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4005126,
                    "reputation": 3083,
                    "user_id": 3671801,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/0ad564cf9f9bc0b78a551fc78e64b161?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bill",
                    "link": "https://stackoverflow.com/users/3671801/bill"
                },
                "reply_to_user": {
                    "account_id": 10905924,
                    "reputation": 81723,
                    "user_id": 8016720,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bXsod.png?s=256",
                    "display_name": "John Hanley",
                    "link": "https://stackoverflow.com/users/8016720/john-hanley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539033251,
                "post_id": 52710050,
                "comment_id": 92346564,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10905924,
                    "reputation": 81723,
                    "user_id": 8016720,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bXsod.png?s=256",
                    "display_name": "John Hanley",
                    "link": "https://stackoverflow.com/users/8016720/john-hanley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539033654,
                "post_id": 52710050,
                "comment_id": 92346689,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4005126,
                    "reputation": 3083,
                    "user_id": 3671801,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/0ad564cf9f9bc0b78a551fc78e64b161?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bill",
                    "link": "https://stackoverflow.com/users/3671801/bill"
                },
                "reply_to_user": {
                    "account_id": 10905924,
                    "reputation": 81723,
                    "user_id": 8016720,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bXsod.png?s=256",
                    "display_name": "John Hanley",
                    "link": "https://stackoverflow.com/users/8016720/john-hanley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539038467,
                "post_id": 52710050,
                "comment_id": 92348124,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1539039923,
                "last_edit_date": 1539039923,
                "creation_date": 1539039134,
                "answer_id": 52711073,
                "question_id": 52710050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a nutshell: `map_values` is your friend.\r\n\r\nLet&#39;s suppose your template is in the file template.json. Then the following script will perform the specified transformation:\r\n\r\n\r\n    #!/bin/bash\r\n    # As far as this example is concerned,\r\n    # there is no need to export any variables\r\n    AWS_DEFAULT_REGION=us-east-2\r\n    AWS_ACCOUNT_ID=123456789012\r\n    ARN_PREFIX=&quot;arn:aws:sns:${AWS_DEFAULT_REGION}:${AWS_ACCOUNT_ID}:&quot;\r\n    \r\n    jq --arg prefix &quot;$ARN_PREFIX&quot; &#39;\r\n      .snstopic |= map_values($prefix + .)\r\n    &#39; template.json\r\n\r\n## Example\r\n\r\ntemplate.json\r\n\r\n    {\r\n      &quot;snstopic&quot;: {\r\n        &quot;topic-project1&quot;: &quot;team-project1-dev&quot;,\r\n        &quot;topci-project2&quot;: &quot;team-project2-dev&quot;\r\n      }\r\n    }\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;snstopic&quot;: {\r\n        &quot;topic-project1&quot;: &quot;arn:aws:sns:us-east-2:123456789012:team-project1-dev&quot;,\r\n        &quot;topci-project2&quot;: &quot;arn:aws:sns:us-east-2:123456789012:team-project2-dev&quot;\r\n      }\r\n    }\r\n\r\n\r\n",
                "title": "replace values with variables - jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1600067492,
        "creation_date": 1539032451,
        "last_edit_date": 1539127289,
        "question_id": 52710050,
        "body_markdown": "I can work out how to use jq to replace a value from a variable, \r\n\r\n    $ jq -n --arg name bar &#39;{&quot;name&quot;:$name}&#39;\r\n    \r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;\r\n    }\r\n\r\nBut I am not sure how to replace multiple values.\r\n\r\n    {\r\n      ...\r\n      &quot;snstopic&quot;: {\r\n        &quot;topic-project1&quot;: &quot;team-project1-dev&quot;,\r\n        &quot;topci-project2&quot;: &quot;team-project2-dev&quot;,\r\n        ...  (different json files have different number of sns topics)\r\n      },\r\n     ...\r\n    }\r\n\r\nI set these environment variables: \r\n\r\n    $ export AWS_DEFAULT_REGION=us-east-2\r\n    $ export AWS_ACCOUNT_ID=123456789012\r\n    $ export ARN_PREFIX=&quot;arn:aws:sns:${AWS_DEFAULT_REGION}:${AWS_ACCOUNT_ID}:&quot;\r\n\r\nI want to get output as below\r\n\r\n    {\r\n      ...\r\n      &quot;snstopic&quot;: {\r\n        &quot;topic-project1&quot;: &quot;arn:aws:sns:us-east-2:123456789012:team-project1-dev&quot;,\r\n        &quot;topci-project2&quot;: &quot;arn:aws:sns:us-east-2:123456789012:team-project2-dev&quot;,\r\n        ...  (different json files have different number of sns topics\r\n      },\r\n     ...\r\n    }\r\n\r\nHow to add it in all matched keys in `.snstopic`? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/52710050/replace-values-with-variables-jq",
        "title": "replace values with variables - jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5036299,
                    "reputation": 540,
                    "user_id": 4044951,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-RtEytZBAx3U/AAAAAAAAAAI/AAAAAAAAAIo/SRpOLEBkxtQ/s256-rj/photo.jpg",
                    "display_name": "Amit chauhan",
                    "link": "https://stackoverflow.com/users/4044951/amit-chauhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539074580,
                "post_id": 52716707,
                "comment_id": 92358974,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "reply_to_user": {
                    "account_id": 5036299,
                    "reputation": 540,
                    "user_id": 4044951,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-RtEytZBAx3U/AAAAAAAAAAI/AAAAAAAAAIo/SRpOLEBkxtQ/s256-rj/photo.jpg",
                    "display_name": "Amit chauhan",
                    "link": "https://stackoverflow.com/users/4044951/amit-chauhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539075133,
                "post_id": 52716707,
                "comment_id": 92359371,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5036299,
                    "reputation": 540,
                    "user_id": 4044951,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-RtEytZBAx3U/AAAAAAAAAAI/AAAAAAAAAIo/SRpOLEBkxtQ/s256-rj/photo.jpg",
                    "display_name": "Amit chauhan",
                    "link": "https://stackoverflow.com/users/4044951/amit-chauhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539075762,
                "post_id": 52716707,
                "comment_id": 92359739,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1539076560,
                "creation_date": 1539076560,
                "answer_id": 52717400,
                "question_id": 52716707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the example code of your requirement please run the code snippet and check your requirement\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    var json1 =&quot;{\\&quot;country\\&quot;: [ { \\&quot;ContinentCode\\&quot;: \\&quot;EU\\&quot;, \\&quot;ContinentGroup\\&quot;: 1, \\&quot;CountryCode\\&quot;: \\&quot;DE\\&quot;, \\&quot;CountryName\\&quot;: \\&quot;Germany\\&quot;, \\&quot;CurrencyIndex\\&quot; : 1}, { \\&quot;ContinentCode\\&quot;: \\&quot;AM\\&quot;, \\&quot;ContinentGroup\\&quot;: 2, \\&quot;CountryCode\\&quot;: \\&quot;CA\\&quot;, \\&quot;CountryName\\&quot;: \\&quot;Canada\\&quot;, \\&quot;CurrencyIndex\\&quot; : 2}]}&quot;;\r\n    var json2 = &quot;{\\&quot;currency\\&quot;: [ { \\&quot;Code\\&quot;: \\&quot;EUR\\&quot;, \\&quot;Name\\&quot;: \\&quot;Euro\\&quot; }, { \\&quot;Code\\&quot;: \\&quot;CAD\\&quot;, \\&quot;Name\\&quot;: \\&quot;Canadian Dollar\\&quot; }]}&quot;;\r\n            \r\n    var jsonParsed1 = JSON.parse(json1);\r\n    var jsonParsed2 = JSON.parse(json2);\r\n\r\n    var json3 = [];\r\n    for(var i=0;i&lt;jsonParsed1.country.length;i++){\r\n      var json3Object = {&quot;Code&quot;:jsonParsed2.currency[i].Code,&quot;Name&quot;:jsonParsed2.currency[i].Name,&quot;Position&quot;:i+1};\r\n      json3.push(json3Object);\r\n    }\r\n    console.log(json3);\r\n\r\n&lt;!-- end snippet --&gt;\r\nTell me if it Helps you \r\n",
                "title": "JQ: add the position in the json array to the element"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539108556,
                "last_edit_date": 1539108556,
                "creation_date": 1539100283,
                "answer_id": 52724927,
                "question_id": 52716707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add the array index to the array elements in arr2.json, you could use `reduce`:\r\n\r\n    jq -f program.jq arr2.json\r\n\r\nwhere program.jq contains:\r\n\r\n    .currency |= reduce range(0;length) as $i (.; .[$i].Position = 1+$i)\r\n   \r\nOr, assuming you&#39;re in a Windows environment:\r\n\r\n    jq &quot;.currency |= reduce range(0;length) as $i (.; .[$i].Position = 1+$i)&quot; arr2.json\r\n\r\n\r\n",
                "title": "JQ: add the position in the json array to the element"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1539108556,
        "creation_date": 1539074318,
        "last_edit_date": 1539080905,
        "question_id": 52716707,
        "body_markdown": "I actually receiving a json via API that contains several Arrays with different informations. Two of the Arrays are indirect linked. Array 1 contains an element that refers on the Array Position of an element in Array 2.\r\nI am actually transforming that json to fits the requested requirements and to move it to a database. It is necessary to link the Information of both Arrays later in the database. So my idea is to add an element with the array position into the array 2.\r\n\r\nExample:\r\n\r\noriginal Array one:\r\n\r\n    {\r\n      &quot;country&quot;: [\r\n        {\r\n          &quot;ContinentCode&quot;: &quot;EU&quot;,\r\n          &quot;ContinentGroup&quot;: 1,\r\n          &quot;CountryCode&quot;: &quot;DE&quot;,\r\n          &quot;CountryName&quot;: &quot;Germany&quot;,\r\n          &quot;CurrencyIndex&quot;: 1\r\n        },\r\n        {\r\n          &quot;ContinentCode&quot;: &quot;AM&quot;,\r\n          &quot;ContinentGroup&quot;: 2,\r\n          &quot;CountryCode&quot;: &quot;CA&quot;,\r\n          &quot;CountryName&quot;: &quot;Canada&quot;,\r\n          &quot;CurrencyIndex&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n\r\nArray original two:\r\n\r\n    {\r\n      &quot;currency&quot;: [\r\n        {\r\n          &quot;CODE&quot;: &quot;EUR&quot;,\r\n          &quot;Name&quot;: &quot;Euro&quot;\r\n        },\r\n        {\r\n          &quot;Code&quot;: &quot;CAD&quot;,\r\n          &quot;Name&quot;: &quot;Canadian Dollar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIdea of the new array two:\r\n\r\n    {\r\n      &quot;currency&quot;: [\r\n        {\r\n          &quot;CODE&quot;: &quot;EUR&quot;,\r\n          &quot;Name&quot;: &quot;Euro&quot;,\r\n          &quot;Position&quot;: 1\r\n        },\r\n        {\r\n          &quot;Code&quot;: &quot;CAD&quot;,\r\n          &quot;Name&quot;: &quot;Canadian Dollar&quot;,\r\n          &quot;Position&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n\r\nI use jq 1.5 under a Windows environment. I took a look in the manual but found no built in Feature to add Array Position into the element. Any ideas?\r\n\r\nregards\r\nTimo\r\n",
        "link": "https://stackoverflow.com/questions/52716707/jq-add-the-position-in-the-json-array-to-the-element",
        "title": "JQ: add the position in the json array to the element"
    },
    {
        "tags": [
            "json",
            "merge",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1539124149,
                "last_edit_date": 1539124149,
                "creation_date": 1539123839,
                "answer_id": 52730148,
                "question_id": 52730022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To merge the .data elements of all the responses into the first response, you could run:\r\n\r\n    jq &#39;reduce inputs.data as $s (.; .data += $s)&#39; page1.json page2.json ...\r\n\r\n## Alternatives\r\nYou could use the following filter in conjunction with the -n command-line option:\r\n\r\n    reduce inputs as $s (input; .data += ($s.data))\r\n\r\nOr if you simply want an object of the form `{&quot;data&quot;: [ ... ]}` then (again assuming you invoke jq with the -n command-line option) the following jq filter would suffice:\r\n\r\n    {data: [inputs.data] | add}\r\n\r\n",
                "title": "Using jq to combine multiple JSON files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1539156548,
                "creation_date": 1539156548,
                "answer_id": 52734858,
                "question_id": 52730022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just to provide closure, @peak provided the solution. I am using it in conjunction with the method found [here][1] for using wildcards in batch files to address multiple files. The code looks like this now:\r\n\r\n    set expanded_list=\r\n\tfor /f &quot;tokens=*&quot; %%F in (&#39;dir /b /a:-d &quot;All Cards\\!setname!_*.json&quot;&#39;) do call set expanded_list=!expanded_list! &quot;All Cards\\%%F&quot;\r\n\tjq-win32 &quot;reduce inputs.data as $s (.; .data += $s)&quot; !expanded_list! &gt; &quot;All Cards\\!setname!.json&quot;\r\n\r\nAll the individual pages for each card set are named &quot;setname&quot;_&quot;pagenumber&quot;.json\r\n\r\nThe code finds all the pages for each set and combines them into one variable which I can pass into jq.\r\n\r\nThanks again!\r\n\r\n\r\n  [1]: https://superuser.com/a/460648",
                "title": "Using jq to combine multiple JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1539156548,
        "creation_date": 1539122955,
        "question_id": 52730022,
        "body_markdown": "First off, I am not an expert with JSON files or with JQ. But here&#39;s my problem:\r\n\r\nI am simply trying to download to card data (for the MtG card game) through an API, so I can use it in my own spreadsheets etc.\r\n\r\nThe card data from the API comes in pages, since there is so much of it, and I am trying to find a nice command line method in Windows to combine the files into one. That will make it nice and easy for me to use the information as external data in my workbooks.\r\n\r\nThe data from the API looks like this:\r\n\r\n    {\r\n      &quot;object&quot;: &quot;list&quot;,\r\n      &quot;total_cards&quot;: 290,\r\n      &quot;has_more&quot;: true,\r\n      &quot;next_page&quot;: &quot;https://api.scryfall.com/cards/search?format=json&amp;include_extras=false&amp;order=set&amp;page=2&amp;q=e%3Alea&amp;unique=cards&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;object&quot;: &quot;card&quot;,\r\n          &quot;id&quot;: &quot;d5c83259-9b90-47c2-b48e-c7d78519e792&quot;,\r\n          &quot;oracle_id&quot;: &quot;c7a6a165-b709-46e0-ae42-6f69a17c0621&quot;,\r\n          &quot;multiverse_ids&quot;: [\r\n            232\r\n          ],\r\n          &quot;name&quot;: &quot;Animate Wall&quot;,\r\n          ......\r\n        }\r\n        {\r\n          &quot;object&quot;: &quot;card&quot;,\r\n          ......\r\n        }\r\n      ]\r\n    }\r\n\r\nBasically I need to take what&#39;s inside the &quot;data&quot; part from each file after the first, and merge it into the first file.\r\n\r\nI have tried a few examples I found online using jq, but I can&#39;t get it to work. I think it might be because in this case the data is sort of under an extra level, since there is some basic information, then the &quot;data&quot; category is beneath it. I don&#39;t know. \r\n\r\nAnyway, any help on how to get this going would be appreciated. I don&#39;t know much about this, but I can learn quickly so even any pointers would be great.\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/52730022/using-jq-to-combine-multiple-json-files",
        "title": "Using jq to combine multiple JSON files"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539145004,
                "post_id": 52732473,
                "comment_id": 92390008,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539145080,
                "post_id": 52732473,
                "comment_id": 92390023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539145158,
                "post_id": 52732473,
                "comment_id": 92390041,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539145421,
                "post_id": 52732473,
                "comment_id": 92390089,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 33,
                "is_accepted": true,
                "score": 33,
                "last_activity_date": 1539145372,
                "last_edit_date": 1539145372,
                "creation_date": 1539144652,
                "answer_id": 52732520,
                "question_id": 52732473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, you need to port the `bash` variable into `jq`&#39;s context usign the `--arg` flag and access it inside the `[..]`\r\n\r\n    jq --arg keyvar &quot;$bash_var&quot; &#39;.[$keyvar]&#39; json\r\n",
                "title": "How to pass bash variable as a key to jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1539145607,
        "creation_date": 1539144364,
        "last_edit_date": 1539144731,
        "question_id": 52732473,
        "body_markdown": "Here is the example json\r\n \r\n    {\r\n       &quot;app&quot;: &quot;K8s&quot;,\r\n       &quot;version&quot;: &quot;1.8&quot;,\r\n       &quot;date&quot;: &quot;2018-10-10&quot;\r\n    }\r\n\r\nIn order to get the value of app, I can do this in jq as\r\n\r\n    jq &#39;.app&#39;\r\n\r\nBut what I want is, I want to pass the key to jq as a bash variable, i.e\r\n\r\n    bash_var=&quot;app&quot;\r\n    jq &#39;.&quot;${bash_var}&quot;&#39;\r\n\r\nI&#39;m getting the output as **null** instead of the value. What is the correct syntax to achieve this?",
        "link": "https://stackoverflow.com/questions/52732473/how-to-pass-bash-variable-as-a-key-to-jq",
        "title": "How to pass bash variable as a key to jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539163712,
                "post_id": 52736476,
                "comment_id": 92398582,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14462083,
                    "reputation": 181,
                    "user_id": 10446644,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7518925e944e9ca4556c023903d55026?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bugnet17",
                    "link": "https://stackoverflow.com/users/10446644/bugnet17"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539164055,
                "post_id": 52736476,
                "comment_id": 92398780,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539164656,
                "last_edit_date": 1539164656,
                "creation_date": 1539162348,
                "answer_id": 52736516,
                "question_id": 52736476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your input, this works:\r\n\r\n    jq -r &#39;{&quot;request&quot;: {&quot;Event&quot;: {&quot;id&quot;: .[0].id, &quot;task&quot;: &quot;new&quot;}}}&#39; &gt; file",
                "title": "Passing JSON value using jq command to a new JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574354373,
        "creation_date": 1539162204,
        "last_edit_date": 1574354373,
        "question_id": 52736476,
        "body_markdown": "I ran curl command and then parsed the value (&quot;id&quot;).\r\n\r\nrequest: \r\n\r\n    curl &quot;http://192.168.22.22/test/index/limit:1/page:1/sort:id/pag1.json&quot; | jq -r &#39;.[0].id&#39;\r\n\r\ncurl response:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;381&quot;,\r\n        &quot;org_id&quot;: &quot;9&quot;,\r\n        &quot;date&quot;: &quot;2018-10-10&quot;,\r\n        &quot;info&quot;: &quot;THIS IS TEST&quot;,\r\n        &quot;uuid&quot;: &quot;5bbd1b41bc&quot;,\r\n        &quot;published&quot;: 1,\r\n        &quot;an&quot;: &quot;2&quot;,\r\n        &quot;attribute_count&quot;: &quot;4&quot;,\r\n        &quot;orgc_id&quot;: &quot;8&quot;,\r\n        &quot;timestamp&quot;: &quot;1&quot;,\r\n        &quot;dEST&quot;: &quot;0&quot;,\r\n        &quot;sharing&quot;: &quot;0&quot;,\r\n        &quot;proposal&quot;: false,\r\n        &quot;locked&quot;: false,\r\n        &quot;level_id&quot;: &quot;1&quot;,\r\n        &quot;publish_timestamp&quot;: &quot;0&quot;,\r\n        &quot;disable_correlation&quot;: false,\r\n        &quot;extends_uuid&quot;: &quot;&quot;,\r\n        &quot;Org&quot;: {\r\n          &quot;id&quot;: &quot;5&quot;,\r\n          &quot;name&quot;: &quot;test&quot;,\r\n          &quot;uuid&quot;: &quot;5b9bc&quot;\r\n        },\r\n        &quot;Orgc&quot;: {\r\n          &quot;id&quot;: &quot;1&quot;,\r\n          &quot;name&quot;: &quot;test&quot;,\r\n          &quot;uuid&quot;: &quot;5b9f93bdeac1b41bc&quot;\r\n        },\r\n        &quot;ETag&quot;: []\r\n      }\r\n    ]\r\n\r\njq response:\r\n \r\n    381\r\n\r\n\r\nNow I&#39;m trying to get the &quot;id&quot; number 381, and then to create a new JSON file on the disk when I place the &quot;id&quot; number in the right place. \r\n\r\nThe new JSON file for example:\r\n\r\n    {\r\n      &quot;request&quot;: {\r\n        &quot;Event&quot;: {\r\n          &quot;id&quot;: &quot;381&quot;,\r\n          &quot;task&quot;: &quot;new&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52736476/passing-json-value-using-jq-command-to-a-new-json-file",
        "title": "Passing JSON value using jq command to a new JSON file"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "amazon-elastic-beanstalk"
        ],
        "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": 1539164588,
                "post_id": 52736675,
                "comment_id": 92399092,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1539167905,
                "last_edit_date": 1539167905,
                "creation_date": 1539164411,
                "answer_id": 52737150,
                "question_id": 52736675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this `jq` command:\r\n\r\n    jq --slurpfile sm SERVICE_MANIFEST &#39;.containerDefinitions[].environment[] |= (select(.name==&quot;SERVICE_MANIFEST&quot;).value=$sm[])&#39; file\r\n\r\n`--slurpfile` assigns the content of the file to the variable `sm`\r\n\r\nThe filter replaces the array `.containerDefinitions[].environment[]` with the content of the file only on the element having `SERVICE_MANIFEST` as `name`.",
                "title": "insert a json file into json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1539228470,
                "last_edit_date": 1539228470,
                "creation_date": 1539180420,
                "answer_id": 52742128,
                "question_id": 52736675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution would use `--argfile` and avoid `select`:\r\n\r\n    &lt; source.json jq --argfile sm service_manifest.json &#39;\r\n      .containerDefinitions[0].environment[0].value = $sm &#39; \r\n\r\nOr if you want only to update the object(s) with `.name == &quot;SERVICE_MANIFEST&quot;` you could use the filter:\r\n\r\n    .containerDefinitions[].environment \r\n      |= map(if .name == &quot;SERVICE_MANIFEST&quot;\r\n             then .value = $sm \r\n             else . end)\r\n\r\n## Variations\r\nThere is no need for any &quot;--arg&quot;-style parameter at all, as illustrated by the following:\r\n\r\n    jq -s &#39;.[1] as $sm\r\n      | .[0] | .containerDefinitions[0].environment[0].value = $sm\r\n    &#39; source.json service_manifest.json\r\n\r\n\r\n",
                "title": "insert a json file into json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1539228470,
        "creation_date": 1539162858,
        "last_edit_date": 1539168464,
        "question_id": 52736675,
        "body_markdown": "I&#39;d like to know a quick way to insert a json to json. \r\n\r\n    $ cat source.json\r\n\r\n    {\r\n      &quot;AWSEBDockerrunVersion&quot;: 2,\r\n      &quot;containerDefinitions&quot;: [\r\n        {\r\n          &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;SERVICE_MANIFEST&quot;,\r\n              &quot;value&quot;: &quot;&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;SERVICE_PORT&quot;,\r\n              &quot;value&quot;: &quot;4321&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nThe SERVICE_MANIFEST is content of another json file\r\n\r\n    $ cat service_manifest.json\r\n\r\n    {\r\n      &quot;connections&quot;: {\r\n        &quot;port&quot;: &quot;1234&quot;\r\n      },\r\n      &quot;name&quot;: &quot;foo&quot;\r\n    }\r\n\r\nI try to make it with jq command\r\n\r\n    cat service_manifest.json |jq --arg SERVICE_MANIFEST - &lt; source.json\r\n\r\nBut seems it doesn&#39;t work\r\n\r\nAny ideas? The final result still should be a valid json file\r\n\r\n    {\r\n      &quot;AWSEBDockerrunVersion&quot;: 2,\r\n      &quot;containerDefinitions&quot;: [\r\n        {\r\n          &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;SERVICE_MANIFEST&quot;,\r\n              &quot;value&quot;: {\r\n                &quot;connections&quot;: {\r\n                  &quot;port&quot;: &quot;1234&quot;\r\n                },\r\n                &quot;name&quot;: &quot;foo&quot;\r\n              }\r\n            },\r\n            ...\r\n          ]\r\n        }\r\n      ],\r\n      ...\r\n    }\r\n\r\n### Updates.\r\n\r\nThanks, here is the command I run from your sample.\r\n\r\n&gt;$ jq --slurpfile sm service_manifest.json &#39;.containerDefinitions[].environment[] |= (select(.name==&quot;SERVICE_MANIFEST&quot;).value=$sm)&#39; source.json\r\n\r\nBut the result is an array, not list.\r\n\r\n    {\r\n      &quot;AWSEBDockerrunVersion&quot;: 2,\r\n      &quot;containerDefinitions&quot;: [\r\n        {\r\n          &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;SERVICE_MANIFEST&quot;,\r\n              &quot;value&quot;: [\r\n                {\r\n                  &quot;connections&quot;: {\r\n                    &quot;port&quot;: &quot;1234&quot;\r\n                  },\r\n                  &quot;name&quot;: &quot;foo&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;SERVICE_PORT&quot;,\r\n              &quot;value&quot;: &quot;4321&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52736675/insert-a-json-file-into-json",
        "title": "insert a json file into json"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 195132,
                    "reputation": 3863,
                    "user_id": 437859,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/914a08dee7ecde47ab8032d0bad87d6b?s=256&d=identicon&r=PG",
                    "display_name": "Stig Perez",
                    "link": "https://stackoverflow.com/users/437859/stig-perez"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539190082,
                "post_id": 52744308,
                "comment_id": 92414924,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13813605,
                    "reputation": 301,
                    "user_id": 9970714,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1ade00fb2f42f9befdfe200af797bf3b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "donald.sys",
                    "link": "https://stackoverflow.com/users/9970714/donald-sys"
                },
                "reply_to_user": {
                    "account_id": 195132,
                    "reputation": 3863,
                    "user_id": 437859,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/914a08dee7ecde47ab8032d0bad87d6b?s=256&d=identicon&r=PG",
                    "display_name": "Stig Perez",
                    "link": "https://stackoverflow.com/users/437859/stig-perez"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539190375,
                "post_id": 52744308,
                "comment_id": 92415083,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1539195947,
                "last_edit_date": 1539195947,
                "creation_date": 1539195592,
                "answer_id": 52746511,
                "question_id": 52744308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since I find [tag:jq] pretty hard, I started in a procedural way: using ruby&#39;s json module:\r\n\r\n    ruby -rjson -e &#39;\r\n      states = JSON.parse(File.read(ARGV.shift)).map {|o| [o[&quot;InstanceId&quot;], o[&quot;State&quot;]]}.to_h\r\n      data = JSON.parse(File.read(ARGV.shift))\r\n      data.each do |obj|\r\n        obj[&quot;Instances&quot;].each do |instance|\r\n          instance[&quot;State&quot;] = states[instance[&quot;InstanceId&quot;]] || &quot;unknown&quot;\r\n        end\r\n      end\r\n      puts JSON.pretty_generate data\r\n    &#39; SomeFile2.json SomeFile1.json \r\n\r\nBut we want jq, so after some trial and error, and finding this in the manual: https://stedolan.github.io/jq/manual/#Complexassignments -- (note, I changed the state for one of the instances so I could verify the output better)\r\n\r\n    $ cat SomeFile2.json \r\n    [\r\n      {\r\n        &quot;InstanceId&quot;: &quot;i-0886ed703de64028a&quot;,\r\n        &quot;State&quot;: &quot;InService&quot;\r\n      },\r\n      {\r\n        &quot;InstanceId&quot;: &quot;i-0561634c4g3b4fa25&quot;,\r\n        &quot;State&quot;: &quot;NOTInService&quot;\r\n      }\r\n    ]\r\n\r\nFirst, extract the states into an object mapping the id to the state:\r\n\r\n    $ state_map=$( jq -c &#39;map({&quot;key&quot;:.InstanceId, &quot;value&quot;:.State}) | from_entries&#39; SomeFile2.json )\r\n    $ echo &quot;$state_map&quot;\r\n    {&quot;i-0886ed703de64028a&quot;:&quot;InService&quot;,&quot;i-0561634c4g3b4fa25&quot;:&quot;NOTInService&quot;}\r\n\r\nThen, update the instances in the first file:\r\n\r\n    jq --argjson states &quot;$state_map&quot; &#39;.[].Instances[] |= . + {&quot;State&quot;: ($states[.InstanceId] // &quot;unknown&quot;)}&#39; SomeFile1.json\r\n&lt;!-- --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;DNSName&quot;: &quot;CLB-test-112a877451.ap-northeast-1.elb.amazonaws.com&quot;,\r\n        &quot;Instances&quot;: [\r\n          {\r\n            &quot;InstanceId&quot;: &quot;i-0886ed703de64028a&quot;,\r\n            &quot;State&quot;: &quot;InService&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;DNSName&quot;: &quot;CLB-test1-156925981.ap-northeast-1.elb.amazonaws.com&quot;,\r\n        &quot;Instances&quot;: [\r\n          {\r\n            &quot;InstanceId&quot;: &quot;i-0561634c4g3b4fa25&quot;,\r\n            &quot;State&quot;: &quot;NOTInService&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\n",
                "title": "how to merge two JSON objects using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1539226888,
                "last_edit_date": 1539226888,
                "creation_date": 1539207580,
                "answer_id": 52749162,
                "question_id": 52744308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the contents of the second file are evidently intended to define a mapping from InstanceId to State, let&#39;s start by hypothesizing the following invocation of jq:\r\n\r\n    jq --argfile dict SomeFile2.json -f program.jq SomeFile1.json\r\n\r\nNext, let&#39;s create a suitable dictionary:\r\n\r\n    reduce $dict[] as $x ({}; . + ($x|{(.InstanceId): .State}))) as $d\r\n\r\nNow the rest is easy:\r\n\r\n    map(.Instances |= map(. + {State: $d[.InstanceId]}))\r\n\r\nPutting the pieces together in program.jq:\r\n\r\n    (reduce $dict[] as $x ({}; . + ($x|{(.InstanceId): .State}))) as $d\r\n    | map(.Instances |= map(. + {State: $d[.InstanceId]}))\r\n\r\n## Alternatives\r\nThe dictionary as above can be constructed without using `reduce`, as follows:\r\n\r\n    ($dict | map( {(.InstanceId): .State}) | add) as $d\r\n\r\nAnother alternative is to use `INDEX/2`: \r\n\r\n    (INDEX($dict[]; .InstanceId) | map_values(.State))) as $d\r\n\r\nIf your jq does not have `INDEX/2` you can snarf its def from \r\nhttps://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq",
                "title": "how to merge two JSON objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1539226888,
        "creation_date": 1539186955,
        "last_edit_date": 1539195693,
        "question_id": 52744308,
        "body_markdown": "I have two file json. I want to append two array of SomeFile2.json to SomeFile1.json as below.\r\n\r\n**SomeFile1.json**\r\n\r\n    [\r\n      {\r\n        &quot;DNSName&quot;: &quot;CLB-test-112a877451.ap-northeast-1.elb.amazonaws.com&quot;,\r\n        &quot;Instances&quot;: [\r\n          {\r\n            &quot;InstanceId&quot;: &quot;i-0886ed703de64028a&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;DNSName&quot;: &quot;CLB-test1-156925981.ap-northeast-1.elb.amazonaws.com&quot;,\r\n        &quot;Instances&quot;: [\r\n          {\r\n            &quot;InstanceId&quot;: &quot;i-0561634c4g3b4fa25&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n**SomeFile2.json**\r\n\r\n    [\r\n      {\r\n        &quot;InstanceId&quot;: &quot;i-0886ed703de64028a&quot;,\r\n        &quot;State&quot;: &quot;InService&quot;\r\n      },\r\n      {\r\n        &quot;InstanceId&quot;: &quot;i-0561634c4g3b4fa25&quot;,\r\n        &quot;State&quot;: &quot;InService&quot;\r\n      }\r\n    ]\r\n\r\nI want the result as below:\r\n\r\n    [\r\n      {\r\n        &quot;DNSName&quot;: &quot;CLB-test-112a877451.ap-northeast-1.elb.amazonaws.com&quot;,\r\n        &quot;Instances&quot;: [\r\n          {\r\n            &quot;InstanceId&quot;: &quot;i-0886ed703de64028a&quot;\r\n            &quot;State&quot;: &quot;InService&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;DNSName&quot;: &quot;CLB-test1-156925981.ap-northeast-1.elb.amazonaws.com&quot;,\r\n        &quot;Instances&quot;: [\r\n          {\r\n            &quot;InstanceId&quot;: &quot;i-0561634c4g3b4fa25&quot;\r\n            &quot;State&quot;: &quot;InService&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;m processing in bash shell via `jq`. But, unsuccessful.",
        "link": "https://stackoverflow.com/questions/52744308/how-to-merge-two-json-objects-using-jq",
        "title": "how to merge two JSON objects using jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1539201979,
                "creation_date": 1539201979,
                "answer_id": 52747993,
                "question_id": 52746668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `@csv`:\r\n\r\n    jq -r &#39;.last_updated as $lu\r\n      | .data[][]\r\n      | [$lu, .station_id, .name, .region_id, .address, (.rental_methods | join(&quot;:&quot;)) ]\r\n      | @csv&#39;\r\n\r\nWhat you were probably missing with `@csv` before was an array constructor around the list of things you wanted in the CSV record.",
                "title": "jq - How to concatenate an array in json"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1539204145,
                "creation_date": 1539204145,
                "answer_id": 52748491,
                "question_id": 52746668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could repair your jq filter as follows:\r\n\r\n    .last_updated as $lu\r\n    | .data[][]\r\n    | [$lu, .station_id, .name, .region_id, .address, \r\n       (.rental_methods | join(&quot;:&quot;))]\r\n    | @csv\r\n\r\nWith your JSON, this would produce:\r\n\r\n    1539122087,&quot;5343&quot;,&quot;Lot&quot;,&quot;461&quot;,&quot;Austin&quot;,&quot;KEY:APPLEPAY:ANDROIDPAY:TRANSITCARD:ACCOUNTNUMBER:PHONE&quot;\r\n\r\n... which is not quite what you&#39;ve said you want.  Changing the last line to:\r\n\r\n    map(tostring) | join(&quot;,&quot;)\r\n\r\nresults in:\r\n\r\n    1539122087,5343,Lot,461,Austin,KEY:APPLEPAY:ANDROIDPAY:TRANSITCARD:ACCOUNTNUMBER:PHONE\r\n\r\nThis is exactly what you&#39;ve indicated you want except for the terminating punctuation, which you can easily add (e.g. by appending `+ &quot;,&quot;` to the program above) if so desired.",
                "title": "jq - How to concatenate an array in json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1539232963,
        "creation_date": 1539196309,
        "last_edit_date": 1539232963,
        "question_id": 52746668,
        "body_markdown": "Struggling with formatting of data in jq.  I have 2 issues.\r\n\r\n  1. Need to take the last array .rental_methods and concatenate them into 1 line, colon separated.\r\n  2. `@csv` doesn&#39;t seem to work with my query.  I get the error `string (&quot;5343&quot;) cannot be csv-formatted, only array`\r\n\r\n\r\njq command is this (without the `| @csv`)\r\n\r\n\tjq --arg LOC &quot;$LOC&quot; &#39;.last_updated as $lu | .data[]|.[]| $lu, .station_id, .name, .region_id, .address, .rental_methods[]&#39;\r\n\r\nJSON:\r\n\r\n\t{\r\n\t\t&quot;last_updated&quot;: 1539122087,\r\n\t\t&quot;ttl&quot;: 60,\r\n\t\t&quot;data&quot;: {\r\n\t\t\t&quot;stations&quot;: [{\r\n\t\t\t\t&quot;station_id&quot;: &quot;5343&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Lot&quot;,\r\n\t\t\t\t&quot;region_id&quot;: &quot;461&quot;,\r\n\t\t\t\t&quot;address&quot;: &quot;Austin&quot;,\r\n\t\t\t\t&quot;rental_methods&quot;: [\r\n\t\t\t\t\t&quot;KEY&quot;,\r\n\t\t\t\t\t&quot;APPLEPAY&quot;,\r\n\t\t\t\t\t&quot;ANDROIDPAY&quot;,\r\n\t\t\t\t\t&quot;TRANSITCARD&quot;,\r\n\t\t\t\t\t&quot;ACCOUNTNUMBER&quot;,\r\n\t\t\t\t\t&quot;PHONE&quot;\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t}\r\n\r\nI&#39;d like the output to end up as:\r\n\r\n\t1539122087,5343,Lot,461,Austin,KEY:APPLEPAY:ANDROIDPAY:TRANSITCARD:ACCOUNTNUMBER:PHONE:,\r\n",
        "link": "https://stackoverflow.com/questions/52746668/jq-how-to-concatenate-an-array-in-json",
        "title": "jq - How to concatenate an array in json"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539232150,
                "last_edit_date": 1539232150,
                "creation_date": 1539204375,
                "answer_id": 52748543,
                "question_id": 52748294,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Working with your program as a starting point, you can simply wrap the separate objects in square brackets, and then use `add`:\r\n\r\n    .results\r\n    | [to_entries[] | { (.key): [ .value.types | keys[] ] } ]\r\n    | add\r\n\r\n",
                "title": "transforming a nested json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1539232210,
        "creation_date": 1539203217,
        "last_edit_date": 1539232210,
        "question_id": 52748294,
        "body_markdown": "I have a nested json object like so:\r\n\r\n    {\r\n      &quot;results&quot;: {\r\n        &quot;category_a&quot;: {\r\n          &quot;types&quot;: {\r\n            &quot;type_a&quot;: {},\r\n            &quot;type_b&quot;: {},\r\n            &quot;type_c&quot;: {}\r\n          }\r\n        },\r\n        &quot;category_b&quot;: {\r\n          &quot;types&quot;: {\r\n            &quot;type_y&quot;: {},\r\n            &quot;type_z&quot;: {}\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nand I&#39;d like to squash it down it into a simpler nested object:\r\n\r\n    {\r\n      &quot;category_a&quot;: [\r\n        &quot;type_a&quot;,\r\n        &quot;type_b&quot;,\r\n        &quot;type_c&quot;\r\n      ],\r\n      &quot;category_b&quot;: [\r\n        &quot;type_y&quot;,\r\n        &quot;type_z&quot;\r\n      ]\r\n    }\r\n\r\nThis is what I have so far, which is close to what I want:\r\n\r\n    .results\r\n    | to_entries[]\r\n    | {\r\n        (.key): [\r\n          .value.types | keys[]\r\n        ]\r\n      }\r\n\r\nexcept that the output is line-oriented instead of being a single object:\r\n\r\n    {\r\n      &quot;category_a&quot;: [\r\n        &quot;type_a&quot;,\r\n        &quot;type_b&quot;,\r\n        &quot;type_c&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;category_b&quot;: [\r\n        &quot;type_y&quot;,\r\n        &quot;type_z&quot;\r\n      ]\r\n    }\r\n\r\nHow can I combine those two json objects into one? Do I need to approach the transformation differently?",
        "link": "https://stackoverflow.com/questions/52748294/transforming-a-nested-json-object",
        "title": "transforming a nested json object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5075932,
                    "reputation": 815,
                    "user_id": 4073304,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YTtdo.jpg?s=256",
                    "display_name": "Parvez Kazi",
                    "link": "https://stackoverflow.com/users/4073304/parvez-kazi"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539243125,
                "post_id": 52754571,
                "comment_id": 92432521,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539243206,
                "post_id": 52754571,
                "comment_id": 92432568,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13813605,
                    "reputation": 301,
                    "user_id": 9970714,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1ade00fb2f42f9befdfe200af797bf3b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "donald.sys",
                    "link": "https://stackoverflow.com/users/9970714/donald-sys"
                },
                "reply_to_user": {
                    "account_id": 5075932,
                    "reputation": 815,
                    "user_id": 4073304,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YTtdo.jpg?s=256",
                    "display_name": "Parvez Kazi",
                    "link": "https://stackoverflow.com/users/4073304/parvez-kazi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539243720,
                "post_id": 52754571,
                "comment_id": 92432829,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539244510,
                "creation_date": 1539244510,
                "answer_id": 52755008,
                "question_id": 52754571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Seems you are using aws cli to fetch ebs volume details, you can use the filters properties of aws cli to filter out results of your query.   \r\nHere you can use below :   \r\n`aws ec2 describe-volumes --filters Name=tag-key,Values=&quot;key3&quot; Name=tag-value,Values=&quot;value3&quot;`\r\n\r\nFind more help at:  \r\n`aws ec2 describe-volumes help`\r\n\r\nI think this will be easier than filtering using jq.",
                "title": "How to just output the correct result with key and value?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539245789,
                "last_edit_date": 1539245789,
                "creation_date": 1539245394,
                "answer_id": 52755238,
                "question_id": 52754571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use select to filter the array under Tags:\r\n\r\n    jq &#39;.[].Tags | select((.[].Key == &quot;key3&quot;) and (.[].Value=&quot;value3&quot;))  &#39; &lt; file.json\r\n\r\nTogether with reading the key and value from the stdin:\r\n\r\n    echo key3 value3 | (\r\n        read key value\r\n        k=$key v=$value jq &quot;.[].Tags\r\n            | select((.[].Key == env.k) and (.[].Value=env.v))\r\n        &quot; &lt; file.json)\r\n\r\n",
                "title": "How to just output the correct result with key and value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1539245789,
        "creation_date": 1539242893,
        "last_edit_date": 1539243947,
        "question_id": 52754571,
        "body_markdown": "I have a json as below:\r\n\r\n    [\r\n        {\r\n          &quot;AvailabilityZone&quot;: &quot;ap-northeast-1a&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;value1&quot;,\r\n              &quot;Key&quot;: &quot;key1&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;value2&quot;,\r\n              &quot;Key&quot;: &quot;key2&quot;\r\n            }\r\n          ],\r\n        },\r\n        {\r\n              &quot;AvailabilityZone&quot;: &quot;ap-northeast-1a&quot;,\r\n              &quot;Tags&quot;: [\r\n                {\r\n                  &quot;Value&quot;: &quot;value3&quot;,\r\n                  &quot;Key&quot;: &quot;key3&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;value4&quot;,\r\n                  &quot;Key&quot;: &quot;key4&quot;\r\n                }\r\n              ],\r\n            },\r\n    ]\r\n\r\nwhen i input key and value from keyboard. I want to just output the correct result with the key and value through the jq option.\r\n\r\nExample: I input Key:value is key3:value3. My desire:\r\n\r\n    {\r\n          &quot;AvailabilityZone&quot;: &quot;ap-northeast-1a&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;value3&quot;,\r\n              &quot;Key&quot;: &quot;key3&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;value4&quot;,\r\n              &quot;Key&quot;: &quot;key4&quot;\r\n            }\r\n          ],\r\n    }",
        "link": "https://stackoverflow.com/questions/52754571/how-to-just-output-the-correct-result-with-key-and-value",
        "title": "How to just output the correct result with key and value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539259806,
                "post_id": 52759139,
                "comment_id": 92442502,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1539260390,
                "post_id": 52759139,
                "comment_id": 92442830,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539261180,
                "creation_date": 1539261180,
                "answer_id": 52760186,
                "question_id": 52759139,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like you&#39;re looking at this:\r\n\r\n    jq &#39;{Offers:[.Offers[] | {Price: .AdultPriceEUR, Currency: .Currency, Link: .Deeplink, Tickettyp: .TicketClassIndex, Flightindex: .FlightIndex }]}&#39; file\r\n\r\nIt just creates a new object containing an `Offers` table with the content you want to put it it.",
                "title": "JQ: Set toplevel path"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1539261180,
        "creation_date": 1539257912,
        "last_edit_date": 1539260362,
        "question_id": 52759139,
        "body_markdown": "I use jq 1.5 under a Windows enviroment to modify a given large json file to extract a single Array (&quot;Offers&quot;) from that large file:\r\n\r\n    &#39;.Offers[] | ({Price: .AdultPriceEUR, Currency: .Currency, Link: .Deeplink, Tickettyp: .TicketClassIndex, Flightindex: .FlightIndex })&#39;\r\n\r\n\r\n After that i got an &quot;unnamed&quot; Array. But for the later processing it is necessary that the Array keeps his old &quot;Name&quot;. I checked the documentation and found the setpath function but it is not possible to keep the Name &quot;easy&quot; on extraction?\r\n\r\nshorten example of the json file:\r\n\r\n       {&quot;Airports&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Aliases&quot;: null,\r\n\t\t\t&quot;ContinentCode&quot;: &quot;EU&quot;,\r\n\t\t\t&quot;ContinentGroup&quot;: 1,\r\n\t\t\t&quot;CountryCode&quot;: &quot;DE&quot;,\r\n\t\t\t&quot;CountryName&quot;: &quot;Germany&quot;,\r\n\t\t\t&quot;DST&quot;: &quot;&quot;,\r\n\t\t\t&quot;DisplayName&quot;: &quot;Hamburg (HAM) Germany&quot;,\r\n\t\t\t&quot;Iata&quot;: &quot;HAM&quot;,\r\n\t\t\t&quot;IataLink&quot;: false,\r\n\t\t\t&quot;Icao&quot;: &quot;EDDH&quot;,\r\n\t\t\t&quot;Latitude&quot;: 53.63215,\r\n\t\t\t&quot;Longitude&quot;: 10.0041609,\r\n\t\t\t&quot;MainCityCode&quot;: &quot;HAM&quot;,\r\n\t\t\t&quot;MainCityDisplayName&quot;: &quot;Hamburg (HAM) Germany&quot;,\r\n\t\t\t&quot;MainCityName&quot;: &quot;Hamburg&quot;,\r\n\t\t\t&quot;Name&quot;: &quot;Hamburg&quot;,\r\n\t\t\t&quot;Priority&quot;: 142,\r\n\t\t\t&quot;StateCode&quot;: null,\r\n\t\t\t&quot;StateName&quot;: null,\r\n\t\t\t&quot;TimeZone&quot;: -798214753\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Aliases&quot;: null,\r\n\t\t\t&quot;ContinentCode&quot;: &quot;AS&quot;,\r\n\t\t\t&quot;ContinentGroup&quot;: 4,\r\n\t\t\t&quot;CountryCode&quot;: &quot;TH&quot;,\r\n\t\t\t&quot;CountryName&quot;: &quot;Thailand&quot;,\r\n\t\t\t&quot;DST&quot;: &quot;&quot;,\r\n\t\t\t&quot;DisplayName&quot;: &quot;Suvarnabhumi, Bangkok (BKK) Thailand&quot;,\r\n\t\t\t&quot;Iata&quot;: &quot;BKK&quot;,\r\n\t\t\t&quot;IataLink&quot;: false,\r\n\t\t\t&quot;Icao&quot;: &quot;VTBS&quot;,\r\n\t\t\t&quot;Latitude&quot;: 13.6922979,\r\n\t\t\t&quot;Longitude&quot;: 100.750694,\r\n\t\t\t&quot;MainCityCode&quot;: &quot;BKK&quot;,\r\n\t\t\t&quot;MainCityDisplayName&quot;: &quot;Bangkok (BKK) Thailand&quot;,\r\n\t\t\t&quot;MainCityName&quot;: &quot;Bangkok&quot;,\r\n\t\t\t&quot;Name&quot;: &quot;Suvarnabhumi&quot;,\r\n\t\t\t&quot;Priority&quot;: 1462,\r\n\t\t\t&quot;StateCode&quot;: null,\r\n\t\t\t&quot;StateName&quot;: null,\r\n\t\t\t&quot;TimeZone&quot;: -640089798\r\n\t\t}], &quot;Offers&quot;: [\r\n\t\t{\r\n\t\t\t&quot;AdultPrice&quot;: 2977.6,\r\n\t\t\t&quot;AdultPriceEUR&quot;: 2977.6,\r\n\t\t\t&quot;AdultPriceExclTax&quot;: 0.0,\r\n\t\t\t&quot;Currency&quot;: &quot;EUR&quot;,\r\n\t\t\t&quot;FeeIndexes&quot;: [\r\n\t\t\t\t0,\r\n\t\t\t\t1,\r\n\t\t\t\t2,\r\n\t\t\t\t3,\r\n\t\t\t\t4,\r\n\t\t\t\t5,\r\n\t\t\t\t6\r\n\t\t\t],\r\n\t\t\t&quot;FlightIndex&quot;: 0,\r\n\t\t\t&quot;IsPaymentIncluded&quot;: true,\r\n\t\t\t&quot;MobileDeepLink&quot;: null,\r\n\t\t\t&quot;PaymentMethods&quot;: [\r\n\t\t\t\t&quot;American Express&quot;,\r\n\t\t\t\t&quot;Diners Club&quot;,\r\n\t\t\t\t&quot;MasterCard Credit&quot;,\r\n\t\t\t\t&quot;MasterCard Debit&quot;,\r\n\t\t\t\t&quot;Paypal&quot;,\r\n\t\t\t\t&quot;Visa Credit&quot;,\r\n\t\t\t\t&quot;Visa Debit&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Score&quot;: 2501.3,\r\n\t\t\t&quot;SegmentFares&quot;: null,\r\n\t\t\t&quot;SegmentKey&quot;: -1,\r\n\t\t\t&quot;TicketClassIndex&quot;: 1,\r\n\t\t\t&quot;TotalIsCalculated&quot;: false,\r\n\t\t\t&quot;TotalPrice&quot;: 2977.6,\r\n\t\t\t&quot;TotalPriceEUR&quot;: 2977.6,\r\n\t\t\t&quot;TotalPriceExclTax&quot;: 0.0\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;AdultPrice&quot;: 4697.27,\r\n\t\t\t&quot;AdultPriceEUR&quot;: 4697.27,\r\n\t\t\t&quot;AdultPriceExclTax&quot;: 0.0,\r\n\t\t\t&quot;Currency&quot;: &quot;EUR&quot;,\r\n\t\t\t&quot;FeeIndexes&quot;: [\r\n\t\t\t\t0,\r\n\t\t\t\t1,\r\n\t\t\t\t2,\r\n\t\t\t\t3,\r\n\t\t\t\t4,\r\n\t\t\t\t7,\r\n\t\t\t\t8,\r\n\t\t\t\t5,\r\n\t\t\t\t6\r\n\t\t\t],\r\n\t\t\t&quot;FlightIndex&quot;: 1,\r\n\t\t\t&quot;IsPaymentIncluded&quot;: true,\r\n\t\t\t&quot;MobileDeepLink&quot;: null,\r\n\t\t\t&quot;PaymentMethods&quot;: [\r\n\t\t\t\t&quot;American Express&quot;,\r\n\t\t\t\t&quot;Diners Club&quot;,\r\n\t\t\t\t&quot;MasterCard Credit&quot;,\r\n\t\t\t\t&quot;MasterCard Debit&quot;,\r\n\t\t\t\t&quot;Paypal&quot;,\r\n\t\t\t\t&quot;Sofort&#252;berweisung&quot;,\r\n\t\t\t\t&quot;&#220;berweisung&quot;,\r\n\t\t\t\t&quot;Visa Credit&quot;,\r\n\t\t\t\t&quot;Visa Debit&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Score&quot;: 3438.64,\r\n\t\t\t&quot;SegmentFares&quot;: null,\r\n\t\t\t&quot;SegmentKey&quot;: -1,\r\n\t\t\t&quot;TicketClassIndex&quot;: 1,\r\n\t\t\t&quot;TotalIsCalculated&quot;: false,\r\n\t\t\t&quot;TotalPrice&quot;: 4697.27,\r\n\t\t\t&quot;TotalPriceEUR&quot;: 4697.27,\r\n\t\t\t&quot;TotalPriceExclTax&quot;: 0.0\r\n\t\t}]\r\n\t}\r\n\r\n\r\n\r\n\r\nthanks \r\n\r\nBR\r\nTimo\r\n",
        "link": "https://stackoverflow.com/questions/52759139/jq-set-toplevel-path",
        "title": "JQ: Set toplevel path"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11629624,
                    "reputation": 65,
                    "user_id": 8518292,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4db5254a1eeebf46781918d6efa0d8c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "captainfreaked",
                    "link": "https://stackoverflow.com/users/8518292/captainfreaked"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539276568,
                "post_id": 52760882,
                "comment_id": 92453104,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 481416,
                    "reputation": 389136,
                    "user_id": 895245,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://i.sstatic.net/5Powi.jpg?s=256",
                    "display_name": "Ciro Santilli OurBigBook.com",
                    "link": "https://stackoverflow.com/users/895245/ciro-santilli-ourbigbook-com"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1748898874,
                "post_id": 52760882,
                "comment_id": 140481569,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1632477429,
                "last_edit_date": 1632477429,
                "creation_date": 1539279089,
                "answer_id": 52765906,
                "question_id": 52760882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq 1.5 has `inputs`, which allows a simple and efficient solution:\r\n\r\n     jq -R -n -c &#39;[inputs|split(&quot;,&quot;)|{(.[0]):.[1]}] | add&#39; input.txt\r\n\r\nImportant: don&#39;t forget the `-n` (`--null-input`) option, otherwise you&#39;ll lose the first line.\r\n\r\n## Alternative\r\nIf your jq does not have `inputs`, then it&#39;s time to upgrade if at all possible.  Otherwise:\r\n\r\n    jq -R -s &#39;\r\n      split(&quot;\\n&quot;)\r\n      | map(if index(&quot;,&quot;) then split(&quot;,&quot;)|{(.[0]):.[1]}\r\n            else empty end)\r\n      | add&#39; input.txt\r\n",
                "title": "I want to convert the text file data to JSON using Jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539497009,
                "creation_date": 1539497009,
                "answer_id": 52799935,
                "question_id": 52760882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @peak indicates, use the `inputs` with the `split` function. But to merge the key/values into one single object, use the [`reduce`][1] method:\r\n\r\n    jq -Rn &#39;[inputs|split(&quot;,&quot;)| {(.[0]): .[1]}] | reduce .[] as $obj ({}; . + $obj) &#39; input.csv\r\n\r\nThe `reduce` method reduces each item in the array into a single item. In this case, we indicate that each item should be assigned to the `$obj` variable, and that we start out with the empty `{}` object. The second argument to the `reduce` method indicates how to &quot;reduce&quot; things down to a single item. In this case, we are adding/merging the `$obj` we assigned with the `{}` object we started out with and then returning the resulting object to be used in the next iteration. After all the iterations have completed, the final item (in this case, the combined object) is returned.  \r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Reduce",
                "title": "I want to convert the text file data to JSON using Jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552703692,
                "creation_date": 1552703692,
                "answer_id": 55192924,
                "question_id": 52760882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you ask is possible to achieve with just standar unix shell utilities (assuming your input in `file.txt`):\r\n\r\n    bash $ echo { \\&quot;$(&lt;file.txt sed &#39;s/,/&quot;:&quot;/g&#39; | paste -s -d, - | sed &#39;s/,/&quot;,&quot;/g&#39;)\\&quot; } \r\n    { &quot;test&quot;:&quot;test&quot;,&quot;test1&quot;:&quot;test1&quot; }\r\n    bash $ \r\n\r\n- resulting output is a valid json",
                "title": "I want to convert the text file data to JSON using Jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1632477429,
        "creation_date": 1539263352,
        "last_edit_date": 1539263464,
        "question_id": 52760882,
        "body_markdown": "I have the date in the file which looks like \r\n\r\n    test,test\r\n    test1,test1\r\n\r\nI want to convert it into like:\r\n\r\n    {&quot;test&quot;:&quot;test&quot;,&quot;test1&quot;:&quot;test1&quot;}\r\n\r\nI have tried jq for this purpose `jq -R -s -c &#39;split(&quot;\\n&quot;)&#39;`\r\n\r\nBut its oupting in the format `[&quot;test,test&quot;,&quot;test1,test1&quot;,&quot;&quot;]`",
        "link": "https://stackoverflow.com/questions/52760882/i-want-to-convert-the-text-file-data-to-json-using-jq",
        "title": "I want to convert the text file data to JSON using Jq"
    },
    {
        "tags": [
            "windows",
            "bash",
            "cygwin",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539266129,
                "post_id": 52761772,
                "comment_id": 92446637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8624929,
                    "reputation": 947,
                    "user_id": 6458418,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/800fee9d7d9d1778f1c3d252687153ee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "knowdotnet",
                    "link": "https://stackoverflow.com/users/6458418/knowdotnet"
                },
                "reply_to_user": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539271612,
                "post_id": 52761772,
                "comment_id": 92450496,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539272161,
                "post_id": 52761772,
                "comment_id": 92450820,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539275421,
                "last_edit_date": 1539275421,
                "creation_date": 1539274759,
                "answer_id": 52764729,
                "question_id": 52761772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have jq installed on cygwin and it can handle json data in Windows.\r\n\r\nYou can install jq on Cygwin by two ways\r\n\r\n1) Run this in cmd. setup-x86_64.exe is your cygwin installation binary\r\n\r\n    setup-x86_64.exe -q -P jq\r\n\r\n2) Install apt-cyg(the package manager of cygwin similar to yum) and run on cygwin\r\n\r\n    apt-cyg install jq\r\n\r\nNOTE: The details of installing packages on Cygwin is mentioned https://stackoverflow.com/questions/9260014/how-do-i-install-cygwin-components-from-the-command-line\r\n",
                "title": "How to process json in bash script in windows environment"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1539281445,
        "creation_date": 1539265754,
        "last_edit_date": 1539281445,
        "question_id": 52761772,
        "body_markdown": "I am writing bash script that is supposed to work both on linux and windows environment. To enable bash on windows we have installed cygwin. \r\nSeems jq lib can handle json but not sure will it work on windows environment too?\r\nSame with sed not sure how to enable it in windows environment?\r\nSome other libraries?",
        "link": "https://stackoverflow.com/questions/52761772/how-to-process-json-in-bash-script-in-windows-environment",
        "title": "How to process json in bash script in windows environment"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1539277921,
                "last_edit_date": 1539277921,
                "creation_date": 1539268405,
                "answer_id": 52762709,
                "question_id": 52762589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`map` and `+` will do this:\r\n\r\n    $ jq &#39;map(. + {stable: &quot;yes&quot;})&#39; tmp.json\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;name&quot;: &quot;Blue&quot;,\r\n        &quot;stable&quot;: &quot;yes&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;name&quot;: &quot;Red&quot;,\r\n        &quot;stable&quot;: &quot;yes&quot;\r\n      }\r\n    ]\r\n\r\nSince the input is an array, the `.` refers to each object in that array, to which we add another object.\r\n\r\nNote this will also override any existing `stable` key in each object.",
                "title": "Add a new key/value to every object in json array in file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1539277921,
        "creation_date": 1539268004,
        "question_id": 52762589,
        "body_markdown": "I have a json file like below. I want to add &quot;stable&quot;: &quot;yes&quot; to every object in this file with jq. How can i do this?\r\n\r\n\r\n     [\r\n        {\r\n            &quot;id&quot;:&quot;1&quot;,\r\n            &quot;name&quot;:&quot;Blue&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;:&quot;2&quot;,\r\n            &quot;name&quot;:&quot;Red&quot;\r\n        }\r\n     ]\r\n\r\nI want it to be like this:\r\n\r\n     [\r\n        {\r\n            &quot;id&quot;:&quot;1&quot;,\r\n            &quot;name&quot;:&quot;Blue&quot;,\r\n            &quot;stable&quot;: &quot;yes&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;:&quot;2&quot;,\r\n            &quot;name&quot;:&quot;Red&quot;,\r\n            &quot;stable&quot;: &quot;yes&quot;\r\n        }\r\n     ]",
        "link": "https://stackoverflow.com/questions/52762589/add-a-new-key-value-to-every-object-in-json-array-in-file-with-jq",
        "title": "Add a new key/value to every object in json array in file with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539320296,
                "post_id": 52772515,
                "comment_id": 92466960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1539320796,
                "post_id": 52772515,
                "comment_id": 92467091,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539328637,
                "last_edit_date": 1539328637,
                "creation_date": 1539321891,
                "answer_id": 52772799,
                "question_id": 52772515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Run below to get desired output:  \r\n\r\n    jq &#39;{ &quot;Test&quot; : .}&#39; file.json",
                "title": "How to create key of object in json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1539328637,
        "creation_date": 1539320200,
        "question_id": 52772515,
        "body_markdown": "I have a json file as belows: \r\n\r\n    {\r\n      &quot;HealthCheckPath&quot;: &quot;/&quot;,\r\n      &quot;HealthCheckIntervalSeconds&quot;: 30\r\n    }\r\n\r\nI wanna create a key with Test name. My desired result:\r\n\r\n    &quot;Test&quot;: {\r\n          &quot;HealthCheckPath&quot;: &quot;/&quot;,\r\n          &quot;HealthCheckIntervalSeconds&quot;: 30\r\n    }\r\n\r\nI want to using jq option with bash or other way via bash shell.",
        "link": "https://stackoverflow.com/questions/52772515/how-to-create-key-of-object-in-json-with-jq",
        "title": "How to create key of object in json with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539345370,
                "post_id": 52778332,
                "comment_id": 92479517,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9931197,
                    "reputation": 196,
                    "user_id": 7351088,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9a0dd0c7fdca6d63ed5ea99cf6115f09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BobMonk",
                    "link": "https://stackoverflow.com/users/7351088/bobmonk"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539351017,
                "post_id": 52778332,
                "comment_id": 92482592,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1539346573,
                "last_edit_date": 1539346573,
                "creation_date": 1539345175,
                "answer_id": 52778983,
                "question_id": 52778332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `fromjson` construct to restore the strings as JSON texts. So, given the content below\r\n\r\n    {\r\n    \t&quot;message&quot;: &quot;{ \\&quot;foo\\&quot;: \\&quot;42\\&quot;, \\&quot;bar\\&quot;: \\&quot;less interesting data\\&quot; }&quot;\r\n    }\r\n\r\nall you need to do to extract `bar` is\r\n\r\n    jq &#39;.&quot;message&quot;|fromjson|.bar&#39; file\r\n    &quot;less interesting data&quot;\r\n\r\nTo print the output without the quotes, use the `-r`/`--raw-ouput` flag which emits text in raw format. As noted in the comments `fromjson.bar` should also work as expected.",
                "title": "Pull value in jq with escaped vars"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1539357980,
        "creation_date": 1539342771,
        "last_edit_date": 1539357980,
        "question_id": 52778332,
        "body_markdown": "I have a JSON that I am trying to process.\r\nI am using jq and can&#39;t for my life get the required output.\r\n\r\nI have a simple eg below,\r\n\r\n    {\r\n        &quot;message&quot; :&quot;{ \\&quot;foo\\&quot;: \\&quot;42\\&quot;, \\&quot;bar\\&quot;: \\&quot;less interesting data\\&quot;}&quot;\r\n    \r\n    }\r\n\r\nMy Build Up  \r\n\r\n    jq &#39;.&quot;message&quot;\r\n    \r\n    {\r\n       &quot;message&quot; :{&quot;foo&quot;: &quot;42&quot;, &quot;bar&quot;: &quot;less interesting data&quot;}\r\n    }\r\ngives \r\n    \r\n    {\r\n      &quot;foo&quot;: &quot;42&quot;,\r\n      &quot;bar&quot;: &quot;less interesting data&quot;\r\n    }\r\n\r\n    .&quot;message&quot;.&quot;bar&quot;\r\ngives\r\n\r\n    &quot;less interesting data&quot;\r\n\r\n\r\nSo\r\n    \r\n    {\r\n       &quot;message&quot; :&quot;{&quot;foo&quot;: &quot;42&quot;, &quot;bar&quot;: &quot;less interesting data&quot;}&quot;\r\n    }\r\nFAILS as JSON invalid\r\n\r\n\r\n    {\r\n       &quot;message&quot; :&quot;{\\&quot;foo\\&quot;: \\&quot;42\\&quot;, \\&quot;bar\\&quot;: \\&quot;less interesting data\\&quot;}&quot;\r\n    }\r\nFAILS &#39;jq: error (at &lt;stdin&gt;:3): Cannot index string with string &quot;bar&quot;\r\nexit status 5&#39;\r\n\r\n\r\nI have tried a whole bunch of differing jq queries (i won&#39;t waste your time listing them)\r\n\r\nSo I would like some advice on how id get &quot;bar&quot; from the JSON\r\n\r\n\r\nIt&#39;s not a duplicate of convert string to JSON as this leads you to the idea of conversion. Without this question, you&#39;d never know the answer is to use fromjson",
        "link": "https://stackoverflow.com/questions/52778332/pull-value-in-jq-with-escaped-vars",
        "title": "Pull value in jq with escaped vars"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1539380133,
                "creation_date": 1539380133,
                "answer_id": 52787286,
                "question_id": 52787205,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The id&#39;s are stored in an array under the key `value`. `.value[].id` lists the ids, if you put them into an array, you can call `max` on it:\r\n\r\n    jq &#39;[.value[].id] | max&#39; &lt; file.json",
                "title": "process json using jq in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1539380133,
        "creation_date": 1539379613,
        "question_id": 52787205,
        "body_markdown": "Below is my json which I need to process using jq in bash script. I need to get the &quot;Id&quot; column value. Since in this json there are 3 records, record with maximum value id would be returned. So after processing of below json I should get 170.\r\nI am newbie and have very limited exposure to bash.\r\n \r\n\r\n    {\r\n      &quot;count&quot;: 3,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;properties&quot;: {},\r\n          &quot;tags&quot;: [],          &quot;validationResults&quot;: [],\r\n          &quot;plans&quot;: [\r\n            {\r\n              &quot;planId&quot;: &quot;49699e0f-b893-4633-bc05-754b8a562d07&quot;\r\n            }\r\n          ],          &quot;triggerInfo&quot;: {},\r\n          &quot;id&quot;: 170,\r\n          &quot;buildNumber&quot;: &quot;20181011.8&quot;,          &quot;status&quot;: &quot;completed&quot;,          &quot;result&quot;: &quot;succeeded&quot;,          &quot;queueTime&quot;: &quot;2018-10-11T15:56:24.9611153Z&quot;,          &quot;startTime&quot;: &quot;2018-10-11T15:56:28.3668144Z&quot;,          &quot;finishTime&quot;: &quot;2018-10-11T15:57:20.5163422Z&quot;,\r\n          &quot;url&quot;: &quot;https://indiatelecom.visualstudio.com/d354caa2-2e88-414a-829b-25df3aceaaaf/_apis/build/Builds/170&quot;,\r\n          &quot;buildNumberRevision&quot;: 8,          &quot;uri&quot;: &quot;vstfs:///Build/Build/170&quot;,\r\n          &quot;sourceBranch&quot;: &quot;refs/heads/master&quot;,          &quot;sourceVersion&quot;: &quot;4303c19f8fda79e35fcb598219d5dca6bb274c2d&quot;,\r\n          &quot;priority&quot;: &quot;normal&quot;,          &quot;reason&quot;: &quot;manual&quot;,          &quot;lastChangedDate&quot;: &quot;2018-10-11T15:57:20.797Z&quot;,          &quot;parameters&quot;: &quot;{\\&quot;system.debug\\&quot;:\\&quot;false\\&quot;}&quot;,\r\n          &quot;orchestrationPlan&quot;: {\r\n            &quot;planId&quot;: &quot;49699e0f-b893-4633-bc05-754b8a562d07&quot;\r\n          },          &quot;keepForever&quot;: false,          &quot;retainedByRelease&quot;: false,          &quot;triggeredByBuild&quot;: null\r\n        },\r\n        {          &quot;properties&quot;: {},          &quot;tags&quot;: [],          &quot;validationResults&quot;: [],\r\n          &quot;plans&quot;: [         {              &quot;planId&quot;: &quot;15026a2f-c725-4e52-974b-61e01a940661&quot;\r\n            }          ],\r\n          &quot;triggerInfo&quot;: {},\r\n          &quot;id&quot;: 160,\r\n          &quot;buildNumber&quot;: &quot;20181009.20&quot;,          &quot;status&quot;: &quot;completed&quot;,          &quot;result&quot;: &quot;succeeded&quot;,          &quot;queueTime&quot;: &quot;2018-10-09T16:47:42.2954075Z&quot;,          &quot;startTime&quot;: &quot;2018-10-09T16:47:43.8034575Z&quot;,\r\n          &quot;finishTime&quot;: &quot;2018-10-09T16:48:35.8340469Z&quot;,          &quot;url&quot;: &quot;https://indiatelecom.visualstudio.com/d354caa2-2e88-414a-829b-25df3aceaaaf/_apis/build/Builds/160&quot;,\r\n          &quot;buildNumberRevision&quot;: 20,          &quot;uri&quot;: &quot;vstfs:///Build/Build/160&quot;,\r\n          &quot;sourceBranch&quot;: &quot;refs/heads/master&quot;,          &quot;sourceVersion&quot;: &quot;19a55c7482083785265b86015150521b40230c11&quot;,\r\n          &quot;priority&quot;: &quot;normal&quot;,          &quot;reason&quot;: &quot;manual&quot;,\r\n          &quot;lastChangedDate&quot;: &quot;2018-10-09T16:48:36.057Z&quot;,          &quot;parameters&quot;: &quot;{\\&quot;system.debug\\&quot;:\\&quot;false\\&quot;}&quot;,\r\n          &quot;orchestrationPlan&quot;: {\r\n            &quot;planId&quot;: &quot;15026a2f-c725-4e52-974b-61e01a940661&quot;\r\n          },\r\n          &quot;keepForever&quot;: false,          &quot;retainedByRelease&quot;: false,\r\n          &quot;triggeredByBuild&quot;: null        },\r\n        {\r\n          &quot;properties&quot;: {},          &quot;tags&quot;: [],\r\n          &quot;validationResults&quot;: [],          &quot;plans&quot;: [\r\n            {\r\n              &quot;planId&quot;: &quot;e45d9da8-4d95-42b7-aa23-478e1c1c49f5&quot;\r\n            }\r\n          ],\r\n          &quot;triggerInfo&quot;: {},\r\n          &quot;id&quot;: 147,\r\n          &quot;buildNumber&quot;: &quot;20181009.7&quot;,          &quot;status&quot;: &quot;completed&quot;,\r\n          &quot;result&quot;: &quot;succeeded&quot;,          &quot;queueTime&quot;: &quot;2018-10-09T15:15:47.0248009Z&quot;,\r\n          &quot;startTime&quot;: &quot;2018-10-09T15:15:50.8899892Z&quot;,          &quot;finishTime&quot;: &quot;2018-10-09T15:16:47.7866356Z&quot;,\r\n          &quot;url&quot;: &quot;https://indiatelecom.visualstudio.com/d354caa2-2e88-414a-829b-25df3aceaaaf/_apis/build/Builds/147&quot;,\r\n          &quot;buildNumberRevision&quot;: 7,          &quot;uri&quot;: &quot;vstfs:///Build/Build/147&quot;,\r\n          &quot;sourceBranch&quot;: &quot;refs/heads/master&quot;,          &quot;sourceVersion&quot;: &quot;70fccb138a2f2a9dfe18290c468959102f504067&quot;,\r\n          &quot;priority&quot;: &quot;normal&quot;,          &quot;reason&quot;: &quot;manual&quot;,\r\n          &quot;lastChangedDate&quot;: &quot;2018-10-09T15:16:48.16Z&quot;,\r\n          &quot;parameters&quot;: &quot;{\\&quot;system.debug\\&quot;:\\&quot;false\\&quot;}&quot;,          &quot;orchestrationPlan&quot;: {\r\n            &quot;planId&quot;: &quot;e45d9da8-4d95-42b7-aa23-478e1c1c49f5&quot;\r\n          },          &quot;keepForever&quot;: false,          &quot;retainedByRelease&quot;: false,\r\n          &quot;triggeredByBuild&quot;: null        }\r\n      ]    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52787205/process-json-using-jq-in-bash-script",
        "title": "process json using jq in bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641832664,
                "last_edit_date": 1641832664,
                "creation_date": 1539684495,
                "answer_id": 52833023,
                "question_id": 52832938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make a recursive function. Something like\r\n\r\n    function {\r\n        foreach $array as $key =&gt; $value {\r\n            if ($key == KEYYOUWANT) {\r\n               $answer = value\r\n               break;\r\n           } else {\r\n                function($value)\r\n           }\r\n        }\r\n    }\r\n\r\nSorry for the pseudo code!",
                "title": "extract array of string values based on specific keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539707186,
                "last_edit_date": 1539707186,
                "creation_date": 1539705874,
                "answer_id": 52839655,
                "question_id": 52832938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For simplicity, let&#39;s start by assuming the core task is to fetch the value(s) associated with\r\none specific key.  For purposes of exposition and clarity, let&#39;s define a function accordingly:\r\n\r\n    # Emit a (possibly empty) stream of key-value objects \r\n    # corresponding to the $key specified as a string\r\n    def getKeyValue($key):\r\n      .. | objects | select(has($key)) | {($key): .[$key]};\r\n\r\nA solution to the problem is now trivial:\r\n\r\n    [.dict[] as $k | getKeyValue($k)] | add\r\n\r\n## Variations\r\nThis solution has several potential problems:\r\n\r\n* It is possible that one or more of the keys of interest does not occur at all in the input;\r\n\r\n* It is possible that one or more of the keys of interest occurs more than once in the input;\r\n\r\n* If the input is large, then a more efficient solution might be preferable.\r\n\r\nThe first two issues can be easily dealt with, but the details will depend on the detailed requirements.\r\nThe efficiency issue can likewise be easily dealt with by modifying the def of getKeyValue so that\r\nthe named argument is an array of strings.\r\n\r\n\r\n",
                "title": "extract array of string values based on specific keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539710472,
                "creation_date": 1539710472,
                "answer_id": 52840859,
                "question_id": 52832938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As a learning experience (for both of us), here&#39;s a version that resembles your last example:\r\n\r\n    .source as $source \r\n    | [ \r\n      .dict[] | . as $key \r\n      | $source | .. \r\n      | select(.[$key]?) \r\n      | { ($key): .[$key]? } \r\n    ] | add\r\n\r\nWhich starts our capturing `.source` as `$source`, then it iterates over `.dict[]`, aliasing each key in it as `$key`. Then it switches back to `$source` and recurses over it (with `..`, which is a shorter version of `recurse(.[]?)`. Then the `select` looks for any sub-objects with a key named `$key`, and the following object constructor extracts that single key/value pair. Finally `add` merges all of those objects into one.\r\n\r\nI don&#39;t make any promises that this is better or faster than the other solutions, but it&#39;s illustrative :)",
                "title": "extract array of string values based on specific keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1641832664,
        "creation_date": 1539684177,
        "last_edit_date": 1539684774,
        "question_id": 52832938,
        "body_markdown": "I hope everyone is well.\r\n \r\n I am struggling with JQ trying to  select array of strings values from an input json using specific keys to select. The &quot;key&quot;:[&quot;string1&quot;,... , &quot;stringn&quot;] can be embeded &quot;somewhere&quot; at any depth in the json. I only know the key values of the arrays.\r\n \r\n Let&#39;s say I have some json that includes the keys dictionnay (dict) and the json source (source). In this exemple, I would like to select the &quot;key4&quot; and &quot;key11&quot; arrays and get them in a result json with the corresponding keys.\r\n \r\n My sample input is :\r\n\r\n     {\r\n    \t&quot;dict&quot;: [&quot;key4&quot;, &quot;key11&quot;],\r\n    \t&quot;source&quot;:{\r\n    \t&quot;key0&quot;: {\r\n    \t\t&quot;key1&quot;: &quot;valueA&quot;,\r\n    \t\t&quot;key2&quot;: 123456,\r\n    \t\t&quot;key3&quot;: [{\r\n    \t\t\t\t&quot;key4&quot;: [&quot;anotherValue4341&quot;, &quot;anotherValue4342&quot;],\r\n    \t\t\t\t&quot;key5&quot;: [{\r\n    \t\t\t\t\t&quot;someKey351&quot;: &quot;someValue351&quot;\r\n    \t\t\t\t}, {\r\n    \t\t\t\t\t&quot;someKey352&quot;: &quot;someValue352&quot;\r\n    \t\t\t\t}],\r\n    \t\t\t\t&quot;key6&quot;: 999\r\n    \t\t\t},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;key7&quot;: &quot;anotherValue342&quot;,\r\n    \t\t\t\t&quot;key8&quot;: &quot;anotherValue352&quot;,\r\n    \t\t\t\t&quot;key9&quot;: 666\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;key10&quot;: {\r\n    \t\t\t&quot;key11&quot;: [&quot;lastvalue111&quot;, &quot;lastvalue112&quot;, &quot;lastvalue113&quot;]\r\n    \t\t}\r\n    \t}\r\n    \r\n    }}\r\n\r\nmy expected output for this sample would be :\r\n\r\n\r\n    {\r\n        &quot;key4&quot;: [&quot;anotherValue4341&quot;, &quot;anotherValue4342&quot;],\r\n        &quot;key11&quot;: [&quot;lastvalue111&quot;, &quot;lastvalue112&quot;, &quot;lastvalue113&quot;]\r\n    }\r\n\r\nI am using JQ to extract the requested output.\r\n\r\nfor now I have attempted to reuse former query to select key/values like this :\r\n\r\n    jq &#39;.dict as $dict | .source | reduce paths as $p (.;getpath($p) as $v| if $v|type == &quot;string&quot; and $dict[$v] then setpath($p; $dict[$v]) else . end)&#39;\r\n\r\nbut it seems it struggles with some values : jq: error (at &lt;stdin&gt;:26): Cannot index array with string &quot;valueA&quot;\r\n\r\nI also have attempted to select matching objects that contains keys in dict :\r\n\r\n    jq &#39;.dict as $dict | .source | recurse(.[]?) | objects | select(in($dict))&#39;\r\n\r\n but this leads to error &quot;Cannot check whether array has a object key&quot;\r\n \r\n I hope I am clear enough to explain my needs/issues.\r\n \r\n Any hints appreciated.",
        "link": "https://stackoverflow.com/questions/52832938/extract-array-of-string-values-based-on-specific-keys",
        "title": "extract array of string values based on specific keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539711283,
                "post_id": 52840069,
                "comment_id": 92597945,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1539708484,
                "creation_date": 1539708484,
                "answer_id": 52840366,
                "question_id": 52840069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This produces the desired result:\r\n\r\n    jq -sr &#39;.[] | &quot;\\(.[0].addr) - \\(.[1].vendor//&quot;&quot;)&quot;&#39; file\r\n",
                "title": "json; duplicate keys and filter based on value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1574354271,
        "creation_date": 1539707394,
        "last_edit_date": 1574354271,
        "question_id": 52840069,
        "body_markdown": "Trying to filter json based on `addrtype` and printing `addr` if `addrtype` is `ipv4` and `vendor` if `addrtype` is `mac`.\r\n\r\nSo far I have `&#39;&quot;\\(.addr) \\(.addrtype) \\(.vendor)&quot;&#39;` which results in:\r\n\r\n    &quot;192.168.1.235 ipv4 null&quot;\r\n    &quot;18:B4:30:8D:AE:BA mac Nest Labs&quot;\r\n    &quot;192.168.1.236 ipv4 null&quot;\r\n    &quot;18:B4:30:8D:B6:18 mac Nest Labs&quot;\r\n    &quot;192.168.1.238 ipv4 null&quot;\r\n    &quot;0C:EA:C9:AF:4F:72 mac null&quot;\r\n    &quot;192.168.1.254 ipv4 null&quot;\r\n    &quot;0C:EA:C9:AF:4F:70 mac null&quot;\r\n\r\n\r\nDesired Result:\r\n\r\n    192.168.1.235 - Nest Labs\r\n    192.168.1.236 - Nest Labs\r\n    192.168.1.238 - \r\n    192.168.1.254 - \r\n\r\nData:\r\n\r\n    [\r\n      {\r\n        &quot;addr&quot;: &quot;192.168.1.235&quot;,\r\n        &quot;addrtype&quot;: &quot;ipv4&quot;\r\n      },\r\n      {\r\n        &quot;addr&quot;: &quot;18:B4:30:8D:AE:BA&quot;,\r\n        &quot;addrtype&quot;: &quot;mac&quot;,\r\n        &quot;vendor&quot;: &quot;Nest Labs&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;addr&quot;: &quot;192.168.1.236&quot;,\r\n        &quot;addrtype&quot;: &quot;ipv4&quot;\r\n      },\r\n      {\r\n        &quot;addr&quot;: &quot;18:B4:30:8D:B6:18&quot;,\r\n        &quot;addrtype&quot;: &quot;mac&quot;,\r\n        &quot;vendor&quot;: &quot;Nest Labs&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;addr&quot;: &quot;192.168.1.238&quot;,\r\n        &quot;addrtype&quot;: &quot;ipv4&quot;\r\n      },\r\n      {\r\n        &quot;addr&quot;: &quot;0C:EA:C9:AF:4F:72&quot;,\r\n        &quot;addrtype&quot;: &quot;mac&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;addr&quot;: &quot;192.168.1.254&quot;,\r\n        &quot;addrtype&quot;: &quot;ipv4&quot;\r\n      },\r\n      {\r\n        &quot;addr&quot;: &quot;0C:EA:C9:AF:4F:70&quot;,\r\n        &quot;addrtype&quot;: &quot;mac&quot;\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52840069/json-duplicate-keys-and-filter-based-on-value",
        "title": "json; duplicate keys and filter based on value"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539791359,
                "post_id": 52853997,
                "comment_id": 92632582,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539796636,
                "creation_date": 1539796636,
                "answer_id": 52860352,
                "question_id": 52853997,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach you could take is get all the paths to all scalar values for each input and take the set intersections. Then copy values from source to target from those paths.\r\n\r\nFirst we&#39;ll need an intersect function (which was surprisingly difficult to craft):\r\n\r\n    def set_intersect($other):\r\n        (map({ ($other[] | tojson): true }) | add) as $o\r\n        | reduce (.[] | tojson) as $v ({}; if $o[$v] then .[$v] = true else . end)\r\n        | keys_unsorted\r\n        | map(fromjson);\r\n\r\nThen to do the update:\r\n\r\n    $ jq --argfile s source.json &#39;\r\n    reduce ([paths(scalars)] | set_intersect([$s | paths(scalars)])[]) as $p (.;\r\n        setpath($p; $s | getpath($p))\r\n    )\r\n    &#39; target.json",
                "title": "Update one JSON file values with values from another JSON using JQ (on all levels)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539856674,
                "last_edit_date": 1539856674,
                "creation_date": 1539822016,
                "answer_id": 52865269,
                "question_id": 52853997,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Note: this response answers the original question, with respect to the original data. The OP may have had paths in mind rather than keys.]\r\n\r\nThere is no need to compute the intersection to achieve a reasonably efficient solution.\r\n\r\nFirst, let&#39;s hypothesize the following invocation of jq:\r\n\r\n    jq -n --argfile source source.json --argfile target target.json -f copy.jq\r\n\r\nIn the file copy.jq, we can begin by defining a helper function:\r\n\r\n    # emit an array of the distinct terminal keys in the input entity\r\n    def keys: [paths | .[-1] | select(type==&quot;string&quot;)] | unique;\r\n    \r\nIn order to inspect all the paths to leaf elements of `$source`, we can use `tostream`:\r\n    \r\n    ($target | keys) as $t\r\n    | reduce ($source|tostream|select(length==2)) as [$p,$v]\r\n        ($target;\r\n         if $t|index($p[-1]) then setpath($p; $v) else . end)\r\n\r\n## Alternatives\r\n\r\nSince $t is sorted, it would (at least in theory) make sense to use `bsearch` instead of `index`:\r\n\r\n     bsearch($p[-1]) &gt; -1\r\n\r\nAlso, instead of `tostream` we could use `paths(scalars)`.  \r\n\r\nPutting these alternatives together:\r\n\r\n    ($target | keys) as $t\r\n    | reduce ($source|paths(scalars)) as $p\r\n        ($target;\r\n         if $t|bsearch($p[-1]) &gt; -1 \r\n         then setpath($p; $source|getpath($p))\r\n         else . end)\r\n\r\n## Output\r\n\r\n    {\r\n      &quot;general&quot;: {\r\n        &quot;level1&quot;: {\r\n          &quot;key1&quot;: &quot;x-x-x-x-x-x-x-x&quot;,\r\n          &quot;key2&quot;: &quot;yyyyyyyy&quot;,\r\n          &quot;key3&quot;: &quot;z-z-z-z-z-z-z-z&quot;\r\n        },\r\n        &quot;onemore&quot;: {\r\n          &quot;kkeeyy&quot;: &quot;0000000&quot;\r\n        }\r\n      },\r\n      &quot;specific&quot;: {\r\n        &quot;stuff&quot;: &quot;test&quot;\r\n      }\r\n    }\r\n",
                "title": "Update one JSON file values with values from another JSON using JQ (on all levels)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1539863290,
                "last_edit_date": 1539863290,
                "creation_date": 1539861995,
                "answer_id": 52872929,
                "question_id": 52853997,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following provides a solution to the revised question, which is actually about &quot;paths&quot; rather than &quot;keys&quot;.\r\n\r\n    ([$target|paths(scalars)] | unique) as $paths\r\n    | reduce ($source|paths(scalars)) as $p\r\n        ($target;\r\n         if $paths | bsearch($p) &gt; -1 \r\n         then setpath($p; $source|getpath($p))\r\n         else . end)\r\n\r\n`unique` is called so that binary search can be used subsequently.\r\n\r\n## Invocation:\r\n\r\n    jq -n --argfile source source.json --argfile target target.json -f program.jq\r\n\r\n",
                "title": "Update one JSON file values with values from another JSON using JQ (on all levels)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1539863290,
        "creation_date": 1539776329,
        "last_edit_date": 1539847734,
        "question_id": 52853997,
        "body_markdown": "I have two JSON files:&lt;br&gt;\r\n\r\n \r\n\r\n&gt;    source.json:\r\n\r\n    {\r\n      &quot;general&quot;: {\r\n        &quot;level1&quot;: {\r\n          &quot;key1&quot;: &quot;x-x-x-x-x-x-x-x&quot;,\r\n          &quot;key3&quot;: &quot;z-z-z-z-z-z-z-z&quot;,\r\n          &quot;key4&quot;: &quot;w-w-w-w-w-w-w-w&quot;\r\n        },\r\n    \t&quot;another&quot; : {\r\n    \t  &quot;key&quot;: &quot;123456&quot;,\r\n          &quot;comments&quot;: {\r\n            &quot;one&quot;: &quot;111&quot;,\r\n            &quot;other&quot;: &quot;222&quot;\r\n          }\r\n    \t}\r\n      },\r\n      &quot;title&quot;: &quot;The best&quot;\r\n    }\r\n\r\nand the \r\n\r\n&gt; target.json:\r\n\r\n    {\r\n      &quot;general&quot;: {\r\n        &quot;level1&quot;: {\r\n          &quot;key1&quot;: &quot;xxxxxxxx&quot;,\r\n          &quot;key2&quot;: &quot;yyyyyyyy&quot;,\r\n          &quot;key3&quot;: &quot;zzzzzzzz&quot;\r\n        },\r\n    \t&quot;onemore&quot;: {\r\n    \t  &quot;kkeeyy&quot;: &quot;0000000&quot;\r\n    \t}\r\n      },\r\n      &quot;specific&quot;: {\r\n    \t&quot;stuff&quot;: &quot;test&quot;\r\n      },\r\n      &quot;title&quot;: {\r\n    \t&quot;one&quot;: &quot;one title&quot;,\r\n    \t&quot;other&quot;: &quot;other title&quot;\r\n      }\r\n    }\r\n\r\nI need all the values for keys which exist in both files, copied from *source.json* to *target.json*, considering all the levels.&lt;br&gt;\r\nI&#39;ve seen and tested the solution from [this post][1].\r\nIt only copies the first level of keys, and I couldn&#39;t get it to do what I need.\r\nThe result from solution in [this post][1], looks like this:\r\n\r\n    {\r\n      &quot;general&quot;: {\r\n        &quot;level1&quot;: {\r\n          &quot;key1&quot;: &quot;x-x-x-x-x-x-x-x&quot;,\r\n          &quot;key3&quot;: &quot;z-z-z-z-z-z-z-z&quot;,\r\n          &quot;key4&quot;: &quot;w-w-w-w-w-w-w-w&quot;\r\n        },\r\n        &quot;another&quot;: {\r\n          &quot;key&quot;: &quot;123456&quot;,\r\n          &quot;comments&quot;: {\r\n            &quot;one&quot;: &quot;111&quot;,\r\n            &quot;other&quot;: &quot;222&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;specific&quot;: {\r\n        &quot;stuff&quot;: &quot;test&quot;\r\n      },\r\n      &quot;title&quot;: &quot;The best&quot;\r\n    }\r\n\r\nEverything under the &quot;general&quot; key was copied as is.&lt;br&gt;\r\nWhat I need, is this:\r\n\r\n    {\r\n      &quot;general&quot;: {\r\n        &quot;level1&quot;: {\r\n          &quot;key1&quot;: &quot;x-x-x-x-x-x-x-x&quot;,\r\n          &quot;key2&quot;: &quot;yyyyyyyy&quot;,\r\n          &quot;key3&quot;: &quot;z-z-z-z-z-z-z-z&quot;\r\n        },\r\n        &quot;onemore&quot;: {\r\n          &quot;kkeeyy&quot;: &quot;0000000&quot;\r\n        }\r\n      },\r\n      &quot;specific&quot;: {\r\n        &quot;stuff&quot;: &quot;test&quot;\r\n      },\r\n      &quot;title&quot;: {\r\n        &quot;one&quot;: &quot;one title&quot;,\r\n        &quot;other&quot;: &quot;other title&quot;\r\n      }\r\n    }\r\n\r\nOnly &quot;key1&quot; and &quot;key3&quot; should be copied.&lt;br&gt;\r\nKeys in *target JSON* must not be deleted and new keys should not be created.\r\n\r\nCan anyone help?\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/44855206/update-one-json-file-values-with-values-from-another-json-using-jq\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52853997/update-one-json-file-values-with-values-from-another-json-using-jq-on-all-level",
        "title": "Update one JSON file values with values from another JSON using JQ (on all levels)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539781324,
                "post_id": 52855368,
                "comment_id": 92626172,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539782448,
                "post_id": 52855368,
                "comment_id": 92626886,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1539782946,
                "post_id": 52855368,
                "comment_id": 92627233,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13191057,
                    "reputation": 27,
                    "user_id": 9527318,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "TS2IR 2018",
                    "link": "https://stackoverflow.com/users/9527318/ts2ir-2018"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539790784,
                "post_id": 52855368,
                "comment_id": 92632293,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13191057,
                    "reputation": 27,
                    "user_id": 9527318,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "TS2IR 2018",
                    "link": "https://stackoverflow.com/users/9527318/ts2ir-2018"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539791112,
                "post_id": 52855368,
                "comment_id": 92632468,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13191057,
                    "reputation": 27,
                    "user_id": 9527318,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "TS2IR 2018",
                    "link": "https://stackoverflow.com/users/9527318/ts2ir-2018"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539794218,
                "post_id": 52855368,
                "comment_id": 92634082,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1539793685,
                "last_edit_date": 1539793685,
                "creation_date": 1539790994,
                "answer_id": 52858784,
                "question_id": 52855368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no point to using multiple `echo`s here at all, and **definitely** no point to making two requests to the API when all the data you need is included in each result.\r\n\r\n    #!/usr/bin/env bash\r\n    curl -X GET &#39;https://api.sunrise-sunset.org/json?lat=36.7201600&amp;lng=-4.4203400&#39; | \\\r\n      jq -r &#39;.results | &quot;Sunrise is expected at \\(.sunrise) and sunset is expected at \\(.sunset)&quot;\r\n\r\nIf you have a more complicated approach where that&#39;s not ideal, it still helps to use more variables:\r\n\r\n    #!/usr/bin/env bash\r\n    api_output=$(curl -X GET &#39;https://api.sunrise-sunset.org/json?lat=36.7201600&amp;lng=-4.4203400&#39;) || exit\r\n    sunrise=$(jq -r &#39;.results.sunrise&#39; &lt;&lt;&lt;&quot;$api_output&quot;)\r\n    sunset=$(jq -r &#39;.results.sunset&#39; &lt;&lt;&lt;&quot;$api_output&quot;)\r\n    echo &quot;Sunrise is expected at $sunrise and sunset at $sunset.&quot;\r\n\r\n---\r\n\r\nNote the use of the `-r` argument to `jq` to tell it to output &quot;raw strings&quot; -- this is why `tr` is not needed here. Also, because `echo` puts a newline after each argument, you should only run `echo` once per line of output desired. (The `-n` argument can suppress this on some versions, but it&#39;s not safe to rely on; better to use `printf &#39;%s&#39; ...` when trailing newlines are undesired).\r\n\r\n`jq` similarly writes a newline after each line of output (as all well-behaved UNIX programs emitting text streams are intended to). Using [command substitution](http://wiki.bash-hackers.org/syntax/expansion/cmdsubst) removes those trailing newlines, so we don&#39;t store them inside the `sunrise` and `sunset` variables and thus reintroduce them in the `echo`.",
                "title": "Extracting multiple pieces from JSON with jq, with output all on one line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1539826844,
        "creation_date": 1539780876,
        "last_edit_date": 1539826844,
        "question_id": 52855368,
        "body_markdown": "my code\r\n   \r\n    #!/bin/bash\r\n    echo &quot;Sunrise is expected at&quot;\r\n    curl -X GET &#39;https://api.sunrise-sunset.org/json?lat=36.7201600&amp;lng=-4.4203400&#39; | jq &#39;.results.sunrise&#39; | tr -d &#39;&quot;&#39;\r\n    echo &quot;and sunset at&quot; \r\n     curl -X GET &#39;https://api.sunrise-sunset.org/json?lat=36.7201600&amp;lng=-4.4203400&#39; | jq &#39;.results.sunset&#39; | tr -d &#39;&quot;&#39;\r\n    echo &quot;.&quot;\r\n\r\n----\r\n\r\nI want to print :\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    Sunrise is expected at 5:12:13 AM and sunset at 6:26:23 PM.\r\n\r\nbut I have this :\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    Sunrise is expected at\r\n    5:12:13\r\n    AM and sunset at\r\n    6:26:23 PM\r\n",
        "link": "https://stackoverflow.com/questions/52855368/extracting-multiple-pieces-from-json-with-jq-with-output-all-on-one-line",
        "title": "Extracting multiple pieces from JSON with jq, with output all on one line"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1539878924,
                "last_edit_date": 1539878924,
                "creation_date": 1539813025,
                "answer_id": 52864126,
                "question_id": 52864063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your original doesn&#39;t do any filtering, add it:\r\n\r\n    .node.nodes[] | select(.nodes != null).key",
                "title": "jq filter on subkey existence"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1539878924,
        "creation_date": 1539812634,
        "question_id": 52864063,
        "body_markdown": "I&#39;ve got some automations for setting up a clustered service [Galera] that uses etcd for service location. I&#39;ve then got a load balancer that reads this information in order to initialize and run.\r\n\r\nThe trouble is that while testing autohealing I noticed that there are empty etcd &#39;directories&#39; where the old nodes used to be, aka lacking a `nodes` subkey. This then causes trouble in the load balancer config.\r\n\r\nBelow is the result of `curl http://etcd/... | jq .node.nodes[]` which illustrates the problem.\r\n\r\nHow do I filter out the sub-objects that do not have a `nodes` key, eg: `172.17.0.16`?\r\n\r\n    {\r\n      &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.8&quot;,\r\n      &quot;dir&quot;: true,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.8/ipaddress&quot;,\r\n          &quot;value&quot;: &quot;172.17.0.8&quot;,\r\n          &quot;modifiedIndex&quot;: 9,\r\n          &quot;createdIndex&quot;: 9\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.8/wsrep_local_state_comment&quot;,\r\n          &quot;value&quot;: &quot;Synced&quot;,\r\n          &quot;expiration&quot;: &quot;2018-10-17T21:24:48.94524993Z&quot;,\r\n          &quot;ttl&quot;: 2,\r\n          &quot;modifiedIndex&quot;: 52905,\r\n          &quot;createdIndex&quot;: 52905\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.8/seqno&quot;,\r\n          &quot;value&quot;: &quot;1367&quot;,\r\n          &quot;expiration&quot;: &quot;2018-10-17T21:24:49.213778533Z&quot;,\r\n          &quot;ttl&quot;: 2,\r\n          &quot;modifiedIndex&quot;: 52907,\r\n          &quot;createdIndex&quot;: 52907\r\n        }\r\n      ],\r\n      &quot;modifiedIndex&quot;: 9,\r\n      &quot;createdIndex&quot;: 9\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.16&quot;,\r\n      &quot;dir&quot;: true,\r\n      &quot;modifiedIndex&quot;: 48,\r\n      &quot;createdIndex&quot;: 48\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.17&quot;,\r\n      &quot;dir&quot;: true,\r\n      &quot;modifiedIndex&quot;: 111,\r\n      &quot;createdIndex&quot;: 111\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.11&quot;,\r\n      &quot;dir&quot;: true,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.11/wsrep_local_state_comment&quot;,\r\n          &quot;value&quot;: &quot;Synced&quot;,\r\n          &quot;expiration&quot;: &quot;2018-10-17T21:24:55.990291814Z&quot;,\r\n          &quot;ttl&quot;: 9,\r\n          &quot;modifiedIndex&quot;: 52909,\r\n          &quot;createdIndex&quot;: 52909\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.11/seqno&quot;,\r\n          &quot;value&quot;: &quot;1367&quot;,\r\n          &quot;expiration&quot;: &quot;2018-10-17T21:24:56.113268568Z&quot;,\r\n          &quot;ttl&quot;: 9,\r\n          &quot;modifiedIndex&quot;: 52910,\r\n          &quot;createdIndex&quot;: 52910\r\n        }\r\n      ],\r\n      &quot;modifiedIndex&quot;: 50749,\r\n      &quot;createdIndex&quot;: 50749\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.14&quot;,\r\n      &quot;dir&quot;: true,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.14/wsrep_local_state_comment&quot;,\r\n          &quot;value&quot;: &quot;Synced&quot;,\r\n          &quot;expiration&quot;: &quot;2018-10-17T21:24:49.029444262Z&quot;,\r\n          &quot;ttl&quot;: 2,\r\n          &quot;modifiedIndex&quot;: 52906,\r\n          &quot;createdIndex&quot;: 52906\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;/galera/mariadb_galera/172.17.0.14/seqno&quot;,\r\n          &quot;value&quot;: &quot;1367&quot;,\r\n          &quot;expiration&quot;: &quot;2018-10-17T21:24:49.358067474Z&quot;,\r\n          &quot;ttl&quot;: 2,\r\n          &quot;modifiedIndex&quot;: 52908,\r\n          &quot;createdIndex&quot;: 52908\r\n        }\r\n      ],\r\n      &quot;modifiedIndex&quot;: 52076,\r\n      &quot;createdIndex&quot;: 52076\r\n    }\r\n\r\nNormally I would use `jq .node.nodes[].key` and the output would be as follows, representing live nodes:\r\n\r\n    &quot;/galera/mariadb_galera/172.17.0.8&quot;\r\n    &quot;/galera/mariadb_galera/172.17.0.11&quot;\r\n    &quot;/galera/mariadb_galera/172.17.0.14&quot;\r\n\r\nBut without filtering out the empty nodes it is this, which includes nodes that no longer exist:\r\n\r\n    &quot;/galera/mariadb_galera/172.17.0.8&quot;\r\n    &quot;/galera/mariadb_galera/172.17.0.16&quot;\r\n    &quot;/galera/mariadb_galera/172.17.0.17&quot;\r\n    &quot;/galera/mariadb_galera/172.17.0.11&quot;\r\n    &quot;/galera/mariadb_galera/172.17.0.14&quot;",
        "link": "https://stackoverflow.com/questions/52864063/jq-filter-on-subkey-existence",
        "title": "jq filter on subkey existence"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3154923,
                    "reputation": 363,
                    "user_id": 2667525,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u313K.jpg?s=256",
                    "display_name": "Ruthe",
                    "link": "https://stackoverflow.com/users/2667525/ruthe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539914152,
                "post_id": 52884819,
                "comment_id": 92682782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12816754,
                    "reputation": 415,
                    "user_id": 9273148,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/295a1405c810fe2cb8a904e8fd18f6ca?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tanvi Jaywant",
                    "link": "https://stackoverflow.com/users/9273148/tanvi-jaywant"
                },
                "reply_to_user": {
                    "account_id": 3154923,
                    "reputation": 363,
                    "user_id": 2667525,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u313K.jpg?s=256",
                    "display_name": "Ruthe",
                    "link": "https://stackoverflow.com/users/2667525/ruthe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539914422,
                "post_id": 52884819,
                "comment_id": 92682829,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539914564,
                "post_id": 52884819,
                "comment_id": 92682856,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12816754,
                    "reputation": 415,
                    "user_id": 9273148,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/295a1405c810fe2cb8a904e8fd18f6ca?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tanvi Jaywant",
                    "link": "https://stackoverflow.com/users/9273148/tanvi-jaywant"
                },
                "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": 1539914855,
                "post_id": 52884819,
                "comment_id": 92682912,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3154923,
                    "reputation": 363,
                    "user_id": 2667525,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u313K.jpg?s=256",
                    "display_name": "Ruthe",
                    "link": "https://stackoverflow.com/users/2667525/ruthe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539915393,
                "post_id": 52884819,
                "comment_id": 92683016,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539918281,
                "creation_date": 1539918281,
                "answer_id": 52885339,
                "question_id": 52884819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON, the following filter will perform the edit conditionally as specified:\r\n\r\n    .amazon.items\r\n    |= map(if .name == &quot;harry potter&quot; and .state == &quot;sold&quot;\r\n           then .state = &quot;returned&quot; else . end)\r\n\r\nOr rather, invoking jq with this filter will emit the updated JSON.  \r\n\r\nYou might want to use `sponge` to overwrite the original file once you&#39;re sure that&#39;s really what you want to do.",
                "title": "How to filter based on value in json using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539930357,
                "creation_date": 1539930357,
                "answer_id": 52886893,
                "question_id": 52884819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another `jq` filter using `select` function:\r\n\r\n    jq &#39;.amazon.items |= map(select(.name==&quot;harry potter&quot;).state=&quot;returned&quot;)&#39; file\r\n\r\n\r\n\r\n",
                "title": "How to filter based on value in json using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1539930357,
        "creation_date": 1539913939,
        "last_edit_date": 1539914788,
        "question_id": 52884819,
        "body_markdown": "    {    &quot;amazon&quot;: {\r\n               \r\n                    &quot;items&quot;: [\r\n                      {\r\n                        &quot;name&quot;: &quot;harry potter&quot;,\r\n                        &quot;state&quot;: &quot;sold&quot;\r\n                      },\r\n                      {\r\n                        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n                        &quot;state&quot;: &quot;in inventory&quot;\r\n                      },\r\n                      {\r\n                        &quot;name&quot;: &quot;watch&quot;,\r\n                        &quot;state&quot;: &quot;returned&quot;\r\n                      },\r\n                     ]\r\n        }\r\n    \r\n    }\r\n\r\nI want to write jq json parsing tool to modify &quot;name:harry potter&quot; from state &quot;sold&quot; to &quot;returned&quot;\r\n\r\nI want to modify this in a shell script ( .sh ) file.\r\n\r\n               \r\n",
        "link": "https://stackoverflow.com/questions/52884819/how-to-filter-based-on-value-in-json-using-jq",
        "title": "How to filter based on value in json using JQ"
    },
    {
        "tags": [
            "http-redirect",
            "pipe",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1539958766,
                "creation_date": 1539958766,
                "answer_id": 52894269,
                "question_id": 52889146,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the jq manual:\r\n\r\n    --unbuffered\r\n    \r\n    Flush the output after each JSON object is printed \r\n    (useful if you’re piping a slow data source into\r\n    jq and piping jq’s output elsewhere).",
                "title": "Redirecting of jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1539958766,
        "creation_date": 1539939919,
        "question_id": 52889146,
        "body_markdown": "In a terminal this works fine:\r\n\r\n`mosquitto_sub -h 192.168.178.20 -t tele/POW/SENSOR/# | jq &#39;.ENERGY|.Power&#39;`\r\n\r\nEvery 10 seconds there is an output on screen because the device POW publishes it&#39;s sensor dates every 10 seconds. The output of mosquitto_sub (it&#39;s a JSON string) is piped to jq and jq shows only the value digit of the key &#39;Power&#39;. Now I try to store the jq output (only the value) to a file &#39;output.log&#39;.\r\n\r\n    mosquitto_sub -h 192.168.178.20 -t tele/POW/SENSOR/# | jq &#39;.ENERGY|.Power&#39; &gt; output.log\r\n\r\nis not working. What is going wrong?\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/52889146/redirecting-of-jq-output",
        "title": "Redirecting of jq output"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "addition",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1539943554,
                "last_edit_date": 1539943554,
                "creation_date": 1539943129,
                "answer_id": 52890078,
                "question_id": 52889783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try:\r\n\r\n    jq -s &#39;add&#39; a.json b.json\r\n\r\nResult:\r\n\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 1\r\n    }\r\n",
                "title": "jq simple json object merge/combination"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540078748,
                "last_edit_date": 1540078748,
                "creation_date": 1539961875,
                "answer_id": 52895244,
                "question_id": 52889783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In some cases it may be desirable to avoid “slurping” the objects, as that requires more memory than necessary.  \r\n\r\nIn any case, to accomplish the task economically, use -n in conjunction with `inputs` as follows:\r\n  \r\n    reduce inputs as $i ({}; . + $i)\r\n\r\n## sigma/1\r\n\r\nIf you don&#39;t mind that `sigma(empty)` evaluates to `null`, you could define a polymorphic `sigma` as follows:\r\n\r\n    def sigma(s): reduce s as $x (null; . +$x);\r\n\r\nThis works on streams of numbers, streams of objects, streams of arrays, and streams of strings, and so would be suitable for your standard library.\r\n\r\nIn any case, with this def, for the task at hand, you could write: `simga(inputs)`. ",
                "title": "jq simple json object merge/combination"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1540078748,
        "creation_date": 1539942126,
        "last_edit_date": 1540078354,
        "question_id": 52889783,
        "body_markdown": "a.json\r\n   \r\n\r\n    {&quot;a&quot;: 1}\r\n\r\nb.json\r\n\r\n    {&quot;b&quot;: 1}\r\n\r\nDesired outcome\r\n\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 1}\r\n\r\n------------------------\r\n\r\n&gt; jq -s &quot;.&quot; a.json b.json\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: 1\r\n      },\r\n      {\r\n        &quot;b&quot;: 1\r\n      }\r\n    ]\r\n\r\nIt&#39;s wrapped in an array\r\n\r\n------------------------\r\n\r\n&gt; jq &quot;.&quot; a.json b.json\r\n\r\n    {\r\n      &quot;a&quot;: 1\r\n    }\r\n    {\r\n      &quot;b&quot;: 1\r\n    }\r\n    \r\nThat&#39;s not even valid json\r\n\r\n------------------------\r\n\r\nIs jq the wrong tool here? What is more appropriate?",
        "link": "https://stackoverflow.com/questions/52889783/jq-simple-json-object-merge-combination",
        "title": "jq simple json object merge/combination"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1539975752,
                "last_edit_date": 1539975752,
                "creation_date": 1539969448,
                "answer_id": 52897135,
                "question_id": 52896898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe your script is too encrusted to debug it effectively.  Anyway, the following is a tweaked extract from your script, and does work nicely:\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    PRESET_ARR=&#39;[{&quot;resolution&quot;:&quot;2160*2160&quot;,&quot;bitrate&quot;:&quot;60M&quot;,&quot;framerate&quot;:60},{&quot;resolution&quot;:&quot;1350*1350&quot;,&quot;bitrate&quot;:&quot;30M&quot;,&quot;framerate&quot;:60}]&#39;\r\n    \r\n    while IFS= read  resolution &amp;&amp;\r\n          IFS= read  bitrate &amp;&amp;\r\n          IFS= read  framerate\r\n    do\r\n    \r\n        echo &quot;resolution=$resolution&quot;\r\n        echo &quot;bitrate=$bitrate&quot;\r\n        echo &quot;framerate=$framerate&quot;\r\n    \r\n    done &lt; &lt;(jq -r &#39;.[] | (.resolution, .bitrate, .framerate)&#39; &lt;&lt;&lt; &quot;${PRESET_ARR}&quot;)\r\n\r\nPerhaps the problem you were facing can be resolved by replacing\r\n`PRESET_ARR=$1` by `PRESET_ARR=&quot;$1&quot;`.\r\n\r\n",
                "title": "jq Handling JSON Array as input to parse the elements of the JSON array within a while loop"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1540250356,
        "creation_date": 1539968333,
        "last_edit_date": 1540033911,
        "question_id": 52896898,
        "body_markdown": "Looked at many posts on a similar topic but I am doing something wrong as I keep getting &quot;jq: error: Could not open file&quot; or &quot;Invalid numeric literal&quot;.\r\nI am trying to pass a JSON array as a string value through jq to a while loop and read the elements of the JSON array within the loop.\r\nBasic bash script works with &lt;&lt;&lt; ${PRESET_ARR}) but doesn&#39;t work when calling from a nodejs app. \r\n\r\nTrying to call this bash script from a nodejs app. I can get just the batch script to work with &lt;&lt;&lt; ${PRESET_ARR})\r\nBut calling the batch script from nodejs causes &quot;parse error: Invalid numeric literal at line 1&quot;.\r\n\r\nChanged to use &lt;&lt;&lt; echo &quot;${PRESET_ARR}&quot;) and calling from nodejs causes &quot;jq: error: Could not open file&quot;\r\n\r\nMy bash script:\r\n\r\n    #!/bin/bash\r\n    \r\n    PRESET_ARR=$1\r\n    echo &quot;PRESET_ARR=${PRESET_ARR}&quot;\r\n    #PRESET_ARR=&#39;[{&quot;resolution&quot;:&quot;2160*2160&quot;,&quot;bitrate&quot;:60M,&quot;framerate&quot;:60},{&quot;resolution&quot;:&quot;1350*1350&quot;,&quot;bitrate&quot;:&quot;30M&quot;,&quot;framerate&quot;:60}]&#39;\r\n    #./batch.sh &#39;[{&quot;resolution&quot;:&quot;2160*2160&quot;,&quot;bitrate&quot;:&quot;60M&quot;,&quot;framerate&quot;:60},{&quot;resolution&quot;:&quot;1350*1350&quot;,&quot;bitrate&quot;:&quot;30M&quot;,&quot;framerate&quot;:60}]&#39;\r\n    #echo &quot;${PRESET_ARR}&quot; | jq -r &#39;.[] | (.resolution, .bitrate, .framerate)&#39; |\r\n\r\n    while IFS= read  resolution &amp;&amp;\r\n          IFS= read  bitrate &amp;&amp;\r\n          IFS= read  framerate;\r\n    #for row in $(echo &quot;${PRESET_ARR}&quot; | jq -r &#39;.[] | (.resolution, .bitrate, .framerate)&#39;);\r\n    do\r\n        \r\n        echo &quot;resolution=$resolution&quot;\r\n        echo &quot;bitrate=$bitrate&quot;\r\n        echo &quot;framerate=$framerate&quot;\r\n    \r\n    done &lt; &lt;(jq -r &#39;.[] | (.resolution, .bitrate, .framerate)&#39; &lt;&lt;&lt; echo &quot;${PRESET_ARR}&quot;)\r\n    #done &lt; &lt;(jq -r &#39;.[] | (&quot;.resolution&quot;, &quot;.bitrate&quot;, &quot;.framerate&quot;)&#39; &lt;&lt;&lt; ${PRESET_ARR})\r\n\r\nTIA",
        "link": "https://stackoverflow.com/questions/52896898/jq-handling-json-array-as-input-to-parse-the-elements-of-the-json-array-within-a",
        "title": "jq Handling JSON Array as input to parse the elements of the JSON array within a while loop"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1540001048,
                "creation_date": 1540001048,
                "answer_id": 52901824,
                "question_id": 52900364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the indicated input, the following filter produces the output as shown:\r\n\r\n    .element_texts\r\n    | [(.[]\r\n       | ((select(.element.name==&quot;Title&quot;),\r\n          (select(.element.name==&quot;Date&quot;)))\r\n       | .text)),\r\n       (map(select(.element.name==&quot;Subject&quot;) | .text) \r\n        | join(&quot;;&quot;) ) ]\r\n    | @tsv\r\n\r\n\r\n## Output\r\n\r\n    Esther Pohl Lovejoy, M.D.\t1894\tLovejoy, Esther Clayson Pohl, M.D., 1869-1967\\r\\n;Physicians, Women;Portraits\r\n\r\n\r\n",
                "title": "Grouping repeated output strings in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1540104671,
        "creation_date": 1539986038,
        "last_edit_date": 1540104671,
        "question_id": 52900364,
        "body_markdown": "I am trying to convert JSON that looks like https://digitalcollections.ohsu.edu/api/items/11801 to a selective tab delimited format with a semicolon for a multivalue separator. I can select fields I want and get them in tab delimited format. \r\n\r\nHowever, I still can&#39;t get multivalued fields to get concatenated into a single field with a semicolon separator without getting super kludgy. For example, \r\n\r\n    jq &#39;.element_texts[] | (select(.element.name==&quot;Title&quot;) | .text), (select(.element.name==&quot;Subject&quot;) | .text)&#39;\r\n\r\noutputs fields I need. But I&#39;m not able to convert the 3 subjects that get returned with this to a 3 item array that I can join -- I always get 3 separate strings. I can accomplish what I need by doing  \r\n\r\n    jq &#39;(.element_texts[] | (select(.element.name==&quot;Title&quot;) | .text), (select(.element.name==&quot;Date&quot;) | .text)), ([.element_texts[] | (select(.element.name==&quot;Subject&quot;) | .text)] | join(&quot;;&quot;))&#39;\r\n\r\nbut I feel like there has to be a much simpler and better way but I can&#39;t see what it is",
        "link": "https://stackoverflow.com/questions/52900364/grouping-repeated-output-strings-in-jq",
        "title": "Grouping repeated output strings in jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "dialog",
            "stdout",
            "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": 0,
                "creation_date": 1540142273,
                "post_id": 52917327,
                "comment_id": 92745634,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540146054,
                "post_id": 52917327,
                "comment_id": 92746778,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1540200754,
                "creation_date": 1540200754,
                "answer_id": 52926207,
                "question_id": 52917327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is possible to concat the information to one string. This results in this code:\r\n\r\n    ALL_VOLUMES_HTTP=$(curl --silent --write-out &quot;HTTPSTATUS:%{http_code}&quot; -H &quot;Authorization: Bearer $1&quot; https://api.hetzner.cloud/v1/volumes)\r\n    ALL_VOLUME_NAMES=$(echo $ALL_VOLUMES_HTTP | jq -r &#39;.volumes[].name&#39;)\r\n    \r\n    VALUES=&quot;&quot;\r\n    for i in $ALL_VOLUME_NAMES; do\r\n            VALUES=&quot;$VALUES $(jq -r &#39;.volumes[]|select(.name==&quot;&#39;$i&#39;&quot;)|.id&#39; &lt;&lt;&lt; &quot;$ALL_VOLUMES_HTTP&quot;) $i&quot;\r\n    done\r\n    \r\n    SELECTED_VOLUME=$(dialog --title &quot;Volume mount&quot; --menu &quot;Select: &quot; 0 0 0 $VALUES 3&gt;&amp;1 1&gt;&amp;2 2&gt;&amp;3)\r\n\r\n   \r\n",
                "title": "Bash dialog menu options as array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1540200789,
        "creation_date": 1540138425,
        "last_edit_date": 1540200789,
        "question_id": 52917327,
        "body_markdown": "I get a http response of the Hetzner API which provides information about all volumes. I want to build a menu with dialog, where you can choose out of all existing volumes. \r\nThis way I get the API&#39;s answer:\r\n\r\n    ALL_VOLUMES_HTTP=$(curl --silent --write-out &quot;HTTPSTATUS:%{http_code}&quot; -H &quot;Authorization: Bearer $1&quot; https://api.hetzner.cloud/v1/volumes)\r\n\r\nwhich is filtered by jq in this way\r\n\r\n    ALL_VOLUME_NAMES=$(jq &#39;.volumes[].name&#39; &lt;&lt;&lt; &quot;$ALL_VOLUMES_HTTP&quot;)\r\nthe output of `ALL_VOLUME_NAMES` is formatted like this\r\n\r\n    &quot;volumeName1&quot;\r\n    &quot;volumeName2&quot;\r\nbut in the menu dialog it is displayed [like in  this image][1]\r\n\r\nI already tried to put brackets about the jq (`jq &#39;[.volumes[].name&#39;`) but it is displayed completely wrong too [like in this example][2]\r\n\r\nFor generating the interface I am using the following code:\r\n\r\n    SELECTED_VOLUME=$(dialog --title &quot;Volume mount&quot; --menu &quot;Select:&quot; 0 0 0 $ALL_VOLUME_NAMES 3&gt;&amp;1 1&gt;&amp;2 2&gt;&amp;3)\r\n\r\n\r\nSo how can I generate a correct menu interface in dialog with the given data?\r\n\r\n\r\n  [1]: https://i.sstatic.net/ByXBv.png\r\n  [2]: https://i.sstatic.net/9h4Nq.png",
        "link": "https://stackoverflow.com/questions/52917327/bash-dialog-menu-options-as-array",
        "title": "Bash dialog menu options as array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1540199994,
                "post_id": 52925518,
                "comment_id": 92761310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 321243,
                    "reputation": 2122,
                    "user_id": 639956,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/6773dbc0a76286c4beeac6a4eec8c637?s=256&d=identicon&r=PG",
                    "display_name": "Soul Reaver",
                    "link": "https://stackoverflow.com/users/639956/soul-reaver"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540202915,
                "post_id": 52925518,
                "comment_id": 92763099,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1540204410,
                "creation_date": 1540204410,
                "answer_id": 52927261,
                "question_id": 52925518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could tweak your pipeline by adding\r\n\r\n    map(. // 0)\r\n\r\nright after forming the array.  If you want to preserve `false`, then you would have to add\r\n\r\n    map(if . == null then 0 else . end)\r\n\r\ninstead.\r\n\r\nIf you wanted a solution that was agnostic about the key names, you could use something along the lines of:\r\n\r\n    def resize($n): [range(0;$n) as $i | .[$i] // 0];\r\n\r\nThis would truncate or expand the input array.  If you don’t ever want to truncate, then tweak accordingly.",
                "title": "Return empty string or 0 (zero) in case of missing key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1540204410,
        "creation_date": 1540198315,
        "last_edit_date": 1540202753,
        "question_id": 52925518,
        "body_markdown": "I am having problems with my json to csv conversion.\r\n\r\nI have json file of this structure:\r\n\r\n    {\r\n    \t&quot;key&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;key1&quot;: 1,\r\n    \t\t\t&quot;key2&quot;: 1,\r\n    \t\t\t&quot;key3&quot;: {\r\n    \t\t\t\t&quot;1&quot;: 1,\r\n    \t\t\t\t&quot;2&quot;: 2,\r\n    \t\t\t\t&quot;3&quot;: 3,\r\n    \t\t\t\t&quot;4&quot;: 4\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;key1&quot;: 2,\r\n    \t\t\t&quot;key2&quot;: 2,\r\n    \t\t\t&quot;key3&quot;: {\r\n       \t\t\t\t&quot;2&quot;: 2\r\n    \t\t\t}\r\n    \t\t}\r\n    \t\t...\r\n    \t],\r\n    \t...\r\n    }\r\n\r\nI was using this jq call to convert my json to csv:\r\n\r\n    bin\\jq-win64 &quot;.key[] | [.key1, .key2, .key3.\\&quot;1\\&quot;, .key3.\\&quot;2\\&quot;, .key3.\\&quot;3\\&quot;, .key3.\\&quot;4\\&quot; ] | tostring] | join(\\&quot;;\\&quot;)&quot; source.json &gt; output.tmp\r\n\r\nI can&#39;t use standard `@csv`, because it&#39;s not good for my locale settings. But back to the problem. In some cases `key3` might not be full 4 element object (4 is the max with keys 1/2/3/4, just like in example). I have a problem with those missing subkeys, because jq returns &quot;null&quot; and that does not work well with CSV evaluation in excel or calc. Is there a way to force empty string or numeric 0 as output in such case?\r\n\r\nIn the end, I can try using some other command line text processor, but I&#39;d be glad if I could do that with single tool.\r\n\r\nEDIT:\r\nI had the wrong json structure example and now the actual problem has changed a bit. Message is updated.",
        "link": "https://stackoverflow.com/questions/52925518/return-empty-string-or-0-zero-in-case-of-missing-key-with-jq",
        "title": "Return empty string or 0 (zero) in case of missing key with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540207236,
                "post_id": 52927897,
                "comment_id": 92765442,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 310512,
                    "reputation": 21527,
                    "user_id": 623519,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/3fda0026a520ef2599a6faaf1c41b1af?s=256&d=identicon&r=PG",
                    "display_name": "artfulrobot",
                    "link": "https://stackoverflow.com/users/623519/artfulrobot"
                },
                "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": 1,
                "creation_date": 1540207419,
                "post_id": 52927897,
                "comment_id": 92765562,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540207804,
                "creation_date": 1540207804,
                "answer_id": 52928317,
                "question_id": 52927897,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could tweak your attempt as follows:\r\n\r\n    jq -s &#39;map({ (.id) : . }) | add&#39; &lt;data\r\n\r\nHowever, it would be more efficient to use `inputs` and `reduce` with the -n command-line option instead of -s.\r\n\r\nOf course, using this approach runs the risk of collisions.\r\n\r\nYou might also want to add `del(.id)`",
                "title": "Create object from stream of objects keyed by a property in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1540214769,
                "last_edit_date": 1540214769,
                "creation_date": 1540207922,
                "answer_id": 52928351,
                "question_id": 52927897,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ah! I&#39;ve got it! Or I&#39;ve got one solution - please post if there&#39;s a better way.\r\n\r\n    jq -s &#39;[group_by(.id)[]| add | { (.id) : . } ]|add&#39; &lt;data\r\n\r\n&lt;https://jqplay.org/s/BfAdRBZUMW&gt;\r\n\r\n1. `group_by` groups the inputs by their `.id` value and produces an array of arrays - the inner arrays are the values that match on id.\r\n\r\n2. for each group the inner arrays are passed to `add` which, because the things in the inner arrays are objects, merges them.\r\n\r\n3. That leaves a 2 item array. We feed that to an object constructor which plucks the `id` as the key and the whole item as the value. This still leaves an array of items.\r\n\r\n4. the outer `[]` (starts at start of pattern) says take all those and feed it to `add` (again), which merges the final objects created in (3).\r\n\r\nIt works, but there may be a cleaner way.\r\n\r\n\r\n## EDIT\r\n\r\nThis is uglier but produces the same result and is ~24% faster on a 9MB dataset.\r\n\r\n    jq -s &#39;reduce [.[]|{ (.id) : . }][] as $item ({}; . * $item )&#39; &lt;data\r\n\r\nThis uses [`reduce &lt;list&gt; as &lt;$var&gt; (&lt;initiation&gt;; &lt;iteration&gt;)`](https://stedolan.github.io/jq/manual/v1.5/#Reduce) starting with an empty object `{}` and using the merge operator `*` starting from the incoming item `.` to create the output. I&#39;m surprised it&#39;s faster, but I understand that `group_by` does a sort, so I guess that&#39;s an additional time cost.",
                "title": "Create object from stream of objects keyed by a property in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1540214769,
        "creation_date": 1540206504,
        "last_edit_date": 1540206983,
        "question_id": 52927897,
        "body_markdown": "This is a question about the command line json processor [jq](https://stedolan.github.io/jq/manual/v1.5/). It is *not* about javascript or jQuery or anything else with js and qs in its name :-)\r\n\r\nI have input data like:\r\n\r\n    { &quot;id&quot;: &quot;person1&quot;, &quot;name&quot;: &quot;wilma&quot;, &quot;age&quot;: &quot;quite old&quot;}\r\n    { &quot;id&quot;: &quot;person2&quot;, &quot;name&quot;: &quot;fred&quot;}\r\n    { &quot;id&quot;: &quot;person1&quot;, &quot;name&quot;: &quot;betty&quot;, &quot;x&quot;: &quot;extra&quot;}\r\n\r\nI want output like this:\r\n\r\n\r\n    {\r\n       &quot;person1&quot;: { &quot;name&quot;: &quot;betty&quot;, &quot;age&quot;: &quot;quite old&quot;, &quot;x&quot;: &quot;extra&quot; },\r\n       &quot;person2&quot;: { &quot;name&quot;: &quot;fred&quot; }\r\n    }\r\n\r\nI have tried various things!\r\n\r\ne.g.\r\n \r\n    jq -s &#39;.[] | { (.id) : . }&#39; &lt;data\r\n\r\ngives\r\n\r\n    { &quot;person1&quot;: { &quot;id&quot;: &quot;person1&quot;, &quot;name&quot;: &quot;wilma&quot;, &quot;age&quot;: &quot;quite old&quot; }}\r\n    { &quot;person2&quot;: { &quot;id&quot;: &quot;person2&quot;, &quot;name&quot;: &quot;fred&quot; }}\r\n    { &quot;person1&quot;: { &quot;id&quot;: &quot;person1&quot;, &quot;name&quot;: &quot;betty&quot;, &quot;x&quot;: &quot;extra&quot; }}\r\n\r\nWhich is sort of there, except it&#39;s outputting a stream of objects instead of just one. I need to merge all those objects together.\r\n\r\n[jqplay.org example](https://jqplay.org/s/_g2-njf8GS)\r\n\r\nI&#39;ve also tried using `group_by(.id)[]|add` which merges each item but still results in a stream. &lt;https://jqplay.org/s/lh6QUQ0DO4&gt;",
        "link": "https://stackoverflow.com/questions/52927897/create-object-from-stream-of-objects-keyed-by-a-property-in-jq",
        "title": "Create object from stream of objects keyed by a property in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1540208429,
                "post_id": 52928296,
                "comment_id": 92766103,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540208578,
                "post_id": 52928296,
                "comment_id": 92766207,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2626024,
                    "reputation": 637,
                    "user_id": 2272992,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/cGnnr.jpg?s=256",
                    "display_name": "rezam",
                    "link": "https://stackoverflow.com/users/2272992/rezam"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540209001,
                "post_id": 52928296,
                "comment_id": 92766477,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1540208861,
                "creation_date": 1540208861,
                "answer_id": 52928612,
                "question_id": 52928296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the keys are always in the same order, you could get away with:\r\n\r\n    jq -r &#39;[.[]]|@tsv&#39;\r\n\r\nIn any case, it would be preferable to use `@tsv`.",
                "title": "jq get all values in a tabbed format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1540208861,
        "creation_date": 1540207749,
        "question_id": 52928296,
        "body_markdown": "i&#39;m trying to convert a json to a tab formatted data:\r\n\r\n    {&quot;level&quot;:&quot;INFO&quot;, &quot;logger&quot;:&quot;db&quot;, &quot;msg&quot;:&quot;connection successful&quot;}\r\n    {&quot;level&quot;:&quot;INFO&quot;, &quot;logger&quot;:&quot;server&quot;, &quot;msg&quot;:&quot;server started&quot;}\r\n    {&quot;level&quot;:&quot;INFO&quot;, &quot;logger&quot;:&quot;server&quot;, &quot;msg&quot;:&quot;listening on port :4000&quot;}\r\n    {&quot;level&quot;:&quot;INFO&quot;, &quot;logger&quot;:&quot;server&quot;, &quot;msg&quot;:&quot;stopping s ervices ...&quot;}\r\n    {&quot;level&quot;:&quot;INFO&quot;, &quot;logger&quot;:&quot;server&quot;, &quot;msg&quot;:&quot;exiting...&quot;}\r\n\r\nto something like this:\r\n\r\n    INFO   db       connection successful\r\n    INFO   server   server started\r\n    INFO   server   listening on port 4000\r\n    DEBUG  server   stopping s ervices ...\r\n    INFO   server   exiting...\r\n\r\nI&#39;ve tried this `jq -r &#39; . | to_entries[] | &quot;\\(.value)&quot;&#39;`, but this prints each value on a separate line.",
        "link": "https://stackoverflow.com/questions/52928296/jq-get-all-values-in-a-tabbed-format",
        "title": "jq get all values in a tabbed format"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6146867,
                    "reputation": 1135,
                    "user_id": 4792552,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Znkzv.jpg?s=256",
                    "display_name": "Berkant İpek",
                    "link": "https://stackoverflow.com/users/4792552/berkant-%c4%b0pek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540211103,
                "post_id": 52929094,
                "comment_id": 92767666,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540211265,
                "post_id": 52929094,
                "comment_id": 92767764,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1540219321,
                "last_edit_date": 1540219321,
                "creation_date": 1540211313,
                "answer_id": 52929402,
                "question_id": 52929094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the entries are enclosed in an array, you can use this `jq` filter that gives all objects having `ROOFTOP` as `location`:\r\n\r\n    jq &#39;.[] | select(.geometry.location_type==&quot;ROOFTOP&quot;)&#39; file\r\n\r\nIf you want to select only the first one from all objects, use the following:\r\n\r\n    jq &#39;map(select(.geometry.location_type==&quot;ROOFTOP&quot;))|.[0]&#39; file\r\n\r\nAnd you only need need some of the values, pipe it another filter like this:\r\n\r\n    jq &#39;map(select(.geometry.location_type==&quot;ROOFTOP&quot;))|.[0]|.place_id, .formatted_address&#39; file",
                "title": "Json object selection"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1540287683,
                "last_edit_date": 1540287683,
                "creation_date": 1540219932,
                "answer_id": 52932190,
                "question_id": 52929094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than using `.[0]` to obtain the first object satisfying, it would be more efficient to use `first/1`.  Here is a solution using `first/1` and `..`:\r\n\r\n    $ jq &#39;first(..|objects|select(.geometry.location_type == &quot;ROOFTOP&quot;))\r\n          | {formatted_address, place_id}&#39; input.json\r\n    {\r\n      &quot;formatted_address&quot;: &quot;8 Rue Michelet, 34000 Montpellier, France&quot;,\r\n      &quot;place_id&quot;: &quot;ChIJ2UaGt6CvthIRJoNW7vS2Ibs&quot;\r\n    }\r\n\r\nUsing `first`in this way avoids having to compute the entire array before taking the first element.\r\n\r\n## Alternatively ...\r\n\r\nRetrieving the first top-level object, without using `..`:\r\n\r\n    first(.[] | select(.geometry.location_type==&quot;ROOFTOP&quot;))\r\n",
                "title": "Json object selection"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1540287683,
        "creation_date": 1540210403,
        "last_edit_date": 1540220000,
        "question_id": 52929094,
        "body_markdown": "I have a large JSON object returned from a Google Maps reverse geocode lookup.\r\nin this object there are many possible location details returned.\r\n\r\nUsing jq how do I select the first returned location with a location_type &quot;ROOFTOP&quot; and get the formatted_address and place_id ?\r\n\r\nin the below example the first entry has a location_type of &quot;GEOMETRIC_CENTER&quot;\r\nThe second entry has the &quot;ROOFTOP&quot; location_type. I want to ignore the entry with  &quot;GEOMETRIC_CENTER&quot; and only return the fist entry with location_type &quot;ROOFTOP&quot;\r\n\r\nMany thanks\r\nMike\r\n\r\n\r\n\r\n      [\r\n       {\r\n         &quot;address_components&quot;: [\r\n           {\r\n            &quot;long_name&quot;: &quot;30&quot;,\r\n            &quot;short_name&quot;: &quot;30&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;street_number&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;All&#233;e Jean de Lattre de Tassigny&quot;,\r\n            &quot;short_name&quot;: &quot;All&#233;e Jean de Lattre de Tassigny&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;route&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;Montpellier&quot;,\r\n            &quot;short_name&quot;: &quot;Montpellier&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;locality&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;H&#233;rault&quot;,\r\n            &quot;short_name&quot;: &quot;H&#233;rault&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;administrative_area_level_2&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;Occitanie&quot;,\r\n            &quot;short_name&quot;: &quot;Occitanie&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;administrative_area_level_1&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;France&quot;,\r\n            &quot;short_name&quot;: &quot;FR&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;country&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;34000&quot;,\r\n            &quot;short_name&quot;: &quot;34000&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;postal_code&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;formatted_address&quot;: &quot;30 All&#233;e Jean de Lattre de Tassigny, 34000 Montpellier, France&quot;,\r\n        &quot;geometry&quot;: {\r\n          &quot;bounds&quot;: {\r\n            &quot;northeast&quot;: {\r\n              &quot;lat&quot;: 43.6097932,\r\n              &quot;lng&quot;: 3.8817559\r\n            },\r\n            &quot;southwest&quot;: {\r\n              &quot;lat&quot;: 43.6094097,\r\n              &quot;lng&quot;: 3.881321299999999\r\n            }\r\n          },\r\n          &quot;location&quot;: {\r\n            &quot;lat&quot;: 43.6095516,\r\n            &quot;lng&quot;: 3.881559199999999\r\n          },\r\n          &quot;location_type&quot;: &quot;GEOMETRIC_CENTER&quot;,\r\n          &quot;viewport&quot;: {\r\n            &quot;northeast&quot;: {\r\n              &quot;lat&quot;: 43.6109504302915,\r\n              &quot;lng&quot;: 3.882887580291503\r\n            },\r\n            &quot;southwest&quot;: {\r\n              &quot;lat&quot;: 43.6082524697085,\r\n              &quot;lng&quot;: 3.880189619708498\r\n            }\r\n          }\r\n        },\r\n        &quot;place_id&quot;: &quot;ChIJ13k0paCvthIRcTgwBrisc10&quot;,\r\n        &quot;types&quot;: [\r\n          &quot;premise&quot;\r\n        ]\r\n       },\r\n       {\r\n        &quot;address_components&quot;: [\r\n          {\r\n            &quot;long_name&quot;: &quot;8&quot;,\r\n            &quot;short_name&quot;: &quot;8&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;street_number&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;Rue Michelet&quot;,\r\n            &quot;short_name&quot;: &quot;Rue Michelet&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;route&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;Montpellier&quot;,\r\n            &quot;short_name&quot;: &quot;Montpellier&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;locality&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;H&#233;rault&quot;,\r\n            &quot;short_name&quot;: &quot;H&#233;rault&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;administrative_area_level_2&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;Occitanie&quot;,\r\n            &quot;short_name&quot;: &quot;Occitanie&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;administrative_area_level_1&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;France&quot;,\r\n            &quot;short_name&quot;: &quot;FR&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;country&quot;,\r\n              &quot;political&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;long_name&quot;: &quot;34000&quot;,\r\n            &quot;short_name&quot;: &quot;34000&quot;,\r\n            &quot;types&quot;: [\r\n              &quot;postal_code&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;formatted_address&quot;: &quot;8 Rue Michelet, 34000 Montpellier, France&quot;,\r\n        &quot;geometry&quot;: {\r\n          &quot;location&quot;: {\r\n            &quot;lat&quot;: 43.60911189999999,\r\n            &quot;lng&quot;: 3.8814264\r\n          },\r\n          &quot;location_type&quot;: &quot;ROOFTOP&quot;,\r\n          &quot;viewport&quot;: {\r\n            &quot;northeast&quot;: {\r\n              &quot;lat&quot;: 43.61046088029149,\r\n              &quot;lng&quot;: 3.882775380291502\r\n            },\r\n            &quot;southwest&quot;: {\r\n              &quot;lat&quot;: 43.60776291970849,\r\n              &quot;lng&quot;: 3.880077419708498\r\n            }\r\n          }\r\n        },\r\n        &quot;place_id&quot;: &quot;ChIJ2UaGt6CvthIRJoNW7vS2Ibs&quot;,\r\n        &quot;plus_code&quot;: {\r\n          &quot;compound_code&quot;: &quot;JV5J+JH Montpellier, France&quot;,\r\n          &quot;global_code&quot;: &quot;8FM5JV5J+JH&quot;\r\n        },\r\n        &quot;types&quot;: [\r\n          &quot;street_address&quot;\r\n        ]\r\n       }\r\n      ]\r\n     \r\n\r\n",
        "link": "https://stackoverflow.com/questions/52929094/json-object-selection",
        "title": "Json object selection"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10537263,
                    "reputation": 562,
                    "user_id": 7764703,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/d00c6339c2c31065dbfaa5f79c22f8ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AG6HQ",
                    "link": "https://stackoverflow.com/users/7764703/ag6hq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540235116,
                "post_id": 52935977,
                "comment_id": 92781321,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1540235473,
                "last_edit_date": 1540235473,
                "creation_date": 1540235126,
                "answer_id": 52936178,
                "question_id": 52935977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your approach using multiple --arg flags can be made to work as illustrated below:\r\n\r\n    key1=Key1\r\n    subkey1=SubKey1\r\n    subkey2=SubKey2\r\n    value1=Value1\r\n    value2=Value1\r\n    \r\n    jq -n --arg key1 &quot;$key1&quot; --arg subkey1 &quot;$subkey1&quot; --arg subkey2 &quot;$subkey2&quot; --arg value1 &quot;$value1&quot; --arg value2 &quot;$value2&quot; &#39;\r\n    {\r\n       ($key1): {\r\n           ($subkey1): $value1,\r\n           ($subkey2): $value2\r\n        }\r\n    }\r\n    &#39;\r\n\r\n## Alternatively ...\r\n\r\n    .[$key1] = (.[$subkey1]=$value1 | .[$subkey2]=$value2)\r\n",
                "title": "JQ Create multi level json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1540235473,
        "creation_date": 1540234330,
        "question_id": 52935977,
        "body_markdown": "I am looking to create a JSON file from scratch that looks like this:\r\n\r\n    {\r\n       &quot;Key1&quot;: {\r\n          &quot;SubKey1&quot;: &quot;Value1&quot;,\r\n          &quot;SubKey2&quot;: &quot;Value2&quot;\r\n        }\r\n    }\r\n\r\nI have the following variables in my bash script:\r\n\r\n    $key1\r\n    $subkey1\r\n    $subkey2\r\n    $value1\r\n    $value2\r\n\r\nI have tried a couple of JQ without results:\r\n\r\n       jq --arg key1 $key1 \\\r\n      --arg subkey1 $subkey1 \\\r\n      --arg value1 $value1 \\\r\n      --arg subkey2 $subkey2 \\\r\n      --arg value2 $value2 \\\r\n      &#39;[$key1].[$subkey1]=$value1 | [$key1].[$subkey2]=$value2&#39; &lt;&lt;&lt;&#39;{}&#39;\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .[key1].[subkey1]=$value1 | .[key1].[subkey2]=$value2        \r\n    jq: 1 compile error\r\n\r\n        jq --arg key1 $key1 \\\r\n       --arg subkey1 $subkey1 \\\r\n       --arg value1 $value1 \\\r\n       --arg subkey2 $subkey2 \\\r\n       --arg value2 $value2 \\\r\n       &#39;.$key1 | .[$subkey1]=$value1 | .[$subkey2]=$value2&#39; &lt;&lt;&lt;&#39;{}&#39;\r\n    {\r\n      &quot;SubKey1&quot;: &quot;Value1&quot;,\r\n      &quot;SubKey2&quot;: &quot;Value2&quot;\r\n    }\r\n\r\n\r\nBut I don&#39;t get the correct results.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52935977/jq-create-multi-level-json",
        "title": "JQ Create multi level json"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540319019,
                "post_id": 52953911,
                "comment_id": 92818714,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1540327147,
                "last_edit_date": 1540327147,
                "creation_date": 1540326774,
                "answer_id": 52957435,
                "question_id": 52953911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will return the `Name` and `Type` attributes of each entry. \r\n\r\n       aws route53 .... | jq &#39;.ResourceRecordSets[] | [.Name, .Type]&#39;",
                "title": "how to output only records with CNAME and A from AWS cli with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1540327147,
        "creation_date": 1540312500,
        "question_id": 52953911,
        "body_markdown": "I have the following query:\r\n\r\n    aws route53 list-resource-record-sets --hosted-zone-id ZJDMYXXXX --profile london | jq &quot;.ResourceRecordSets[].Type&quot;\r\n\r\nwhich returns as expected \r\n\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;A&quot;\r\n    &quot;CNAME&quot;\r\n    &quot;CNAME&quot;\r\n    ...\r\n\r\nbut how do I also return the `Name` from the output, which is something like:\r\n\r\n\r\n    {\r\n        &quot;ResourceRecordSets&quot;: [\r\n    \r\n            {\r\n                &quot;ResourceRecords&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;123.123.123.123&quot;\r\n                    }\r\n                ],\r\n                &quot;TTL&quot;: 21600,\r\n                &quot;Type&quot;: &quot;A&quot;,\r\n                &quot;Name&quot;: &quot;www.domain.tld.&quot;\r\n            },\r\n    ...\r\n        ]\r\n    }\r\n\r\nAny advice is much appreciated",
        "link": "https://stackoverflow.com/questions/52953911/how-to-output-only-records-with-cname-and-a-from-aws-cli-with-jq",
        "title": "how to output only records with CNAME and A from AWS cli with jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6774888,
                    "reputation": 410,
                    "user_id": 10549044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb4ba565bc09a2b1d3915fc99a6d6099?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ma7555",
                    "link": "https://stackoverflow.com/users/10549044/ma7555"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540339204,
                "post_id": 52959216,
                "comment_id": 92825815,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1540338901,
                "creation_date": 1540338901,
                "answer_id": 52959288,
                "question_id": 52959216,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could write:\r\n\r\n    .[$servername] | .port\r\n\r\nor simply:\r\n\r\n    .[$servername].port",
                "title": "Passing bash shell variable to jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1540338901,
        "creation_date": 1540338301,
        "question_id": 52959216,
        "body_markdown": "Trying to pass a bash shell variable into a jq filter\r\n\r\nJSON:\r\n\r\n    {\r\n    &quot;server1&quot;: {\r\n    &quot;port&quot;: 3333,\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;timesincelast&quot;: 248054\r\n    },\r\n    &quot;server2&quot;: {\r\n    &quot;port&quot;: 4444,\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;timesincelast&quot;: 248054\r\n      }\r\n      }\r\nBash command trying to execute:\r\n\r\n     servername=&#39;server1&#39;\r\n     jq --arg servername &quot;$servername&quot; &#39;.$servername .port&#39;\r\n\r\nBut getting an error\r\n\r\n     jq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at \r\n    &lt;top-level&gt;, line 1:\r\n\r\nBut direct substitution works \r\n\r\n    jq &#39;.server1 .port&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52959216/passing-bash-shell-variable-to-jq-filter",
        "title": "Passing bash shell variable to jq filter"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "keyvaluepair"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540377520,
                "post_id": 52964732,
                "comment_id": 92840023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6436047,
                    "reputation": 25,
                    "user_id": 4987569,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0f440b4a433e8de8177c2d003848f849?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sillydeedee",
                    "link": "https://stackoverflow.com/users/4987569/sillydeedee"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540381476,
                "post_id": 52964732,
                "comment_id": 92842477,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540412412,
                "post_id": 52964732,
                "comment_id": 92861149,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1540414325,
                "last_edit_date": 1540414325,
                "creation_date": 1540372778,
                "answer_id": 52965326,
                "question_id": 52964732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, when specifying a key name using a variable in the way you are doing, the variable must be parenthesized, so you would have:\r\n\r\n     {($bundle_release): ...}\r\n\r\nNext, jq variables are not the same as shell variables and should be specified without quoting them, and without using bash-isms. \r\n\r\nThird, when setting the value of the shell variable named `value`, you would have to quote the expression appropriately.\r\n\r\nFourth, to simplify things, use `--argjson` for `$value`.\r\n\r\nFifth, your sample JSON is not quite right.  Once it&#39;s fixed, the following will work in a bash or bash-like environment (assuming you&#39;re using a version of jq that supports `--argjson`):\r\n\r\n    bundle_release=&quot;1034,567&quot;\r\n    value=&#39;{&quot;release&quot;:&quot;2018.1006&quot;,&quot;kernel&quot;:&quot;2.6.32-754.3.5.el6.x86_64&quot;,&quot;os&quot;:&quot;6.10&quot;,&quot;current&quot;:true}&#39;\r\n\r\n    jq --arg b &quot;$bundle_release&quot; --argjson v &quot;$value&quot;  &#39;\r\n      . + {($b): $v}&#39; &lt;&lt;&lt; &quot;$version6json&quot;\r\n\r\n",
                "title": "Dynamically add key value pair in jSON object using shell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1540377533,
                "last_edit_date": 1592644375,
                "creation_date": 1540377533,
                "answer_id": 52966869,
                "question_id": 52964732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re not giving the `--arg` option enough parameters: from the manual: \n\n&gt;    `--arg name value`:\n&gt;\n&gt;&gt;    This option passes a value to the jq program as a predefined variable. If you run jq with `--arg foo bar`, then\n        `$foo`  is  available  in  the program and has the value `&quot;bar&quot;`. Note that value will be treated as a string, so\n        `--arg foo 123` will bind `$foo` to `&quot;123&quot;`.\n",
                "title": "Dynamically add key value pair in jSON object using shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1540414325,
        "creation_date": 1540371181,
        "last_edit_date": 1540408633,
        "question_id": 52964732,
        "body_markdown": "I have a json object named `version6json` as follows \r\n\r\n    {\r\n      &quot;20007.098&quot;: {\r\n        &quot;os_version&quot;: &quot;6.9&quot;,\r\n        &quot;kernel&quot;: &quot;2.6.32-696&quot;,\r\n        &quot;sfdc-release&quot;: &quot;2017.08&quot;\r\n      },\r\n      &quot;200907.09678”: {\r\n        &quot;os_version&quot;: &quot;6.9&quot;,\r\n        &quot;kernel&quot;: &quot;2.6.32-696&quot;,\r\n        &quot;sfdc-release&quot;: &quot;201.7909&quot;\r\n      },\r\n      &quot;206727.1078”: {\r\n        &quot;os_version&quot;: &quot;6.9&quot;,\r\n        &quot;kernel&quot;: &quot;2.6.32-696.10.2.el6.x86_64&quot;,\r\n        &quot;sfdc-release&quot;: &quot;20097.109”\r\n      }\r\n    }\r\n\r\nI want to add one more key value pair. The key is also a variable and the value too. bundle_release=&quot;2019.78&quot; and value= {&quot;release&quot;:&quot;2018.1006&quot;,&quot;kernel&quot;:&quot;2.6.32-754.3.5.el6.x86_64&quot;,&quot;os&quot;:&quot;6.10&quot;,&quot;current&quot;:true}\r\n Now I want the bundle_release as key and value as its value, So the new entry would be &quot;2018.1006&quot;: {&quot;release&quot;:&quot;2018.1006&quot;,&quot;kernel&quot;:&quot;2.6.32-754.3.5.el6.x86_64&quot;,&quot;os&quot;:&quot;6.10&quot;,&quot;current&quot;:true}\r\n\r\nTo achieve this, I am doing the folllowing\r\n\r\n    echo &quot;$version6json&quot; | jq --arg &quot;$bundle_release&quot; &quot;$value&quot; &#39;. + {$bundle_release: &quot;${value}&quot;}&#39;\r\n    \r\nAny help will be appriciated.\r\n\r\n\r\nP.S- The question is edited as suggested by peak\r\n      \r\n\r\n",
        "link": "https://stackoverflow.com/questions/52964732/dynamically-add-key-value-pair-in-json-object-using-shell",
        "title": "Dynamically add key value pair in jSON object using shell"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540421362,
                "post_id": 52978489,
                "comment_id": 92864333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1540421237,
                "last_edit_date": 1540421237,
                "creation_date": 1540419724,
                "answer_id": 52978703,
                "question_id": 52978489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you haven&#39;t given an example showing the output format you want, all I can suggest is the following:\r\n\r\n    .result.spaces[].priceschema.prices[]\r\n    | {price: .}\r\n    | select((.price.costs? | length) &gt; 1)\r\n\r\nHopefully this will direct you towards the answer you&#39;re looking for.\r\n\r\n",
                "title": "Extract JSON array based on subarray length?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1540421237,
        "creation_date": 1540418447,
        "last_edit_date": 1540418829,
        "question_id": 52978489,
        "body_markdown": "Given\r\n\r\n    {\r\n    \t&quot;result&quot;: {\r\n    \t\t&quot;spaces&quot;: [{\r\n    \t\t\t&quot;priceschema&quot;: {\r\n    \t\t\t\t&quot;prices&quot;: [{\r\n    \t\t\t\t\t&quot;costs&quot;: [{\r\n    \t\t\t\t\t\t&quot;amount&quot;: &quot;3&quot;\r\n    \t\t\t\t\t}]\r\n    \t\t\t\t}]\r\n    \t\t\t}\r\n    \t\t}]\r\n    \t}\r\n    }\r\n\r\nI&#39;d like to display all `prices` that have more than one costs. I came up with the following jq query, but it returns all costs, even the ones with a single element.\r\n\r\n    {price: .result.spaces[].priceschema.prices[]?} | select((.price.costs[] | length) &gt; 1)\r\n\r\nNote that `prices` or `costs` may not be present.",
        "link": "https://stackoverflow.com/questions/52978489/extract-json-array-based-on-subarray-length",
        "title": "Extract JSON array based on subarray length?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1540478388,
                "last_edit_date": 1540478388,
                "creation_date": 1540477474,
                "answer_id": 52991670,
                "question_id": 52991305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not an expert on jq, but here is what I&#39;ve come up with:\r\n\r\n    jq --arg k a --argfile file2 file2.json &#39;with_entries(.key |= $file2[.][$k])&#39; file1.json &gt; out_a.json\r\n\r\nChange `--arg k a` and `out_a.json` for other keys and output files.\r\n",
                "title": "JQ: Replace keys with corresponding value in another file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540540712,
                "last_edit_date": 1540540712,
                "creation_date": 1540480320,
                "answer_id": 52992677,
                "question_id": 52991305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have more than a trivial number of keys &quot;a&quot;, &quot;b&quot;, ..., and if you don&#39;t mind if the output files are minified, you could avoid the multiple calls to jq using the approach illustrated here:\r\n\r\n    &lt; file1.json jq -rc --argjson keys &#39;[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]&#39; --argfile file2 &lt;(file2) &#39;\r\n      $keys[] as $k \r\n      | ($k, (with_entries(.key |= $file2[.][$k]) ))\r\n    &#39; | awk &#39;file {print &gt; file &quot;.json&quot;; file=0; next} {file=$0}&#39;\r\n\r\nYou could go one step further and compute `$keys` programatically using (for example):\r\n\r\n       [$file2[]][0]|keys_unsorted",
                "title": "JQ: Replace keys with corresponding value in another file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540538763,
                "last_edit_date": 1540538763,
                "creation_date": 1540485599,
                "answer_id": 52994255,
                "question_id": 52991305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How do I handle the scenario where the key from File 1 might not exist in File 2, resulting in the &quot;Cannot use null (null) as object key&quot;?\r\n\r\nThe most obvious thing to do would probably be to test whether the object has the key:\r\n\r\n    with_entries(.key |= (if $file2[.]|has($k) then $file2[.][$k]  else . end))",
                "title": "JQ: Replace keys with corresponding value in another file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1540540712,
        "creation_date": 1540476289,
        "last_edit_date": 1540480459,
        "question_id": 52991305,
        "body_markdown": "I&#39;m trying to replace the value of a key in my original JSON with the value of an object with the corresponding key in another document.\r\n\r\nThese are my two files:\r\nFile 1:\r\n\r\n    {\r\n        &quot;-KaM0otlgWxXniYiacFe&quot;: {\r\n            &quot;-LNxx1IiX6oYTxJ4IXx2&quot;: true\r\n        },\r\n        &quot;-KlJTvbfonIMI_-YfS5R&quot;: {\r\n            &quot;-LNxx1IbaB-yrZ623hrX&quot;: true\r\n        }\r\n    }\r\n\r\nFile 2:\r\n\r\n    {\r\n        &quot;-KaM0otlgWxXniYiacFe&quot;: {\r\n            &quot;a&quot;: &quot;-L-b__nH9PlMcz0stDDE&quot;,\r\n            &quot;b&quot;: &quot;-L7ZNKSZy570TlrQUzHM&quot;,\r\n            &quot;c&quot;: &quot;-Kaae3MsQUyViCKPs8Iv&quot;\r\n        },\r\n        &quot;-KlJTvbfonIMI_-YfS5R&quot;: {\r\n            &quot;a&quot;: &quot;-LAlXKfUUTdYDeCZH-u-&quot;,\r\n            &quot;b&quot;: &quot;-L7ZNKSTnob7w0HXjHr6&quot;,\r\n        &quot;    c&quot;: &quot;-KYYicPD7VA9DEF_rus3&quot;\r\n        }\r\n    }\r\n\r\n\r\nThe goal is to create 3 new files, where the original keys have been replaced with the value of a, b and c in each file.\r\n\r\nDesired result when looking against &quot;a&quot;:\r\n\r\n    {\r\n        &quot;-L-b__nH9PlMcz0stDDE&quot;: {\r\n            &quot;-LNxx1IiX6oYTxJ4IXx2&quot;: true\r\n        },\r\n        &quot;-LAlXKfUUTdYDeCZH-u-&quot;: {\r\n            &quot;-LNxx1IbaB-yrZ623hrX&quot;: true\r\n        }\r\n    }\r\n\r\nI have tried using something along the lines of:\r\n\r\n    cat file1.json | jq --slurpfile file2 file2.json &#39;| map(with_entries(.key = .file2[.key].a&#39;\r\n\r\nBut I&#39;m feeling rather clueless as I havn&#39;t used jq before.\r\n\r\nAny help is appreciated.\r\n\r\n\r\n**Update:**\r\n\r\nHow do I handle the scenario where the key from File 1 might not exist in File 2, resulting in the &quot;Cannot use null (null) as object key&quot;?\r\n",
        "link": "https://stackoverflow.com/questions/52991305/jq-replace-keys-with-corresponding-value-in-another-file",
        "title": "JQ: Replace keys with corresponding value in another file"
    },
    {
        "tags": [
            "json",
            "bash",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540480888,
                "last_edit_date": 1540480888,
                "creation_date": 1540480577,
                "answer_id": 52992771,
                "question_id": 52992608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, you will almost certainly want to use the `-n` command-line option; second, `module` is a keyword and so cannot be used as a $-variable name.  But:\r\n\r\n\r\n    jq -n --arg m themodule --arg version &quot;3.0&quot; &#39;\r\n      {require: { ($m): $version} }&#39; \r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;require&quot;: {\r\n        &quot;themodule&quot;: &quot;3.0&quot;\r\n      }\r\n    }\r\n\r\nThe trick here is to enclose the expression specifying the key-name in parentheses.",
                "title": "Write jq file with key value on sub object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1540480888,
        "creation_date": 1540480134,
        "last_edit_date": 1540480672,
        "question_id": 52992608,
        "body_markdown": "I want to create a Json file (Composer) with JQ from nothing.\r\nMy objective is to set module and version from args passed in jq command\r\n\r\n    {\r\n        &quot;require&quot; : {\r\n    \t    &quot;mymodule&quot;: &quot;myversion&quot;\r\n       }\r\n    }\r\n\r\nI tried something like this and I don&#39;t understand why it&#39;s not correct.\r\n\r\n    jq --arg module &quot;themodule&quot; --arg version &quot;3.0&quot; &#39;{.require.($module):$version}&#39; \r\n\r\nThanks for your help",
        "link": "https://stackoverflow.com/questions/52992608/write-jq-file-with-key-value-on-sub-object",
        "title": "Write jq file with key value on sub object"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5311603,
                    "reputation": 52689,
                    "user_id": 4237701,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/oAvgY.jpg?s=256",
                    "display_name": "helloV",
                    "link": "https://stackoverflow.com/users/4237701/hellov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540496607,
                "post_id": 52995690,
                "comment_id": 92898802,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1540496785,
                "creation_date": 1540496785,
                "answer_id": 52996983,
                "question_id": 52995690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .Tags[]\r\n    | select(.Key == &quot;Application&quot;)\r\n    | &quot;\\(.Key) : \\(.Value)&quot;\r\n\r\n",
                "title": "How to filter key and value using jq filter in bash"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1540497046,
                "creation_date": 1540497046,
                "answer_id": 52997040,
                "question_id": 52995690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution without using `jq`\r\n\r\n    aws ec2 describe-tags   --filter &quot;Name=resource-id,Values=i-8dh7435490fjksfd&quot; --query &#39;Tags[?Key==`Application`].Value[]&#39; --output text",
                "title": "How to filter key and value using jq filter in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1540715089,
                "creation_date": 1540715089,
                "answer_id": 53029629,
                "question_id": 52995690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get it in this way with using jq. Putting parentheses around the key means it will be evaluated as an expression.\r\n\r\n    cat example.json | jq &#39;.[] | {(.[].Key): (.[].Value)}&#39;\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;Environment&quot;: &quot;production&quot;\r\n    }\r\n    {\r\n      &quot;Environment&quot;: &quot;webserver&quot;\r\n    }\r\n    {\r\n      &quot;Application&quot;: &quot;production&quot;\r\n    }\r\n    {\r\n      &quot;Application&quot;: &quot;webserver&quot;\r\n    }\r\n\r\nRef: https://stedolan.github.io/jq/manual/",
                "title": "How to filter key and value using jq filter in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1540715089,
        "creation_date": 1540491444,
        "last_edit_date": 1540587936,
        "question_id": 52995690,
        "body_markdown": "After running the following command\r\n\r\n`aws ec2 describe-tags   --filter &quot;Name=resource-id,Values=i-8dh7435490fjksfd&quot;`\r\n\r\nI have the following JSON output\r\n\r\n    {\r\n        &quot;Tags&quot;: [\r\n            {\r\n                &quot;ResourceType&quot;: &quot;instance&quot;, \r\n                &quot;ResourceId&quot;: &quot;i-8dh7435490fjksfd&quot;, \r\n                &quot;Value&quot;: &quot;production&quot;, \r\n                &quot;Key&quot;: &quot;Environment&quot;\r\n            }, \r\n            {\r\n                &quot;ResourceType&quot;: &quot;instance&quot;, \r\n                &quot;ResourceId&quot;: &quot;i-8dh7435490fjksfd&quot;, \r\n                &quot;Value&quot;: &quot;webserver&quot;, \r\n                &quot;Key&quot;: &quot;Application&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nHow do i get the following output using jq filter \r\n\r\nApplication : webserver\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52995690/how-to-filter-key-and-value-using-jq-filter-in-bash",
        "title": "How to filter key and value using jq filter in bash"
    },
    {
        "tags": [
            "json",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6497421,
                    "reputation": 11,
                    "user_id": 5029573,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10152804562956086/picture?type=large",
                    "display_name": "George R Malary",
                    "link": "https://stackoverflow.com/users/5029573/george-r-malary"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540504868,
                "post_id": 52997801,
                "comment_id": 92902013,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540500986,
                "last_edit_date": 1540500986,
                "creation_date": 1540500686,
                "answer_id": 52997927,
                "question_id": 52997801,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You almost got it but you can do this without a loop with this line:\r\n\r\n    $ echo &#39;{&quot;KNOCK_KNOCK&quot;: &quot;Who is there?&quot;}&#39; | jq -r &#39;to_entries[] | .key + &quot;=\\&quot;&quot; + (.value|tostring) + &quot;\\&quot;&quot;&#39;\r\n    KNOCK_KNOCK=&quot;Who is there?&quot;\r\n\r\n## Explanation\r\n\r\n`to_entries` transforms your object to an array of objects like this:\r\n\r\n    $ echo &#39;{&quot;KNOCK_KNOCK&quot;: &quot;Who is there?&quot;}&#39; | jq -r &#39;to_entries&#39;                   \r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;KNOCK_KNOCK&quot;,\r\n        &quot;value&quot;: &quot;Who is there?&quot;\r\n      }\r\n    ]\r\n\r\nYou can then take each array element with the `[]` and use the `key` and `value` field to do simple string concatenation using the `+` operator.",
                "title": "Use jq to parse json into environment variable format"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1540675760,
                "last_edit_date": 1540675760,
                "creation_date": 1540501901,
                "answer_id": 52998185,
                "question_id": 52997801,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possibilities:\r\n\r\n    jq -r &#39;to_entries[] | [.key,.value] | join(&quot;=&quot;)&#39; &lt;&lt;&lt; &quot;$TEST_FILE&quot;\r\n\r\nIt would probably be advisable to use `@sh` as well:\r\n\r\n    $ echo $&#39;{&quot;KNOCK_KNOCK&quot;: &quot;Who \\&#39;is\\&#39; there?&quot;}&#39;\r\n      | jq -r &#39;to_entries[] | [.key,(.value|@sh)] | join(&quot;=&quot;)&#39;\r\n    KNOCK_KNOCK=&#39;Who &#39;\\&#39;&#39;is&#39;\\&#39;&#39; there?&#39;\r\n    \r\n    $ KNOCK_KNOCK=&#39;Who &#39;\\&#39;&#39;is&#39;\\&#39;&#39; there?&#39;\r\n    $ echo &quot;$KNOCK_KNOCK&quot;\r\n    Who &#39;is&#39; there?\r\n    $ \r\n\r\nNote also that if you are going to use `$TEST_FILE`, the double-quotes might be necessary.",
                "title": "Use jq to parse json into environment variable format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1540675760,
        "creation_date": 1540500135,
        "last_edit_date": 1540506871,
        "question_id": 52997801,
        "body_markdown": "I would like to below code to output  \r\n`KNOCK_KNOCK=&quot;Who is there?&quot;`\r\n\r\n\r\n    TEST_FILE=&#39;{\r\n      &quot;KNOCK_KNOCK&quot;: &quot;Who is there?&quot;\r\n    }&#39;\r\n    for s in $(echo $TEST_FILE | jq -r &quot;to_entries|map(\\&quot;\\ \r\n    (.key)=\\(.value|tostring)\\&quot;)|.[]&quot; ); do\r\n        echo $s\r\n    done\r\n   \r\nI got the loop from this post: https://stackoverflow.com/questions/48512914/exporting-json-to-environment-variables\r\n\r\nand cannot figure out how to modify to get my expected output.  The problem seems to be the spaces in the .value\r\n\r\nFor the following test case I get the expected results:\r\n\r\n    TEST_FILE=&#39;{\r\n      &quot;KNOCK_KNOCK&quot;: &quot;Whoisthere?&quot;,\r\n      &quot;POSTGRES_URI&quot;: &quot;postgress://user:pass@testdb.com&quot;,\r\n      &quot;WILL&quot;: &quot;I.AM&quot;\r\n    }&#39;\r\n    for s in $(echo $TEST_FILE | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\ \r\n    (.value|tostring)\\&quot;)|.[]&quot; ); do\r\n        echo $s\r\n    done\r\n\r\n    KNOCK_KNOCK=Whoisthere?\r\n    POSTGRES_URI=postgress://user:pass@testdb.com\r\n    WILL=I.AM\r\n\r\n\r\n---\r\n\r\nI went with the following solution, which works for me, but the accepted answer is ok.\r\n\r\n    TEST_FILE=&#39;{\r\n      &quot;KNOCK_KNOCK&quot;: &quot;Who is there?&quot;\r\n    }&#39;\r\n    echo $TEST_FILE | sed &#39;s_[{}]__&#39;| sed &#39;s_: _=_&#39; | sed &#39;s_  _export _&#39;",
        "link": "https://stackoverflow.com/questions/52997801/use-jq-to-parse-json-into-environment-variable-format",
        "title": "Use jq to parse json into environment variable format"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1540819587,
                "creation_date": 1540819587,
                "answer_id": 53046501,
                "question_id": 53046253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this `jq` filter:\r\n\r\n    jq &#39;.data.items|=map(select(.name|endswith(&quot;1&quot;)|not))&#39; file\r\n\r\nThis replace `.data.items` with the a new array having objects whose `name`s don&#39;t end with `1`.",
                "title": "How to delete array elements that end with 1?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1540822912,
                "last_edit_date": 1592644375,
                "creation_date": 1540822912,
                "answer_id": 53047538,
                "question_id": 53046253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Your attempt will work with recent versions of jq (that is, more recent than version 1.5).\n\n2. Yet another variant (perhaps the most concise robust alternative):\n\n   `.data.items|=map(select(.name|test(&quot;[^1]$&quot;)))`\n",
                "title": "How to delete array elements that end with 1?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1540822912,
        "creation_date": 1540818739,
        "question_id": 53046253,
        "body_markdown": "I need to remove all array elements that have the `name` field ending with `1`. \r\n\r\n**Input:**\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;code&quot;: &quot;abc123&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;exp1&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;exp2&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;exp11&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n**Desired output:**\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;code&quot;: &quot;abc123&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;exp2&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\n----------\r\n\r\n\r\n**My attempt:**\r\n\r\n    jq &#39;del(.data.items[] | select(.name | endswith(&quot;1&quot;)))&#39; input\r\n\r\nWhich results in `Invalid path expression`.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53046253/how-to-delete-array-elements-that-end-with-1",
        "title": "How to delete array elements that end with 1?"
    },
    {
        "tags": [
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 955087,
                    "reputation": 58464,
                    "user_id": 980550,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://i.sstatic.net/8emhY.jpg?s=256",
                    "display_name": "lurker",
                    "link": "https://stackoverflow.com/users/980550/lurker"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1540846837,
                "post_id": 53053691,
                "comment_id": 93007060,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 955087,
                    "reputation": 58464,
                    "user_id": 980550,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://i.sstatic.net/8emhY.jpg?s=256",
                    "display_name": "lurker",
                    "link": "https://stackoverflow.com/users/980550/lurker"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1540847316,
                "post_id": 53053691,
                "comment_id": 93007258,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1619971625,
                "post_id": 53053691,
                "comment_id": 119058763,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1540847240,
                "creation_date": 1540847240,
                "answer_id": 53053834,
                "question_id": 53053691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do \r\n\r\n    sed &#39;s/[,&quot;]//g&#39; \r\n\r\ninstead of two seds (if that&#39;s even a word)",
                "title": "Combine sed commands into one command in bash script"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1540848281,
                "last_edit_date": 1540848281,
                "creation_date": 1540847517,
                "answer_id": 53053898,
                "question_id": 53053691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you really want to, this combines the functionality of all your `sed` and `grep` lines:\r\n\r\n    sed -n &#39;s/arn:aws:iam::123456789101:user\\///g; s/[,&quot;]//g; /tdunphy/ {p}&#39;\r\n\r\nWhether that counts as an improvement is somewhat in the eye of the beholder.",
                "title": "Combine sed commands into one command in bash script"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1540904050,
                "last_edit_date": 1540904050,
                "creation_date": 1540847620,
                "answer_id": 53053911,
                "question_id": 53053691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Change your call to `jq` to look like this and then you don&#39;t have to strip the other characters:\r\n\r\n    jq -r &#39;.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[]&#39;\r\n                                                                   ^^ Add these\r\n\r\nYou could try this also:\r\n\r\n    aws iam get-role --role-name rl-company-admin --profile=company-bill | \\\r\n      jq -r &#39;.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | split(&quot;/&quot;) | last&#39; | \\\r\n      grep tdunphy\r\n\r\nThis might be a bit terse, but you can do it all with one `jq` call:\r\n\r\n    jq -r &#39;[.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | split(&quot;/&quot;) | last] | map(select(. == &quot;tdunphy&quot;))[]&#39;",
                "title": "Combine sed commands into one command in bash script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1540872020,
                "last_edit_date": 1540872020,
                "creation_date": 1540847831,
                "answer_id": 53053956,
                "question_id": 53053691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace\r\n\r\n    sed &quot;s/arn:aws:iam::123456789101:user\\///g&quot; |\r\n    grep tdunphy |\r\n    sed &#39;s/&quot;//g&#39;|\r\n    sed &#39;s/,//g&#39;\r\n\r\nwith\r\n\r\n    sed -n &#39;/tdunphy/ {\r\n            s/arn:aws:iam::123456789101:user\\///g\r\n            s/[,&quot;]//g\r\n            p\r\n         &#39;\r\n",
                "title": "Combine sed commands into one command in bash script"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1540907901,
                "last_edit_date": 1540907901,
                "creation_date": 1540848759,
                "answer_id": 53054143,
                "question_id": 53053691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It can be done in **single `jq`** command like this this avoiding invoking multiple external commands e.g. `grep`, `sed` etc:\r\n\r\n    aws iam get-role --role-name rl-company-admin --profile=company-bill |\r\n    jq --arg u &#39;tdunphy&#39; -r &#39;\r\n     .Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] |\r\n     select(. | endswith($u)) | sub(&quot;arn:aws:iam::123456789101:user/&quot;; &quot;&quot;)&#39;\r\n\r\n&lt;p/&gt;\r\n\r\n**Output:**\r\n\r\n    tdunphy\r\n",
                "title": "Combine sed commands into one command in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1540907901,
        "creation_date": 1540846642,
        "last_edit_date": 1540907552,
        "question_id": 53053691,
        "body_markdown": "I&#39;d like to improve this line:\r\n\r\n    aws_iam_role=$(aws iam get-role --role-name rl-company-admin --profile=company-bill |\r\n    jq -r &#39;.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS&#39; |\r\n    sed &quot;s/arn:aws:iam::123456789101:user\\///g&quot; |\r\n    grep tdunphy |\r\n    sed &#39;s/&quot;//g&#39;|\r\n    sed &#39;s/,//g&#39;)\r\n\r\nThis is the raw output of the command with no processing:\r\n\r\n    aws iam get-role --role-name rl-company-admin --profile=company-bill\r\n    {\r\n        &quot;Role&quot;: {\r\n            &quot;Description&quot;: &quot;company Admin Role&quot;, \r\n            &quot;AssumeRolePolicyDocument&quot;: {\r\n                &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                &quot;Statement&quot;: [\r\n                    {\r\n                        &quot;Action&quot;: &quot;sts:AssumeRole&quot;, \r\n                        &quot;Effect&quot;: &quot;Allow&quot;, \r\n                        &quot;Principal&quot;: {\r\n                            &quot;AWS&quot;: [\r\n                                &quot;arn:aws:iam::123456789101:user/tdunphy&quot;, \r\n                                &quot;arn:aws:iam::123456789101:user/user1&quot;, \r\n                                &quot;arn:aws:iam::123456789101:user/user2&quot;, \r\n                                &quot;arn:aws:iam::123456789101:user/user3&quot;, \r\n                            ]\r\n                        }\r\n                    }\r\n                ]\r\n            }, \r\n            &quot;MaxSessionDuration&quot;: 3600, \r\n            &quot;RoleId&quot;: &quot;AROAJGNAT3IXV7DIWSDCK&quot;, \r\n            &quot;CreateDate&quot;: &quot;2018-01-18T17:35:27Z&quot;, \r\n            &quot;RoleName&quot;: &quot;rl-company-admin&quot;, \r\n            &quot;Path&quot;: &quot;/&quot;, \r\n            &quot;Arn&quot;: &quot;arn:aws:iam::188087670762:role/rl-company-admin&quot;\r\n        }\r\n    }\r\n\r\nHow can I use one sed statement to process this text instead of using multiple sed statements?",
        "link": "https://stackoverflow.com/questions/53053691/combine-sed-commands-into-one-command-in-bash-script",
        "title": "Combine sed commands into one command in bash script"
    },
    {
        "tags": [
            "amazon-web-services",
            "ansible",
            "terraform",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1540862355,
                "creation_date": 1540862355,
                "answer_id": 53056069,
                "question_id": 53055418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, jq&#39;s `-r` option will remove the outermost quotation marks from JSON string outputs.\r\n\r\nSecond, the following jq filter, used in conjunction with the aforementioned `-r` option, should be sufficient to achieve your goals, though it&#39;s hard to verify since you haven&#39;t provided an [MCVE][1]:\r\n\r\n    .Reservations[].Instances[].PublicIpAddress\r\n    | &quot;inst&quot; + . + &quot; ansible_ssh_hosts=&quot; + . + &quot; ansible_ssh_user=ubuntu&quot;\r\n\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "Cleaner way to use jq selection"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1540890312,
                "creation_date": 1540890312,
                "answer_id": 53060702,
                "question_id": 53055418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure why you&#39;re setting an Ansible inventory name that includes the IP address as this seems pretty pointless to me as it doesn&#39;t give it a human readable name or add anything useful compared to just using the IP address.\r\n\r\nIf you&#39;re happy with ditching that requirement then in reality you can just use the [`query` option of the AWS CLI][1] and ditch `jq` and your formatting:\r\n\r\n    cat &lt;&lt;EOF &gt; hosts-file.ini\r\n    [all:vars]\r\n    ansible_ssh_user=ubuntu\r\n    \r\n    [all]\r\n    EOF\r\n    aws ec2 describe-instances --query &#39;Reservations[*].Instances[*].PublicIpAddress&#39; --output text &gt;&gt; hosts-file.ini\r\n\r\nThis will set some inline vars at the all level to set the SSH user to be `ubuntu` and then dump all of the EC2 instance&#39;s public IP addresses under the `all` block.\r\n\r\n\r\n  [1]: https://docs.aws.amazon.com/cli/latest/userguide/controlling-output.html#controlling-output-filter",
                "title": "Cleaner way to use jq selection"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1540890312,
        "creation_date": 1540856463,
        "question_id": 53055418,
        "body_markdown": "The background of my question is loaded; but I&#39;d like to focus on just the `jq` portion in this current piece (although if you could help in its entirety, it&#39;d be so very much welcomed and appreciated).\r\n\r\nI have a Terraform spec that I&#39;ve successfully applied to create an autoscaling group in AWS (re: Terraform provisioning I will ask on a separate question, if perhaps there&#39;s a better way than what I&#39;m doing). I had wanted to run some provisioning in each of the produced instances, and in so doing, I decided to couple it with an `ansible` command.\r\n\r\nAnsible, as you may know, runs on inventory/host file. Consequently, I&#39;d have to update my host file each time AWS scales up or down in order to successfully run the following ansible ad-hoc command `ansible -i ./myansible.hostfile myawsinstances -a &quot;reprovisioning_command&quot;` (which itself has a different set of issues, tbd.)\r\n\r\nOn the part of creating the ansible host file, I got what I needed using the following command:\r\n\r\n**command sample 1**\r\n\r\n    aws ec2 describe-instances | jq .Reservations[].Instances[].PublicIpAddress | sed &#39;s/&quot;//g&#39; | awk &#39;{print &quot;inst&quot;$1 &quot; ansible_ssh_host=&quot;$1 &quot; ansible_ssh_user=ubuntu&quot;}&#39; &gt; myansible.hostfile\r\n    \r\n\r\n**output sample 1 in `myansible.hostfile`**\r\n\r\n    inst[ip_no1] ansible_ssh_host=[ip_no1] ansible_ssh_user=ubuntu\r\n    inst[ip_no2] ansible_ssh_host=[ip_no2] ansible_ssh_user=ubuntu\r\n\r\nIt seems to me rather long and somewhat convoluted.\r\n\r\nIf I were to just use `jq` alone along with its string operation facilities, such as:\r\n\r\n**command sample 2**\r\n\r\n    aws ec2 describe-instances | jq &#39;&quot;inst&quot; + .Reservations[].Instances[].PublicIpAddress + &quot; ansible_ssh_hosts=&quot; + .Reservations[].Instances[].PublicIpAddress + &quot; ansible_ssh_user=ubuntu&quot;&#39; &gt; myansible.hostfile\r\n\r\nI would receive dupes of the output like so:\r\n\r\n**output sample 2 in `myansible.hostfile`**\r\n\r\n    inst[ip_no1] ansible_ssh_host=[ip_no1] ansible_ssh_user=ubuntu\r\n    inst[ip_no2] ansible_ssh_host=[ip_no2] ansible_ssh_user=ubuntu\r\n    inst[ip_no1] ansible_ssh_host=[ip_no1] ansible_ssh_user=ubuntu\r\n    inst[ip_no2] ansible_ssh_host=[ip_no2] ansible_ssh_user=ubuntu\r\n\r\nPresumably because I&#39;m calling the object selectors twice in the same command.\r\nThe question is:\r\n\r\na. **Is there a cleaner command expression that I could use instead of (command sample 1) to achieve the same (output sample 1)?**\r\n\r\nb. **What would be the correct way to strictly use `jq` command like in (command sample 2) in order to produce the desired (output sample 1) without dupes like in the (output sample 2)?**\r\n\r\nThanks much in advance.\r\n",
        "link": "https://stackoverflow.com/questions/53055418/cleaner-way-to-use-jq-selection",
        "title": "Cleaner way to use jq selection"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540908048,
                "post_id": 53065702,
                "comment_id": 93030361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540908141,
                "post_id": 53065702,
                "comment_id": 93030434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3418005,
                    "reputation": 133,
                    "user_id": 2866357,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae30e37c63aabc81fce427a7f0dbe30b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Melkor S.K",
                    "link": "https://stackoverflow.com/users/2866357/melkor-s-k"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540908195,
                "post_id": 53065702,
                "comment_id": 93030469,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3418005,
                    "reputation": 133,
                    "user_id": 2866357,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae30e37c63aabc81fce427a7f0dbe30b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Melkor S.K",
                    "link": "https://stackoverflow.com/users/2866357/melkor-s-k"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540908296,
                "post_id": 53065702,
                "comment_id": 93030526,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3418005,
                    "reputation": 133,
                    "user_id": 2866357,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae30e37c63aabc81fce427a7f0dbe30b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Melkor S.K",
                    "link": "https://stackoverflow.com/users/2866357/melkor-s-k"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540908371,
                "post_id": 53065702,
                "comment_id": 93030573,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1540909390,
                "post_id": 53065702,
                "comment_id": 93031260,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1540909617,
                "last_edit_date": 1540909617,
                "creation_date": 1540909024,
                "answer_id": 53066337,
                "question_id": 53065702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your question is rather unclear, but yet I understand correctly, this is likely what you want.\r\n\r\nProvided your input file is:\r\n\r\n    [\r\n      {\r\n        &quot;TMC&quot;: &quot;E17+02412&quot;,\r\n        &quot;ROADNUMBER&quot;: &quot;A-2&quot;,\r\n        &quot;DIR&quot;: &quot;E-90/AP-2/BARCELONA-ZARAGOZA (SOSES)&quot;,\r\n        &quot;PROV&quot;: &quot;LLEIDA&quot;,\r\n        &quot;CCAA&quot;: &quot;CATALUNYA&quot;,\r\n        &quot;StartLatitude&quot;: &quot;41.5368273&quot;,\r\n        &quot;StartLongitude&quot;: &quot;0.4387071&quot;,\r\n        &quot;EndLatitude&quot;: &quot;41.5388396&quot;,\r\n        &quot;EndLongitude&quot;: &quot;0.4638462&quot;\r\n      }\r\n    ]\r\nYou can filter the content using this `jq` filter:\r\n\r\n    jq &#39;map({ type: &quot;Feature&quot;, &quot;geometry&quot;: {&quot;type&quot;: &quot;LineString&quot;,&quot;coordinates&quot;: [ [.StartLongitude, .StartLatitude| tonumber], [ .EndLongitude, .EndLatitude | tonumber] ] }, properties: {tmc: .TMC, roadnumber: .ROADNUMBER, dir: .DIR, prov: .PROV, ccaa: .CCAA}})&#39; file\r\n\r\nresulting in this new JSON data:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;LineString&quot;,\r\n          &quot;coordinates&quot;: [\r\n            [\r\n              0.4387071,\r\n              41.5368273\r\n            ],\r\n            [\r\n              0.4638462,\r\n              41.5388396\r\n            ]\r\n          ]\r\n        },\r\n        &quot;properties&quot;: {\r\n          &quot;tmc&quot;: &quot;E17+02412&quot;,\r\n          &quot;roadnumber&quot;: &quot;A-2&quot;,\r\n          &quot;dir&quot;: &quot;E-90/AP-2/BARCELONA-ZARAGOZA (SOSES)&quot;,\r\n          &quot;prov&quot;: &quot;LLEIDA&quot;,\r\n          &quot;ccaa&quot;: &quot;CATALUNYA&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq: error: syntax error, unexpected $end (Windows cmd shell quoting issues?)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1540974200,
        "creation_date": 1540907015,
        "last_edit_date": 1540974200,
        "question_id": 53065702,
        "body_markdown": "    type sols3json.json | jq-win64.exe  &quot;[.[] | { &quot;type&quot;: &quot;FeatureCollection&quot;,&quot;features&quot;:[{  type: &quot;Feature&quot;, &quot;geometry&quot;:  {&quot;type&quot;: &quot;LineString&quot;,&quot;coordinates&quot;:  [  [.OpStartLongitude, .OpStartLatitude| tonumber],  [ .OpEndLongitude, .OpEndLatitude | tonumber] ]  },  properties: {name: .SolName}}]}&quot;  &gt; sols3.geojson\r\n\r\n\r\n\r\nI get jq: error: syntax error, unexpected $end (Windows cmd shell quoting issues?)\r\nWhat am I doing wrong?\r\nThe output should be like this:\r\n\r\n    {\r\n    &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n    &quot;features&quot;: \r\n        [\r\n        {\r\n        &quot;properties&quot;: {\r\n        &quot;ccaa&quot;: &quot;CATALUNYA&quot;,\r\n        &quot;prov&quot;: &quot;LLEIDA&quot;,\r\n        &quot;dir&quot;: &quot;N-IIA/SOSES/TORRES DE SEGRE/ALCARR&#224;S&quot;,\r\n        &quot;roadnumber&quot;: &quot;A-2&quot;,\r\n        &quot;tmc&quot;: &quot;E17+02413&quot;\r\n        },\r\n        &quot;geometry&quot;: {\r\n        &quot;coordinates&quot;: [\r\n        [\r\n        0.4714937,\r\n        41.5420936\r\n        ],\r\n        [\r\n        0.4891472,\r\n        41.5497014\r\n        ]\r\n        ],\r\n        &quot;type&quot;: &quot;LineString&quot;\r\n        },\r\n        &quot;type&quot;: &quot;Feature&quot;\r\n        }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/53065702/jq-error-syntax-error-unexpected-end-windows-cmd-shell-quoting-issues",
        "title": "jq: error: syntax error, unexpected $end (Windows cmd shell quoting issues?)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1540926807,
                "post_id": 53071290,
                "comment_id": 93041069,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14652735,
                    "reputation": 13,
                    "user_id": 10582273,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-E1YV1YwAdpA/AAAAAAAAAAI/AAAAAAAAAAc/5P2Bn93SkYE/s256-rj/photo.jpg",
                    "display_name": "Vasiliy Vershkov",
                    "link": "https://stackoverflow.com/users/10582273/vasiliy-vershkov"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540974345,
                "post_id": 53071290,
                "comment_id": 93055512,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14652735,
                    "reputation": 13,
                    "user_id": 10582273,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-E1YV1YwAdpA/AAAAAAAAAAI/AAAAAAAAAAc/5P2Bn93SkYE/s256-rj/photo.jpg",
                    "display_name": "Vasiliy Vershkov",
                    "link": "https://stackoverflow.com/users/10582273/vasiliy-vershkov"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540975509,
                "post_id": 53071290,
                "comment_id": 93056073,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1540928235,
                "last_edit_date": 1540928235,
                "creation_date": 1540927903,
                "answer_id": 53071632,
                "question_id": 53071290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `|=` &quot;update-assignment&quot; operator with the following syntax :\r\n\r\n    (.TaskGroups[] | select(.Name == (&quot;test1&quot;, &quot;test5&quot;)).Count) |= 0 | {Job : . }\r\n\r\nIt is documented [here](https://stedolan.github.io/jq/manual/#Update-assignment:|=).\r\n\r\nI&#39;ve been able to successfully test it on jqplay : https://jqplay.org/s/578mkUAklU",
                "title": "jq - replace some variables in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1540975797,
        "creation_date": 1540926464,
        "last_edit_date": 1540975797,
        "question_id": 53071290,
        "body_markdown": "This question is caused due to [nomad behaviour][1]\r\n\r\nI have an json like this:\r\n\r\n    # cat test.json \r\n    {\r\n      &quot;Name&quot;: &quot;test&quot;,\r\n      &quot;TaskGroups&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;test1&quot;,\r\n          &quot;Count&quot;: 1\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;test2&quot;,\r\n          &quot;Count&quot;: 1\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;test3&quot;,\r\n          &quot;Count&quot;: 1\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;test4&quot;,\r\n          &quot;Count&quot;: 1\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;test5&quot;,\r\n          &quot;Count&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n\r\nI need to change it like this:\r\n1) add &quot;Job&quot; in front of my json - I can do it with\r\n\r\n    # cat test.json | jq &#39;{&quot;Job&quot;: .}&#39;\r\n2) replace &quot;Count&quot; variable for multiple items in array, like test1 and test5, I can do it like this:\r\n\r\n    # cat test.json | jq &#39; .TaskGroups[0,4].Count = 0 &#39;\r\n\r\nI can run both commands as whole thing and it works fine like this:\r\n\r\n    # cat test.json | jq &#39; .TaskGroups[0,4].Count = 0 | {&quot;Job&quot;: .} &#39;\r\nBut also I want to search for variables I want to change by their names, not by their number in array. So I can do something like this:\r\n\r\n    cat test.json | jq &#39; .TaskGroups[] | select(.Name == (&quot;test1&quot;, &quot;test5&quot;)).Count = 0 &#39;\r\n\r\nBut because of I am listing array, not whole json - I am loosing some variables and &quot;Job:&quot;, that I just added. Or I can add it to the every item in my array.\r\nSo how I can change variable by its name and also add &quot;Job:&quot; at the same time?\r\n\r\n  [1]: https://github.com/hashicorp/nomad/issues/698#issuecomment-327643977\r\n",
        "link": "https://stackoverflow.com/questions/53071290/jq-replace-some-variables-in-array",
        "title": "jq - replace some variables in array"
    },
    {
        "tags": [
            "json",
            "file",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4749917,
                    "reputation": 4574,
                    "user_id": 3840213,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fbc4dd44d31b478ee005d7ebfac8b7b0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Narendra",
                    "link": "https://stackoverflow.com/users/3840213/narendra"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540951199,
                "post_id": 53074931,
                "comment_id": 93048630,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1540952254,
                "creation_date": 1540952254,
                "answer_id": 53075358,
                "question_id": 53074931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, let&#39;s think of an appropriate way to invoke jq.  Here&#39;s one possibility:\r\n\r\n    jq -n --argfile file1 file1.json --argfile file2 file2.json -f merge.jq\r\n\r\nAnd here is merge.jq, which uses `|=` to update the array:\r\n\r\n    # Create the dictionary based on .name\r\n    ($file2 | map( {(.name): {size, status}} )|add) as $dict\r\n    | $file1\r\n    | .storage_attachments |= map(. + $dict[.storage_volume_name])\r\n\r\n",
                "title": "Merge two json files, retrieving attribute value based on key value matching"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1540974768,
        "creation_date": 1540948335,
        "last_edit_date": 1540974768,
        "question_id": 53074931,
        "body_markdown": "I am trying to retrieve the disk volume size that is in another json file based on the storage_volume names derived from a master json file containing virtual machine information, the two json files of the following structure \r\n\r\n## file1.json ##\r\n\r\n          {\r\n     &quot;hostname&quot;: &quot;samplevm&quot;,\r\n     &quot;state&quot;: &quot;running&quot;,\r\n     &quot;storage_attachments&quot;: [\r\n        {\r\n           &quot;index&quot;: 1,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/0dc4d0cd-4be1-4220-b10b-5a1b105f1678&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/boot&quot;\r\n        },\r\n        {\r\n           &quot;index&quot;: 2,\r\n           &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/1ac17918-c999-49a1-b200-957b2d56dbf7&quot;,\r\n           &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data2&quot;\r\n          },\r\n        {\r\n          &quot;index&quot;: 3,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/a068182e-882f-4314-bf00-0a4001935b26&quot;,\r\n        &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data1&quot;\r\n      },\r\n        {\r\n        &quot;index&quot;: 4,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/117a5abe-c5dd-43a6-8935-bebb739d358b&quot;,\r\n           &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/bits&quot;\r\n         },\r\n         {\r\n         &quot;index&quot;: 5,\r\n           &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/ae5c5916-0a21-492e-ae20-5dd0fb383f0f&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/data&quot;\r\n          }\r\n           ]\r\n                 }\r\n\r\n**file2.json**\r\n\r\n          [\r\n      {\r\n        &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/bits&quot;,\r\n        &quot;size&quot;: &quot;64424509440&quot;,\r\n        &quot;status&quot;: &quot;Online&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/boot&quot;,\r\n        &quot;size&quot;: &quot;34359738368&quot;,\r\n        &quot;status&quot;: &quot;Online&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/data&quot;,\r\n        &quot;size&quot;: &quot;536870912000&quot;,\r\n        &quot;status&quot;: &quot;Online&quot;\r\n       },\r\n      {\r\n        &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data1&quot;,\r\n        &quot;size&quot;: &quot;912680550400&quot;,\r\n        &quot;status&quot;: &quot;Online&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data2&quot;,\r\n        &quot;size&quot;: &quot;80530636800&quot;,\r\n        &quot;status&quot;: &quot;Online&quot;\r\n      }\r\n    ]\r\n\r\nI want to merge these files such that the output file looks like\r\n\r\n**result.json**\r\n\r\n               {\r\n      &quot;hostname&quot;: &quot;samplevm&quot;,\r\n      &quot;state&quot;: &quot;running&quot;,\r\n      &quot;storage_attachments&quot;: [\r\n        {\r\n          &quot;index&quot;: 1,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/0dc4d0cd-4be1-4220-b10b-5a1b105f1678&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/boot&quot;,\r\n          &quot;size&quot;: &quot;34359738368&quot;,\r\n          &quot;status&quot;: &quot;Online&quot;\r\n        },\r\n        {\r\n          &quot;index&quot;: 2,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/1ac17918-c999-49a1-b200-957b2d56dbf7&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data2&quot;,\r\n          &quot;size&quot;: &quot;80530636800&quot;,\r\n          &quot;status&quot;: &quot;Online&quot;\r\n        },\r\n        {\r\n          &quot;index&quot;: 3,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/a068182e-882f-4314-bf00-0a4001935b26&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data1&quot;,\r\n          &quot;size&quot;: &quot;912680550400&quot;,\r\n          &quot;status&quot;: &quot;Online&quot;\r\n         },\r\n        {\r\n          &quot;index&quot;: 4,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/117a5abe-c5dd-43a6-8935-bebb739d358b&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/bits&quot;,\r\n          &quot;size&quot;: &quot;64424509440&quot;,\r\n          &quot;status&quot;: &quot;Online&quot;\r\n        },\r\n        {\r\n          &quot;index&quot;: 5,\r\n          &quot;name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/ae5c5916-0a21-492e-ae20-5dd0fb383f0f&quot;,\r\n          &quot;storage_volume_name&quot;: &quot;/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/data&quot;,\r\n          &quot;size&quot;: &quot;536870912000&quot;,\r\n          &quot;status&quot;: &quot;Online&quot;\r\n        }\r\n       ] \r\n     }\r\n\r\nHow can i accomplish this using jq? Thank you for  your assistance",
        "link": "https://stackoverflow.com/questions/53074931/merge-two-json-files-retrieving-attribute-value-based-on-key-value-matching",
        "title": "Merge two json files, retrieving attribute value based on key value matching"
    },
    {
        "tags": [
            "bash",
            "key-value",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541007904,
                "post_id": 53089179,
                "comment_id": 93075453,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541008241,
                "post_id": 53089179,
                "comment_id": 93075627,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541008264,
                "post_id": 53089179,
                "comment_id": 93075640,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541009074,
                "post_id": 53089179,
                "comment_id": 93076051,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541009542,
                "post_id": 53089179,
                "comment_id": 93076263,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1541009516,
                "last_edit_date": 1541009516,
                "creation_date": 1541008001,
                "answer_id": 53089272,
                "question_id": 53089179,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So, first, so people who don&#39;t have `yum` can test this, let&#39;s make a wrapper function:\r\n\r\n    write_output() { cat &lt;&lt;EOF\r\n    Repo-id: wazuh_repo\r\n    Repo-name: Wazuhrepository\r\n    Repo-status: enabled\r\n    Repo-revision: 1536348945\r\n    Repo-updated: FriSep712:35:512018\r\n    Repo-pkgs: 73\r\n    Repo-size: 920M\r\n    Repo-baseurl: https://packages.wazuh.com/3.x/yum/\r\n    Repo-expire: 21,600second(s)(last:WedOct3108:59:002018)\r\n    EOF\r\n    }\r\n\r\nNotably, all your keys come before the string `: `, and the values come after them -- so we want to read line-by-line, split based on colon-space sequences, treat what was in front as a key, and treat what&#39;s in back as a value.\r\n\r\n---\r\n\r\nGiven that:\r\n\r\n    jq -Rn &#39;[inputs | split(&quot;: &quot;)] | reduce .[] as $kv ({}; .[$kv[0]] = $kv[1])&#39; &lt; &lt;(write_output)\r\n\r\n...properly emits:\r\n\r\n    {\r\n      &quot;Repo-id&quot;: &quot;wazuh_repo&quot;,\r\n      &quot;Repo-name&quot;: &quot;Wazuhrepository&quot;,\r\n      &quot;Repo-status&quot;: &quot;enabled&quot;,\r\n      &quot;Repo-revision&quot;: &quot;1536348945&quot;,\r\n      &quot;Repo-updated&quot;: &quot;FriSep712:35:512018&quot;,\r\n      &quot;Repo-pkgs&quot;: &quot;73&quot;,\r\n      &quot;Repo-size&quot;: &quot;920M&quot;,\r\n      &quot;Repo-baseurl&quot;: &quot;https://packages.wazuh.com/3.x/yum/&quot;,\r\n      &quot;Repo-expire&quot;: &quot;21,600second(s)(last:WedOct3108:59:002018)&quot;\r\n    }\r\n\r\n---\r\n\r\n...so, how does that work?\r\n\r\n- `jq -R` turns on *raw input* mode; input is parsed as a sequence of raw strings, not as a sequence of JSON documents.\r\n- `jq -n` treats `null` as the only direct input, so one can then use `input` and `inputs` primitives inside the script where needed.\r\n- `[ inputs ]` reads all your lines of input, and puts them into a single array.\r\n- `[ inputs | split(&quot;: &quot;)]` changes that from an array of strings to an array of lists -- with content both before and after the `&quot;: &quot;` sequence.\r\n- `reduce .[] as $kv ( {}; ... )` starts a *reducer*, with an initial value of `{}`, and then feeds each value that `.[]` evaluates to (which is to say, each item in your list) into that reducer (the `...` code) as the `$kv` variable, replacing the `.` value each time.\r\n\r\n---\r\n\r\nTo run this with your yum command as the real input, change `&lt; &lt;(write_output)` to `&lt; &lt;(yum -v repolist all | grep -B2 -A6 &quot;enabled&quot; | sed &#39;s/[[:space:]]//g&#39; , &#39;s/--//g&#39; , &#39;s/name=name=/name=/g&#39;)`.",
                "title": "How can I convert a &quot;key: value&quot; sequence into JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541009934,
                "creation_date": 1541009934,
                "answer_id": 53089755,
                "question_id": 53089179,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a slightly more robust variation of @CharlesDuffy&#39;s answer.  Since the latter provides excellent explanatory notes, further explanations are not given here.\r\n\r\n    jq -nR &#39;\r\n      [inputs | index(&quot;: &quot;) as $ix | {(.[:$ix]): .[$ix+2:]}]\r\n      | add&#39;\r\n\r\nThis avoids using `split` in case the &quot;value&quot; contains &quot;: &quot;.  It might, however, be still better not to assume that a space follows the first relevant &quot;:&quot;.\r\n\r\nNotice also that `add` is used here instead of `reduce`, solely for compactness and simplicity.",
                "title": "How can I convert a &quot;key: value&quot; sequence into JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541106721,
                "creation_date": 1541106721,
                "answer_id": 53109418,
                "question_id": 53089179,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For these sorts of problems, I would prefer to use a regular expression to match keys and values. Otherwise, I would take an approach similar to Charles&#39;s.\r\n\r\n    $ ... | jq -Rn &#39;reduce (inputs | capture(&quot;(?&lt;k&gt;[^:]+):\\\\s*(?&lt;v&gt;.+)&quot;)) as {$k, $v} ({}; .[$k] = $v)&#39;",
                "title": "How can I convert a &quot;key: value&quot; sequence into JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1541106721,
        "creation_date": 1541007549,
        "last_edit_date": 1541008916,
        "question_id": 53089179,
        "body_markdown": "hokay, I am trying to write a script that takes information from the `yum - repolist all` and puts it into pretty JSON for me to use in some data collecting.. Right now I have my output from the yum command looking like this.\r\n\r\nAll I have for code right now is just the yum repolist command.\r\n\r\n`#!/bin/bash -x\r\nyum -v repolist all | grep -B2 -A6 &quot;enabled&quot; | sed &#39;s/[[:space:]]//g&#39; , &#39;s/--//g&#39; , &#39;s/name=name=/name=/g&#39;` \r\n\r\n\r\nthe output from that command looks like:\r\n    \r\n    Repo-id: wazuh_repo\r\n    Repo-name: Wazuhrepository\r\n    Repo-status: enabled\r\n    Repo-revision: 1536348945\r\n    Repo-updated: FriSep712:35:512018\r\n    Repo-pkgs: 73\r\n    Repo-size: 920M\r\n    Repo-baseurl: https://packages.wazuh.com/3.x/yum/\r\n    Repo-expire: 21,600second(s)(last:WedOct3108:59:002018)\r\n\r\nThere are about 8 entries and the titles are always the same... Can someone explain like I am five how to convert this into json, I&#39;ve read the jq man page, I&#39;ve read about hash&#39;s. nothing seems to make sense. I know I need to have a &quot;key&quot;/&quot;value&quot; how to I designate these? \r\n\r\nI just want to take the output and make it look like pretty JSON, this is part of a larger script I am writing to help keep ontop of the repos we use at work. I am just totally not getting JSON though. \r\n\r\nedit: I would prefer not to use a wrapper function and do/learn the proper way\r\n",
        "link": "https://stackoverflow.com/questions/53089179/how-can-i-convert-a-key-value-sequence-into-json",
        "title": "How can I convert a &quot;key: value&quot; sequence into JSON?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1541531301,
                "last_edit_date": 1541531301,
                "creation_date": 1541090115,
                "answer_id": 53105534,
                "question_id": 53104102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this jq filter:\r\n\r\n    jq &#39;.TheArray |= map(select(.F1==&quot;V11&quot;))&#39; file\r\n\r\n`select` command choose the right element and `map` is building the array based on the selected elements.",
                "title": "Array filtering with jq on sub level"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541092868,
                "last_edit_date": 1541092868,
                "creation_date": 1541090209,
                "answer_id": 53105555,
                "question_id": 53104102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following would be suitable if you want a solution that simply &quot;edits&quot; the original document, retaining any other keys that the top-level object might have:\r\n\r\n    .TheArray |= map(select(.F1==&quot;V11&quot;))\r\n\r\n## Variations\r\n\r\n    with_entries( .value |= map(select(.F1 == &quot;V11&quot;)))\r\n\r\nAnother:\r\n\r\n    del(.TheArray[] | select(.F1!=&quot;V11&quot;))\r\n\r\nAnd if you have a more recent version of jq than version 1.5:\r\n\r\n    .TheArray[] |= select(.F1==&quot;V11&quot;)\r\n",
                "title": "Array filtering with jq on sub level"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1541531301,
        "creation_date": 1541085229,
        "last_edit_date": 1541090214,
        "question_id": 53104102,
        "body_markdown": "All the demo/examples I saw are filtering on the *first* level, but I want to do the array filtering with jq on the second level:\r\n\r\n    {\r\n      &quot;TheArray&quot;: [\r\n        {\r\n          &quot;F1&quot;: &quot;V11&quot;,\r\n          &quot;F2&quot;: &quot;V12&quot;,\r\n          &quot;F3&quot;: &quot;V13&quot;\r\n        },      \r\n        {       \r\n          &quot;F1&quot;: &quot;V21&quot;,\r\n          &quot;F2&quot;: &quot;V22&quot;,\r\n          &quot;F3&quot;: &quot;V33&quot;\r\n        }  ]\r\n    }\r\n\r\nI want to filter with `&quot;F1&quot; == &quot;V11&quot;`, and get:\r\n\r\n    {\r\n      &quot;TheArray&quot;: [\r\n        {\r\n          &quot;F1&quot;: &quot;V11&quot;,\r\n          &quot;F2&quot;: &quot;V12&quot;,\r\n          &quot;F3&quot;: &quot;V13&quot;\r\n        }  ]\r\n    }\r\n\r\nIs that possible with `jq`? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/53104102/array-filtering-with-jq-on-sub-level",
        "title": "Array filtering with jq on sub level"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1541095795,
                "last_edit_date": 1541095795,
                "creation_date": 1541092576,
                "answer_id": 53106164,
                "question_id": 53105673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that is a simple variation of the filter you&#39;ve shown:\r\n\r\n    .[].run?.command\r\n\r\nThe &quot;?&quot; is syntactic sugar for a `try` wrapper.\r\n\r\nHere&#39;s another variation, which suggests still others:\r\n\r\n    .[] | objects | .run.command\r\n\r\n",
                "title": "How to use jq to filter an array with elements of mixed type"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1541099844,
                "last_edit_date": 1541099844,
                "creation_date": 1541096224,
                "answer_id": 53107079,
                "question_id": 53105673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re dealing with  sets of those kinds of arrays with a fixed structure where the first item is like an alias followed by a bunch of actions, you could just skip the first item and process the rest.\r\n\r\n    .[1:][].run.command\r\n\r\nOtherwise if it is truly mixed and any item can be anything, some sort of filtering would have to be done as peak outlines.",
                "title": "How to use jq to filter an array with elements of mixed type"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1541148402,
        "creation_date": 1541090654,
        "last_edit_date": 1541148402,
        "question_id": 53105673,
        "body_markdown": "Given the below JSON, I&#39;m trying to select all the `command` elements. My issue is that the `&quot;checkout&quot;` string is messing up my selection of all the `&quot;run&quot;` dicts. \r\n\r\nI&#39;m trying to pass jq something like `.[].run.command` but I keep getting the error `jq: error (at &lt;stdin&gt;:33): Cannot index string with string &quot;run&quot;`\r\n\r\nHow do I exclude the `&quot;checkout&quot;` string from being selected?\r\n\r\n    [\r\n      &quot;checkout&quot;,\r\n      {\r\n        &quot;run&quot;: {\r\n          &quot;command&quot;: &quot;pip install cfn-lint pycodestyle pyflakes&quot;,\r\n          &quot;name&quot;: &quot;Install Dependencies&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;run&quot;: {\r\n          &quot;command&quot;: &quot;find stacks -type f -name \\&quot;*.yml\\&quot; -exec cfn-lint -i E3016 -i E3012 -i E1029 --template {} \\\\; | tee -a output.txt&quot;,\r\n          &quot;name&quot;: &quot;Run cfn-lint&quot;\r\n        }\r\n    },\r\n      {\r\n        &quot;run&quot;: {\r\n          &quot;command&quot;: &quot;find stacks -type f -name \\&quot;*.py\\&quot; -exec pyflakes {} \\\\; | tee -a output.txt&quot;,\r\n          &quot;name&quot;: &quot;Run pyflakes&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;run&quot;: {\r\n          &quot;command&quot;: &quot;pycodestyle --show-source --show-pep8 --ignore=E501,W605 stacks/src | tee -a output.txt&quot;,\r\n          &quot;name&quot;: &quot;Run pycodestyle&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;run&quot;: {\r\n          &quot;command&quot;: &quot;if [[ -s output.txt ]]; then cat output.txt; exit 1; fi&quot;,\r\n          &quot;name&quot;: &quot;Exit if there are validation warnings/errors&quot;\r\n        }\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/53105673/how-to-use-jq-to-filter-an-array-with-elements-of-mixed-type",
        "title": "How to use jq to filter an array with elements of mixed type"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1541167229,
                "creation_date": 1541167229,
                "answer_id": 53119971,
                "question_id": 53119261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Any tips?\r\n\r\nYes!  If you cannot find the answer in the onine jq manual, check the jq [FAQ][1]:\r\n\r\n&gt; &#119928;: How can I access the value of a key with hyphens or $ or other\r\n&gt; special characters in it? Why does .a.[&quot;$&quot;] produce a syntax error?\r\n&gt; \r\n&gt; A: The basic form for accessing the value of a key is .[&quot;KEYNAME&quot;]\r\n&gt; where &quot;KEYNAME&quot; is any valid JSON string, but recent versions of jq\r\n&gt; also allow .&quot;KEYNAME&quot;.\r\n&gt; \r\n&gt; Using the basic form might require explicit use of the pipe symbol, as\r\n&gt; in .[&quot;a-b&quot;]|.[&quot;x-y&quot;], but this can be abbreviated to .[&quot;a-b&quot;][&quot;x-y&quot;].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "jq extract key with - under powershell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1541402547,
        "creation_date": 1541164431,
        "last_edit_date": 1541402547,
        "question_id": 53119261,
        "body_markdown": "\r\n\r\nI use jq 1.5 in a Windows Environment to modify an json object that i receiving from Amazon s3. I have there a funny Problem. I use jq to extract single keys of the object:\r\n\r\n    {\r\n      &quot;s3_direct_url&quot;: &quot;https://fanzo-photos.s3.amazonaws.com/photos/images/034/005/322/screen1.jpg&quot;,\r\n      &quot;url&quot;: &quot;https://fanzo-photos.s3.amazonaws.com&quot;,\r\n      &quot;fields&quot;: {\r\n        &quot;key&quot;: &quot;photos/images/034/005/322/screen1.jpg&quot;,\r\n        &quot;success_action_status&quot;: &quot;200&quot;,\r\n        &quot;Content-Type&quot;: &quot;image/jpeg&quot;,\r\n        &quot;acl&quot;: &quot;public-read&quot;,\r\n        &quot;policy&quot;: &quot;eyJleHBpcmF0aW9uIjoiMjAxOC0xMS0wMlQxMzo0NzoxNVoiLCJjb25kaXRpb25zIjpbeyJidWNrZXQiOiJmYW56by1waG90b3MifSx7ImtleSI6InBob3Rvcy9pbWFnZXMvMDM0LzAwNS8zMjIvc2NyZWVuMS5qcGcifSx7InN1Y2Nlc3NfYWN0aW9uX3N0YXR1cyI6IjIwMCJ9LHsiQ29udGVudC1UeXBlIjoiaW1hZ2UvanBlZyJ9LHsiYWNsIjoicHVibGljLXJlYWQifSx7IngtYW16LWNyZWRlbnRpYWwiOiJBS0lBSlkzWVRCV1NMQzQ2SFdCQS8yMDE4MTEwMi91cy1lYXN0LTEvczMvYXdzNF9yZXF1ZXN0In0seyJ4LWFtei1hbGdvcml0aG0iOiJBV1M0LUhNQUMtU0hBMjU2In0seyJ4LWFtei1kYXRlIjoiMjAxODExMDJUMTI0NzE1WiJ9XX0=&quot;,\r\n        &quot;x-amz-credential&quot;: &quot;AKIAJY3YTBWSLC46HWBA/20181102/us-east-1/s3/aws4_request&quot;,\r\n        &quot;x-amz-algorithm&quot;: &quot;AWS4-HMAC-SHA256&quot;,\r\n        &quot;x-amz-date&quot;: &quot;20181102T124715Z&quot;,\r\n        &quot;x-amz-signature&quot;: &quot;52d8246536e8743fba8e7668cb65a08a1142221d54a58676b6ab14e3835482a3&quot;\r\n      },\r\n      &quot;id&quot;: 34005322,\r\n      &quot;media_type&quot;: &quot;InputMedia&quot;\r\n    }\r\n\r\nIf i extract informations from the &#39;fields&#39; object without a &#39;-&#39; in the key name that works fine. If i try to extract a key with &#39;-&#39; in the name i got following error: \r\n\r\n     jq: error: amz/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .fields.x-amz-credential          \r\n    jq: error: credential/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .fields.x-amz-credential              \r\n    jq: 2 compile errors\r\n    exit status 3\r\n\r\nUpdate: \r\nAfter the hint with the FAQ and the &quot; i rebuild the jq command and tested it in jqplay: .fields.&quot;Content-Type&quot; where it works as expected. Under powershell that variant didn&#39;t working since the powershell didn&#39;t excepting the quotating. \r\n\r\n    .\\jq .fields.&quot;Content-Type&quot; jq: error: Type/0 is not defined at &lt;top-level&gt;, line 1: .fields.Content-Type jq: 1 compile error\r\n\r\n\r\nBR\r\nTimo\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53119261/jq-extract-key-with-under-powershell",
        "title": "jq extract key with - under powershell"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541169117,
                "last_edit_date": 1541169117,
                "creation_date": 1541168128,
                "answer_id": 53120233,
                "question_id": 53119566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s `split` requires an argument, which must be a valid JSON string. In your case, you might want to use `splits` instead as it takes a regular expression argument.  However, `splits` produces a stream, so you would presumably want to write something along the lines of:\r\n\r\n\r\n    .value[]\r\n    | { &quot;id&quot;: [.[&quot;subject&quot;] | splits(&quot;  *&quot;)][-1],\r\n        &quot;date&quot;: .receivedDateTime }",
                "title": "pyjq error while trying to split line to select the last word"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1541169435,
        "creation_date": 1541165645,
        "last_edit_date": 1541169435,
        "question_id": 53119566,
        "body_markdown": "I am trying to cut the last word of a json key value using `.split()[-1]` with pyjq, but failing with error: `jq: error: syntax error, unexpected &#39;(&#39;`\r\n\r\n&gt;The key/value - &quot;subject&quot;: &quot;The user has user id: 2432343f3f-34kfert-343mn5788886&quot;\r\n\r\nThe JSON:\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;The user has user id: 76e195fa-67f1-4ea6-bb0e-29c123855978&quot;,\r\n            &quot;date&quot;: &quot;2018-11-01T08:41:53Z&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;The user has user id: 195fa76e-67f1-4ea6-bb0e-5597829c1238&quot;,\r\n            &quot;date&quot;: &quot;2018-10-31T14:43:04Z&quot;\r\n        }\r\n    ]\r\n\r\n    response_read = open(&#39;my.json&#39;, &#39;r&#39;)\r\n    response_read_parsed = json.loads(response_read.read())\r\n\trule = pyjq.all(&#39;.value[] | { &quot;id&quot;: .[&quot;subject&quot;].split()[-1], &quot;date&quot;: .receivedDateTime }&#39;, response_read_parsed)\r\n\r\nBut this approach works if i write without pyjq\r\n\r\n    myid= (response_read_parsed[&#39;subject&#39;].split()[-1])\r\n    print json.dumps(myid, indent=4)\r\n\r\nAs there are multiple entries like above, i decided to filter using pyjq.\r\n\r\nIs there any mistake i have done? i am not able to figure it out still. Please help. Thank you very much.",
        "link": "https://stackoverflow.com/questions/53119566/pyjq-error-while-trying-to-split-line-to-select-the-last-word",
        "title": "pyjq error while trying to split line to select the last word"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq",
            "kubectl"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13863020,
                    "reputation": 163362,
                    "user_id": 10008173,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc86d913c15f3b126673faa654e9668c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Maze",
                    "link": "https://stackoverflow.com/users/10008173/david-maze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541173359,
                "post_id": 53121439,
                "comment_id": 93137891,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4643855,
                    "reputation": 1065,
                    "user_id": 3762850,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/9fe366d63e2ac1776102b1be23b4dc16?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "James",
                    "link": "https://stackoverflow.com/users/3762850/james"
                },
                "reply_to_user": {
                    "account_id": 13863020,
                    "reputation": 163362,
                    "user_id": 10008173,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc86d913c15f3b126673faa654e9668c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Maze",
                    "link": "https://stackoverflow.com/users/10008173/david-maze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541174759,
                "post_id": 53121439,
                "comment_id": 93138649,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1541175371,
                "last_edit_date": 1541175371,
                "creation_date": 1541174908,
                "answer_id": 53122156,
                "question_id": 53121439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "use the jsonpath\r\n\r\n\r\n    C02W84XMHTD5:~ iahmad$ kubectl get pods --all-namespaces -o=jsonpath=&#39;{range .items[*]}{.metadata.name}{&quot;\\n&quot;}&#39;\r\n    coredns-c4cffd6dc-nsd2k\r\n    etcd-minikube\r\n    kube-addon-manager-minikube\r\n    kube-apiserver-minikube\r\n    kube-controller-manager-minikube\r\n    kube-dns-86f4d74b45-d5njm\r\n    kube-proxy-pg89s\r\n    kube-scheduler-minikube\r\n    kubernetes-dashboard-6f4cfc5d87-b7n7v\r\n    storage-provisioner\r\n    tiller-deploy-778f674bf5-vt4mj\r\n\r\nhttps://kubernetes.io/docs/reference/kubectl/jsonpath/\r\n\r\nit can output key values as well\r\n\r\n    C02W84XMHTD5:~ iahmad$ kubectl get pods --all-namespaces -o=jsonpath=&#39;{range .items[*]}{.metadata.name}{&quot;\\t&quot;}{.status.startTime}{&quot;\\n&quot;}{end}&#39;\r\n    coredns-c4cffd6dc-nsd2k\t2018-10-16T21:44:19Z\r\n    etcd-minikube\t2018-10-29T17:30:56Z\r\n    kube-addon-manager-minikube\t2018-10-29T17:30:56Z\r\n    kube-apiserver-minikube\t2018-10-29T17:30:56Z\r\n    kube-controller-manager-minikube\t2018-10-29T17:30:56Z\r\n    kube-dns-86f4d74b45-d5njm\t2018-10-16T21:44:16Z\r\n    kube-proxy-pg89s\t2018-10-29T17:32:05Z\r\n    kube-scheduler-minikube\t2018-10-29T17:30:56Z\r\n    kubernetes-dashboard-6f4cfc5d87-b7n7v\t2018-10-16T21:44:19Z\r\n    storage-provisioner\t2018-10-16T21:44:19Z\r\n    tiller-deploy-778f674bf5-vt4mj\t2018-11-01T13:45:23Z\r\n\r\nthen you can split those by space and form json or list",
                "title": "How to parse JSON format output of &quot;kubectl get pods&quot; using jq and create an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1541180229,
                "last_edit_date": 1541180229,
                "creation_date": 1541179507,
                "answer_id": 53123260,
                "question_id": 53121439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will do it in bash. You&#39;d be surprised how much you can do with bash:\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    NAMES=`kubectl get pods -o=jsonpath=&#39;{range .items[*]}{.spec.containers[*].env[*].name}{&quot;\\n&quot;}&#39; | tr -d &#39;\\011\\012\\015&#39;`\r\n    VALUES=`kubectl get pods -o=jsonpath=&#39;{range .items[*]}{.spec.containers[*].env[*].value}{&quot;\\n&quot;}&#39; | tr -d &#39;\\011\\012\\015&#39;`\r\n    \r\n    IFS=&#39; &#39; read -ra NAMESA &lt;&lt;&lt; &quot;$NAMES&quot;\r\n    IFS=&#39; &#39; read -ra VALUESA &lt;&lt;&lt; &quot;$VALUES&quot;\r\n    \r\n    MAXINDEX=`expr ${#NAMESA[@]} - 1`\r\n    \r\n    printf &quot;[\\n&quot;\r\n    for i in &quot;${!NAMESA[@]}&quot;; do\r\n      printf &quot;  {\\n&quot;\r\n      printf &quot;  \\&quot;USER_NAME\\&quot;: \\&quot;${NAMESA[$i]}\\&quot;,\\n&quot;\r\n      printf &quot;  \\&quot;USER_ADDRESS\\&quot;: \\&quot;${VALUESA[$i]}\\&quot;\\n&quot;\r\n      if [ &quot;$i&quot; == &quot;${MAXINDEX}&quot; ]; then\r\n        printf &quot;  }\\n&quot;\r\n      else\r\n        printf &quot;  },\\n&quot;\r\n      fi\r\n    done\r\n    printf &quot;]\\n&quot;",
                "title": "How to parse JSON format output of &quot;kubectl get pods&quot; using jq and create an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626970042,
                "creation_date": 1626970042,
                "answer_id": 68488128,
                "question_id": 53121439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While you are using `jq` as a filter, why not use it as a transformer, too?\r\n```jq\r\nkubectl get pods -o json | \\\r\njq &#39;.items|map(.spec.containers|map(.env|map({key: .name, value})|from_entries)|add)&#39;\r\n```\r\n_I know this is totally a necromancer badge, but still ;)_",
                "title": "How to parse JSON format output of &quot;kubectl get pods&quot; using jq and create an array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1626970042,
        "creation_date": 1541172395,
        "last_edit_date": 1541174578,
        "question_id": 53121439,
        "body_markdown": "The JSON output returned to me after running this command \r\n\r\n    kubectl get pods -o json | jq &#39;.items[].spec.containers[].env&#39;\r\n\r\n \r\non my kuberntes cluster is this\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;USER_NAME&quot;,\r\n        &quot;value&quot;: &quot;USER_NAME_VALUE_A&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;USER_ADDRESS&quot;,\r\n        &quot;value&quot;: &quot;USER_ADDRESS_VALUE_A&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;USER_NAME&quot;,\r\n        &quot;value&quot;: &quot;USER_NAME_VALUE_B&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;USER_ADDRESS&quot;,\r\n        &quot;value&quot;: &quot;USER_ADDRESS_VALUE_B&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;d like to create a unified array/dictionary (Using **Bash** script) which looks like the example below and how can I get the value of each key?\r\n\r\n    [\r\n      {\r\n        &quot;USER_NAME&quot;: &quot;USER_NAME_VALUE_A&quot;,\r\n        &quot;USER_ADDRESS&quot;: &quot;USER_ADDRESS_VALUE_A&quot;\r\n      },\r\n      {\r\n        &quot;USER_NAME&quot;: &quot;USER_NAME_VALUE_B&quot;,\r\n        &quot;USER_ADDRESS&quot;: &quot;USER_ADDRESS_VALUE_B&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/53121439/how-to-parse-json-format-output-of-kubectl-get-pods-using-jq-and-create-an-arr",
        "title": "How to parse JSON format output of &quot;kubectl get pods&quot; using jq and create an array"
    },
    {
        "tags": [
            "json",
            "wrapper",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7026737,
                    "reputation": 2840,
                    "user_id": 5383863,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/3d49b6d699a15cc7522cc01e467e8568?s=256&d=identicon&r=PG",
                    "display_name": "Ettore Rizza",
                    "link": "https://stackoverflow.com/users/5383863/ettore-rizza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541190135,
                "post_id": 53125290,
                "comment_id": 93145467,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1541190011,
                "creation_date": 1541190011,
                "answer_id": 53125329,
                "question_id": 53125290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to wrap an object around the input.\r\n\r\n    jq &#39;{payload: .}&#39; some.json",
                "title": "How to copy a JSON document inside another using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1565404225,
        "creation_date": 1541189760,
        "last_edit_date": 1565404225,
        "question_id": 53125290,
        "body_markdown": "How can I transform a JSON document like this:\r\n\r\n\r\n    { &quot;foo&quot;: 123, &quot;bar&quot;: &quot;abc&quot; }\r\n\r\ninto something like this:\r\n\r\n\r\n    { &quot;payload&quot;:  { &quot;foo&quot;: 123, &quot;bar&quot;: &quot;abc&quot; } }\r\n\r\nusing the command line tool `jq`?",
        "link": "https://stackoverflow.com/questions/53125290/how-to-copy-a-json-document-inside-another-using-jq",
        "title": "How to copy a JSON document inside another using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "amazon-cognito",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1541212701,
                "creation_date": 1541212701,
                "answer_id": 53127920,
                "question_id": 53127511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider first this filter:\r\n\r\n    .Users[].Attributes\r\n    | map(select(.Name | . == &quot;custom:jobtitle&quot; or . == &quot;custom:user_id&quot; or . == &quot;email&quot;) )\r\n    | from_entries\r\n    | [ .email, .[&quot;custom:jobtitle&quot;], .[&quot;custom:user_id&quot;] ]\r\n    | @csv\r\n\r\nThe trick used here is the use of `from_entries` to convert the array of Name/Value pairs to an object with the Names as keys.\r\n\r\nAssuming valid JSON input along the lines shown in the Q, invoking jq with the -r option would yield:\r\n\r\n    &quot;foo.bar@email.com&quot;,&quot;Director&quot;,&quot;38&quot;\r\n\r\nUnfortunately the precise requirements are not so clear to me, but you should be able to adapt the above in accordance with your needs.\r\n\r\n",
                "title": "Convert JSON to CSV - string manipulation (jq, bash, awk, sed, etc.)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1541212701,
        "creation_date": 1541207160,
        "question_id": 53127511,
        "body_markdown": "I&#39;m in a dire need of help for a script to basically convert JSON text to CSV text in an attempt to copy users from one AWS Cognito userpool to another.\r\n\r\nThe export JSON looks like this:\r\n\r\n    {\r\n        &quot;Users&quot;: [\r\n            {\r\n                &quot;Username&quot;: &quot;user.name&quot;,\r\n                &quot;Attributes&quot;: [\r\n                    {\r\n                        &quot;Name&quot;: &quot;sub&quot;,\r\n                        &quot;Value&quot;: &quot;some-value&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;email_verified&quot;,\r\n                        &quot;Value&quot;: &quot;true&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;custom:jobtitle&quot;,\r\n                        &quot;Value&quot;: Director&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;custom:user_id&quot;,\r\n                        &quot;Value&quot;: &quot;38&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;email&quot;,\r\n                        &quot;Value&quot;: &quot;foo.bar@email.com&quot;\r\n                    }\r\n                ],\r\n                &quot;UserCreateDate&quot;: some-value,\r\n                &quot;UserLastModifiedDate&quot;: some-value,\r\n                &quot;Enabled&quot;: some-value,\r\n                &quot;UserStatus&quot;: &quot;some-value&quot;\r\n            }\r\n            [more lines down here]... \r\n        ] }\r\n\r\nThen the CSV file would contain these lines:\r\n\r\n    ,,,,,,,,,foo.bar@email.com,TRUE,,,,,,FALSE,,,Director,,38,FALSE,foo.bar\r\n    [more lines down here]...\r\n\r\nSo, the variables would be like this for JSON:\r\n\r\n    {\r\n        &quot;Users&quot;: [\r\n            {\r\n                &quot;Username&quot;: &quot;%USERNAME%&quot;,\r\n                &quot;Attributes&quot;: [\r\n                    {\r\n                        &quot;Name&quot;: &quot;sub&quot;,\r\n                        &quot;Value&quot;: &quot;some-value&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;email_verified&quot;,\r\n                        &quot;Value&quot;: &quot;true&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;custom:jobtitle&quot;,\r\n                        &quot;Value&quot;: %JOB_TITLE%&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;custom:user_id&quot;,\r\n                        &quot;Value&quot;: &quot;%USER_ID%&quot;\r\n                    },\r\n                    {\r\n                        &quot;Name&quot;: &quot;email&quot;,\r\n                        &quot;Value&quot;: %EMAIL%&quot;\r\n                    }\r\n                ],\r\n                &quot;UserCreateDate&quot;: some-value,\r\n                &quot;UserLastModifiedDate&quot;: some-value,\r\n                &quot;Enabled&quot;: some-value,\r\n                &quot;UserStatus&quot;: &quot;some-value&quot;\r\n            }\r\n            ...\r\n        ]\r\n    }\r\n    \r\n\r\nAnd like this for CSV:\r\n  \r\n\r\n    ,,,,,,,,,%EMAIL%,TRUE,,,,,,FALSE,,,%JOB_TITLE%,,%USER_ID%,FALSE,%USERNAME%\r\n\r\nwhere `%EMAIL%`, `%JOB_TITLE%`, `%USER_ID%`, and `%USERNAME%` are variables, everything else should be just string.\r\n\r\nAppreciate your help in advanced guys.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53127511/convert-json-to-csv-string-manipulation-jq-bash-awk-sed-etc",
        "title": "Convert JSON to CSV - string manipulation (jq, bash, awk, sed, etc.)"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541245465,
                "post_id": 53130924,
                "comment_id": 93155553,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2075037,
                    "reputation": 86088,
                    "user_id": 1848654,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84180c0f3c9c04f8b8f0613fc0129dac?s=256&d=identicon&r=PG",
                    "display_name": "melpomene",
                    "link": "https://stackoverflow.com/users/1848654/melpomene"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1541246513,
                "post_id": 53130924,
                "comment_id": 93155805,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1541277550,
                "last_edit_date": 1541277550,
                "creation_date": 1541247235,
                "answer_id": 53131189,
                "question_id": 53130924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use jq.\r\n\r\n* to assign the output to a variable:\r\n\r\n        addr=$(./xuez-cli getnetworkinfo | jq -r &#39;.localaddresses[0].address // &quot;something other than null&quot;&#39;)\r\n\r\n* to write output to a file:\r\n\r\n        ./xuez-cli getnetworkinfo | jq -r &#39;.localaddresses[0].address // &quot;something other than null&quot;&#39; &gt; addrfile",
                "title": "How to get a specific part of a command output on bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1666425136,
        "creation_date": 1541244855,
        "last_edit_date": 1666425136,
        "question_id": 53130924,
        "body_markdown": "I&#39;m trying to get a specific part of a command&#39;s output using bash. So when you run this command;\r\n\r\n`./xuez-cli getnetworkinfo`\r\n\r\nit gives you an output like this;\r\n\r\n    &quot;localaddresses&quot; : [\r\n        {\r\n            &quot;address&quot; : &quot;snyc3vzezoch2jax.onion&quot;,\r\n            &quot;port&quot; : 41798,\r\n            &quot;score&quot; : 4\r\n        }\r\n    ]\r\n\r\nand from this output, I need to get this address, `snyc3vzezoch2jax.onion` and put into into a text file or a variable.\r\n\r\nThe `.onion` part always stay the same, although the characters before it will be different each time so I need a general solution to get the whole address.\r\n\r\nI&#39;ve tried `./xuez-cli getnetworkinfo | grep address` though it gave me this output;\r\n\r\n    &quot;localaddresses&quot; : [\r\n            &quot;address&quot; : &quot;snyc3vzezoch2jax.onion&quot;,\r\nand still couldn&#39;t find a way to paste this `address` part into a text file or a variable.\r\n\r\nHow can I do that?",
        "link": "https://stackoverflow.com/questions/53130924/how-to-get-a-specific-part-of-a-command-output-on-bash",
        "title": "How to get a specific part of a command output on bash"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1541276746,
                "post_id": 53135035,
                "comment_id": 93163590,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1541276787,
                "creation_date": 1541276787,
                "answer_id": 53135202,
                "question_id": 53135035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, a note: There&#39;s nothing inherently wrong with `addr=null`; you can just test for it:\r\n\r\n    if [[ $addr = null ]]; then ...code here...; fi\r\n\r\nThe rest of this answer pretends the above were untrue. :)\r\n\r\n---\r\n\r\nThere are two practices that are notable as improving ease of error handling for this case:\r\n\r\n- Using `set -o pipefail` will detect whether any part -- not just the last component -- of a shell pipeline fails.\r\n- Using `jq -e` will cause `jq`&#39;s exit status to reflect whether it returned content that was either false or null.\r\n\r\n---\r\n\r\nThus:\r\n\r\n    set -o pipefail\r\n    if addr=$(./xuez-cli getnetworkinfo | jq -er &#39;.localaddresses[0].address&#39;); then\r\n      : &quot;address retrieved successfully; this message is not logged unless set -x is active&quot;\r\n    else\r\n      echo &quot;Running other logic here&quot;\r\n    fi\r\n\r\n...goes to `Running other logic here` if *either* `jq` fails (and `-e` specifies that `false` and `null` shall be treated as failures), *or* if `xuez-cli` reports an unsuccessful exit status.",
                "title": "jq returning null as string if the json is empty"
            },
            {
                "up_vote_count": 104,
                "is_accepted": false,
                "score": 103,
                "last_activity_date": 1558253698,
                "creation_date": 1558253698,
                "answer_id": 56205949,
                "question_id": 53135035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something useful I found for shell scripts was:\r\n\r\n    jq &#39;.foo // empty&#39;\r\n\r\nWhich returns the match if successful, and the empty string if unsuccessful. So in bash I use:\r\n\r\n    addr=$(./xuez-cli getnetworkinfo | jq -r &#39;.localaddresses[0].address // empty&#39;)\r\n\r\n    if [[ ! -z &quot;$addr&quot; ]]; then\r\n        # do something\r\n    fi\r\n\r\nRef: https://github.com/stedolan/jq/issues/354#issuecomment-43147898\r\nhttps://unix.stackexchange.com/questions/451479/jq-print-for-null-values ",
                "title": "jq returning null as string if the json is empty"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 39,
        "last_activity_date": 1558253698,
        "creation_date": 1541275363,
        "question_id": 53135035,
        "body_markdown": "I&#39;m running this command do get a value from the json;\r\n\r\n`addr=$(./xuez-cli getnetworkinfo | jq -r &#39;.localaddresses[0].address&#39;)`\r\n\r\nand it works just fine.\r\n\r\nBUT if this `.localaddresses[0].address` part empty or doesn&#39;t even exist, jq sets the `addr` variable as `null` like this; `addr=null`\r\n\r\nand I want to check if the json is empty/null and run some other command instead of parsing it as `null` string.\r\n\r\nI couldn&#39;t find a way to work this around. How can I do this?",
        "link": "https://stackoverflow.com/questions/53135035/jq-returning-null-as-string-if-the-json-is-empty",
        "title": "jq returning null as string if the json is empty"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1541292769,
                "creation_date": 1541292769,
                "answer_id": 53136847,
                "question_id": 53136706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An (the?) elegant way:\r\n\r\n    $ jq -n --argfile f1 file1.json --argfile f2 file2.json -f program.jq\r\n\r\nwhere program.jq is:\r\n\r\n    [$f1,$f2]\r\n    | transpose\r\n    | map(add)",
                "title": "jq: how to add elements from an array into another array one by one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1541404305,
        "creation_date": 1541290898,
        "last_edit_date": 1541404305,
        "question_id": 53136706,
        "body_markdown": "First array file1:\r\n\r\n    [{&quot;1&quot;:&quot;2&quot;}, {&quot;3&quot;:&quot;4&quot;}] \r\n\r\nSecond array in file2:\r\n\r\n    [{&quot;a&quot;:&quot;b&quot;}, {&quot;c&quot;:&quot;d&quot;}]\r\n\r\nI tried &quot;jq -s -c &#39;.[0][] + .[1][]&#39; file1 file2&quot;. The result:\r\n\r\n    {&quot;1&quot;:&quot;2&quot;,&quot;a&quot;:&quot;b&quot;}\r\n    {&quot;3&quot;:&quot;4&quot;,&quot;a&quot;:&quot;b&quot;}\r\n    {&quot;1&quot;:&quot;2&quot;,&quot;c&quot;:&quot;d&quot;}\r\n    {&quot;3&quot;:&quot;4&quot;,&quot;c&quot;:&quot;d&quot;}\r\n\r\nHowever, I want the following:\r\n\r\n    {&quot;1&quot;:&quot;2&quot;,&quot;a&quot;:&quot;b&quot;}\r\n    {&quot;3&quot;:&quot;4&quot;,&quot;c&quot;:&quot;d&quot;}\r\n\r\nThanks for the help.",
        "link": "https://stackoverflow.com/questions/53136706/jq-how-to-add-elements-from-an-array-into-another-array-one-by-one",
        "title": "jq: how to add elements from an array into another array one by one"
    },
    {
        "tags": [
            "json",
            "recursion",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1541379330,
                "last_edit_date": 1541379330,
                "creation_date": 1541368145,
                "answer_id": 53145829,
                "question_id": 53145680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is this possible with jq?\r\n\r\njq is Turing-complete :-)\r\n\r\nHere&#39;s a simple solution:\r\n\r\n    walk( if type == &quot;object&quot; and .type == &quot;t&quot; then .dst = .src else . end)\r\n\r\nIf your jq does not have `walk/1`, then it might be a good time to upgrade (to jq 1.6); otherwise, you can snarf its def from the web, e.g. by googling: `jq &quot;def walk&quot;`\r\n\r\n## Alternatively ...\r\n\r\n    reduce paths as $x (.;\r\n        if (getpath($x)|.type? // false) == &quot;t&quot;\r\n        then setpath( $x + [&quot;dst&quot;]; getpath( $x + [&quot;src&quot;] ))\r\n        else . end)\r\n\r\n",
                "title": "jq recursively update values for certain elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1541379372,
        "creation_date": 1541367052,
        "last_edit_date": 1541379372,
        "question_id": 53145680,
        "body_markdown": "The intent for the JSON data below is to update the value of the field `dst` with the value of `src` within all elements of `type` `t`, regardless of depth within the tree, while at the same time preserving the whole structure of the data.\r\n\r\nIs this possible with `jq`? My several attempts have boiled down to the following command that is not working to achieve the intended purpose:\r\n\r\n`$ jq -r &#39;map_values(select(.. | .type? == &quot;t&quot; |= (.dst = .src)))&#39;`\r\n\r\n    {\r\n        &quot;a&quot;: &quot;b&quot;,\r\n        &quot;c&quot;: [\r\n            {\r\n                &quot;type&quot;: &quot;t&quot;,\r\n                &quot;src&quot;: &quot;xx&quot;,\r\n                &quot;dst&quot;: &quot;zz&quot;\r\n            },\r\n            {\r\n                &quot;type&quot;: &quot;t&quot;,\r\n                &quot;src&quot;: &quot;xx&quot;,\r\n                &quot;dst&quot;: &quot;zz&quot;\r\n            }\r\n        ],\r\n        &quot;d&quot;: [\r\n            {\r\n                &quot;e&quot;: [\r\n                    {\r\n                        &quot;type&quot;: &quot;t&quot;,\r\n                        &quot;src&quot;: &quot;xx&quot;,\r\n                        &quot;dst&quot;: &quot;zz&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;type&quot;: &quot;t2&quot;,\r\n                &quot;src&quot;: &quot;xx&quot;,\r\n                &quot;dst&quot;: &quot;zz&quot;\r\n            }\r\n         ]\r\n    }",
        "link": "https://stackoverflow.com/questions/53145680/jq-recursively-update-values-for-certain-elements",
        "title": "jq recursively update values for certain elements"
    },
    {
        "tags": [
            "json",
            "bash",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4362282,
                    "reputation": 97842,
                    "user_id": 3558960,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/a98b52149d419c2aad558befe51c8cc5?s=256&d=identicon&r=PG",
                    "display_name": "Robby Cornelissen",
                    "link": "https://stackoverflow.com/users/3558960/robby-cornelissen"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1541393029,
                "post_id": 53148443,
                "comment_id": 93187499,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14661905,
                    "reputation": 83,
                    "user_id": 10588814,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-49D4OLQ_MIM/AAAAAAAAAAI/AAAAAAAAAAA/ABtNlbD4J4t25YdLT_GYVGMTqhbxTOO05g/mo/s256-rj/photo.jpg",
                    "display_name": "Gerald",
                    "link": "https://stackoverflow.com/users/10588814/gerald"
                },
                "reply_to_user": {
                    "account_id": 4362282,
                    "reputation": 97842,
                    "user_id": 3558960,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/a98b52149d419c2aad558befe51c8cc5?s=256&d=identicon&r=PG",
                    "display_name": "Robby Cornelissen",
                    "link": "https://stackoverflow.com/users/3558960/robby-cornelissen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541393331,
                "post_id": 53148443,
                "comment_id": 93187567,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1541393932,
                "post_id": 53148443,
                "comment_id": 93187696,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1541394020,
                "post_id": 53148443,
                "comment_id": 93187720,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14654276,
                    "reputation": 350,
                    "user_id": 10583298,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-B7UxQ5u_tjo/AAAAAAAAAAI/AAAAAAAANLc/YM1u7UwtkaA/s256-rj/photo.jpg",
                    "display_name": "PhaseRush",
                    "link": "https://stackoverflow.com/users/10583298/phaserush"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1541395805,
                "post_id": 53148443,
                "comment_id": 93188147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6807639,
                    "reputation": 26395,
                    "user_id": 5238915,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/fncqh.jpg?s=256",
                    "display_name": "RoadRunner",
                    "link": "https://stackoverflow.com/users/5238915/roadrunner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541399340,
                "post_id": 53148443,
                "comment_id": 93189150,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541410038,
                "creation_date": 1541410038,
                "answer_id": 53151554,
                "question_id": 53148443,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, your example json file contains three syntax errors:\r\n\r\n- A closing curly bracket `}` is missing at the end of text.\r\n- There is an extra double-quote just after *false,* in the second object.\r\n- The entire objects must be enclosed by square brackets `[]` as an array.\r\n\r\nThen the modified json file will look like:\r\n\r\n    $ cat test.json\r\n    [\r\n    {&quot;@hrinn&quot;: {&quot;host&quot;: {&quot;1&quot;: &quot; \\&quot;some.host.name\\&quot;,&quot;, &quot;2&quot;: &quot; false,&quot;}, &quot;password&quot;: {&quot;1&quot;: &quot; \\&quot;123456\\&quot;,&quot;}}},\r\n    {&quot;@hrinn&quot;: {&quot;host&quot;: {&quot;1&quot;: &quot; \\&quot;another.host.name\\&quot;,&quot;, &quot;2&quot;: &quot; false,&quot;}, &quot;password&quot;: {&quot;1&quot;: &quot; \\&quot;654321\\&quot;,&quot;}}},\r\n    {&quot;@Abnerene&quot;: {&quot;host&quot;: {&quot;1&quot;: &quot; \\&quot;example.com\\&quot;,&quot;, &quot;2&quot;: &quot; false,&quot;}, &quot;username&quot;: {&quot;1&quot;: &quot; \\&quot;username\\&quot;,&quot;}, &quot;password&quot;: {&quot;1&quot;: &quot; \\&quot;password123\\&quot;,&quot;}}}\r\n    ]\r\n\r\nNote that the inserted newlines are just for human readability and have nothing to do with the parser.  \r\nNow you can feed the json file to `jq`:\r\n\r\n    $ jq -r &#39;.[] | .[] | [.host[&quot;1&quot;], .username[&quot;1&quot;], .password[&quot;1&quot;]] | @sh&#39; test.json\r\n\r\nwhich yields:\r\n\r\n    &#39; &quot;some.host.name&quot;,&#39; null &#39; &quot;123456&quot;,&#39;\r\n    &#39; &quot;another.host.name&quot;,&#39; null &#39; &quot;654321&quot;,&#39;\r\n    &#39; &quot;example.com&quot;,&#39; &#39; &quot;username&quot;,&#39; &#39; &quot;password123&quot;,&#39;\r\n\r\nIf the values in your json file are proper ones, the result will look nicer.  \r\nHope this helps.\r\n",
                "title": "How to sort all the JSON data into plain TXT file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1541410038,
        "creation_date": 1541392841,
        "last_edit_date": 1541394043,
        "question_id": 53148443,
        "body_markdown": "I was wondering if someone could tell me how to sort the following JSON data into plain text ? I&#39;ve tried with &#39;jq&#39; and &#39;jsonv&#39; (linux apps) but no luck.\r\n\r\nHere&#39;s the JSON data:\r\n\r\n    {&quot;@hrinn&quot;: {&quot;host&quot;: {&quot;1&quot;: &quot; \\&quot;some.host.name\\&quot;,&quot;, &quot;2&quot;: &quot; false,&quot;}, &quot;password&quot;: {&quot;1&quot;: &quot; \\&quot;123456\\&quot;,&quot;}}},{&quot;@hrinn&quot;: {&quot;host&quot;: {&quot;1&quot;: &quot; \\&quot;another.host.name\\&quot;,&quot;, &quot;2&quot;: &quot; false,&quot;&quot;}, &quot;password&quot;: {&quot;1&quot;: &quot; \\&quot;654321\\&quot;,&quot;}}},{&quot;@Abnerene&quot;: {&quot;host&quot;: {&quot;1&quot;: &quot; \\&quot;example.com\\&quot;,&quot;, &quot;2&quot;: &quot; false,&quot;}, &quot;username&quot;: {&quot;1&quot;: &quot; \\&quot;username\\&quot;,&quot;}, &quot;password&quot;: {&quot;1&quot;: &quot; \\&quot;password123\\&quot;,&quot;}}\r\n\r\nPlease note that all the JSON data is all on the same line\r\n\r\nThe expected results would be:\r\n\r\n    hostname username password\r\n    host1.net johndoe q1w2e3\r\n    host2.com alex    qwerty\r\n    host3.org bob     123456  \r\n\r\n\r\nAny help would be very appreciated\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/53148443/how-to-sort-all-the-json-data-into-plain-txt-file",
        "title": "How to sort all the JSON data into plain TXT file"
    },
    {
        "tags": [
            "json",
            "bash",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14579781,
                    "reputation": 585,
                    "user_id": 10530633,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0f24d2c3110b0d1102168e8c16030f73?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nsa",
                    "link": "https://stackoverflow.com/users/10530633/nsa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541436777,
                "post_id": 53156774,
                "comment_id": 93208072,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8544586,
                    "reputation": 1538,
                    "user_id": 6403504,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/a16abf6e1930e8f1f081480c499b33fe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bowi",
                    "link": "https://stackoverflow.com/users/6403504/bowi"
                },
                "reply_to_user": {
                    "account_id": 14579781,
                    "reputation": 585,
                    "user_id": 10530633,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0f24d2c3110b0d1102168e8c16030f73?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nsa",
                    "link": "https://stackoverflow.com/users/10530633/nsa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541436970,
                "post_id": 53156774,
                "comment_id": 93208185,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541437504,
                "post_id": 53156774,
                "comment_id": 93208445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541438321,
                "post_id": 53156774,
                "comment_id": 93208824,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14579781,
                    "reputation": 585,
                    "user_id": 10530633,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0f24d2c3110b0d1102168e8c16030f73?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nsa",
                    "link": "https://stackoverflow.com/users/10530633/nsa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541440480,
                "post_id": 53156774,
                "comment_id": 93209815,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8544586,
                    "reputation": 1538,
                    "user_id": 6403504,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/a16abf6e1930e8f1f081480c499b33fe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bowi",
                    "link": "https://stackoverflow.com/users/6403504/bowi"
                },
                "reply_to_user": {
                    "account_id": 14579781,
                    "reputation": 585,
                    "user_id": 10530633,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0f24d2c3110b0d1102168e8c16030f73?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nsa",
                    "link": "https://stackoverflow.com/users/10530633/nsa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541491790,
                "post_id": 53156774,
                "comment_id": 93225736,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1541444801,
                "creation_date": 1541444801,
                "answer_id": 53160623,
                "question_id": 53156774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample input in input.json, and using jq 1.6 (or a jq with INDEX/2), the following invocation of jq produces the desired output:\r\n\r\n    jq -r --argjson ids &#39;[11111, 22222, 33333, 44444, 55555]&#39; -f tossv.jq input.json \r\n\r\nassuming tossv.jq contains the program:\r\n\r\n    INDEX(.persons[]; .personID) as $dict\r\n    | $ids\r\n    | map( $dict[tostring] | .phoneNumber)\r\n    | join(&quot;;&quot;)\r\n\r\n## Program notes\r\n1. INDEX/2 produces a JSON object that serves as a dictionary. Since JSON keys must be strings, `tostring` must be used in line 3 above.\r\n\r\n2. When using `join(&quot;;&quot;)`, `null` values effectively become empty strings.\r\n\r\n\r\n3. If your jq does not have INDEX/2, then now might be a good time to upgrade.   Otherwise you can snarf its definition by googling: `jq &quot;def INDEX&quot; builtin.jq`\r\n",
                "title": "Output semicolon-separated string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541492556,
                "creation_date": 1541492556,
                "answer_id": 53168163,
                "question_id": 53156774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately I couldn&#39;t test if [peak&#39;s answer][1] works since I only have jq 1.5. Here&#39;s what I came up with yesterday evening:\r\n\r\n* For each semicolon, add the following query\r\n\r\n        (\\&quot;;\\&quot; as \\$a | \\$a)\r\n\r\n* Resulting command (abstract):\r\n\r\n         cat persons.txt | jq &quot;(&lt;1&#39;s phone number&gt;), (\\&quot;;\\&quot; as \\$a | \\$a), \r\n         (&lt;2&#39;s phone number&gt;), (\\&quot;;\\&quot; as \\$a | \\$a), ...&quot;\r\n\r\n* Resulting command (concrete):\r\n\r\n        cat persons.txt | jq &quot;(.persons[] | select(.personID==11111) | .phoneNumber), (\\&quot;;\\&quot; as \\$a | \\$a), \r\n        (.persons[] | select(.personID==22222) | .phoneNumber), (\\&quot;;\\&quot; as \\$a | \\$a), \r\n        (.persons[] | select(.personID==33333) | .phoneNumber), (\\&quot;;\\&quot; as \\$a | \\$a), \r\n        (.persons[] | select(.personID==44444) | .phoneNumber), (\\&quot;;\\&quot; as \\$a | \\$a), \r\n        (.persons[] | select(.personID==55555) | .phoneNumber)&quot;\r\n\r\n* Result: \r\n\r\n        123456\r\n        &quot;;&quot;\r\n        432100\r\n        &quot;;&quot;\r\n        &quot;;&quot;\r\n        &quot;;&quot;\r\n        147258\r\n\r\n* Delete the newlines and `&quot;`:\r\n\r\n        &lt;commandAsAbove&gt; | tr --delete &quot;\\n\\&quot;&quot;\r\n\r\n* Result:\r\n\r\n        123456;432100;;;147258\r\n\r\nDo not get me wrong, this is far uglier than peak&#39;s answer, but it worked for me yesterday.\r\n\r\n  [1]: https://stackoverflow.com/a/53160623/6403504",
                "title": "Output semicolon-separated string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541517769,
                "creation_date": 1541517769,
                "answer_id": 53174879,
                "question_id": 53156774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without jq solution:\r\n\r\n    for i in $(seq 11111 11111 55555)\r\n    do\r\n      string=$(grep -B1 &quot;$i&quot; persons.txt | head -1 | sed &#39;s/.* \\(.*\\),/\\1/g&#39;)\r\n      echo &quot;$string;&quot; &gt;&gt; output\r\n    done\r\n    cat output | tr -d &#39;\\n&#39; | rev | cut -d&#39;;&#39; -f2- | rev &gt; tmp &amp;&amp; mv tmp output\r\n\r\nThis little script will yield the result you want and you can adapt it quickly if the input data varies\r\n\r\n    cat output\r\n    123456;432100;;;147258\r\n\r\n\r\n",
                "title": "Output semicolon-separated string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1541517769,
        "creation_date": 1541429528,
        "last_edit_date": 1541455588,
        "question_id": 53156774,
        "body_markdown": "Lets say we have this file:\r\n\r\n    {\r\n      &quot;persons&quot;: [\r\n        {\r\n          &quot;friends&quot;: 4,\r\n          &quot;phoneNumber&quot;: 123456,\r\n          &quot;personID&quot;: 11111\r\n        },\r\n        {\r\n          &quot;friends&quot;: 2057,\r\n          &quot;phoneNumber&quot;: 432100,\r\n          &quot;personID&quot;: 22222\r\n        },\r\n        {\r\n          &quot;friends&quot;: 50,\r\n          &quot;phoneNumber&quot;: 147258,\r\n          &quot;personID&quot;: 55555\r\n        }\r\n      ]\r\n    }\r\n\r\nI now want to extract the phone numbers of the persons `11111`, `22222`, `33333`, `44444` and `55555` as a semicolon-separated string:\r\n\r\n    123456;432100;;;147258\r\n\r\nWhile running \r\n\r\n    cat persons.txt | jq &quot;.persons[] | select(.personID==&lt;ID&gt;) | .phoneNumber&quot;\r\n\r\nonce for each `&lt;ID&gt;` and glueing the results together with the `;` afterwards works, this is terribly slow, because it has to reload the file for each of the IDs (and other fields I want to extract).\r\n\r\nConcatenating it in a single query:\r\n\r\n     cat persons.txt | jq &quot;(.persons[] | select(.personID==11111) | .phoneNumber), (.persons[] | select(.personID==22222) | .phoneNumber), (.persons[] | select(.personID==33333) | .phoneNumber), (.persons[] | select(.personID==44444) | .phoneNumber), (.persons[] | select(.personID==55555) | .phoneNumber)&quot;\r\n\r\nThis also works, but it gives\r\n\r\n    123456\r\n    432100\r\n    147258\r\n\r\nso I do not know which of the fields are missing and how many `;` I have to insert.",
        "link": "https://stackoverflow.com/questions/53156774/output-semicolon-separated-string",
        "title": "Output semicolon-separated string"
    }
]