[
  {
    "context": [
      "I am trying to restructure my JSON by assigning an id to each object in a given array. This id would be created by using an existing key value (osm_id).",
      "This is my input:",
      "[ { \"geometry\" : { \"coordinates\" : [ -0.7118478, 51.0930284 ], \"type\" : \"Point\" }, \"properties\" : { \"osm_id\" : \"262661\", \"religion\" : \"christian\" }, \"type\" : \"Feature\" }, { \"geometry\" : { \"coordinates\" : [ -0.7207513, 51.0897118 ], \"type\" : \"Point\" }, \"properties\" : { \"denomination\" : \"catholic\", \"osm_id\" : \"262662\", \"religion\" : \"christian\" }, \"type\" : \"Feature\" } ]",
      "This is my desired output:",
      "\"262661\": { ... }, \"262662\": { ... }",
      "jq 'map( { (.properties.osm_id|tostring): . } ) | add'"
    ],
    "utterance": "Restructure an array so that each element becomes a key-value pair with the key taken from properties.osm_id and the value as the entire original object.",
    "expressions": [
      "map({ (.properties.osm_id|tostring): . }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "geometry": {
              "coordinates": [
                -0.7118478,
                51.0930284
              ],
              "type": "Point"
            },
            "properties": {
              "osm_id": "262661",
              "religion": "christian"
            },
            "type": "Feature"
          },
          {
            "geometry": {
              "coordinates": [
                -0.7207513,
                51.0897118
              ],
              "type": "Point"
            },
            "properties": {
              "denomination": "catholic",
              "osm_id": "262662",
              "religion": "christian"
            },
            "type": "Feature"
          }
        ],
        "output": {
          "262661": {
            "geometry": {
              "coordinates": [
                -0.7118478,
                51.0930284
              ],
              "type": "Point"
            },
            "properties": {
              "osm_id": "262661",
              "religion": "christian"
            },
            "type": "Feature"
          },
          "262662": {
            "geometry": {
              "coordinates": [
                -0.7207513,
                51.0897118
              ],
              "type": "Point"
            },
            "properties": {
              "denomination": "catholic",
              "osm_id": "262662",
              "religion": "christian"
            },
            "type": "Feature"
          }
        }
      }
    ],
    "identifier": 42443409
  },
  {
    "context": [
      "Given a json file in the format as :\r\n\r\n[\r\n {\r\n  name : \"A\",\r\n  value : \"1\"\r\n },\r\n {\r\n  name : \"B\",\r\n  value : \"5\"\r\n },\r\n {\r\n  name : \"E\",\r\n  value : \"8\"\r\n }\r\n]",
      "How would I convert it to something like this using jq:\r\n\r\n{\r\n \"A\" : {\r\n   name : \"A\",\r\n   value : \"1\"\r\n },\r\n \"B\" : {\r\n  name : \"B\",\r\n  value : \"5\"\r\n },\r\n \"E\" : {\r\n  name : \"E\",\r\n  value : \"8\"\r\n }\r\n}",
      "map( { (.name|tostring): . } ) | add",
      "If your jq has `INDEX/1` (introduced in version 1.6), you can simply write:\r\n\r\n    INDEX(.name)",
      "reduce .[] as $i ({}; .[$i.name] = $i)"
    ],
    "utterance": "Transform an array of objects, each with a 'name' field, into an object where each key is the value of 'name' and its value is the corresponding object.",
    "expressions": [
      "map({ (.name|tostring): . }) | add",
      "INDEX(.name)",
      "reduce .[] as $i ({}; .[$i.name] = $i)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "A",
            "value": "1"
          },
          {
            "name": "B",
            "value": "5"
          },
          {
            "name": "E",
            "value": "8"
          }
        ],
        "output": {
          "A": {
            "name": "A",
            "value": "1"
          },
          "B": {
            "name": "B",
            "value": "5"
          },
          "E": {
            "name": "E",
            "value": "8"
          }
        }
      }
    ],
    "identifier": 42427725
  },
  {
    "context": [
      "So add the top level fields and the object from the skills array if lang=spanish and the school hash from the skills object for spanish if it exists",
      "| [.name, .age] +\n  (.skills[]\n  | select(.lang == \"spanish\")\n  | [.grade, .school.name, .school.url, input_filename, input_line_number] )\n| @csv"
    ],
    "utterance": "Extract name and age, plus the grade, school name, and school url from the skills entry where lang is spanish; include file and line number in each row; output as CSV.",
    "expressions": [
      ".[]\n| [.name, .age] +\n  (.skills[]\n   | select(.lang == \"spanish\")\n   | [.grade, .school.name, .school.url, input_filename, input_line_number])\n| @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "joe",
            "age": 21,
            "skills": [
              {
                "lang": "spanish",
                "grade": "47",
                "school": {
                  "name": "my school",
                  "url": "example.com/sp-school"
                }
              },
              {
                "lang": "english",
                "grade": "87"
              }
            ]
          },
          {
            "name": "sarah",
            "age": 34,
            "skills": [
              {
                "lang": "french",
                "grade": "47",
                "school": {
                  "name": "my school",
                  "url": "example.com/sp-school"
                }
              },
              {
                "lang": "english",
                "grade": "87"
              }
            ]
          },
          {
            "name": "jim",
            "age": 26,
            "skills": [
              {
                "lang": "spanish",
                "grade": "60"
              },
              {
                "lang": "english",
                "grade": "66",
                "school": {
                  "name": "eg school",
                  "url": "eg-school.com"
                }
              }
            ]
          }
        ],
        "output": [
          "\"joe\",21,\"47\",\"my school\",\"example.com/sp-school\",\"input.json\",51",
          "\"jim\",26,\"60\",,,\"input.json\",51"
        ]
      }
    ],
    "identifier": 41605653
  },
  {
    "context": [
      "Consider:\r\n\r\n    $ jq -c 'keys[] as $k | ($k, .[$k])' <<< \"$var\"\r\n    \"build\"\r\n    \"123\"\r\n    \"deploy\"\r\n    \"False\"\r\n    \"install\"\r\n    \"False\"\r\n    \"ip\"\r\n    \"0.0.0.0\"\r\n    \"password\"\r\n    \"kilby\"\r\n    \"user\"\r\n    \"jack\"\r\n\r\nYou can then use the bash command, `readarray`, or the idiom: \r\n\r\n    while read -r line\r\n    do ...\r\n    done",
      "If you want these pairs in an associative array in bash 4+, you might do this:\r\n\r\n    $ declare -A a=\"( $(jq -r 'keys[] as $k | \"[\\($k)]=\\\"\\(.[$k])\\\"\"' <<<\"$var\" ) )\"\r\n    $ declare -p a\r\n    declare -A a=([build]=\"123\" [install]=\"False\" [ip]=\"0.0.0.0\" [user]=\"jack\" [deploy]=\"False\" [password]=\"kilby\" )",
      "### Using `jq`:\r\n\r\n    readarray -t arr < <(jq -r 'keys_unsorted[] as $k | $k, .[$k]' properties.txt)\r\n\r\nThe `jq` command is a variation of [peak's helpful answer](https://stackoverflow.com/a/42317877/45375): `keys_unsorted` ensures that the keys are enumerated in input order, and `-r` ensures that the results are output as raw values rather than JSON-encoded, which in this case means that the double quotes are stripped."
    ],
    "utterance": "Extract all key and value pairs as alternating elements in an array, preserving order; empty string values must be included as empty entries.",
    "expressions": [
      "jq -r 'keys_unsorted[] as $k | $k, .[$k]' properties.txt",
      "jq -c 'keys[] as $k | ($k, .[$k])' <<< \"$var\""
    ],
    "data": [
      {
        "input": {
          "k1": "",
          "k2": "",
          "k3": ""
        },
        "output": [
          "k1",
          "",
          "k2",
          "",
          "k3",
          ""
        ]
      },
      {
        "input": {
          "user": "jack",
          "password": "kilby",
          "install": "False",
          "deploy": "False",
          "build": "123",
          "ip": "0.0.0.0"
        },
        "output": [
          "user",
          "jack",
          "password",
          "kilby",
          "install",
          "False",
          "deploy",
          "False",
          "build",
          "123",
          "ip",
          "0.0.0.0"
        ]
      }
    ],
    "identifier": 42316542
  },
  {
    "context": [
      "I&#39;m trying to extract the `sids, ll, state, name, smry` values in my `JSON` file using `jq` and export to a csv.",
      ".data[]|{\r\n        \"sids\":(.meta.sids[0]|split(\" \")[0]),\r\n        \"ll\":(.meta.ll|map(tostring)|join(\",\")),\r\n        \"state\":.meta.state,\r\n        \"name\":.meta.name,\r\n        \"smry\":(.smry[]|join(\",\"))\r\n    }|join(\",\")",
      "# or, for robust csv output\r\n    # } | @csv ",
      "Output:\r\n\r\n    CA008102500,-66.9333,47.0667,NB,LONG LAKE,42,1955-02-23\r\n    CA008103425,-67.2333,45.9667,NB,NACKAWIC,40,1969-02-23\r\n    CA008104933,-67.4667,47.4667,NB,ST QUENTIN,M,M\r\n    CA008104936,-67.2667,45.1833,NB,ST STEPHEN,48,1900-02-23\r\n    CA008105000,-67.25,47.2667,NB,SISSON DAM,35,1955-02-23\r\n"
    ],
    "utterance": "Export the sids, ll, state, name, and smry values from each data entry as comma-separated lines, formatting ll as two comma-separated numbers and flattening arrays to single values.",
    "expressions": [
      ".data[] | {\"sids\": (.meta.sids[0] | split(\" \")[0]), \"ll\": (.meta.ll | map(tostring) | join(\",\")), \"state\": .meta.state, \"name\": .meta.name, \"smry\": (.smry[] | join(\",\"))} | join(\",\")",
      ".data[] | [(.meta.sids[0]|split(\" \")[0]), (.meta.ll[]), .meta.state, .meta.name, (.smry[0][])] | @csv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "meta": {
                "uid": 74529,
                "ll": [
                  -66.9333,
                  47.0667
                ],
                "sids": [
                  "CA008102500 6"
                ],
                "state": "NB",
                "elev": 1250,
                "name": "LONG LAKE"
              },
              "smry": [
                [
                  "42",
                  "1955-02-23"
                ]
              ]
            },
            {
              "meta": {
                "uid": 74534,
                "ll": [
                  -67.2333,
                  45.9667
                ],
                "sids": [
                  "CA008103425 6"
                ],
                "state": "NB",
                "elev": 150.9,
                "name": "NACKAWIC"
              },
              "smry": [
                [
                  "40",
                  "1969-02-23"
                ]
              ]
            },
            {
              "meta": {
                "uid": 74549,
                "ll": [
                  -67.4667,
                  47.4667
                ],
                "sids": [
                  "CA008104933 6"
                ],
                "state": "NB",
                "elev": 794,
                "name": "ST QUENTIN"
              },
              "smry": [
                [
                  "M",
                  "M"
                ]
              ]
            },
            {
              "meta": {
                "uid": 74550,
                "ll": [
                  -67.2667,
                  45.1833
                ],
                "sids": [
                  "CA008104936 6"
                ],
                "state": "NB",
                "elev": 36.1,
                "name": "ST STEPHEN"
              },
              "smry": [
                [
                  "48",
                  "1900-02-23"
                ]
              ]
            },
            {
              "meta": {
                "uid": 74554,
                "ll": [
                  -67.25,
                  47.2667
                ],
                "sids": [
                  "CA008105000 6"
                ],
                "state": "NB",
                "elev": 915.4,
                "name": "SISSON DAM"
              },
              "smry": [
                [
                  "35",
                  "1955-02-23"
                ]
              ]
            }
          ]
        },
        "output": [
          "CA008102500,-66.9333,47.0667,NB,LONG LAKE,42,1955-02-23",
          "CA008103425,-67.2333,45.9667,NB,NACKAWIC,40,1969-02-23",
          "CA008104933,-67.4667,47.4667,NB,ST QUENTIN,M,M",
          "CA008104936,-67.2667,45.1833,NB,ST STEPHEN,48,1900-02-23",
          "CA008105000,-67.25,47.2667,NB,SISSON DAM,35,1955-02-23"
        ]
      }
    ],
    "identifier": 42414365
  },
  {
    "context": [
      "I have a json structure and would like to replace strings in 2 fields that are in a seperate text file.",
      "Here is the json file with 2 records:",
      "And here is the txt file that I want to substitue in:",
      "The key to the following solution is the helper function, `map_nth_value/2`, which modifies the value of the nth key in a JSON object:",
      "With the above jq program in a file (say program.jq), and with the text file in a file (say input.txt) and the JSON object in a file (say object.json), the following invocation:",
      "produces:",
      "{ ... \"l\": [49.28713, -123.124026] ... }, { ... \"l\": [36.12977, -115.172811] ... }"
    ],
    "utterance": "Replace the values of all '.geo.*.l' fields with pairs of numbers provided line by line in a separate text file, in order.",
    "expressions": [
      "def map_nth_value(n; filter):\n  to_entries\n  | (.[n] |= {\"key\": .key, \"value\": (.value | filter)} )\n  | from_entries ;\n[inputs | select(length > 0) | split(\",\") | map(tonumber)] as $lists\n| reduce range(0; $lists|length) as $i\n    ( $object;\n      .geo |= map_nth_value($i; .l = $lists[$i] ) )"
    ],
    "data": [
      {
        "input": {
          "events": {
            "-KKQQIUR7FAVxBOPOFhr": {
              "dateAdded": 1487592568926,
              "owner": "62e6aaa0-a50c-4448-a381-f02efde2316d",
              "type": "boycott"
            },
            "-KKjjM-pAXvTuEjDjoj_": {
              "dateAdded": 1487933370561,
              "owner": "62e6aaa0-a50c-4448-a381-f02efde2316d",
              "type": "boycott"
            }
          },
          "geo": {
            "-KKQQIUR7FAVxBOPOFhr": {
              ".priority": "qw3yttz1k9",
              "g": "qw3yttz1k9",
              "l": [
                40.762632,
                -73.973837
              ]
            },
            "-KKjjM-pAXvTuEjDjoj_": {
              ".priority": "qw3yttx6bv",
              "g": "qw3yttx6bv",
              "l": [
                41.889019,
                -87.626291
              ]
            }
          },
          "log": "null",
          "users": {
            "62e6aaa0-a50c-4448-a381-f02efde2316d": {
              "events": {
                "-KKQQIUR7FAVxBOPOFhr": {
                  "type": "boycott"
                },
                "-KKjjM-pAXvTuEjDjoj_": {
                  "type": "boycott"
                }
              }
            }
          }
        },
        "output": {
          "events": {
            "-KKQQIUR7FAVxBOPOFhr": {
              "dateAdded": 1487592568926,
              "owner": "62e6aaa0-a50c-4448-a381-f02efde2316d",
              "type": "boycott"
            },
            "-KKjjM-pAXvTuEjDjoj_": {
              "dateAdded": 1487933370561,
              "owner": "62e6aaa0-a50c-4448-a381-f02efde2316d",
              "type": "boycott"
            }
          },
          "geo": {
            "-KKQQIUR7FAVxBOPOFhr": {
              ".priority": "qw3yttz1k9",
              "g": "qw3yttz1k9",
              "l": [
                49.28713,
                -123.124026
              ]
            },
            "-KKjjM-pAXvTuEjDjoj_": {
              ".priority": "qw3yttx6bv",
              "g": "qw3yttx6bv",
              "l": [
                36.12977,
                -115.172811
              ]
            }
          },
          "log": "null",
          "users": {
            "62e6aaa0-a50c-4448-a381-f02efde2316d": {
              "events": {
                "-KKQQIUR7FAVxBOPOFhr": {
                  "type": "boycott"
                },
                "-KKjjM-pAXvTuEjDjoj_": {
                  "type": "boycott"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 42450296
  },
  {
    "context": [
      "I wish to find an element inside the \"conference\" Json TAG, when I find the Conference name I wonder how to bring \"connect_time\" once I had found the conference value:",
      "conference\": \"JOG1_VMR6\" \r\n\r\nI wanna find what is the \"connect_time\" in this particular",
      "jq  '.objects[] | select(.conference==\"JOG1_VMR6\") | .connect_time'"
    ],
    "utterance": "Find the connect_time of the object where conference is equal to JOG1_VMR6.",
    "expressions": [
      ".objects[] | select(.conference==\"JOG1_VMR6\") | .connect_time"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "limit": 200,
            "next": null,
            "offset": 0,
            "previous": null,
            "total_count": 2
          },
          "objects": [
            {
              "bandwidth": 768,
              "call_direction": "in",
              "call_uuid": "84e6098a-d0a9-44ed-846e-074b6d563cfb",
              "conference": "JOG1_VMR6",
              "connect_time": "2017-01-26T19:20:01.096940",
              "destination_alias": "9892@192.168.20.11",
              "display_name": "JG - Sala 2",
              "encryption": "On",
              "has_media": true,
              "id": "92dab287-0091-4d57-bdff-f37cce6c586e",
              "is_muted": false,
              "is_on_hold": false,
              "is_presentation_supported": true,
              "is_presenting": false,
              "is_streaming": false,
              "license_count": 1,
              "license_type": "port",
              "media_node": "192.168.20.11",
              "parent_id": "",
              "participant_alias": "h323:192.168.51.153",
              "protocol": "H323",
              "remote_address": "192.168.51.153",
              "remote_port": 11000,
              "resource_uri": "/api/admin/status/v1/participant/92dab287-0091-4d57-bdff-f37cce6c586e/",
              "role": "chair",
              "service_tag": "JOG1",
              "service_type": "conference",
              "signalling_node": "192.168.20.11",
              "source_alias": "h323:192.168.51.153",
              "system_location": "CUSTOMER-JG-LAN",
              "vendor": "TANDBERG (Tandberg 529)"
            },
            {
              "bandwidth": 1280,
              "call_direction": "in",
              "call_uuid": "dd60c9a2-22e0-4685-9a3d-8573e5e6cc75",
              "conference": "Sala_Teste-Turn-up",
              "connect_time": "2017-01-27T01:42:11.103894",
              "destination_alias": "5001",
              "display_name": "John",
              "encryption": "On",
              "has_media": true,
              "id": "dd60c9a2-22e0-4685-9a3d-8573e5e6cc75",
              "is_muted": false,
              "is_on_hold": false,
              "is_presentation_supported": false,
              "is_presenting": false,
              "is_streaming": false,
              "license_count": 1,
              "license_type": "port",
              "media_node": "172.24.25.106",
              "parent_id": "",
              "participant_alias": "John",
              "protocol": "WebRTC",
              "remote_address": "179.65.15.9",
              "remote_port": 62794,
              "resource_uri": "/api/admin/status/v1/participant/dd60c9a2-22e0-4685-9a3d-8573e5e6cc75/",
              "role": "chair",
              "service_tag": "JOG",
              "service_type": "conference",
              "signalling_node": "172.24.25.106",
              "source_alias": "John",
              "vendor": "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36"
            }
          ]
        },
        "output": "2017-01-26T19:20:01.096940"
      }
    ],
    "identifier": 42090354
  },
  {
    "context": [
      "In this file, I want to grep `\"1a\":\"<value>\"` and `\"h\":\"<value of logA or logB>\"` which there should not be any duplicates.",
      "Expected Output:\n\n    \"1a\":\"2017-01-28 00:00:00\" \"h\":\"logA\"\n    \"1a\":\"2017-01-28 00:00:11\" \"h\":\"logB\"",
      "Instead of standard utilities, consider use of the very flexible **[`jq`](https://stedolan.github.io/jq/) JSON CLI**, which:\n\n* simplifies the solution\n* makes it robust\n* allows it to be generalized.\n\n<!--  -->\n\n    echo '\n    [\n      { \"1a\":\"2017-01-28 00:00:00\", \"2a\":\"sample\", \"h\":\"logA\", \"i\":\"IFX\" }, \n      { \"1a\":\"2017-01-28 00:00:11\", \"2a\":\"sample\", \"h\":\"logB\", \"i\":\"IFX\" }\n    ]' |\n      jq -r --argjson keys '[ \"1a\", \"h\" ]' '\n        .[] | \"\\\"\\($keys[0])\\\": \\\"\\(.[$keys[0]])\\\" \\\"\\($keys[1])\\\": \\\"\\(.[$keys[1]])\\\"\"\n      ' \n\nyields:\n\n    \"1a\": \"2017-01-28 00:00:00\" \"h\": \"logA\"\n    \"1a\": \"2017-01-28 00:00:11\" \"h\": \"logB\"",
      "here's **a simpler, more `jq`-like alternative that yields the same output**:\n\n    echo '\n    [\n      { \"1a\":\"2017-01-28 00:00:00\", \"2a\":\"sample\", \"h\":\"logA\", \"i\":\"IFX\" },\n      { \"1a\":\"2017-01-28 00:00:11\", \"2a\":\"sample\", \"h\":\"logB\", \"i\":\"IFX\" }\n    ]\n    ' |\n      jq -r --argjson keys '[ \"1a\", \"h\", \"i\"  ]' '\n        def printKv($k): \"\\\"\\($k)\\\": \\\"\\(.[$k])\\\"\";\n        .[] | [ $keys[] as $k | printKv($k) ] | join(\" \")\n      '\n\nyields (3 key-value pairs per line, because 3 keys were passed):\n\n    \"1a\": \"2017-01-28 00:00:00\" \"h\": \"logA\" \"i\": \"IFX\"\n    \"1a\": \"2017-01-28 00:00:11\" \"h\": \"logB\" \"i\": \"IFX\"",
      "def printKV($k): \"\\\"\\($k)\\\": \\\"\\(.[$k])\\\"\"; \n\n.[] | printKV($keys[0]) + \" \" + printKV($keys[1])",
      ".[] | printKeyValues($keys)"
    ],
    "utterance": "Extract the values of fields named \"1a\" and \"h\" from each object, formatting the output as pairs of key-value strings separated by a space, for all records in the data.",
    "expressions": [
      "jq -r --argjson keys '[ \"1a\", \"h\" ]' '.[] | \"\\\"\\($keys[0])\\\": \\\"\\(.[$keys[0]])\\\" \\\"\\($keys[1])\\\": \\\"\\(.[$keys[1]])\\\"\"'",
      "jq -r --argjson keys '[ \"1a\", \"h\" ]' 'def printKv($k): \"\\\"\\($k)\\\": \\\"\\(.[$k])\\\"\"; .[] | [ $keys[] as $k | printKv($k) ] | join(\" \")'",
      "jq -r --argjson keys '[ \"1a\", \"h\" ]' 'def printKV($k): \"\\\"\\($k)\\\": \\\"\\(.[$k])\\\"\"; .[] | printKV($keys[0]) + \" \" + printKV($keys[1])'"
    ],
    "data": [
      {
        "input": [
          {
            "1a": "2017-01-28 00:00:00",
            "2a": "sample",
            "a": "12345",
            "b": "2017-02-06",
            "c": "2017-02-06T17:51:02.454-08:00",
            "d": "Mozilla/5.0 ; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1",
            "e": "2017-02-06 ",
            "f": "03",
            "g": "example",
            "h": "logA",
            "i": "IFX",
            "j": "a85",
            "k": "12345678"
          },
          {
            "1a": "2017-01-28 00:00:11",
            "2a": "sample",
            "a": "12345",
            "b": "2017-02-06",
            "c": "2017-02-06T17:51:02.454-08:00",
            "d": "Mozilla/5.0 ; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1",
            "e": "2017-02-06 ",
            "f": "03",
            "g": "example",
            "h": "logB",
            "i": "IFX",
            "j": "a85",
            "k": "12345678"
          }
        ],
        "output": [
          "\"1a\": \"2017-01-28 00:00:00\" \"h\": \"logA\"",
          "\"1a\": \"2017-01-28 00:00:11\" \"h\": \"logB\""
        ]
      }
    ],
    "identifier": 42389561
  },
  {
    "context": [
      "How do I check for the presence of `.property_history` key before proceeding with `map(...)`?",
      "You can use the select-expression in `jq` to do what you intend to achieve, something as,\n\n    jq '.result \n      | select(.property_history != null) \n      | .property_history \n      | map(select(.event_name == \"Sold\"))[0].date'",
      "Technically, to test for the presence of a property, you should use `has/1`, but in the present context, it would probably be better to use the postfix `?` operator, e.g.:\n\n    $ jq '.result \n      | .property_history[]?\n      | select(.event_name == \"Sold\") \n      | .date'\n    \"08/30/2004\"",
      "The trick is to use // together with empty:\n\n```\njq '.result.property_history // empty | map(select(.event_name == \"Sold\"))[0:1][].date'\n```",
      "Another alternative is to use an additional select:\n\n```javascript\njq '.result.property_history | select(.) | map(select(.event_name == \"Sold\"))[0:1][].date'\n```",
      "General pattern:\n\n    try (...) // \"default_value\"\n\nWith your logic:\n\n    jq 'try (.result.property_history | map(select(.event_name == \"Sold\"))[0].date) // \"default_value\"'"
    ],
    "utterance": "Extract the date of the first object with event_name equal to \"Sold\" from result.property_history, but only if the property_history key exists; otherwise, return null or nothing.",
    "expressions": [
      ".result | select(.property_history != null) | .property_history | map(select(.event_name == \"Sold\"))[0].date",
      ".result | .property_history[]? | select(.event_name == \"Sold\") | .date",
      ".result.property_history // empty | map(select(.event_name == \"Sold\"))[0:1][].date",
      ".result.property_history | select(.) | map(select(.event_name == \"Sold\"))[0:1][].date",
      "try (.result.property_history | map(select(.event_name == \"Sold\"))[0].date) // null"
    ],
    "data": [
      {
        "input": {
          "result": {
            "property_history": [
              {
                "date": "01/27/2016",
                "price_changed": 0,
                "price": 899750,
                "event_name": "Listed",
                "sqft": 0
              },
              {
                "date": "12/15/2015",
                "price_changed": 0,
                "price": 899750,
                "event_name": "Listed",
                "sqft": 2357
              },
              {
                "date": "08/30/2004",
                "price_changed": 0,
                "price": 739000,
                "event_name": "Sold",
                "sqft": 2357
              }
            ]
          }
        },
        "output": "08/30/2004"
      },
      {
        "input": {
          "result": {
            "some_other_key": []
          }
        },
        "output": null
      }
    ],
    "identifier": 42097410
  },
  {
    "context": [
      "What I'm trying to do is inside of .outputLayout.fields[] I want to create a new pair called \"isIdentifier\" where it is true if the .outputLayout.fields[].name is LoadSeqNum and false if it's not but I need to keep the rest of the json just as it is.",
      ".outputLayout.fields[] |= (.isIdentifier = (.displayName == \"LoadSeqNum\") )",
      ".outputLayout.fields |= map( .isIdentifier = (.displayName == \"LoadSeqNum\") )"
    ],
    "utterance": "Add an isIdentifier field to each object in outputLayout.fields, setting it to true if the displayName is LoadSeqNum and false otherwise, while preserving the rest of the structure.",
    "expressions": [
      ".outputLayout.fields[] |= (.isIdentifier = (.displayName == \"LoadSeqNum\") )",
      ".outputLayout.fields |= map( .isIdentifier = (.displayName == \"LoadSeqNum\") )"
    ],
    "data": [
      {
        "input": {
          "importType": "Upsert",
          "immediateDeployment": false,
          "isIgnoreNulls": false,
          "isOverwriteNullsOnly": false,
          "isPreferredandSync": false,
          "outputLayout": {
            "fields": [
              {
                "name": "TEMP_KEY",
                "type": "String",
                "length": "2000",
                "displayName": "TEMP_KEY"
              },
              {
                "name": "LoadSeqNum",
                "type": "String",
                "length": "2000",
                "displayName": "LoadSeqNum"
              }
            ]
          }
        },
        "output": {
          "importType": "Upsert",
          "immediateDeployment": false,
          "isIgnoreNulls": false,
          "isOverwriteNullsOnly": false,
          "isPreferredandSync": false,
          "outputLayout": {
            "fields": [
              {
                "name": "TEMP_KEY",
                "type": "String",
                "length": "2000",
                "displayName": "TEMP_KEY",
                "isIdentifier": false
              },
              {
                "name": "LoadSeqNum",
                "type": "String",
                "length": "2000",
                "displayName": "LoadSeqNum",
                "isIdentifier": true
              }
            ]
          }
        }
      }
    ],
    "identifier": 42148703
  },
  {
    "context": [
      "Here in the following code snippet I have to replace `v`'s value corresponding to key `k` in the JSON object `node`.",
      "The problem is if there is already a value is present then I need to pass an empty string as value.",
      "If `v` is an empty string, you need to quote its expansion. You should pass the value of `$k` via a variable as well, rather than attempting to interpolate it.",
      "jq --arg flag \"$node\" \\\n   --arg temp  \"$v\" \\\n   --arg k1 \"$k\" \\\n   '(.[$flag]|.[$k1])|=$temp' properties.json > tempprop.json"
    ],
    "utterance": "Replace the value of key k within object node with a given value v, which may be an empty string.",
    "expressions": [
      "(.[$flag]|.[$k1])|=$temp"
    ],
    "identifier": 42320072
  },
  {
    "context": [
      "What I would like to get, using jq, is simply an array of objects containing all the objects of the bottom layer, each of which with an additional key/value pair identifying the top-layer key it originally belonged to.",
      "In other words, I would like to turn a JSON\n\n    {\n     \"key1\": [obj1, obj2],\n     \"key2\": [obj3]\n    }\n\ninto a plain array\n\n    [OBJ1, OBJ2, OBJ3]\n\nwhere each `OBJi` is simply the original object with an extra key/value pair\n\n    \"parent-key-name\": keyx\n\nwhere `keyx` would be the top-layer key `obji` belonged to, i.e. `\"key1\"` for `obj1` and `obj2`, and `\"key2\"` for `obj3`.",
      "You can divide your items to entries, store the key in a variable and add the value for each item in `value` object:",
      "jq  '[ to_entries[] | .key as $parent | .value[] |\n   .[\"parent-key-name\"] |= (.+ $parent) ] ' test.json",
      "1. First, let's make the changes to obj[i] \"in-place\":",
      "with_entries( .key as $k | .value[] |= ( . + {\"parent-key-name\": $k} ) )",
      "2. To flatten, simply append `| [.[]]` to the above filter. This produces:"
    ],
    "utterance": "Flatten a nested object where each top-level key maps to an array of objects into an array, adding a field 'parent-key-name' to each object with the key it originated from.",
    "expressions": [
      "[to_entries[] | .key as $parent | .value[] | . + {\"parent-key-name\": $parent}]",
      "with_entries(.key as $k | .value[] |= (. + {\"parent-key-name\": $k})) | [.[]]"
    ],
    "data": [
      {
        "input": {
          "key1": [
            {
              "name": "Emma"
            },
            {
              "name": "Bob"
            }
          ],
          "key2": [
            {
              "name": "Jean"
            }
          ]
        },
        "output": [
          {
            "name": "Emma",
            "parent-key-name": "key1"
          },
          {
            "name": "Bob",
            "parent-key-name": "key1"
          },
          {
            "name": "Jean",
            "parent-key-name": "key2"
          }
        ]
      }
    ],
    "identifier": 42401073
  },
  {
    "context": [
      "Now, I want to parse this, and get the key out of it and store it in a variable.",
      "ID=$(echo $json | jq '.key' )",
      "You will need to quote the input string so the shell doesn't do anything with your string",
      "json='{\"id\":\"12345\",\"key\":\"ABC-DEF\",\"url\":\"https://google.com\"}'",
      "ID=$(echo \"$json\" | jq '.key' )"
    ],
    "utterance": "Extract the value of the key field from an input object where key is present, specifically retrieving 'ABC-DEF'.",
    "expressions": [
      ".key"
    ],
    "data": [
      {
        "input": {
          "id": "12345",
          "key": "ABC-DEF",
          "url": "https://google.com"
        },
        "output": "ABC-DEF"
      }
    ],
    "identifier": 41562602
  },
  {
    "context": [
      "I want the \"c\" value for each",
      "Something like: \".a.*.c\"",
      ".a | .[] | .c",
      "which can be abbreviated as:",
      ".a[].c"
    ],
    "utterance": "Extract all values associated with the key 'c' under the object 'a' whose keys are dynamic or numeric.",
    "expressions": [
      ".a | .[] | .c",
      ".a[].c"
    ],
    "data": [
      {
        "input": {
          "a": {
            "1": {
              "c": "text1"
            },
            "999": {
              "c": "text99"
            }
          }
        },
        "output": [
          "text1",
          "text99"
        ]
      }
    ],
    "identifier": 41389347
  },
  {
    "context": [
      "I want to get only Photo values, from output i want get this:",
      "\"photo_807\": \"Ih2RnaBTg2o.jpg\"",
      "\"photo_604\": \"zodCm9fQgX8.jpg\"",
      "\"photo_130\": \"4Dx-SUNKBw4.jpg\"",
      "Now about my problem, from next JSON file i will get photo items with new names like this:",
      "\"photo_181\": \"Ih2RnaBTg2o.jpg\",",
      "\"photo_583\": \"zodCm9fQgX8.jpg\",",
      "\"photo_975\": \"4Dx-SUNKBw4.jpg\",",
      "How I can get this values from dynamic items photo_* ?",
      "You can use a `jq` filter as below as tested on [jq-play](https://jqplay.org/s/479MnPNJDF)!",
      "jq '. | to_entries[] | select(.key | startswith(\"photo\")) | \"\\(.key) :\\(.value)\"' json"
    ],
    "utterance": "Extract all key-value pairs where the key starts with 'photo', regardless of the number following it.",
    "expressions": [
      ". | to_entries[] | select(.key | startswith(\"photo\")) | \"\\(.key) :\\(.value)\""
    ],
    "data": [
      {
        "input": {
          "photo_807": "Ih2RnaBTg2o.jpg",
          "photo_604": "zodCm9fQgX8.jpg",
          "photo_130": "4Dx-SUNKBw4.jpg",
          "photo_75": "7COWb8ou1qA.jpg",
          "user_id": 100,
          "owner_id": -2435432542783750,
          "access_key": "fc5275423676514042234324265cc3df7607c",
          "post_id": 380435645368865101,
          "date": 14858616848616779856424245814,
          "text": "",
          "height": 417,
          "width": 740,
          "id": 45624575446886886564368555,
          "album_id": -36
        },
        "output": [
          "photo_807 :Ih2RnaBTg2o.jpg",
          "photo_604 :zodCm9fQgX8.jpg",
          "photo_130 :4Dx-SUNKBw4.jpg",
          "photo_75 :7COWb8ou1qA.jpg"
        ]
      }
    ],
    "identifier": 42551038
  },
  {
    "context": [
      "I have a list of objects and want to replace all occurrences of `.` with `:` when the key is `Name` using `jq`",
      ".Name |= gsub(\"\\\\.\":\":\")",
      "walk( if type == \"object\" and (.Name|type) == \"string\" then .Name |= gsub(\"\\\\.\":\":\")) else . end )",
      "(.Parameters[].Name)|=(split(\".\")|join(\":\"))"
    ],
    "utterance": "Replace all dots with colons in values of the Name key within each object in the Parameters array.",
    "expressions": [
      ".Parameters[].Name |= gsub(\"\\\\.\"; \":\")",
      "walk( if type == \"object\" and (.Name|type) == \"string\" then .Name |= gsub(\"\\\\.\"; \":\") else . end )",
      "(.Parameters[].Name)|=(split(\".\")|join(\":\"))"
    ],
    "data": [
      {
        "input": {
          "Parameters": [
            {
              "Name": "TEST.AB.SOMETHING",
              "Value": "hvfuycsgvfiwbiwbibibewfiwbcfwifcbwibcibc"
            },
            {
              "Name": "TEST_GF_USER",
              "Value": "ssssecret"
            }
          ]
        },
        "output": {
          "Parameters": [
            {
              "Name": "TEST:AB:SOMETHING",
              "Value": "hvfuycsgvfiwbiwbibibewfiwbcfwifcbwibcibc"
            },
            {
              "Name": "TEST_GF_USER",
              "Value": "ssssecret"
            }
          ]
        }
      }
    ],
    "identifier": 42355182
  },
  {
    "context": [
      "I would like to print the full content (like below) for all entries where the \"file_name\" contains 197407",
      "Assuming your input file contains an array of the model you posted, you can match your records with :",
      "cat file1.json | jq '.[] | select(.file_name | contains(\"197407\"))'"
    ],
    "utterance": "Return all objects whose file_name contains the string 197407.",
    "expressions": [
      ".[] | select(.file_name | contains(\"197407\"))"
    ],
    "data": [
      {
        "input": [
          {
            "license": 5,
            "file_name": "COCO_train2014_000000057870.jpg",
            "coco_url": "http://mscoco.org/images/57870",
            "height": 480,
            "width": 640,
            "date_captured": "2013-11-14 16:28:13",
            "flickr_url": "http://farm4.staticflickr.com/3153/2970773875_164f0c0b83_z.jpg",
            "id": 57870
          },
          {
            "license": 5,
            "file_name": "COCO_train2014_000000197407.jpg",
            "coco_url": "http://mscoco.org/images/197407",
            "height": 480,
            "width": 640,
            "date_captured": "2013-11-15 17:29:14",
            "flickr_url": "http://farm4.staticflickr.com/3153/2970773875_164f0c0b83_z.jpg",
            "id": 197407
          }
        ],
        "output": [
          {
            "license": 5,
            "file_name": "COCO_train2014_000000197407.jpg",
            "coco_url": "http://mscoco.org/images/197407",
            "height": 480,
            "width": 640,
            "date_captured": "2013-11-15 17:29:14",
            "flickr_url": "http://farm4.staticflickr.com/3153/2970773875_164f0c0b83_z.jpg",
            "id": 197407
          }
        ]
      }
    ],
    "identifier": 41411283
  },
  {
    "context": [
      "Im using the following command in shell script \r\n\r\n    echo $(jq -n '\"1\\n2\\n3\" | gsub(\"\\n\"; @t \" * \")')\r\n\r\nand the expected output is \r\n\r\n    \"1 * 2 * 3\"",
      "You need to quote the command substitution to prevent the result (`1 * 2 * 3`) from undergoing pathname expansion.\r\n\r\n    echo \"$(jq -n '\"1\\n2\\n3\" | gsub(\"\\n\"; @t \" * \")')\"\r\n",
      "$ jq -n '\"1\\n2\\n3\" | gsub(\"\\n\"; @t \" * \")'\r\n    \"1 * 2 * 3\""
    ],
    "utterance": "Replace all newlines in the string '1\\n2\\n3' with ' * ', resulting in the value '1 * 2 * 3'.",
    "expressions": [
      "jq -n '\"1\\n2\\n3\" | gsub(\"\\n\"; @t \" * \")'"
    ],
    "data": [
      {
        "input": "1\n2\n3",
        "output": "\"1 * 2 * 3\""
      }
    ],
    "identifier": 42498997
  },
  {
    "context": [
      "And I would like to get ouput like this:  \r\n\r\n    jack:1.0  \r\n    jack:2.0\r\n\r\nHow to achieve that with jq?",
      "Use this:\r\n\r\n    jq -r '\"\\(.name):\\(.tags[])\"' file.json"
    ],
    "utterance": "Print each tag value on its own line, prefixed by the name value, separated by a colon.",
    "expressions": [
      "\"\\(.name):\\(.tags[])\""
    ],
    "data": [
      {
        "input": {
          "name": "jack",
          "tags": [
            "1.0",
            "2.0"
          ]
        },
        "output": [
          "jack:1.0",
          "jack:2.0"
        ]
      }
    ],
    "identifier": 42484253
  },
  {
    "context": [
      "I would like to be able to specify a package by name, find the corresponding entry in either `dependencies` or `devDependencies` and update the value.",
      "How can I update the desired value without affecting the other properties in the original JSON?",
      "Try this instead:",
      "$ jq --arg p webpack --arg v 1.2.3 '\ndef update_package($package; $version):\n    if has($package) then .[$package] = $version\n    else . end;\n.dependencies |= update_package($p; $v)\n    | .devDependencies |= update_package($p; $v)' project.json",
      "Using your approach, it would be better to use map_values:",
      "map_values(if type == \"object\" \n           then with_entries( if .key == $p and (.value | startswith(\"^\")?) \n                              then .value = $v else . end )\n           else . end)",
      "You might also like to consider using `walk/1`:",
      "walk(if type == \"object\" and has($p) and (.[$p]|startswith(\"^\"))\n     then .[$p] = $v else . end)"
    ],
    "utterance": "Update the value of a specified package in both dependencies and devDependencies, matching by name, leaving all other properties unchanged.",
    "expressions": [
      "--arg p webpack --arg v 1.2.3 'def update_package($package; $version): if has($package) then .[$package] = $version else . end; .dependencies |= update_package($p; $v) | .devDependencies |= update_package($p; $v)'",
      "--arg p webpack --arg v 1.2.3 'map_values(if type == \"object\" then with_entries( if .key == $p and (.value | startswith(\"^\")?) then .value = $v else . end ) else . end)'",
      "--arg p webpack --arg v 1.2.3 'walk(if type == \"object\" and has($p) and (.[$p]|startswith(\"^\")) then .[$p] = $v else . end)'"
    ],
    "data": [
      {
        "input": {
          "name": "tom",
          "scripts": {
            "webpack": "webpack --progress --colors --watch"
          },
          "dependencies": {},
          "devDependencies": {
            "webpack": "^2.2.1"
          }
        },
        "output": {
          "name": "tom",
          "scripts": {
            "webpack": "webpack --progress --colors --watch"
          },
          "dependencies": {},
          "devDependencies": {
            "webpack": "1.2.3"
          }
        }
      }
    ],
    "identifier": 42373924
  },
  {
    "context": [
      "But on this JSON file , I would like to get the fields such as \"detected\" and \"result\" in a `CSV` format.",
      "Instead of #3 , I would like the output to be as \r\n\r\n#Output \r\n\r\n    true , Trojan.Win32.Generic!BT\r\n    true , FileCryptor.NJX\r\n    true , Generic.Ransom.Purge.DC87C66E",
      "@csv will convert from a flat array to CSV, so this should get you started:\r\n\r\n    jq -r '[.detected, .result] | @csv'\r\n\r\nGiven your sample input, this will produce:\r\n\r\n    true,\"Trojan.Win32.Generic!BT\"\r\n    true,\"FileCryptor.NJX\"\r\n    true,\"Generic.Ransom.Purge.DC87C66E\"",
      "If you want the quotation marks removed, then consider:\r\n\r\n    jq -r '\"\\(.detected), \\(.result)\"'"
    ],
    "utterance": "Extract the 'detected' and 'result' fields from each object, outputting each pair on one line separated by a comma.",
    "expressions": [
      "[.detected, .result] | @csv",
      "\"\\(.detected), \\(.result)\""
    ],
    "data": [
      {
        "input": [
          {
            "detected": true,
            "result": "Trojan.Win32.Generic!BT",
            "update": "20170115",
            "version": "1.5.0.42"
          },
          {
            "detected": true,
            "result": "FileCryptor.NJX",
            "update": "20170115",
            "version": "16.0.0.4749"
          },
          {
            "detected": true,
            "result": "Generic.Ransom.Purge.DC87C66E",
            "update": "20170115",
            "version": "1.0.1.9"
          }
        ],
        "output": [
          "true,\"Trojan.Win32.Generic!BT\"",
          "true,\"FileCryptor.NJX\"",
          "true,\"Generic.Ransom.Purge.DC87C66E\""
        ]
      }
    ],
    "identifier": 42479789
  },
  {
    "context": [
      "echo '{\"tag_string\":\"/\\/\\/\\ test\"}' | jq",
      "parse error: Invalid escape at line 1, column 27",
      "echo '{\"tag_string\":\"/\\\\/\\\\/\\\\ test\"}' | jq -r '.tag_string'",
      "/\\/\\/\\ test",
      "echo '{\"tag_string\":\"/\\\\\\\\/\\\\\\\\/\\\\\\\\ test\"}' | jq -r '.[\"tag_string\"]'",
      "/\\/\\/\\ test",
      "printf \"%s\" '{\"tag_string\":\"/\\\\/\\\\/\\\\ test\"}' | jq -r '.[\"tag_string\"]'",
      "/\\/\\/\\ test"
    ],
    "utterance": "Output the value of the 'tag_string' field containing a string with sequences of slashes and backslashes, preserving all characters exactly.",
    "expressions": [
      ".tag_string",
      ".[\"tag_string\"]"
    ],
    "data": [
      {
        "input": {
          "tag_string": "/\\/\\/\\ test"
        },
        "output": "/\\/\\/\\ test"
      }
    ],
    "identifier": 42545752
  },
  {
    "context": [
      "I can create an array of the recalculated percents in **Filter A**, and I can output the array I'm expecting (minus the new percent values) in **Filter B** but can't find a way to combine these into a **Filter C**.",
      "the following filter produces the required answer. The key is `transpose`:\n\n\n    ($a | [.hits_percents, .visitors_percents, .bytes_percents] | transpose)\n    | . as $v\n    | reduce range(0; length) as $i\n        ($b;\n           .[$i].hits.percent = $v[$i][0] \n         | .[$i].visitors.percent = $v[$i][1]\n         | .[$i].bytes.percent = $v[$i][2] )",
      "This could be used by adding `map(map(percent))` after the transposition:\n\n\n    def percent:\n      ((1000 * .) | floor)\n      | (. % 10) as $r\n      | ((. / 10) | floor) as $answer\n      | if $r > 4 then ($answer + 1) else $answer end\n      | . / 100;\n    ($a | [.hits_percents, .visitors_percents, .bytes_percents] | transpose)\n      | map(map(percent))\n      | . as $v\n      | reduce range(0; length) as $i\n          ($b;\n             .[$i].hits.percent = $v[$i][0] \n           | .[$i].visitors.percent = $v[$i][1]\n           | .[$i].bytes.percent = $v[$i][2] )"
    ],
    "utterance": "Combine an array of objects with corresponding calculated percent values for hits, visitors, and bytes into a single array where each object includes its counts and the recalculated rounded percent values for each field.",
    "expressions": [
      "($a | [.hits_percents, .visitors_percents, .bytes_percents] | transpose)\n| . as $v\n| reduce range(0; length) as $i\n    ($b;\n       .[$i].hits.percent = $v[$i][0] \n     | .[$i].visitors.percent = $v[$i][1]\n     | .[$i].bytes.percent = $v[$i][2] )",
      "def percent:\n  ((1000 * .) | floor)\n  | (. % 10) as $r\n  | ((. / 10) | floor) as $answer\n  | if $r > 4 then ($answer + 1) else $answer end\n  | . / 100;\n($a | [.hits_percents, .visitors_percents, .bytes_percents] | transpose)\n  | map(map(percent))\n  | . as $v\n  | reduce range(0; length) as $i\n      ($b;\n         .[$i].hits.percent = $v[$i][0] \n       | .[$i].visitors.percent = $v[$i][1]\n       | .[$i].bytes.percent = $v[$i][2] )"
    ],
    "identifier": 41389981
  },
  {
    "context": [
      "I want to filter out only the unique combinations of each of the values jq.",
      "I've used `unique` but that didnt generate the proper results.",
      "so consider:\n\nInvocation: jq -c 'unique[]' input.json",
      "jq -M -s -f filter.jq data.json\n\nwith the following filter.jq\n\nforeach .[] as $r (\n  {}\n; ($r | map(.)) as $p | if getpath($p) then empty else setpath($p;1) end\n; $r\n)",
      "A slower but more robust `filter.jq` is\n\nforeach .[] as $r (\n  {}\n; [$r | tojson] as $p | if getpath($p) then empty else setpath($p;1) end\n; $r\n)\n\nwhich uses the json representation of the entire row as a unique key to determine if a row has been previously seen."
    ],
    "utterance": "Return only the objects with unique combinations of all values, removing duplicates while preserving order.",
    "expressions": [
      "unique[]",
      "foreach .[] as $r ({}; ($r | map(.)) as $p | if getpath($p) then empty else setpath($p;1) end; $r)",
      "foreach .[] as $r ({}; [$r | tojson] as $p | if getpath($p) then empty else setpath($p;1) end; $r)"
    ],
    "data": [
      {
        "input": [
          {
            "header1": "a",
            "header2": "1a",
            "header3": "1a",
            "header4": "apple"
          },
          {
            "header1": "b",
            "header2": "2a",
            "header3": "2a",
            "header4": "orange"
          },
          {
            "header1": "c",
            "header2": "1a",
            "header3": "2a",
            "header4": "banana"
          },
          {
            "header1": "d",
            "header2": "2a",
            "header3": "1a",
            "header4": "apple"
          },
          {
            "header1": "a",
            "header2": "2a",
            "header3": "1a",
            "header4": "banana"
          },
          {
            "header1": "b",
            "header2": "1a",
            "header3": "2a",
            "header4": "orange"
          },
          {
            "header1": "b",
            "header2": "1a",
            "header3": "1a",
            "header4": "orange"
          },
          {
            "header1": "d",
            "header2": "1a",
            "header3": "1a",
            "header4": "apple"
          },
          {
            "header1": "a",
            "header2": "2a",
            "header3": "1a",
            "header4": "banana"
          }
        ],
        "output": [
          {
            "header1": "a",
            "header2": "1a",
            "header3": "1a",
            "header4": "apple"
          },
          {
            "header1": "b",
            "header2": "2a",
            "header3": "2a",
            "header4": "orange"
          },
          {
            "header1": "c",
            "header2": "1a",
            "header3": "2a",
            "header4": "banana"
          },
          {
            "header1": "d",
            "header2": "2a",
            "header3": "1a",
            "header4": "apple"
          },
          {
            "header1": "a",
            "header2": "2a",
            "header3": "1a",
            "header4": "banana"
          },
          {
            "header1": "b",
            "header2": "1a",
            "header3": "2a",
            "header4": "orange"
          },
          {
            "header1": "b",
            "header2": "1a",
            "header3": "1a",
            "header4": "orange"
          },
          {
            "header1": "d",
            "header2": "1a",
            "header3": "1a",
            "header4": "apple"
          }
        ]
      }
    ],
    "identifier": 42479103
  },
  {
    "context": [
      "What I cannot find is any means to set the values for the same objects in $obj, i.e. effectively:\n\n$obj[0].location[($locs[])].setpoints[($setpoints[])] = $vals",
      "to recap my goal, I wish to:\n\nget the proper object values in $retobj via location keys derived from the local obj and the setpoint keys defined in the filter, and set the same paths in local object to those values.",
      "The following filter will adjust $retobj based on the contents of  thermostats2.json:\n\n    . as $in\n    | reduce [\"location\",\n              (.location | keys[]),\n              \"setpoints\",\n              [\"day\",\"night\",\"away\"][]] as $path\n        ( $retobj;\n\t      setpath( $path; ($in | getpath($path)) ) )"
    ],
    "utterance": "Update values in local object's setpoints for each location and specified setpoint keys using values from a returned object, matching only the location keys present in the local data.",
    "expressions": [
      ". as $in\n| reduce [\"location\",\n          (.location | keys[]),\n          \"setpoints\",\n          [\"day\",\"night\",\"away\"][]] as $path\n    ( $retobj;\n      setpath( $path; ($in | getpath($path)) ) )"
    ],
    "data": [
      {
        "input": {
          "mode": "Home",
          "location": {
            "livingroom": {
              "scale": "Celcius",
              "current": {
                "valid": "YES",
                "reading": "23000",
                "time": "000000"
              },
              "previous": {
                "reading": "23000",
                "time": "000000"
              },
              "setpoints": {
                "schedule": {
                  "weekday": {
                    "day": "0600",
                    "night": "2100"
                  },
                  "weekend": {
                    "day": "0630",
                    "night": "2200"
                  }
                },
                "active": "day",
                "day": "23000",
                "night": "15556",
                "away": "12778"
              }
            },
            "familyroom": {
              "scale": "Celcius",
              "current": {
                "valid": "YES",
                "reading": "23000",
                "time": "000000"
              },
              "previous": {
                "reading": "23000",
                "time": "000000"
              },
              "setpoints": {
                "schedule": {
                  "weekday": {
                    "day": "0600",
                    "night": "2100"
                  },
                  "weekend": {
                    "day": "0630",
                    "night": "2200"
                  }
                },
                "active": "day",
                "day": "23000",
                "night": "15556",
                "away": "12778"
              }
            },
            "28-000005e2fdef": {
              "scale": "Celcius",
              "current": {
                "valid": "YES",
                "reading": "23000",
                "time": "000000"
              },
              "previous": {
                "reading": "23000",
                "time": "000000"
              },
              "setpoints": {
                "schedule": {
                  "weekday": {
                    "day": "0600",
                    "night": "2100"
                  },
                  "weekend": {
                    "day": "0630",
                    "night": "2200"
                  }
                },
                "active": "day",
                "day": "23000",
                "night": "15556",
                "away": "12778"
              }
            }
          }
        },
        "output": null
      }
    ],
    "identifier": 42126776
  },
  {
    "context": [
      "I want to modify a JSON file by using the Linux command line.",
      "cat $CONF_FILE\n    {\n      \"global\" : {\n        \"name\" : \"asd\",\n        \"id\" : 1\n      }\n    }",
      "Desired output:\n\n    [root@localhost]# cat $CONF_FILE\n        {   \"global\" : {\n        \"name\" : \"dsa\",\n        \"id\" : 1   } }",
      "It's much simpler and safer to pass the value using the `--arg` option:\n\n    jq -r --arg newname \"$INPUT\" '.global.name |= $newname' \"$CONF_FILE\"",
      "Using `jq` with a straight forward filter, should do it for you.\n\n    .global.name = \"dsa\"\n\ni.e.\n\n    jq '.global.name = \"dsa\"' json-file\n    {\n      \"global\": {\n        \"name\": \"dsa\",\n        \"id\": 1\n      }\n    }"
    ],
    "utterance": "Replace the value of the 'name' key inside the 'global' object with the value of a shell variable.",
    "expressions": [
      ".global.name = \"dsa\"",
      ".global.name |= \"dsa\"",
      ".global.name |= $newname"
    ],
    "data": [
      {
        "input": {
          "global": {
            "name": "asd",
            "id": 1
          }
        },
        "output": {
          "global": {
            "name": "dsa",
            "id": 1
          }
        }
      }
    ],
    "identifier": 41503387
  },
  {
    "context": [
      "I have a simple JSON object and would like to convert it into a properties file in bash.",
      "Input:",
      "{",
      "    \"foo\": \"bar\",",
      "    \"abc\": \"def ghi\"",
      "}",
      "expected output:",
      "foo=\"bar\"",
      "abc=\"def ghi\"",
      "You can use `to_entries` for that:",
      "jq -r 'to_entries[]|\"\\(.key)=\\\"\\(.value)\\\"\"' input.json"
    ],
    "utterance": "Convert an object so that each key-value pair becomes key=\"value\" lines.",
    "expressions": [
      "to_entries[] | \"\\(.key)=\\\"\\(.value)\\\"\""
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "abc": "def ghi"
        },
        "output": "foo=\"bar\"\nabc=\"def ghi\""
      }
    ],
    "identifier": 42356536
  },
  {
    "context": [
      "Is it possible to parse Chrome bookmarks with jq in one line?\r\n(for csv output)",
      "With `jq '.roots.other.children[]'` Bookmarks\r\nI get separate lines",
      "jq -r '.roots.other.children[]\n           | [.date_added,.id,.name,.sync_transaction_version,.type,.url,\n              (.meta_info|tostring)]\n           | @csv'"
    ],
    "utterance": "Produce a CSV with columns for date_added, id, name, sync_transaction_version, type, url, and the string form of meta_info for each bookmark in .roots.other.children.",
    "expressions": [
      ".roots.other.children[] | [.date_added,.id,.name,.sync_transaction_version,.type,.url, (.meta_info|tostring)] | @csv"
    ],
    "identifier": 42156950
  },
  {
    "context": [
      "I have to recursively remove objects that contain a given key value.",
      "Config is:\r\n\r\n    walk( if ((type == \"object\" and has(\"index\")) and (.\":index\" | test(\"monitoring*\"))) then del(.) else . end )",
      "Output is:\r\n\r\n    null,\r\n          {\r\n            \"health\": \"yellow\",\r\n            \"status\": \"open\",\r\n            \"index\": \"robot-log-01.02.2017\",\r\n            \"uuid\": \"lFndm8gDS2OAGXZhP5KSkw\",\r\n            \"pri\": \"5\",\r\n            \"rep\": \"1\",\r\n            \"docs.count\": \"127887\",\r\n            \"docs.deleted\": \"0\",\r\n            \"store.size\": \"35.1mb\",\r\n            \"pri.store.size\": \"35.1mb\"\r\n          }",
      "In brief, use `empty` instead of `del(.)`.  After simplifying:\r\n\r\n   walk(if type == \"object\" and has(\"index\") and (.index | test(\"monitoring\")) \r\n        then empty else . end )"
    ],
    "utterance": "Recursively remove objects where the index property matches the pattern 'monitoring'.",
    "expressions": [
      "walk(if type == \"object\" and has(\"index\") and (.index | test(\"monitoring\")) then empty else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "health": "yellow",
            "status": "open",
            "index": ".monitoring-es-2-2017.03.03",
            "uuid": "Py3FY-UwSjmda3jbYeIdMg",
            "pri": "1",
            "rep": "1",
            "docs.count": "23494",
            "docs.deleted": "78",
            "store.size": "12mb",
            "pri.store.size": "12mb"
          },
          {
            "health": "yellow",
            "status": "open",
            "index": "robot-log-01.02.2017",
            "uuid": "lFndm8gDS2OAGXZhP5KSkw",
            "pri": "5",
            "rep": "1",
            "docs.count": "127887",
            "docs.deleted": "0",
            "store.size": "35.1mb",
            "pri.store.size": "35.1mb"
          }
        ],
        "output": [
          {
            "health": "yellow",
            "status": "open",
            "index": "robot-log-01.02.2017",
            "uuid": "lFndm8gDS2OAGXZhP5KSkw",
            "pri": "5",
            "rep": "1",
            "docs.count": "127887",
            "docs.deleted": "0",
            "store.size": "35.1mb",
            "pri.store.size": "35.1mb"
          }
        ]
      }
    ],
    "identifier": 42635730
  },
  {
    "context": [
      "I want to change the value of address in the file itself but so far I've been unable to do so. I tried using:\n\n    jq '.address = \"abcde\"' test.json\nbut it didn't work. Any suggestions?",
      "AFAIK `jq` does not support in-place editing, so you must redirect to a temporary file first and then replace your original file with it, or use `sponge` utility from the moreutils package, like that:\n\n    jq '.address = \"abcde\"' test.json|sponge test.json",
      "Use a temporary file; it's what any program that claims to do in-place editing is doing.\n\n    tmp=$(mktemp)\n    jq '.address = \"abcde\"' test.json > \"$tmp\" && mv \"$tmp\" test.json",
      "if you want it in a shell script.\n\n    jq --arg a \"${address}\" '.address = $a' test.json > \"tmp\" && mv \"tmp\" test.json",
      "contents=\"$(jq '.address = \"abcde\"' test.json)\" && \\\necho -E \"${contents}\" > test.json"
    ],
    "utterance": "Overwrite the value of address in test.json with abcde, updating the file itself.",
    "expressions": [
      "jq '.address = \"abcde\"' test.json | sponge test.json",
      "tmp=$(mktemp)\njq '.address = \"abcde\"' test.json > \"$tmp\" && mv \"$tmp\" test.json",
      "jq --arg a \"abcde\" '.address = $a' test.json > tmp && mv tmp test.json",
      "contents=\"$(jq '.address = \"abcde\"' test.json)\" && echo -E \"${contents}\" > test.json"
    ],
    "data": [
      {
        "input": {
          "name": "abcd",
          "age": 30,
          "address": "abc"
        },
        "output": {
          "name": "abcd",
          "age": 30,
          "address": "abcde"
        }
      }
    ],
    "identifier": 42716734
  },
  {
    "context": [
      "I need to split this JSON into multiple files, using this method:\r\n\r\nEach JSON file will consist of one object. Using the example file above, I should end up with `000106.json`, and `000560.json`. (All names, must have 6 digits, so zeros must be added.)",
      "Expected output:",
      "JSON file 1, named `000106.json`:\r\n\r\n    {\r\n       \"106\" : { ... } }",
      "JSON file 2, named `000560.json`:\r\n\r\n    {\r\n        \"560\" : { ... } }"
    ],
    "utterance": "Split a top-level object into separate files, each containing a single property (object) with a filename that is its key padded to 6 digits with leading zeros.",
    "expressions": [
      "to_entries[] | { (\"%06d\" % (.key|tonumber) + \".json\"): { (.key): .value } }"
    ],
    "data": [
      {
        "input": {
          "106": {
            "id54011": [
              {
                "partno1": "16690617"
              },
              {
                "partno2": "5899180"
              }
            ],
            "parts": [
              "0899180",
              "16920617"
            ],
            "id5632": [
              {
                "partno1": "090699180"
              }
            ]
          },
          "560": {
            "id9452": [
              {
                "partno2": "1569855"
              }
            ],
            "parts": [
              "03653624",
              "15899855"
            ],
            "id578": [
              {
                "partno3": "0366393624"
              },
              {
                "partno4": "0363213624"
              }
            ]
          }
        },
        "output": [
          {
            "000106.json": {
              "106": {
                "id54011": [
                  {
                    "partno1": "16690617"
                  },
                  {
                    "partno2": "5899180"
                  }
                ],
                "parts": [
                  "0899180",
                  "16920617"
                ],
                "id5632": [
                  {
                    "partno1": "090699180"
                  }
                ]
              }
            }
          },
          {
            "000560.json": {
              "560": {
                "id9452": [
                  {
                    "partno2": "1569855"
                  }
                ],
                "parts": [
                  "03653624",
                  "15899855"
                ],
                "id578": [
                  {
                    "partno3": "0366393624"
                  },
                  {
                    "partno4": "0363213624"
                  }
                ]
              }
            }
          }
        ]
      }
    ],
    "identifier": 42715792
  },
  {
    "context": [
      "I try to edit a geojson file to keep only objects that have the key \"name\".",
      "cat file.geojson | jq '.features[].properties | select(has(\"name\"))'",
      "The \"geometry\" is also a child of \"features\" but I can't find a way to make the selection directly from the \"features\" level.",
      "jq '.features |= map(select(.properties|has(\"name\")))'"
    ],
    "utterance": "Filter the features array to include only items whose properties object contains a key named \"name\".",
    "expressions": [
      ".features |= map(select(.properties|has(\"name\")))"
    ],
    "data": [
      {
        "input": {
          "features": [
            {
              "type": "Feature",
              "id": "way/24824633",
              "properties": {
                "@id": "way/24824633",
                "highway": "tertiary",
                "lit": "yes",
                "maxspeed": "50",
                "name": "Rue de Kleinbettingen",
                "surface": "asphalt"
              },
              "geometry": {
                "type": "LineString",
                "coordinates": [
                  [
                    5.8997935,
                    49.6467825
                  ],
                  [
                    5.8972561,
                    49.6467445
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "id": "way/474396855",
              "properties": {
                "@id": "way/474396855",
                "highway": "path"
              },
              "geometry": {
                "type": "LineString",
                "coordinates": [
                  [
                    5.8020608,
                    49.6907648
                  ],
                  [
                    5.8020695,
                    49.6906054
                  ]
                ]
              }
            }
          ]
        },
        "output": {
          "features": [
            {
              "type": "Feature",
              "id": "way/24824633",
              "properties": {
                "@id": "way/24824633",
                "highway": "tertiary",
                "lit": "yes",
                "maxspeed": "50",
                "name": "Rue de Kleinbettingen",
                "surface": "asphalt"
              },
              "geometry": {
                "type": "LineString",
                "coordinates": [
                  [
                    5.8997935,
                    49.6467825
                  ],
                  [
                    5.8972561,
                    49.6467445
                  ]
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 42313772
  },
  {
    "context": [
      "I want to get the output in the format: \r\n\r\n    math : enrolled\r\n    english : not-enrolled",
      "you could do this:\r\n\r\n    .courses | to_entries[] | \"\\(.key) : \\(.value.enrollment)\""
    ],
    "utterance": "List all courses with their enrollment values in the format: course : enrollment.",
    "expressions": [
      ".courses | to_entries[] | \"\\(.key) : \\(.value.enrollment)\""
    ],
    "data": [
      {
        "input": {
          "studentName": "good student",
          "age": "18",
          "address": "street 123",
          "courses": {
            "math": {
              "description": "how to calculate",
              "enrollment": "enrolled",
              "status": {
                "result": "OK"
              }
            },
            "english": {
              "description": "abc",
              "enrollment": "not-enrolled",
              "status": {
                "result": "OK"
              }
            }
          }
        },
        "output": [
          "math : enrolled",
          "english : not-enrolled"
        ]
      }
    ],
    "identifier": 41644633
  },
  {
    "context": [
      "Basically if items contains kafka print name.",
      "Here is a simple jq solution using **if** and **any**:",
      "if .metadata.items | any(.key == \"kafka\") then . else empty end\n| .name"
    ],
    "utterance": "List the name field for each object where any metadata.items has key equal to \"kafka\".",
    "expressions": [
      "if .metadata.items | any(.key == \"kafka\") then .name else empty end"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "fingerprint": "xxxxx=",
            "items": [
              {
                "key": "kafka",
                "value": "xxx="
              },
              {
                "key": "some_key",
                "value": "vars"
              }
            ],
            "kind": "compute#metadata"
          },
          "name": "instance-name",
          "networkInterfaces": [
            {
              "accessConfigs": [
                {
                  "kind": "compute#accessConfig",
                  "name": "External NAT",
                  "natIP": "ip",
                  "type": "ONE_TO_ONE_NAT"
                }
              ],
              "kind": "compute#networkInterface",
              "name": "",
              "network": "xxxxx"
            }
          ]
        },
        "output": "instance-name"
      }
    ],
    "identifier": 42707331
  },
  {
    "context": [
      "Is there a `jq` command line tool or wrapper which lets you pipe output into it and interactively explore `jq`, with the JSON input in one pane and your interactively updating result in another pane, similar to `jmespath.terminal` ?",
      "I want to be able to, in the shell, pipe the json output of a command into an interactive `jq` which allows me to explore and experiment with `jq` commands.",
      "I've been using `jiq` and I'm pretty happy with it.",
      "https://github.com/fiatjaf/jiq",
      "You can drill down interactively by using jq filtering queries.",
      "jiq uses jq internally, and it requires you to have jq in your PATH.",
      "aws ec2 describe-regions --region-names us-east-1 us-west-1 | jiq",
      "[Filter]> .Regions"
    ],
    "utterance": "Interactively explore and filter the output of a command to display the value of the .Regions key in a structured format.",
    "expressions": [
      ".Regions"
    ],
    "data": [
      {
        "input": {
          "Regions": [
            {
              "Endpoint": "ec2.us-east-1.amazonaws.com",
              "RegionName": "us-east-1"
            },
            {
              "Endpoint": "ec2.us-west-1.amazonaws.com",
              "RegionName": "us-west-1"
            }
          ]
        },
        "output": [
          {
            "Endpoint": "ec2.us-east-1.amazonaws.com",
            "RegionName": "us-east-1"
          },
          {
            "Endpoint": "ec2.us-west-1.amazonaws.com",
            "RegionName": "us-west-1"
          }
        ]
      }
    ],
    "identifier": 41631626
  },
  {
    "context": [
      "I have this input JSON\n\n    [{\n       \"Name\":\"Wolfenstein\",\n       \"24 Hour\":\"FALSE\",\n       \"Shop 1\":\"TRUE\",\n       \"Shop 2\":\"FALSE\",\n    }]\n\nand want to change all \"FALSE\" and \"TRUE\" values to `false` and `true` respectively.",
      "As a bonus, I only want to select those array items whose keys start with \"Shop\" and have at least on \"Shop\" set to \"TRUE\".",
      "map( if any( to_entries[];\n             (.key|startswith(\"Shop\")) and .value==\"TRUE\" )\n     then map_values(toboolean)\n     else .\n     end)",
      "map( if any( to_entries[];\n             (.key|startswith(\"Shop\")) and .value==\"TRUE\" )\n     then with_entries( if .key|startswith(\"Shop\")\n                        then .value |= toboolean\n                        else .\n                        end)\n     else .\n     end)",
      ".[][] |= if . == \"TRUE\" then true end \n  | .[][] |= if . == \"FALSE\" then false end \n  | map(select(with_entries(select((.key | startswith(\"Shop\")) and .value))!={}))"
    ],
    "utterance": "Replace all values equal to \"TRUE\" or \"FALSE\" with their respective boolean values, and select only those objects where at least one key starting with \"Shop\" is set to true.",
    "expressions": [
      "map(map_values(if . == \"TRUE\" then true elif . == \"FALSE\" then false else . end)) | map(select([ to_entries[] | select((.key|startswith(\"Shop\")) and .value==true) ] | length > 0))",
      ".[][] |= if . == \"TRUE\" then true elif . == \"FALSE\" then false else . end | map(select(with_entries(select((.key | startswith(\"Shop\")) and .value))!={}))",
      "def toboolean: if . == \"TRUE\" then true elif . == \"FALSE\" then false else . end;\nmap(if any(to_entries[]; (.key|startswith(\"Shop\")) and .value==\"TRUE\") then map_values(toboolean) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "Wolfenstein",
            "24 Hour": "FALSE",
            "Shop 1": "TRUE",
            "Shop 2": "FALSE"
          }
        ],
        "output": [
          {
            "Name": "Wolfenstein",
            "24 Hour": false,
            "Shop 1": true,
            "Shop 2": false
          }
        ]
      }
    ],
    "identifier": 42705676
  },
  {
    "context": [
      "I'm looking to transform JSON using `jq` to a delimiter-separated and flattened structure.",
      "However the solutions on that page fail if the JSON contains arrays.",
      "For example, if the JSON is: {\"a\":{\"b\":[1]},\"x\":[{\"y\":2},{\"z\":3}]}\n\nThe solution above will fail to transform the above to:\n\n    {\"a.b.0\":1,\"x.0.y\":2,\"x.1.z\":3}",
      "In addition, I'm looking for a solution that will also allow for an arbitrary delimiter. For example, suppose the space character is the delimiter.  In this case, the result would be:\n\n    {\"a b 0\":1,\"x 0 y\":2,\"x 1 z\":3}",
      "The solution should work with all JSON data types, including *null* and *boolean*. For example, consider the following input:\n\n    {\"a\":{\"b\":[\"p q r\"]},\"w\":[{\"x\":null},{\"y\":false},{\"z\":3}]}\n\nIt should produce:\n\n    {\"a b 0\":\"p q r\",\"w 0 x\":null,\"w 1 y\":false,\"w 2 z\":3}",
      "$ jq --arg delim '.' 'reduce (tostream|select(length==2)) as $i ({};\n    .[[$i[0][]|tostring]|join($delim)] = $i[1]\n)' input.json",
      "$ jq --arg delim '.' 'reduce (tostream|select(length==2)) as $i ({};\n    [$i[0][]|tostring] as $path_as_strings\n        | ($path_as_strings|join($delim)) as $key\n        | $i[1] as $value\n        | .[$key] = $value\n)' input.json",
      "With this jq program in flatten.jq:\n\n$ jq --arg delim . -f flatten.jq input.json\n\n{\n  \"a.b.0\": \"p q r\",\n  \"w.0.x\": null,\n  \"w.1.y\": false,\n  \"w.2.z\": 3\n}",
      "def allpaths:\n  def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\n  path(conditional_recurse(.[]?)) | select(length > 0);\n\ndef all_leaf_paths:\n  def isscalar: type | (. != \"object\" and . != \"array\");\n  allpaths as $p\n  | select(getpath($p)|isscalar)\n  | $p ;\n\n.\n| reduce all_leaf_paths as $path ({};\n     . + { ($path | map(tostring) | join($delim)): . | getpath($path) })"
    ],
    "utterance": "Flatten nested structures into a single-level dictionary mapping paths to leaf values, representing array indices and object keys in the path, using a custom delimiter such as '.' or space, and including all value types (including null and boolean).",
    "expressions": [
      "reduce (tostream|select(length==2)) as $i ({}; .[[$i[0][]|tostring]|join($delim)] = $i[1])",
      "reduce (tostream|select(length==2)) as $i ({}; [$i[0][]|tostring] as $path_as_strings | ($path_as_strings|join($delim)) as $key | $i[1] as $value | .[$key] = $value )",
      "def allpaths:\n  def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\n  path(conditional_recurse(.[]?)) | select(length > 0);\n\ndef all_leaf_paths:\n  def isscalar: type | (. != \"object\" and . != \"array\");\n  allpaths as $p\n  | select(getpath($p)|isscalar)\n  | $p ;\n\n. as $in \n| reduce all_leaf_paths as $path ({};\n     . + { ($path | map(tostring) | join($delim)): $in | getpath($path) })"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": [
              "p q r"
            ]
          },
          "w": [
            {
              "x": null
            },
            {
              "y": false
            },
            {
              "z": 3
            }
          ]
        },
        "output": {
          "a.b.0": "p q r",
          "w.0.x": null,
          "w.1.y": false,
          "w.2.z": 3
        }
      }
    ],
    "identifier": 42299905
  },
  {
    "context": [
      "I'm attempting to follow all branches in a tree-styled JSON object to create one long, concatenated string from each branch. The number of children and the maximum depth per node are unknown, so the result must be generalized to any amount.",
      "Desired output from the jqplay above:  \n\"root/foo/bar\"\n\"root/foo/baz\"\n\"root/zoo/zar/zaz\"",
      "Since your data structure is recursive, a recursive helper function is what's needed here:",
      "def flat:\n  [.name] + (.children[] // {} | if has(\"name\") then flat else [] end);\n\nflat | join(\"/\")"
    ],
    "utterance": "List all leaf-to-root paths as slash-separated strings, covering every branch no matter the depth or number of children.",
    "expressions": [
      "def flat: [.name] + (.children[] // {} | if has(\"name\") then flat else [] end);\nflat | join(\"/\")"
    ],
    "data": [
      {
        "input": {
          "name": "root",
          "children": [
            {
              "name": "foo",
              "children": [
                {
                  "name": "bar",
                  "children": []
                },
                {
                  "name": "baz",
                  "children": []
                }
              ]
            },
            {
              "name": "zoo",
              "children": [
                {
                  "name": "zar",
                  "children": [
                    {
                      "name": "zaz",
                      "children": []
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "root/foo/bar",
          "root/foo/baz",
          "root/zoo/zar/zaz"
        ]
      }
    ],
    "identifier": 42701983
  },
  {
    "context": [
      "what I want is the numbers to become strings and be concatenated like \r\n\r\n    2.294891,48.875284\r\n    -2.14908,53.281214\r\n    ...\r\n\r\nbut I don't know how to do it with jq.",
      "$ jq -r @csv input.json \r\n    2.294891,48.875284\r\n    -2.14908,53.281214\r\n    1.963667,48.768891\r\n    -3.739434,40.390413\r\n"
    ],
    "utterance": "Convert each pair of latitude and longitude numbers in arrays into a comma-separated string, one per line.",
    "expressions": [
      "@csv"
    ],
    "data": [
      {
        "input": [
          [
            2.294891,
            48.875284
          ],
          [
            -2.14908,
            53.281214
          ],
          [
            1.963667,
            48.768891
          ],
          [
            -3.739434,
            40.390413
          ]
        ],
        "output": "2.294891,48.875284\n-2.14908,53.281214\n1.963667,48.768891\n-3.739434,40.390413"
      }
    ],
    "identifier": 42266468
  },
  {
    "context": [
      "I am trying to build a json with jq with --arg arguments however I&#39;d like for the json not to be able to have a condition if the variable is empty.",
      "I&#39;d like the json in that case to be `{}` if myvar happens to be empty (Because the variable ${SOMEVAR} does not exist) and not `{ \"myvar\": \"\" }` which is what I get by just running the command above.",
      "Is there any way to achieve this through some sort of condition?",
      "I want to build a json based on several environment variables but only include the variables that have a value.",
      "But only include varA if its value is defined and so on. The issue now is that if value is not defined, the property `varA` will still exist with an empty value",
      "jq -n --arg myvar \"${SOMEVAR}\" 'if ($myvar|length > 0) then {$myvar} else {} end'",
      "def adjust: with_entries( env[.key] as $v | select($v != null) | .value = $v );",
      "{a,b,c} | adjust",
      "$ export a=123",
      "$ jq -n -f -c adjust.jq ",
      "{\"a\":\"123\"}"
    ],
    "utterance": "Create an object that only includes variables whose values are not empty or undefined, omitting properties with empty values.",
    "expressions": [
      "if ($myvar|length > 0) then {$myvar} else {} end",
      "def adjust: with_entries( env[.key] as $v | select($v != null) | .value = $v );\n{a,b,c} | adjust"
    ],
    "identifier": 41673543
  },
  {
    "context": [
      "Now what I want to do is, I want to add another input under `interestingtag` that's similar to the others.",
      "jq '.firsttag.secondtag[0].thirdtag[0].interestingtag |= .+ [{\"refId\": \"D\", \"refID\": \"C\"}]' myfile.json",
      "`+` does not append elements to arrays. You want to merge arrays using `|= .+ [...]`"
    ],
    "utterance": "Append an object with refId equal to D and target equal to ddd to the interestingtag array under firsttag.secondtag[0].thirdtag[0].",
    "expressions": [
      ".firsttag.secondtag[0].thirdtag[0].interestingtag |= .+ [{\"refId\": \"D\", \"target\": \"ddd\"}]"
    ],
    "data": [
      {
        "input": {
          "firsttag": {
            "secondtag": [
              {
                "thirdtag": [
                  {
                    "interestingtag": [
                      {
                        "refId": "A",
                        "target": "abc"
                      },
                      {
                        "refId": "B",
                        "target": "bbb"
                      },
                      {
                        "refId": "C",
                        "target": "ccc"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "firsttag": {
            "secondtag": [
              {
                "thirdtag": [
                  {
                    "interestingtag": [
                      {
                        "refId": "A",
                        "target": "abc"
                      },
                      {
                        "refId": "B",
                        "target": "bbb"
                      },
                      {
                        "refId": "C",
                        "target": "ccc"
                      },
                      {
                        "refId": "D",
                        "target": "ddd"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 41995666
  },
  {
    "context": [
      "I\u2019m trying to use take a JSON object from a REST API `GET` call, then add the contents of a raw file (.md file in this case) into it using [jq][1], before updating the same object using a `PUT` call.",
      "I\u2019d like to add the content of the raw file into `content`, so the result is as follows:\n\n    {\n      \"content\" : \"My markdown file contents.\\n\\nMy JSON content\",\n      \"owner\":...\n    }",
      "The key to a simple jq solution here is to read the raw text file using 'jq -R -s', and to read the JSON using one of the options in the --arg family.  Here, I'll use `--argfile` for simplicity and robustness across jq versions, but please note that the documentation says it is deprecated.",
      "With the following jq program in a file, say program.jq:\n\n    . as $file\n    | $json\n    | (.content = $file + \"\\n\" + .content)",
      "the invocation:\n\n    jq -R -s --argfile json curl.json -f program.jq contents.txt",
      "produces:\n\n    {\n      \"content\": \"Line 1 of contents.txt;\\nline 2.\\n\\nMy JSON content\",\n      \"owner\": \"etc\"\n    }"
    ],
    "utterance": "Prepend the contents of a text file followed by a blank line to the 'content' key of an existing object, keeping all other fields unchanged.",
    "expressions": [
      ". as $file | $json | (.content = $file + \"\\n\" + .content)"
    ],
    "data": [
      {
        "input": {
          "text-file": "Line 1 of contents.txt;\nline 2.\n",
          "json": {
            "content": "My JSON content",
            "owner": "etc"
          }
        },
        "output": {
          "content": "Line 1 of contents.txt;\nline 2.\n\nMy JSON content",
          "owner": "etc"
        }
      }
    ],
    "identifier": 42701268
  },
  {
    "context": [
      "Given\n\n    [{\n      \"objects\": [{\n        \"key\": \"value\"\n      },{\n        \"key\": \"value\"\n      }]\n    }, {\n      \"objects\": [{\n        \"key\": \"value\"\n      }, {\n        \"key\": \"value\"\n      }]\n    }]\n\nHow do I generate\n\n    [{\n      \"objects\": [{\n        \"id\": 0,\n        \"key\": \"value\"\n      },{\n        \"id\": 1,\n        \"key\": \"value\"\n      }]\n    }, {\n      \"objects\": [{\n        \"id\": 2,\n        \"key\": \"value\"\n      }, {\n        \"id\": 3,\n        \"key\": \"value\"\n      }]\n    }]\n\n\nUsing jq?",
      "The key to a simple solution here is to break the problem down into easy pieces. This can be accomplished by defining a helper function, `addId/1`.  Once that is done, the rest is straightforward:\n\n    # starting at start, add {id: ID} to each object in the input array \n    def addId(start):\n      reduce .[] as $o\n        ([];\n         length as $l \n         | .[length] = ($o | (.id = start + $l)));\n    \n    reduce .[] as $o\n      ( {start: -1, answer: []};\n        (.start + 1) as $next\n        | .answer += [$o | (.objects |= addId($next))]\n        | .start += ($o.objects | length) )\n    | .answer\n",
      "Inspired by @peak answer, I came up with this solution. Not much difference, just shorter way to generate IDs and opt for `foreach` instead of `reduce` since there is intermediate result involved.\n\n    def addIdsStartWith($start):\n        [to_entries | map((.value.id = .key + $start) | .value)];\n\n    [foreach .[] as $set (\n        {start: 0};\n        .set = $set |\n            .start as $start | .set.objects |= addIdsStartWith($start) |\n            .start += ($set.objects | length);\n        .set\n    )]"
    ],
    "utterance": "Add a unique, incrementing id field starting from 0 to each object inside the objects arrays, continuing across all arrays in the list.",
    "expressions": [
      "def addId(start): reduce .[] as $o ([]; length as $l | .[length] = ($o | (.id = start + $l)));\nreduce .[] as $o ( {start: -1, answer: []}; (.start + 1) as $next | .answer += [$o | (.objects |= addId($next))] | .start += ($o.objects | length) ) | .answer",
      "def addIdsStartWith($start): [to_entries | map((.value.id = .key + $start) | .value)];\n[foreach .[] as $set (\n    {start: 0};\n    .set = $set |\n        .start as $start | .set.objects |= addIdsStartWith($start) |\n        .start += ($set.objects | length);\n    .set\n)]"
    ],
    "data": [
      {
        "input": [
          {
            "objects": [
              {
                "key": "value"
              },
              {
                "key": "value"
              }
            ]
          },
          {
            "objects": [
              {
                "key": "value"
              },
              {
                "key": "value"
              }
            ]
          }
        ],
        "output": [
          {
            "objects": [
              {
                "id": 0,
                "key": "value"
              },
              {
                "id": 1,
                "key": "value"
              }
            ]
          },
          {
            "objects": [
              {
                "id": 2,
                "key": "value"
              },
              {
                "id": 3,
                "key": "value"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 42697048
  },
  {
    "context": [
      "I need to limit what comes back to filter out the ones that do not have a dockerConfig.",
      "You can use [`select`](https://stedolan.github.io/jq/manual/#select(boolean_expression)) to restrict the content of the array to objects whose `dockerContainerName` differs from `null` :",
      "jq '.[] | select(.dockerContainerName != null)' <<EOF",
      "{",
      "  \"dockerContainerName\": \"my_awesome_container\",",
      "  \"servers\": [",
      "    \"serverX01\",",
      "    \"serverX02\"",
      "  ]",
      "}"
    ],
    "utterance": "Return only objects whose dockerContainerName is not null.",
    "expressions": [
      ".[] | select(.dockerContainerName != null)"
    ],
    "data": [
      {
        "input": [
          {
            "dockerContainerName": null,
            "servers": []
          },
          {
            "dockerContainerName": "my_awesome_container",
            "servers": [
              "serverX01",
              "serverX02"
            ]
          }
        ],
        "output": {
          "dockerContainerName": "my_awesome_container",
          "servers": [
            "serverX01",
            "serverX02"
          ]
        }
      }
    ],
    "identifier": 41960261
  },
  {
    "identifier": 42262960
  },
  {
    "context": [
      "jq -r '.[] | select(.ParameterKey==\"RTSMEMAIL\") | .ParameterValue' json",
      "email=\"RTSMEMAIL\"",
      "jq --arg email \"$email\" -r '.[] | select(.ParameterKey==$email) | .ParameterValue' json",
      "param=$(jq -r '.[] | select(.ParameterKey == \"RTSMEMAIL\")|.ParameterValue' cloudformation/parameters_v13.json )",
      "jq --arg param \"$param\" -f edit.jq input.json",
      "(.[] | select(.ParameterKey == \"RTSMEMAIL\")|.ParameterValue) |= $param",
      "($p[] | select(.ParameterKey == \"RTSMEMAIL\")|.ParameterValue) as $param | (.[]| select(.ParameterKey == \"RTSMEMAIL\")|.ParameterValue) |= $param"
    ],
    "utterance": "Extract the ParameterValue where ParameterKey equals RTSMEMAIL from cloudformation/parameters_v13.json.",
    "expressions": [
      ".[] | select(.ParameterKey==\"RTSMEMAIL\") | .ParameterValue",
      "-r '.[] | select(.ParameterKey==\"RTSMEMAIL\") | .ParameterValue'",
      "--arg email \"RTSMEMAIL\" -r '.[] | select(.ParameterKey==$email) | .ParameterValue'"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "RTSMEMAIL",
            "ParameterValue": "secretemail"
          }
        ],
        "output": "secretemail"
      }
    ],
    "identifier": 41382610
  },
  {
    "context": [
      "What I want is:\r\n    \r\n    { \"key1\":{\r\n          \"key2\": .key2\r\n           },\r\n      \"key3\":{\r\n          \"key4\": .key4\r\n           }\r\n    }",
      "With your input, and using jq -n, this produces:\r\n\r\n    {\r\n      \"key1\": {\r\n        \"key2\": \"mykey\"\r\n      },\r\n      \"key3\": {\r\n        \"key4\": \"mykey\"\r\n      }\r\n    }",
      "def selection(mykey):\r\n      . as $in\r\n      | reduce (paths(objects) | select(.[-1] == mykey)) as $path\r\n          (null; setpath($path; $in|getpath($path)) );\r\n    \r\n    data | selection(\"mykey\")",
      "I only need to add a filter to the selection to retain the 1st two elements of each path that includes \"mykey\":\r\n\r\n    def selection(mykey):\r\n    \r\n      . as $in \r\n      | reduce (paths(objects) | select(last(.[])==mykey)|.[0:2]) as $path\r\n          (null; setpath($path; $in|getpath($path)) );\r\n    \r\n    data | selection(\"mykey\")",
      "Which returns what I desired:\r\n\r\n    {\"key1\":{\"key2\":{\"mykey\":{\"a\":123},\r\n                     \"another\":{\"q\":\"six\"}}},\r\n     \"key3\":{\"key6\":{\"mykey\":{\"d\":997},\r\n                     \"another\":{\"q\":\"seven\"}}}\r\n    }"
    ],
    "utterance": "Produce an object containing only the sub-objects along the top two levels of paths ending in 'mykey', preserving all sibling keys at that level.",
    "expressions": [
      ". as $in | reduce (paths(objects) | select(last(.[])==\"mykey\")|.[0:2]) as $path (null; setpath($path; $in|getpath($path)))"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "key2": {
              "mykey": {
                "a": 123
              },
              "another": {
                "q": "six"
              }
            },
            "key6": {
              "key7": {
                "d": 997
              }
            }
          },
          "key3": {
            "key8": {
              "key9": {
                "b": 234
              }
            },
            "key10": {
              "mykey": {
                "d": 997
              },
              "another": {
                "q": "seven"
              }
            }
          },
          "key4": {
            "key11": {
              "key5": {
                "a": 123
              }
            }
          }
        },
        "output": {
          "key1": {
            "key2": {
              "mykey": {
                "a": 123
              },
              "another": {
                "q": "six"
              }
            }
          },
          "key3": {
            "key10": {
              "mykey": {
                "d": 997
              },
              "another": {
                "q": "seven"
              }
            }
          }
        }
      }
    ],
    "identifier": 42584824
  },
  {
    "context": [
      "I will pass JSON object name as an input. So if I know \"images1\" is the object, then I need all the keys and values of that object to be stored in two separate arrays, so that I can make use of them in further processing.",
      "jq \".images1 | { keys: keys_unsorted, values: [.[]] }\"",
      "It will produce an object whose `keys` property will be an array of the keys of `$1` and `values` an array of the associated values : ...",
      "{\n  \"keys\": [\n\t\"size\",\n\t\"idiom\",\n\t\"filename\",\n\t\"scale\"\n  ],\n  \"values\": [\n\t\"29x29\",\n\t\"iphone\",\n\t\"Icon-Small@2x.png\",\n\t\"2x\"\n  ]\n}"
    ],
    "utterance": "Given an object name, extract all its keys as an array and all its values as a separate array.",
    "expressions": [
      ".images1 | { keys: keys_unsorted, values: [.[]] }",
      ".$1 | { keys: keys_unsorted, values: [.[]] }"
    ],
    "data": [
      {
        "input": {
          "images1": {
            "size": "29x29",
            "idiom": "iphone",
            "filename": "Icon-Small@2x.png",
            "scale": "2x"
          },
          "images2": {
            "size": "29x30",
            "idiom": "iphone2",
            "filename": "Icon-Small@2x.png2",
            "scale": "22x"
          }
        },
        "output": {
          "keys": [
            "size",
            "idiom",
            "filename",
            "scale"
          ],
          "values": [
            "29x29",
            "iphone",
            "Icon-Small@2x.png",
            "2x"
          ]
        }
      }
    ],
    "identifier": 42675550
  },
  {
    "context": [
      "I am trying to get this:\r\n\r\n\t[\t\r\n\t\t[\"John Black\",[ \r\n\t\t\t[\"Lorem ipsum dolor sit amet.\",27], \r\n\t\t\t[\"Ut tempus lectus ut mi.\",23]\r\n\t\t]],\r\n\t\t[\"Peter Pan\",[ \r\n\t\t\t[\"Quisque pulvinar odio.\",22],\r\n\t\t\t[\"Nec ut lorem quis interdum elit.\",32]\r\n\t\t]],\r\n\t\t[\"Gary Halbert\",[ \r\n\t\t\t[\"Placerat aliquam.\",17]\r\n\t\t]],\r\n\t\t[\"Richard Gere\",[ \r\n\t\t\t[\"Porttitor commodo fermentum.\",28]\r\n\t\t]]\r\n\t]",
      "Till now, this is what I got:\r\n\r\n\t[ [\"John Black\",[\"Lorem ipsum dolor sit amet.\",27]], [\"Peter Pan\",[\"Quisque pulvinar odio.\",22]], [\"John Black\",[\"Ut tempus lectus ut mi.\",23]], [\"Gary Halbert\",[\"Placerat aliquam.\",17]], [\"Peter Pan\",[\"Nec ut lorem quis interdum elit.\",32]], [\"Richard Gere\",[\"Porttitor commodo fermentum.\",28]] ]",
      "This is an appropriate use case for a reducer. Most of the below is related not to joining items under shared keys, but to getting them into the desired nested-list form:",
      "jq -n '[\r\n  inputs |\r\n  reduce .[] as $item ({}; .[$item[0]] += [$item[1]]) |\r\n  to_entries |\r\n  .[] |\r\n  [.key, .value]\r\n]' <<<\"$A\"\r\n",
      "...yields as output (edited only for compactness with regard to whitespace):\r\n\r\n    [\r\n      [\"John Black\", [[\"Lorem ipsum dolor sit amet.\", 27], [\"Ut tempus lectus ut mi.\",23]]],\r\n      [\"Peter Pan\", [[\"Quisque pulvinar odio.\",22], [\"Nec ut lorem quis interdum elit.\", 32]]],\r\n      [\"Gary Halbert\", [[\"Placerat aliquam.\", 17]]],\r\n      [\"Richard Gere\", [[\"Porttitor commodo fermentum.\", 28]]]\r\n    ]"
    ],
    "utterance": "Group entries by the first element, and for each group, create an array containing the group key and all associated values as arrays.",
    "expressions": [
      "[inputs | reduce .[] as $item ({}; .[$item[0]] += [$item[1]]) | to_entries | .[] | [.key, .value]]"
    ],
    "data": [
      {
        "input": [
          [
            "John Black",
            [
              "Lorem ipsum dolor sit amet.",
              27
            ]
          ],
          [
            "Peter Pan",
            [
              "Quisque pulvinar odio.",
              22
            ]
          ],
          [
            "John Black",
            [
              "Ut tempus lectus ut mi.",
              23
            ]
          ],
          [
            "Gary Halbert",
            [
              "Placerat aliquam.",
              17
            ]
          ],
          [
            "Peter Pan",
            [
              "Nec ut lorem quis interdum elit.",
              32
            ]
          ],
          [
            "Richard Gere",
            [
              "Porttitor commodo fermentum.",
              28
            ]
          ]
        ],
        "output": [
          [
            "John Black",
            [
              [
                "Lorem ipsum dolor sit amet.",
                27
              ],
              [
                "Ut tempus lectus ut mi.",
                23
              ]
            ]
          ],
          [
            "Peter Pan",
            [
              [
                "Quisque pulvinar odio.",
                22
              ],
              [
                "Nec ut lorem quis interdum elit.",
                32
              ]
            ]
          ],
          [
            "Gary Halbert",
            [
              [
                "Placerat aliquam.",
                17
              ]
            ]
          ],
          [
            "Richard Gere",
            [
              [
                "Porttitor commodo fermentum.",
                28
              ]
            ]
          ]
        ]
      }
    ],
    "identifier": 42633045
  },
  {
    "context": [
      "I can filter that file with the command: jq '.daily.data' till that state: http://pastebin.com/Mukz14rJ but I cant filter it further than that.",
      "To extract just the `.summary` values from each element of `.daily.data` with `[]`, use \n\n    .daily.data[].summary",
      "Running this over the value from the specified pastebin returns\n\n    \"Leichter Regen am Vormittag und Nacht.\"\n    \"Leichter Regen am Vormittag.\"\n    \"Den ganzen Tag lang \u00fcberwiegend bew\u00f6lkt.\"\n    \"Leichter Regen von nachmittags bis abends.\"\n    \"Den ganzen Tag lang stark bew\u00f6lkt.\"\n    \"Abends Nieselregen.\"\n    \"Den ganzen Tag lang Regen.\"\n    \"Leichter Regen am Vormittag und Abend.\""
    ],
    "utterance": "Extract the summary values from each element inside the daily.data array.",
    "expressions": [
      ".daily.data[].summary"
    ],
    "data": [
      {
        "input": {
          "daily": {
            "data": [
              {
                "summary": "Leichter Regen am Vormittag und Nacht."
              },
              {
                "summary": "Leichter Regen am Vormittag."
              },
              {
                "summary": "Den ganzen Tag lang \u00fcberwiegend bew\u00f6lkt."
              },
              {
                "summary": "Leichter Regen von nachmittags bis abends."
              },
              {
                "summary": "Den ganzen Tag lang stark bew\u00f6lkt."
              },
              {
                "summary": "Abends Nieselregen."
              },
              {
                "summary": "Den ganzen Tag lang Regen."
              },
              {
                "summary": "Leichter Regen am Vormittag und Abend."
              }
            ]
          }
        },
        "output": [
          "Leichter Regen am Vormittag und Nacht.",
          "Leichter Regen am Vormittag.",
          "Den ganzen Tag lang \u00fcberwiegend bew\u00f6lkt.",
          "Leichter Regen von nachmittags bis abends.",
          "Den ganzen Tag lang stark bew\u00f6lkt.",
          "Abends Nieselregen.",
          "Den ganzen Tag lang Regen.",
          "Leichter Regen am Vormittag und Abend."
        ]
      }
    ],
    "identifier": 42603670
  },
  {
    "context": [
      "Who can I select the content of the most outer wrapping element without selecting it by name?",
      "You can use `jq` like this:\r\n\r\n    jq -r 'to_entries[0].value' file.json",
      "Even easier:\r\n\r\n    jq '.[]'"
    ],
    "utterance": "Select the content inside the single top-level key of an object, regardless of its name.",
    "expressions": [
      ".[]",
      "to_entries[0].value"
    ],
    "data": [
      {
        "input": {
          "a": {
            "x": 0
          }
        },
        "output": {
          "x": 0
        }
      },
      {
        "input": {
          "b": {
            "y": 1,
            "z": 2
          }
        },
        "output": {
          "y": 1,
          "z": 2
        }
      }
    ],
    "identifier": 42673485
  },
  {
    "context": [
      "jq: error: REPORT/0 is not defined at <top-level>, line 1:",
      ".messages[.messages| length] |= . + $REPORT",
      "jq --argjson args \"$REPORT\" '.data.messages += [$args]' file",
      "echo `jq --argjson args \"$REPORT\" '.data.messages += [$args]' $FILE_PATH` > $FILE_PATH",
      "update)\n        jq --argjson new_msg \"$new_message\" \\\n           '.messages += [ $new_msg ]' \\\n           \"$file_path\" > \"$file_path.tmp\" && mv \"$file_path.tmp\" \"$file_path\" ;;"
    ],
    "utterance": "Append the object stored in the REPORT shell variable as a new element to the messages array in the output, using a variable passed into the command.",
    "expressions": [
      "jq --argjson args \"$REPORT\" '.data.messages += [$args]' file",
      "jq --argjson args \"$REPORT\" '.messages += [$args]' $FILE_PATH",
      "jq --argjson new_msg \"$new_message\" '.messages += [ $new_msg ]' \"$file_path\""
    ],
    "data": [
      {
        "input": {
          "date": "2017-02-17",
          "csv": "file.csv",
          "messages": [
            {
              "timestamp": "2017-02-17:12:31:21",
              "step": "1",
              "status": "OK",
              "code": "33",
              "message": "message 33"
            }
          ]
        },
        "output": {
          "date": "2017-02-17",
          "csv": "file.csv",
          "messages": [
            {
              "timestamp": "2017-02-17:12:31:21",
              "step": "1",
              "status": "OK",
              "code": "33",
              "message": "message 33"
            },
            {
              "timestamp": "2017-02-17:11:51:14",
              "step": "2",
              "status": "OK",
              "code": "34",
              "message": "message 34 file.xml"
            }
          ]
        }
      }
    ],
    "identifier": 42296559
  },
  {
    "context": [
      "Is it possible in jq to normalize the data like below?",
      "I'm kind of new to jq so I don't know where to really begin. My main issue is how to create an object beforehand that would then be populated as I iterate through the passed in json",
      "and how do I get the index of an appended object?",
      "Another issue is making sure an object such as a `job` or `location` isn't duplicated so I'd want to make sure there isn't an object with duplicate fields.",
      "If I understand your question correctly, you should be able to accomplish what you want using `reduce`, along the lines of:\r\n\r\n    reduce .[] as $o\r\n      ({\r\n         people: [],\r\n         terms: [],\r\n         jobs: [],\r\n         locations: []\r\n       }; ......\r\n     )",
      "The easiest way to check for duplicates is probably using `index/1`.",
      "I'd suggest using helper functions (`def ...`) to keep things easy-to-read and easy-to-maintain.",
      "If you need to generate a numerical id, then it might be easier to use the idiom:\r\n \r\n    . as $in | reduce range(0;length) as $i (INITIAL; $in[$i] as $o | ......)"
    ],
    "utterance": "Transform an array of people with nested positions into a denormalized object with separate arrays for people, terms, jobs, and locations, assigning numeric ids and avoiding duplicate jobs and locations.",
    "expressions": [
      "reduce .[] as $o ({people: [], terms: [], jobs: [], locations: []}; ... )",
      ". as $in | reduce range(0;length) as $i (INITIAL; $in[$i] as $o | ... )"
    ],
    "data": [
      {
        "input": [
          {
            "names": {
              "official_full": "John Smith",
              "nickname": "Johnny"
            },
            "positions": [
              {
                "start": "1993-01-05",
                "end": "2002-12-03",
                "title": "Executive VP of Operations",
                "city": "Winnipeg",
                "state": "Michigan"
              }
            ]
          }
        ],
        "output": {
          "people": [
            {
              "full_name": "John Smith"
            }
          ],
          "terms": [
            {
              "start": "1993-01-05",
              "end": "2002-12-03",
              "person": 1,
              "job": 0
            }
          ],
          "jobs": [
            {
              "title": "Executive VP of Operations",
              "location": 0
            }
          ],
          "locations": [
            {
              "city": "Winnipeg",
              "state": "Michigan"
            }
          ]
        }
      }
    ],
    "identifier": 42588027
  },
  {
    "context": [
      "I need to capture using JQ, but so far I only manage to capture the parent parameter (SUBSCRIBER_ID), but unable to capture the sub-parent parameter which is \"Offer\".",
      "Need your guys help on providing a correct JQ filter to capture both \"SUBSCRIBER_ID\" and \"Offer\" value.",
      "#Expected output:#\n\n    SUBSCRIBER_ID,Offer\n    999050280010099,12344",
      "jq -r '.Data1|.[]|.Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv' file > out.csv",
      "jq -r '.Data1[].Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv' file",
      "jq -r '.[]|.[]|map([.SUBSCRIBER_ID, .OFFERS[].Offer])|.[]|@csv' file",
      "$ jq -r '.Data1|.[]|.Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv' file.json\n\"999050280010099\",12344",
      "$ jq -r '.[]|.[]|map([.SUBSCRIBER_ID, .OFFERS[].Offer])|.[]|@csv' file.json\n\"999050280010099\",12344"
    ],
    "utterance": "Extract the value of SUBSCRIBER_ID and the nested Offer for each record, outputting both fields together per record.",
    "expressions": [
      ".Data1|.[]|.Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv",
      ".Data1[].Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv",
      ".[]|.[]|map([.SUBSCRIBER_ID, .OFFERS[].Offer])|.[]|@csv"
    ],
    "data": [
      {
        "input": {
          "Data1": [
            {
              "Data2": {
                "SUBSCRIBER_ID": "999050280010099",
                "MSISDN": "999050280010099",
                "EMAIL": "john@email.com",
                "OFFERS": [
                  {
                    "Offer": 12344,
                    "EffectiveDate": "1488787236",
                    "ExpiryDate": "4070869200"
                  }
                ],
                "IsGroup": "false"
              }
            }
          ]
        },
        "output": "\"999050280010099\",12344"
      }
    ],
    "identifier": 42643920
  },
  {
    "context": [
      "I have the following objects:\r\n\r\n    // exhibit a\r\n    {\r\n      &quot;exported_modules&quot;: [&quot;a&quot;, &quot;b&quot;]\r\n    }\r\n    // exhibit b\r\n    {\r\n      &quot;name&quot;: &quot;thing b&quot;\r\n    }\r\n\r\nThey exist in separate files. I need to basically transform them such that they are output unified in the following state:\r\n\r\n    {\r\n      &quot;exported_modules&quot;: [&quot;a&quot;, &quot;b&quot;],\r\n      &quot;modules&quot;: {\r\n        &quot;a&quot;: {\r\n          &quot;name&quot;: &quot;thing b&quot;\r\n        }\r\n     }\r\n    }",
      "Essentially I need to insert the contents of exhibit b into `.modules.a`. Is there a way to do this in jq? I&#39;m on `jq` 1.3 unfortunately, which is provided by my distribution.",
      "jq 1.3 is ancient so the solution using that version is rather inelegant.  Perhaps the best approach would be to \"slurp\" the two files:\r\n\r\n    jq1.3 -s '[1] as $o | .[0] | .modules.a = $o' exhibit-a.json exhibit-b.json"
    ],
    "utterance": "Insert the contents of a separate object into the 'modules.a' field of another object while preserving other fields.",
    "expressions": [
      ".[1] as $o | .[0] | .modules.a = $o"
    ],
    "data": [
      {
        "input": [
          {
            "exported_modules": [
              "a",
              "b"
            ]
          },
          {
            "name": "thing b"
          }
        ],
        "output": {
          "exported_modules": [
            "a",
            "b"
          ],
          "modules": {
            "a": {
              "name": "thing b"
            }
          }
        }
      }
    ],
    "identifier": 42261911
  },
  {
    "context": [
      "I am trying to convert all time stamps in a file to the Unix time format preferably using jq/bash/python.",
      "The original format is kinda odd:\r\n\r\n    %Y-%m-%dT%H:%M:%S.%z",
      "I was able to convert just one single value to Unix by running this:\r\n\r\nInput:\r\n\r\n    jq 'strptime(\"%Y-%m-%dT%H:%M:%S.%z\") | mktime';\r\n    \"2015-03-05T04:50:25.+0000\"",
      "To tackle both the first question and the main goal, you'll probably want to define a convenience function, which is here specified according to your one-liner:",
      "def convert: strptime(\"%Y-%m-%dT%H:%M:%S.%z\") | mktime;",
      "The filter to answer the first question could then be written as follows:\r\n\r\n    map( ( .startdate |= convert) | (.enddate |= convert) )"
    ],
    "utterance": "Convert all timestamp fields named 'startdate' and 'enddate' in each array object from %Y-%m-%dT%H:%M:%S.%z format to Unix time.",
    "expressions": [
      "def convert: strptime(\"%Y-%m-%dT%H:%M:%S.%z\") | mktime; map((.startdate |= convert) | (.enddate |= convert))"
    ],
    "data": [
      {
        "input": [
          {
            "Last Name": "John",
            "Subject": "Meet Now",
            "meetingId": "983329197",
            "meetingType": "immediate",
            "First Name": "Doe",
            "Conference Info": "111-222-333",
            "startdate": "2017-01-25T04:50:25.+0000",
            "enddate": "2017-01-25T05:50:25.+0000",
            "status": "INACTIVE"
          },
          {
            "Last Name": "John",
            "Subject": "dumb meeting",
            "meetingId": "569996685",
            "meetingType": "scheduled",
            "First Name": "Doe",
            "Conference Info": "111-222-333",
            "startdate": "2017-02-15T10:00:00.+0000",
            "enddate": "2017-02-15T10:30:00.+0000",
            "status": "INACTIVE"
          }
        ],
        "output": [
          {
            "Last Name": "John",
            "Subject": "Meet Now",
            "meetingId": "983329197",
            "meetingType": "immediate",
            "First Name": "Doe",
            "Conference Info": "111-222-333",
            "startdate": 1485329425,
            "enddate": 1485333025,
            "status": "INACTIVE"
          },
          {
            "Last Name": "John",
            "Subject": "dumb meeting",
            "meetingId": "569996685",
            "meetingType": "scheduled",
            "First Name": "Doe",
            "Conference Info": "111-222-333",
            "startdate": 1487152800,
            "enddate": 1487154600,
            "status": "INACTIVE"
          }
        ]
      }
    ],
    "identifier": 41929906
  },
  {
    "context": [
      "cat test.jq\n{\"number\":$number}",
      "jq -n --arg number 3000 -f test.jq\n{\n  \"number\": \"3000\"\n}",
      "If you want it to be a number you need to use --argjson:\n\n    jq -n --argjson number 3000 -f test.jq\n    {\n      \"number\": 3000\n    }"
    ],
    "utterance": "Insert a variable into the 'number' field of an object defined in a jq script file and output the resulting object, with the option for the value to be treated as a number or as a string.",
    "expressions": [
      "jq -n --arg number 3000 -f test.jq",
      "jq -n --argjson number 3000 -f test.jq"
    ],
    "data": [
      {
        "input": "{ \"number\": $number }",
        "output": {
          "number": "3000"
        }
      },
      {
        "input": "{ \"number\": $number }",
        "output": {
          "number": 3000
        }
      }
    ],
    "identifier": 41868687
  },
  {
    "context": [
      "How do I print the key and subvalue?",
      "plan: 14208",
      "resource: 1427143",
      "user: 104475",
      "$ jq -r '.indices | to_entries[] | \"\\(.key): \\(.value.primaries.docs.count)\"' input.json",
      ".indices\n| keys[] as $k\n| \"\\($k): \\(.[$k].primaries.docs.count)\"",
      "{\n  \"indices\": {\n    \"plan\":     { \"primaries\": { \"docs\": { \"count\": 123 }}},\n    \"resource\": { \"primaries\": { \"docs\": { \"count\": 456 }}},\n    \"user\":     { \"primaries\": { \"docs\": { \"count\": 789 }}}\n  }\n}"
    ],
    "utterance": "For each top-level entry in 'indices', print the entry's key followed by its corresponding value for primaries.docs.count in the format 'key: value'.",
    "expressions": [
      ".indices | to_entries[] | \"\\(.key): \\(.value.primaries.docs.count)\"",
      ".indices | keys[] as $k | \"\\($k): \\(.[$k].primaries.docs.count)\""
    ],
    "data": [
      {
        "input": {
          "indices": {
            "plan": {
              "primaries": {
                "docs": {
                  "count": 123
                }
              }
            },
            "resource": {
              "primaries": {
                "docs": {
                  "count": 456
                }
              }
            },
            "user": {
              "primaries": {
                "docs": {
                  "count": 789
                }
              }
            }
          }
        },
        "output": [
          "plan: 123",
          "resource: 456",
          "user: 789"
        ]
      }
    ],
    "identifier": 41386019
  },
  {
    "context": [
      "I would use `map()` like this:\n\n    jq 'map(select(.key!=\"something\"))'",
      "it should be:\n\n    jq 'walk(if(type == \"object\" and (.key | test(\"something\"))) then del(.) else . end)'",
      "let me venture to guess that it is to delete the object (.) itself. That can be done using `empty`:\n\n    walk(if type == \"object\" and (.key | test(\"something\"))\n         then empty\n         else . end)"
    ],
    "utterance": "Remove all objects from the top-level array whose 'key' field matches 'something'.",
    "expressions": [
      "map(select(.key != \"something\"))",
      "walk(if type == \"object\" and (.key | test(\"something\"))\n     then empty\n     else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "key": "something",
            "value": "something"
          },
          {
            "key": "another thing",
            "value": "another thing"
          },
          {
            "key": "something",
            "value": "something"
          }
        ],
        "output": [
          {
            "key": "another thing",
            "value": "another thing"
          }
        ]
      }
    ],
    "identifier": 42227949
  },
  {
    "context": [
      "jq \".[]\" data.txt >newfile.json",
      "subprocess.call([\u2019jq\u2019, \u2019.[]\u2019, \u2019data.txt\u2019],\n  cwd=r\u2019C:/Users/john/Desktop/swag\u2019,\n  stdout=open(\u2019C:/Users/john/Desktop/swag/newfile.json\u2019, \u2019w\u2019))"
    ],
    "utterance": "Extract all elements from an array in the file data.txt and write them to newfile.json.",
    "expressions": [
      ".[]"
    ],
    "identifier": 41861503
  },
  {
    "context": [
      "I would like to extract the values of the fields within *data* whose \"name\" matches a certain pattern. For example, I would like to extract all the case-insensitive coincidences of \"what a burger\" to get",
      "[1,2,3],[a,a,3]",
      ".data | to_entries | map(select(.key | match(\"what a burger\";\"i\"))) | map(.value)",
      ".data | with_entries(select(.key|match(\"what a burger\";\"i\")))[]"
    ],
    "utterance": "Extract all values from the 'data' object whose key matches 'what a burger' case-insensitively.",
    "expressions": [
      ".data | to_entries | map(select(.key | match(\"what a burger\";\"i\"))) | map(.value)",
      ".data | with_entries(select(.key|match(\"what a burger\";\"i\")))[]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "what a burger": [
              1,
              2,
              3
            ],
            "wap": [
              66
            ],
            "the map": [
              11,
              20
            ],
            "H. Incandenza": [
              1,
              1
            ],
            "What a burger": [
              "a",
              "a",
              3
            ]
          }
        },
        "output": [
          [
            1,
            2,
            3
          ],
          [
            "a",
            "a",
            3
          ]
        ]
      }
    ],
    "identifier": 42051601
  },
  {
    "context": [
      "I would like to filter (using `jq`) the value based on tags and get the title as output.",
      "For instance, I would filter all the values that have _tags1_(and the output would be `t1` and `t2`).",
      ".[] | select( .tags | index(\"tags1\") ) | .title",
      "Output:",
      "\"t1\"",
      "\"t2\""
    ],
    "utterance": "Return the titles of all objects where the tags array contains the string \"tags1\".",
    "expressions": [
      ".[] | select(.tags | index(\"tags1\")) | .title"
    ],
    "data": [
      {
        "input": [
          {
            "path": "p1",
            "title": "t1",
            "tags": [
              "tags1"
            ]
          },
          {
            "path": "p2",
            "title": "t2",
            "tags": [
              "tags1",
              "tag2"
            ]
          },
          {
            "path": "p3",
            "title": "t3",
            "tags": [
              "tags2"
            ]
          }
        ],
        "output": [
          "t1",
          "t2"
        ]
      }
    ],
    "identifier": 42177558
  },
  {
    "context": [
      "An improvement would have been:\n\n    {\n      \"\\\"a.b\\\"[0]\": \"value\"\n    }",
      "That is easily accomplished using a helper function along these lines:\n\ndef flattenPath(delim):\n  reduce .[] as $s (\"\";\n    if $s|type == \"number\" \n    then ((if . == \"\" then \".\" else . end) + \"[\\($s)]\")\n    else . + ($s | tostring | if index(delim) then \"\\\"\\(.)\\\"\" else . end)\n    end );"
    ],
    "utterance": "Flatten object paths so that keys containing the delimiter are quoted and array indices are represented as [N], forming keys like '\"a.b\"[0]' with their corresponding values.",
    "expressions": [
      "def flattenPath(delim):\n  reduce .[] as $s (\"\";\n    if $s|type == \"number\" \n    then ((if . == \"\" then \".\" else . end) + \"[\\($s)]\")\n    else . + ($s | tostring | if index(delim) then \"\\\"\\(.)\\\"\" else . end)\n    end );"
    ],
    "data": [
      {
        "input": {
          "a.b": [
            "value"
          ]
        },
        "output": {
          "\"a.b\"[0]": "value"
        }
      }
    ],
    "identifier": 42553309
  },
  {
    "context": [
      "I'm looking to trim out all the records whose IP's do not start with '10.10'.",
      "aws ec2 describe-instances --no-paginate --filter \"Name=instance-state-name,Values=running\" --query 'Reservations[].Instances[].{Private:PrivateIpAddress,PublicDNS:PublicDnsName,PublicIP:PublicIpAddress}' | jq '.[] | select( .Private | contains(\"10.10\"))'",
      "This gets me the exact opposite of what I want. It seems logical that I should be able to negate the contains in some way - but I've not been able to glean it from the documentation, nor through experimentation.",
      "It might be a bit better, since this catches only objects that start with 10.10, whereas the jq from above will catch any object that contains 10.10, so things like 10.100. or 110.100, etc... will get through. That's assuming there is not a similar operator to \"starts_with\" in jq. Probably there is."
    ],
    "utterance": "Select all items where the Private IP does not start with '10.10'.",
    "expressions": [
      ".[] | select(.Private | startswith(\"10.10\") | not)"
    ],
    "identifier": 41452437
  },
  {
    "context": [
      "Is there a way I can tell jq to only create the `'quote'` key if it exists (i.e. is not null)? Or more generally, create ALL keys only if they exist in the object being inspected.",
      ".student |  {name} + if has(\"quote\") then {quote} else null end",
      "def maybe(k): if has(k) then {(k): .[k]} else null end; .student |  {name} + maybe(\"quote\")",
      ".student |  {name} + ((select(.quote) | {quote}) // null)",
      "$ jq --argjson keys '[\"name\",\"quote\"]' '\ndef copy_keys($keys): . as $o\n    | reduce $keys[] as $k ({}; if ($o|has($k)) then .[$k] = $o[$k] else . end)\n    ;\n.student | copy_keys($keys)' text.txt"
    ],
    "utterance": "Create an object with 'name' and 'quote' keys, including only the keys that exist and are not null in the input's 'student' field.",
    "expressions": [
      ".student | {name} + if has(\"quote\") then {quote} else null end",
      "def maybe(k): if has(k) then {(k): .[k]} else null end; .student | {name} + maybe(\"quote\")",
      ".student | {name} + ((select(.quote) | {quote}) // null)",
      "def copy_keys($keys): . as $o | reduce $keys[] as $k ({}; if ($o|has($k)) then .[$k] = $o[$k] else . end); .student | copy_keys($keys)"
    ],
    "data": [
      {
        "input": {
          "student": {
            "name": "george",
            "age": "15",
            "quote": "Hello I am George"
          }
        },
        "output": {
          "name": "george",
          "quote": "Hello I am George"
        }
      },
      {
        "input": {
          "student": {
            "name": "Shirley"
          }
        },
        "output": {
          "name": "Shirley"
        }
      }
    ],
    "identifier": 41823497
  },
  {
    "context": [
      "I have a JSON object that looks something like:\n\n    {\n    \"timestamp\":1455408955250999808,\n    \"client\":  \n        {\n        \"ip\":\"76.72.172.208\",\n        \"srcPort\":0,\n        \"country\":\"us\",\n        \"deviceType\":\"desktop\"},\n    \"clientRequest\":\n        {\n        \"bytes\":410,\n        \"bodyBytes\":0}\n      }\n\nWhat I'm trying to do is create a new JSON object that looks likes:\n\n    {\n    \"timestamp\":1455408955250999808,\n    \"client\":  \n        {\n        \"ip\":\"76.72.172.208\",\n         }\n    \"clientRequest\":\n        {\n        \"bytes\":410\n        }\n    }",
      "It looks like it will be simplest if you construct the object you want.  Based on your example, you could do so using the following filter:\n\n    { timestamp,\n      client: { ip: .client.ip },\n      clientRequest: {bytes: .clientRequest.bytes }\n    }",
      "cat LogSample.txt | jq  '. | {Id: .Id, client: {ip: .client.ip}}'",
      "By contrast, `map` expects its input to be an array, whereas your input is a JSON object."
    ],
    "utterance": "Reduce the object to include only the timestamp, client.ip, and clientRequest.bytes fields.",
    "expressions": [
      "{ timestamp, client: { ip: .client.ip }, clientRequest: { bytes: .clientRequest.bytes } }"
    ],
    "data": [
      {
        "input": {
          "timestamp": 1455408955250999808,
          "client": {
            "ip": "76.72.172.208",
            "srcPort": 0,
            "country": "us",
            "deviceType": "desktop"
          },
          "clientRequest": {
            "bytes": 410,
            "bodyBytes": 0
          }
        },
        "output": {
          "timestamp": 1455408955250999808,
          "client": {
            "ip": "76.72.172.208"
          },
          "clientRequest": {
            "bytes": 410
          }
        }
      }
    ],
    "identifier": 41819201
  },
  {
    "context": [
      "for all items in array I need output two items, one with added `\"lanuage\": \"en\"` key value pair and one with `\"lanuage\": \"ru\"`",
      "I need a catesian product of input array of objects `is` with another array `xs`, which would give me pairs `(i, x)`. For each pair I want to output object that have all (key, value) pairs of `i` plus some key (`language` in my case) with with value of `x`.",
      "$ jq --argjson langs '[\"en\",\"fr\"]' '[(.[]|{x:.a,b}) + {language:$langs[]}]' input.json",
      "$ jq --argjson langs '[\"en\",\"fr\"]' '[.[]|{x:.a,b,language:$langs[]}]' input.json",
      "$ jq --argjson langs '[\"en\",\"fr\"]' 'map({x:.a,b,language:$langs[]})' input.json"
    ],
    "utterance": "For each object in the input array, output one item for each value in [\"en\",\"fr\"], where the result object has keys x:.a, b, and language set to the value.",
    "expressions": [
      "[.[]|{x:.a,b,language:$langs[]}]",
      "map({x:.a,b,language:$langs[]})",
      "[(.[]|{x:.a,b}) + {language:$langs[]}]"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 3,
            "b": 4
          }
        ],
        "output": [
          {
            "x": 1,
            "b": 2,
            "language": "en"
          },
          {
            "x": 1,
            "b": 2,
            "language": "fr"
          },
          {
            "x": 3,
            "b": 4,
            "language": "en"
          },
          {
            "x": 3,
            "b": 4,
            "language": "fr"
          }
        ]
      }
    ],
    "identifier": 41999706
  },
  {
    "identifier": 41784823
  },
  {
    "context": [
      "How do I loop through key and also get value?",
      "Here is an entirely unreadable one-liner that does it:",
      "jq -r 'to_entries[] | [.key, .value] | @tsv' < infile.json",
      "Get a list of arrays with key/value in each using [.key, .value], resulting in",
      "[",
      "  \"login\",",
      "  \"lambda\"",
      "]",
      "Finally, use the [@tsv](https://stedolan.github.io/jq/manual/v1.5/#Formatstringsandescaping) filter to get the key-value pairs as a tab separated list:",
      "login   lambda",
      "dictionary | reduce to_entries[] as $pair (template; gsub(\"%\\($pair.key)%\"; $pair.value))",
      "The above produces:",
      "\"Lamba login name is lambda, and avatar url is https://avatars.githubusercontent.com/u/37398?v=3\""
    ],
    "utterance": "Produce a list of all key-value pairs as arrays, where each array contains the key and its corresponding value from the object.",
    "expressions": [
      "to_entries[] | [.key, .value]",
      "to_entries[] | @tsv"
    ],
    "data": [
      {
        "input": {
          "login": "lambda",
          "id": 37398,
          "avatar_url": "https://avatars.githubusercontent.com/u/37398?v=3"
        },
        "output": [
          [
            "login",
            "lambda"
          ],
          [
            "id",
            37398
          ],
          [
            "avatar_url",
            "https://avatars.githubusercontent.com/u/37398?v=3"
          ]
        ]
      }
    ],
    "identifier": 41418646
  },
  {
    "context": [
      "How can I increment the START arg so that the second object has an id of 11 and so on?",
      "You can use `to_entries`, which, when given an array, will give the index for each item : ",
      "jq --arg START 10 '[.z[] | select(has(\"name\"))]\n  | to_entries\n  | map({name:.value.name, id: ($START | tonumber) + .key })'",
      "Assuming your jq has `foreach`:",
      "def counts(s; start):\n  foreach s as $i (start-1; .+1; {id:., value: $i});",
      "[ counts(.z[] | select(has(\"name\")); $START|tonumber)\n| {id, name: .value.name} ]"
    ],
    "utterance": "Create an array of objects with names from all objects under .z that have a \"name\" key, assigning each an id starting from the START argument and incrementing by one for each subsequent object.",
    "expressions": [
      "jq --arg START 10 '($START | tonumber) as $s | [.z[] | select(has(\"name\"))] | to_entries | map({name:.value.name, id: ($s + .key) })'",
      "def counts(s; start): foreach s as $i (start-1; .+1; {id:., value: $i}); [ counts(.z[] | select(has(\"name\")); $START|tonumber) | {id, name: .value.name} ]"
    ],
    "data": [
      {
        "input": {
          "u": "stuff",
          "x": [
            1,
            2,
            3
          ],
          "y": {
            "field": "value"
          },
          "z": {
            "stuffWithoutName": {
              "ex": "stuff"
            },
            "zz": {
              "name": "change me",
              "more": "stuff"
            },
            "randomKey": {
              "name": "change me",
              "random": "more stuff"
            }
          }
        },
        "output": [
          {
            "name": "change me",
            "id": 10
          },
          {
            "name": "change me",
            "id": 11
          }
        ]
      }
    ],
    "identifier": 41431965
  },
  {
    "context": [
      "I have as input an array of JSON objects:\r\n\r\n    [\r\n        {\r\n            \"foo\": 1,\r\n            \"bar\": 2\r\n        },\r\n        {\r\n            \"foo\": 3,\r\n            \"bar\": 4\r\n        },\r\n        (...)\r\n    ]\r\n\r\nand I want as output the JSONL version of the same, aka one object per line, not an array:",
      "The answer to the original question is to use the filter `.[]` together with the `-c` command-line option:\r\n\r\n    $ jq -c '.[]'",
      "Found: it's\r\n\r\n    map(tostring) | reduce .[] as $item (\"\"; . + $item + \"\\n\")\r\n\r\nYou also need to use `--raw-output`."
    ],
    "utterance": "Output each object from the input array on a separate line in line-delimited format.",
    "expressions": [
      ".[]",
      "map(tostring) | reduce .[] as $item (\"\"; . + $item + \"\\n\")"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 1,
            "bar": 2
          },
          {
            "foo": 3,
            "bar": 4
          }
        ],
        "output": [
          "{\"foo\":1,\"bar\":2}",
          "{\"foo\":3,\"bar\":4}"
        ]
      }
    ],
    "identifier": 42178636
  },
  {
    "context": [
      "So my objective is to merge json files obtain this format:\r\n\r\n    {\r\n      \"title\": \"NamesBook\",\r\n      \"list\": [\r\n        {\r\n          \"name\": \"Ajay\"\r\n        },\r\n        {\r\n          \"name\": \"Al\"\r\n        }\r\n      ]\r\n    }",
      "And I have files that look like this format:\r\n\r\nblahblah.json\r\n\r\n    {\r\n      \"title\": \"NamesBook\",\r\n      \"list\": [\r\n        {\r\n          \"name\": \"Ajay\"\r\n        }\r\n      ]\r\n    }\r\n\r\nblueblue.json\r\n\r\n    {\r\n      \"title\": \"NamesBook\",\r\n      \"list\": [\r\n        {\r\n          \"name\": \"Al\"\r\n        }\r\n      ]\r\n    }",
      "You can merge your files with _add_ (jq 1.3+):\r\n\r\n    jq -s '.[0].list=[.[].list|add]|.[0]' *.json",
      "or _flatten_ (jq 1.5+):\r\n\r\n    jq -s '.[0].list=([.[].list]|flatten)|.[0]' *.json",
      "This assumes that jq is invoked with the -s option.\r\n\r\nIncidentally, `add` is the way to go here: simple and fast."
    ],
    "utterance": "Combine multiple files containing objects with the same 'title' and separate 'list' arrays into one object with the shared title and a single 'list' array containing all entries from every file.",
    "expressions": [
      "jq -s '.[0].list=[.[].list|add]|.[0]' *.json",
      "jq -s '.[0].list=([.[].list]|flatten)|.[0]' *.json",
      "jq 'reduce inputs as $i (.; .list += $i.list)' blahblah.json blueblue.json"
    ],
    "data": [
      {
        "input": [
          {
            "title": "NamesBook",
            "list": [
              {
                "name": "Ajay"
              }
            ]
          },
          {
            "title": "NamesBook",
            "list": [
              {
                "name": "Al"
              }
            ]
          }
        ],
        "output": {
          "title": "NamesBook",
          "list": [
            {
              "name": "Ajay"
            },
            {
              "name": "Al"
            }
          ]
        }
      }
    ],
    "identifier": 42011086
  },
  {
    "context": [
      "Here is a sample JSON response from my curl:",
      "I want to check the status of ID=2. Here is the command I tried:",
      "cat test.txt|jq --arg v \"2\" '.jobStatus[]|select(.ID == $v)|.status'",
      "response: there is none",
      "\"jq is data-type-aware",
      "so, in order to compare them, you must use an explicit type conversion, such as with [`tonumber/1`]:",
      "jq --arg v '2' '.jobStatus[] | select(.ID == ($v | tonumber)) | .status' test.txt",
      "Given that you're only passing a _scalar_ argument here, the following solution, using --argjson is a bit of an overkill, but it is an alternative to explicit type conversion in that passing a *JSON* argument in effect passes _typed_ data:",
      "jq --argjson v '2' '.jobStatus[] | select(.ID == $v) | .status' test.txt",
      "Assuming you want to check for the JSON value `2`, you have a choice to make - either convert the argument of --arg to a number, or use --argjson with a numeric argument. These alternatives are illustrated by the following:",
      "jq --arg v 2 '.jobStatus[] | select(.ID == ($v|tonumber)) | .status'",
      "jq --argjson v 2 '.jobStatus[] | select(.ID == $v) | .status'"
    ],
    "utterance": "Select the status value where the ID field equals the value 2, using a variable for the ID.",
    "expressions": [
      ".jobStatus[] | select(.ID == ($v|tonumber)) | .status",
      ".jobStatus[] | select(.ID == $v) | .status"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "message": "jobStatus",
          "jobStatus": [
            {
              "ID": 9,
              "status": "Successful"
            },
            {
              "ID": 2,
              "status": "Successful"
            },
            {
              "ID": 99,
              "status": "Failed"
            }
          ]
        },
        "output": "\"Successful\""
      }
    ],
    "identifier": 41772776
  },
  {
    "context": [
      "I am trying to write a simple script that loops through a JSON file, gets two values within each object and assigns them to two separate variables I can use with a curl REST call.",
      "jq -rc '.populator.value + \" \" + .populator.addr' file.json |",
      "while read -r value addr; do",
      "jq -rc '.populator | (.value,.addr)' file.json"
    ],
    "utterance": "For each object, extract both the value and addr fields inside populator to use as separate variables in a shell loop.",
    "expressions": [
      ".[] | .populator.value + \" \" + .populator.addr",
      ".[] | .populator | (.value, .addr)"
    ],
    "identifier": 41966417
  },
  {
    "context": [
      "How to recursively delete all keys that match a given pattern?",
      "A robust way (with respect to different jq versions) to delete all keys matching a pattern (say PATTERN) would be to use the idiom:",
      "with_entries(select( .key | test(PATTERN) | not))",
      "Plugging this into `walk/1` yields:",
      "walk(if type == \"object\" then with_entries(select(.key | test(PATTERN) | not)) else . end)"
    ],
    "utterance": "Recursively remove all keys where the key matches a specified regular expression pattern.",
    "expressions": [
      "walk(if type == \"object\" then with_entries(select(.key | test(PATTERN) | not)) else . end)"
    ],
    "identifier": 42635140
  },
  {
    "context": [
      "With jq you can use --slurp to create arrays, and -c to make multiline json single line.  However, I can't see how to combine the two into a single command.",
      "ls *.json | awk -v group=10 -v tmpfile=json.tmp ... print \"jq -s . \" files \" > \" tmpfile;",
      "Here is what I came up with. It seems to work and is importing at roughly 80 a second into an external hard drive.",
      "for((I=0;I<${#files[*]};I+=500)); do jq -c '.' ${files[@]:I:500} | mongoimport --writeConcern 0 --numInsertionWorkers 16 --db mydb --collection all --quiet;echo $I; done"
    ],
    "utterance": "Combine every 10 files into a single array so that each batch can be imported together.",
    "expressions": [
      "jq -s . file1.json file2.json file3.json file4.json file5.json file6.json file7.json file8.json file9.json file10.json",
      "jq -s . *.json",
      "jq -s . ${files[@]:I:10}"
    ],
    "identifier": 41718679
  },
  {
    "context": [
      "Can I use jq to run a filter that behaves similarly to from_entries, with the one difference being, if multiple entries for the same key are encountered, it will collate the values into an array, rather than just use the last value?",
      "for example, if my input is:",
      "[ { \"key\": \"a\", \"value\": 1 }, { \"key\": \"b\", \"value\": 2 }, { \"key\": \"a\", \"value\": 3 }, { \"key\": \"b\", \"value\": 4 } ]",
      "then the desired output would be:",
      "{ \"a\": [1,3], \"b\": [2,4] }",
      "def merge_entries:\n  reduce .[] as $pair ({}; .[$pair[\"key\"]] += [$pair[\"value\"]] );",
      "jq 'reduce .[] as $p ({}; .[$p.key] += [$p.value])'"
    ],
    "utterance": "Group all entries by key and collect their values into arrays for each key occurrence where multiple values can exist.",
    "expressions": [
      "reduce .[] as $p ({}; .[$p.key] += [$p.value])"
    ],
    "data": [
      {
        "input": [
          {
            "key": "a",
            "value": 1
          },
          {
            "key": "b",
            "value": 2
          },
          {
            "key": "a",
            "value": 3
          },
          {
            "key": "b",
            "value": 4
          }
        ],
        "output": {
          "a": [
            1,
            3
          ],
          "b": [
            2,
            4
          ]
        }
      }
    ],
    "identifier": 41603594
  },
  {
    "context": [
      "I am trying to use `jq` to figure out which index number in the list is based on a `select` query.",
      "But I want it's index. In this case `2` (starting counting at 0)",
      "A straightforward solution (pointed out by @peak) is to use the builtin function, `index`:",
      "map(.name == \"something\") | index(true)",
      "If there is no item satisfying the condition, then the result will be `null`.",
      "If you wanted ALL indices for which the condition is true, then the above is easily transformed into a super-fast solution by simply changing `index` to `indices`:",
      "map(.name == \"something\") | indices(true)"
    ],
    "utterance": "Find the index of the first object in an array whose name field equals \"something\".",
    "expressions": [
      "map(.name == \"something\") | index(true)",
      "map(.name == \"something\") | indices(true)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "1",
            "urgent": false
          },
          {
            "name": "2",
            "urgent": false
          },
          {
            "name": "something",
            "urgent": false
          }
        ],
        "output": 2
      }
    ],
    "identifier": 41958475
  },
  {
    "context": [
      "I have a JSON file:",
      "[ { \"keyProp\": 11111111111111, \"values\": [ \"VALUE1\" ] }, { \"keyProp\": 2222, \"values\": [ \"VALUE2\" ] } ]",
      "I want to use jq to select values where `keyProp==11111111111111`. Expected output is 'VALUE2'",
      "$ jq '.[] | select(.keyProp==11111111111111)' file",
      "{ \"values\": [ \"VALUE1\" ], \"keyProp\": 11111111111111 }",
      "$ jq '.[] | select(.keyProp==11111111111111).values' file",
      "[ \"VALUE1\" ]",
      "$ jq '.[] | select(.keyProp==11111111111111).values[0]' file",
      "\"VALUE1\""
    ],
    "utterance": "Extract the first element from the 'values' array where keyProp equals 11111111111111.",
    "expressions": [
      ".[] | select(.keyProp==11111111111111).values[0]"
    ],
    "data": [
      {
        "input": [
          {
            "keyProp": 11111111111111,
            "values": [
              "VALUE1"
            ]
          },
          {
            "keyProp": 2222,
            "values": [
              "VALUE2"
            ]
          }
        ],
        "output": "VALUE1"
      }
    ],
    "identifier": 41716141
  },
  {
    "context": [
      "and I want to extract the value `XXXXXXXXXX` of the disk_total. What is the syntax to do this?",
      "Tho dot in `storage_server.disk_total\" needs to be escaped to prevent it from being interpreted as an object key separator. so you can use:\n\n    jq '.stats.\"storage_server.disk_total\"'\n\nassuming that `XXXXXXXXXX` is a valid JSON number in your real JSON.",
      "The inner key name has a period in it, and therefore the `.keyname` shorthand cannot be used for it.  So you could write:\n   .stats[\"storage_server.disk_total\"] \n\nor if your jq allows it:\n\n   .stats.\"storage_server.disk_total\" \n\nThese are both abbreviations for:\n\n   .stats | .[\"storage_server.disk_total\"] ",
      "To get *deeply* nested values by their key:\n\n    $ jq '.. |.\"storage_server.disk_total\"? | select(. != null)'"
    ],
    "utterance": "Extract the value associated with the key storage_server.disk_total under the stats object.",
    "expressions": [
      ".stats[\"storage_server.disk_total\"]",
      ".stats.\"storage_server_disk_total\"",
      ".stats | .[\"storage_server.disk_total\"]",
      ".. | .\"storage_server.disk_total\"? | select(. != null)"
    ],
    "data": [
      {
        "input": {
          "stats": {
            "storage_server.disk_total": 1234567890
          },
          "counters": {}
        },
        "output": 1234567890
      }
    ],
    "identifier": 41712363
  },
  {
    "context": [
      "can I use JQ to generate an output json like this:\r\n\r\n    { \"col1\":{ \"int\" : 123 }, \"col2\": { \"string\" : \"foo\"} }\r\n    { \"col1\":{ \"int\" : 123 }, \"col2\": { \"string\" : \"foo\"} }",
      "You might want to transform your first file in an easier to consume format first: map the `.type` to the `.field` properties to an object (to use as a dictionary)",
      "$ jq --argfile file1 file1.json '\r\n(reduce $file1[] as $i ({}; .[$i.field] = $i.type)) as $map\r\n    | with_entries(.value = { ($map[.key]): .value })\r\n' file2.json",
      "which yields:\r\n{\r\n  \"col1\": {\r\n    \"int\": 123\r\n  },\r\n  \"col2\": {\r\n    \"string\": \"foo\"\r\n  }\r\n}\r\n{\r\n  \"col1\": {\r\n    \"int\": 123\r\n  },\r\n  \"col2\": {\r\n    \"string\": \"foo\"\r\n  }\r\n}"
    ],
    "utterance": "Wrap each top-level key's value in an object whose key is the specified type from a mapping file, for all objects in an input where mappings are given as field/type pairs.",
    "expressions": [
      "(reduce $file1[] as $i ({}; .[$i.field] = $i.type)) as $map | with_entries(.value = { ($map[.key]): .value })"
    ],
    "data": [
      {
        "input": [
          {
            "field": "col1",
            "type": "int"
          },
          {
            "field": "col2",
            "type": "string"
          }
        ],
        "output": {
          "col1": {
            "int": 123
          },
          "col2": {
            "string": "foo"
          }
        }
      },
      {
        "input": {
          "col1": 123,
          "col2": "foo"
        },
        "output": {
          "col1": {
            "int": 123
          },
          "col2": {
            "string": "foo"
          }
        }
      }
    ],
    "identifier": 41896783
  },
  {
    "context": [
      "How can I move all the properties of b to be under the parent a:",
      "$ jq '.a |= (.b = {}) + .b' input.json",
      "$ jq '.a |= with_entries(if .key == \"b\" then (.value = {}), (.value | to_entries[]) else . end)' input.json",
      ".a |= ({b:{}} + .b)"
    ],
    "utterance": "Move all properties from the child object 'b' under 'a' to be direct children of 'a', replacing 'b' with an empty object.",
    "expressions": [
      ".a |= (.b = {}) + .b",
      ".a |= ({b:{}} + .b)",
      ".a |= with_entries(if .key == \"b\" then (.value = {}), (.value | to_entries[]) else . end)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": {
              "c": 1,
              "d": 2
            }
          }
        },
        "output": {
          "a": {
            "c": 1,
            "d": 2,
            "b": {}
          }
        }
      }
    ],
    "identifier": 42214984
  },
  {
    "context": [
      "I want to fetch just **hosts_up : 9** or simply the number **9**, tried many examples but it didn&#39;t went well, help me.",
      "$ jq '.status.hostgroup_summary[].hosts_up' input.json",
      "jq '[\"status\"][\"hostgroup_summary\"][] | .[\"hosts_up\"]'",
      "$ jq '.status.hostgroup_summary[] | { \"hosts_up\" }' input.json",
      "$ jq '.. | .hosts_up? | select(.)'",
      "$ jq '.. | select(type == \"object\" and has(\"hosts_up\")) | .hosts_up'",
      "$ jq '.. | objects | select(has(\"hosts_up\")) | .hosts_up'",
      "$ jq '.status.hostgroup_summary[0].hosts_up' file",
      "$ jq '.status.hostgroup_summary[].hosts_up' file",
      "$ jq '.status.hostgroup_summary[] | { \"hosts_up\" }' file",
      "| jq -r '.[] | .[] | .[] | .hosts_up'  "
    ],
    "utterance": "Extract the value 9 associated with the key hosts_up inside status.hostgroup_summary.",
    "expressions": [
      ".status.hostgroup_summary[].hosts_up",
      ".[\"status\"][\"hostgroup_summary\"][] | .[\"hosts_up\"]",
      ".status.hostgroup_summary[0].hosts_up",
      ".status.hostgroup_summary[] | { \"hosts_up\" }",
      ".. | .hosts_up? | select(.)",
      ".. | select(type == \"object\" and has(\"hosts_up\")) | .hosts_up",
      ".. | objects | select(has(\"hosts_up\")) | .hosts_up",
      ".[] | .[] | .[] | .hosts_up"
    ],
    "data": [
      {
        "input": {
          "cgi_json_version": "1.8.0",
          "status": {
            "hostgroup_summary": [
              {
                "hostgroup_name": "ESXI",
                "hosts_up": 9,
                "hosts_down": 0,
                "hosts_down_unacknowledged": 0,
                "hosts_down_scheduled": 0,
                "hosts_down_acknowledged": 0,
                "hosts_down_disabled": 0,
                "hosts_unreachable": 0,
                "hosts_unreachable_unacknowledged": 0,
                "hosts_unreachable_scheduled": 0,
                "hosts_unreachable_acknowledged": 0,
                "hosts_unreachable_disabled": 0,
                "hosts_pending": 0,
                "services_ok": 0,
                "services_warning": 0,
                "services_warning_unacknowledged": 0,
                "services_warning_host_problem": 0,
                "services_warning_scheduled": 0,
                "services_warning_acknowledged": 0,
                "services_warning_disabled": 0,
                "services_unknown": 0,
                "services_unknown_unacknowledged": 0,
                "services_unknown_host_problem": 0,
                "services_unknown_scheduled": 0,
                "services_unknown_acknowledged": 0,
                "services_unknown_disabled": 0,
                "services_critical": 0,
                "services_critical_unacknowledged": 0,
                "services_critical_host_problem": 0,
                "services_critical_scheduled": 0,
                "services_critical_acknowledged": 0,
                "services_critical_disabled": 0,
                "services_pending": 0
              }
            ]
          }
        },
        "output": 9
      }
    ],
    "identifier": 41681227
  },
  {
    "context": [
      "and I want to match the name in the csv to the name of the json file and add in the id, name, and slug to the properties so I get this:",
      "jq --args id \"$id\" \\\n   --args name \"$name\" \\\n   --args slug \"$slug\" \\\n   'features[0].properties += {id: $id, name: $name, slug: $slug}' \"$name.json\" > tmp && mv tmp \"$name.json\""
    ],
    "utterance": "Add fields id, name, and slug from a matching CSV row into the properties object of features[0] in each file named <name>.json, where name matches the CSV row.",
    "expressions": [
      "features[0].properties += {id: $id, name: $name, slug: $slug}"
    ],
    "data": [
      {
        "input": {
          "type": "mass",
          "features": [
            {
              "type": "sub",
              "properties": {
                "key1": "value1",
                "key2": "value2"
              }
            }
          ]
        },
        "output": {
          "type": "mass",
          "features": [
            {
              "type": "sub",
              "properties": {
                "key1": "value1",
                "key2": "value2",
                "id": "12345",
                "name": "Case A",
                "slug": "case-a-12345"
              }
            }
          ]
        }
      }
    ],
    "identifier": 41877739
  },
  {
    "context": [
      "I\u2019m trying to pipe json logs from docker into `jq`.",
      "if I try to tail it, it gets stuck (displaying nothing).",
      "docker logs -f container_id 2>&1 | jq '.'",
      "Instead of tailing from stdout you might want to tail the log file that is stored in the container directory.",
      "tail -f  /var/lib/docker/containers/[container_ID]/[container_ID]-json.log | jq '.'"
    ],
    "utterance": "Pipe live logs from a running container into jq by following the container's JSON log file.",
    "expressions": [
      "tail -f /var/lib/docker/containers/[container_ID]/[container_ID]-json.log | jq '.'"
    ],
    "identifier": 41678524
  },
  {
    "context": [
      "I am trying to get the below result using jq. Any help would be appreciated:",
      "{\"Name\": \"unix-global\", \"Title\": \"AWS cli should be installed\", \"desc\": \"System Package aws-cli should be installed\", \"result\": \"passed\"}",
      "{\"Name\": \"unix-global\", \"Title\": \"AWS cli should be installed\", \"desc\": \"Service besclient should be installed\", \"result\": \"failed\"}",
      "Here&#39;s a `jq` filter to flatten this out.",
      "jq '.profiles[] \n     | { Name: .name , Controls: .controls[] } \n     | { Name: .Name, Desc: .Controls.desc , Title: .Controls.title , Results: .Controls.results[] } \n     | { Name: .Name, Desc: .Desc , Title: .Title , StartTime: .Results.start_time , RunTime: .Results.run_time , Result: .Results.status }'"
    ],
    "utterance": "Extract objects with Name, Title, desc, and result fields from deeply nested structure so each object represents a control result with its metadata and status.",
    "expressions": [
      ".profiles[] | { Name: .name , Controls: .controls[] } | { Name: .Name, desc: .Controls.desc , Title: .Controls.title , result: .Controls.results[].status }"
    ],
    "data": [
      {
        "input": {
          "version": "1.7.1",
          "profiles": [
            {
              "name": "java",
              "title": "InSpec Java in system",
              "controls": [
                {
                  "title": "identify java in system",
                  "desc": "identify java in PATH system",
                  "results": [
                    {
                      "status": "passed",
                      "code_desc": "java_info should exist",
                      "run_time": 0.000895896,
                      "start_time": "2017-01-20 05:04:47 +0000"
                    },
                    {
                      "status": "passed",
                      "code_desc": "java_info version should match \"1.7\"",
                      "run_time": 0.067581113,
                      "start_time": "2017-01-20 05:04:47 +0000"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "Name": "java",
            "Title": "identify java in system",
            "desc": "identify java in PATH system",
            "result": "passed"
          },
          {
            "Name": "java",
            "Title": "identify java in system",
            "desc": "identify java in PATH system",
            "result": "passed"
          }
        ]
      }
    ],
    "identifier": 41896618
  },
  {
    "context": [
      "I would like to split the large file such that each features object would have its own file containing a its type object and features(coordinates) object. So essentially, I am trying to get many of these:",
      "jq -c '.features = (.features[] | [.]) ' input.json | awk '{ print > \"/tmp/file\" NR \".json\"}'",
      "N=0\njq -c '.features = (.features[] | [.])' input.json |\n  while read -r json ; do\n\t  N=$((N+1))\n\t  jq . <<< \"$json\"  > \"/tmp/file${N}.json\"\ndone"
    ],
    "utterance": "Split a FeatureCollection so each feature is placed in its own FeatureCollection object, each containing a single feature.",
    "expressions": [
      ".features = (.features[] | [.])"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {},
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -37.880859375,
                      78.81903553711727
                    ],
                    [
                      -42.01171875,
                      78.31385955743478
                    ],
                    [
                      -37.6171875,
                      78.06198918665974
                    ],
                    [
                      -37.880859375,
                      78.81903553711727
                    ]
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {},
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -37.6171875,
                      78.07107600956168
                    ],
                    [
                      -35.48583984375,
                      78.42019327591201
                    ],
                    [
                      -37.880859375,
                      78.81903553711727
                    ],
                    [
                      -37.6171875,
                      78.07107600956168
                    ]
                  ]
                ]
              }
            }
          ]
        },
        "output": [
          {
            "type": "FeatureCollection",
            "features": [
              {
                "type": "Feature",
                "properties": {},
                "geometry": {
                  "type": "Polygon",
                  "coordinates": [
                    [
                      [
                        -37.880859375,
                        78.81903553711727
                      ],
                      [
                        -42.01171875,
                        78.31385955743478
                      ],
                      [
                        -37.6171875,
                        78.06198918665974
                      ],
                      [
                        -37.880859375,
                        78.81903553711727
                      ]
                    ]
                  ]
                }
              }
            ]
          },
          {
            "type": "FeatureCollection",
            "features": [
              {
                "type": "Feature",
                "properties": {},
                "geometry": {
                  "type": "Polygon",
                  "coordinates": [
                    [
                      [
                        -37.6171875,
                        78.07107600956168
                      ],
                      [
                        -35.48583984375,
                        78.42019327591201
                      ],
                      [
                        -37.880859375,
                        78.81903553711727
                      ],
                      [
                        -37.6171875,
                        78.07107600956168
                      ]
                    ]
                  ]
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 41500569
  },
  {
    "context": [
      "i just want to keep name=name1, remove the nested array object with name=name4 and want to keep the rest of the object intact.",
      "result should be the following. in addition i want to avoid enumeration all attributes to keep on outer objects:",
      "A very targeted solution would be:\r\n\r\n    path(.[0].organizations[0].spaces) as $target\r\n    | (getpath($target) | map(select(.name != \"name4\"))) as $new\r\n    | setpath($target; $new)",
      "If permissible, though, you might consider:\r\n\r\n    walk(if type == \"object\" and .spaces|type == \"array\"\r\n         then .spaces |= map(select(.name != \"name4\"))\r\n         else . end)",
      "or:\r\n\r\n    del(.. | .spaces? // empty | .[] | select(.name == \"name4\") )",
      "Here is a solution using select, reduce, tostream and delpaths",
      "map(  \r\n\t    select(.name == \"name1\")\r\n\t  | reduce (tostream|select(length==2)) as [$p,$v] (\r\n\t      .\r\n\t    ; if [$p[-1],$v] == [\"name\",\"name4\"] then delpaths([$p[:-1]]) else . end\r\n\t    )\r\n\t)",
      "You can use the below and it will remove the `\"name\": \"name4\"` array only.\r\n\r\n    jq 'del(.[] | .organizations? | .[] | .spaces?|.[] | select(.name? == \"name4\"))' yourJsonFile.json"
    ],
    "utterance": "Keep only the top-level object where name equals name1 and, within its organizations, remove any spaces whose name is name4 while preserving all other data.",
    "expressions": [
      "map(select(.name == \"name1\")) | walk(if type == \"object\" and .spaces|type == \"array\" then .spaces |= map(select(.name != \"name4\")) else . end)",
      "map(select(.name == \"name1\") | reduce (tostream|select(length==2)) as [$p,$v] (. ; if [$p[-1],$v] == [\"name\",\"name4\"] then delpaths([$p[:-1]]) else . end))",
      "map(select(.name == \"name1\")) | del(.. | .spaces? // empty | .[] | select(.name == \"name4\"))",
      "map(select(.name == \"name1\")) | del(.[] | .organizations? | .[] | .spaces? | .[] | select(.name? == \"name4\"))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name1",
            "organizations": [
              {
                "name": "name2",
                "spaces": [
                  {
                    "name": "name3",
                    "otherkey": "otherval"
                  },
                  {
                    "name": "name4",
                    "otherkey": "otherval"
                  }
                ]
              }
            ]
          },
          {
            "name": "name21",
            "organizations": [
              {
                "name": "name22",
                "spaces": [
                  {
                    "name": "name23",
                    "otherkey": "otherval"
                  },
                  {
                    "name": "name24",
                    "otherkey": "otherval"
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "name": "name1",
            "organizations": [
              {
                "name": "name2",
                "spaces": [
                  {
                    "name": "name3",
                    "otherkey": "otherval"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 42215211
  },
  {
    "context": [
      "So the last directory is removed from the path.",
      "The point is to get the `path` value and modify it.",
      "... | jq '.[] | .path|=(split(\"/\")[:-1]|join(\"/\"))",
      "`split(\"/\")` takes a string and returns an array",
      "`x[:-1]` returns an array consisting of all but the last element of `x`",
      "`join(\"/\")` combines the elements of the incoming array with `/` to return a single string.",
      "`.path|=x` takes the value of `.path`, feeds it through the filter `x`, and assigns the resulting value to `.path` again."
    ],
    "utterance": "Replace the value of the path field with the path string minus its last directory segment.",
    "expressions": [
      ".[] | .path |= (split(\"/\")[:-1] | join(\"/\"))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 169,
            "path": "dir1/dir2"
          }
        ],
        "output": [
          {
            "id": 169,
            "path": "dir1"
          }
        ]
      }
    ],
    "identifier": 41678444
  },
  {
    "context": [
      "I was hoping to use `jq` to show the top N keys with the deeper contents hidden.  And then once I find the keys I&#39;m interesting in, keep drilling down, only showing me N levels down from my starting point similar to a text editors ability to fold everything below N levels.  Is this possible?",
      "If you&#39;re interested in viewing objects at a specific depth, you could utilize `getpath` and `paths`.  `paths` will return paths to all values in the graph.  You could filter those paths to paths of specific lengths then get the corresponding value using `getpath`.\r\n\r\ne.g., looking at all values at depth 3 from the current object\r\n\r\n    getpath(paths | select(length == 3))",
      "Here is a filter which emits a stream of synopses of all the paths of\r\nlength &lt;= depth in the input entity, except that if depth &lt;= 0, the\r\ndepth limitation is ignored.\r\n\r\nThe synopsis of a path [p1, p2, ...] is constructed by replacing\r\ninteger components with &quot;.[]&quot;, and prefixing string components with &quot;.&quot;,\r\nso for example, if i and j are integers, then\r\n[i, &quot;keyname&quot;, j] would be represented as .[].keyname.[]\r\n\r\nHere is an example of the output produced using `jq -r`:\r\n\r\n    .[]\r\n    .[].data\r\n    .[].data.children\r\n    .[].data.modhash\r\n    .[].kind\r\n    \r\n### paths_synopsis/1\r\n\r\n    # If depth&lt;0 then select paths of length equal to -depth    \r\n    def paths_synopsis(depth):\r\n      [ paths\r\n      | if depth &gt; 0 then select(length &lt;= depth)\r\n        elif (depth &lt; 0) then select(length == -depth)\r\n        else . end\r\n      | [.[]|if type==&quot;number&quot; then &quot;[]&quot; else . end]]\r\n      | unique\r\n      | .[]\r\n      | &quot;.&quot; + join(&quot;.&quot;)\r\n      ;"
    ],
    "utterance": "Show the top N keys or paths, hiding contents deeper than N levels, and allow drilling down to view N levels at each step.",
    "expressions": [
      "getpath(paths | select(length == N))",
      "def paths_synopsis(depth):\n  [ paths\n  | if depth > 0 then select(length <= depth)\n    elif (depth < 0) then select(length == -depth)\n    else . end\n  | [.[]|if type==\"number\" then \"[]\" else . end]]\n  | unique\n  | .[]\n  | \".\" + join(\".\")\n  ;"
    ],
    "identifier": 41491773
  },
  {
    "context": [
      "I want to append an element to an array in a JSON file using the `jq``add` command, but it&#39;s not working.",
      "Here&#39;s how I want the output to look:",
      "jq '.data.messages += [{\n     \"date\": \"2010-01-07T19:55:99.999Z\",\n     \"xml\": \"xml_samplesheet_2017_01_07_run_09.xml\", \n     \"status\": \"OKKK\", \n     \"message\": \"metadata loaded into iRODS successfullyyyyy\"\n}]'",
      "which produces the output you need:",
      "{\n  \"report\": \"1.0\",\n  \"data\": {\n    \"date\": \"2010-01-07\",\n    \"messages\": [\n      {\n        \"date\": \"2010-01-07T19:58:42.949Z\",\n        \"xml\": \"xml_samplesheet_2017_01_07_run_09.xml\",\n        \"status\": \"OK\",\n        \"message\": \"metadata loaded into iRODS successfully\"\n      },\n      {\n        \"date\": \"2010-01-07T20:22:46.949Z\",\n        \"xml\": \"xml_samplesheet_2017_01_07_run_09.xml\",\n        \"status\": \"NOK\",\n        \"message\": \"metadata duplicated into iRODS\"\n      },\n      {\n        \"date\": \"2010-01-07T22:11:55.949Z\",\n        \"xml\": \"xml_samplesheet_2017_01_07_run_09.xml\",\n        \"status\": \"NOK\",\n        \"message\": \"metadata was not validated by XSD schema\"\n      },\n      {\n        \"date\": \"2010-01-07T19:55:99.999Z\",\n        \"xml\": \"xml_samplesheet_2017_01_07_run_09.xml\",\n        \"status\": \"OKKK\",\n        \"message\": \"metadata loaded into iRODS successfullyyyyy\"\n      }\n    ]\n  }\n}"
    ],
    "utterance": "Append an object with date '2010-01-07T19:55:99.999Z', xml 'xml_samplesheet_2017_01_07_run_09.xml', status 'OKKK', and message 'metadata loaded into iRODS successfullyyyyy' to the messages array under the data key.",
    "expressions": [
      ".data.messages += [{\"date\": \"2010-01-07T19:55:99.999Z\", \"xml\": \"xml_samplesheet_2017_01_07_run_09.xml\", \"status\": \"OKKK\", \"message\": \"metadata loaded into iRODS successfullyyyyy\"}]"
    ],
    "data": [
      {
        "input": {
          "report": "1.0",
          "data": {
            "date": "2010-01-07",
            "messages": [
              {
                "date": "2010-01-07T19:58:42.949Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "OK",
                "message": "metadata loaded into iRODS successfully"
              },
              {
                "date": "2010-01-07T20:22:46.949Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "NOK",
                "message": "metadata duplicated into iRODS"
              },
              {
                "date": "2010-01-07T22:11:55.949Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "NOK",
                "message": "metadata was not validated by XSD schema"
              }
            ]
          }
        },
        "output": {
          "report": "1.0",
          "data": {
            "date": "2010-01-07",
            "messages": [
              {
                "date": "2010-01-07T19:58:42.949Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "OK",
                "message": "metadata loaded into iRODS successfully"
              },
              {
                "date": "2010-01-07T20:22:46.949Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "NOK",
                "message": "metadata duplicated into iRODS"
              },
              {
                "date": "2010-01-07T22:11:55.949Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "NOK",
                "message": "metadata was not validated by XSD schema"
              },
              {
                "date": "2010-01-07T19:55:99.999Z",
                "xml": "xml_samplesheet_2017_01_07_run_09.xml",
                "status": "OKKK",
                "message": "metadata loaded into iRODS successfullyyyyy"
              }
            ]
          }
        }
      }
    ],
    "identifier": 42245288
  },
  {
    "context": [
      "I have the following JSON data",
      "\"Mean_Test_Time_(ms)\": 481.6876712328767,",
      "I'm using the following jq that's able to get out every other parameter except Mean_Test_Time_(ms) because of the brackets",
      "cat sample.data | jq '.perf.cumulativeStatistics[0].Response_bytes_per_second'",
      "It's interpretting the brackets itself. So when I use Mean_Test_time_(ms) with that command, I get the following error",
      ".perf.cumulativeStatistics[0].Mean_Test_Time_(ms)",
      "How do I escape these paranthesis?",
      "Like in Javascript, you can use brackets to access such \"problematic\" property names, like this:",
      "jq '.perf.cumulativeStatistics[0][\"Mean_Test_Time_(ms)\"]' sample.data"
    ],
    "utterance": "Select the Mean_Test_Time_(ms) value from the first element of the cumulativeStatistics array inside the perf object.",
    "expressions": [
      ".perf.cumulativeStatistics[0][\"Mean_Test_Time_(ms)\"]"
    ],
    "data": [
      {
        "input": {
          "perf": {
            "cumulativeStatistics": [
              {
                "Mean_Test_Time_(ms)": 481.6876712328767,
                "Response_bytes_per_second": 10514.456156404525,
                "Errors": 0.0,
                "testNumber": 1.0,
                "TPS": 2.141001049970378,
                "testDescription": "Some status",
                "Mean_time_to_first_byte": 481.1034246575342,
                "Tests": 1460.0,
                "Peak_TPS": 4.0
              },
              {
                "Mean_Test_Time_(ms)": 453.88211103495547,
                "Response_bytes_per_second": 10507.254474105619,
                "Errors": 0.0,
                "testNumber": 2.0,
                "TPS": 2.1395346108950557,
                "testDescription": "Status Again",
                "Mean_time_to_first_byte": 453.4825222755312,
                "Tests": 1459.0,
                "Peak_TPS": 4.0
              }
            ]
          }
        },
        "output": 481.6876712328767
      }
    ],
    "identifier": 41677435
  },
  {
    "context": [
      "An example would be:\r\n\r\n    {\r\n      \"values\": [\r\n        [\r\n          1483633677,\r\n          42\r\n        ]\r\n      ],\r\n      \"columns\": [\r\n        \"time\",\r\n        \"count_value\"\r\n      ],\r\n      \"name\": \"response_time_error\"\r\n    }\r\n\r\nI would want to extract just the value for a certain column (e.g. `count_value`) and I can extract it by using `[-1]` in this specific case, but I want to select the column by its name in case they change in the future.",
      "you could find the index in the `columns` array then use that index into the `values` array.",
      "$ jq --arg col 'count_value' '.values[][.columns | index($col)]' input.json",
      "If the specified column name does not exist in .columns, then Jeff's filter will fail with a rather obscure error message. It might therefore be preferable to check whether the column name is found.",
      "jq --arg col count_value '\n  (.columns | index($col)) as $ix\n  | if $ix then .values[][$ix] else empty end' input.json"
    ],
    "utterance": "Extract all values for the column named 'count_value', using the column name to find its position.",
    "expressions": [
      ".values[][.columns | index($col)]",
      "(.columns | index($col)) as $ix | if $ix then .values[][$ix] else empty end"
    ],
    "data": [
      {
        "input": {
          "values": [
            [
              1483633677,
              42
            ]
          ],
          "columns": [
            "time",
            "count_value"
          ],
          "name": "response_time_error"
        },
        "output": [
          42
        ]
      }
    ],
    "identifier": 41490031
  },
  {
    "context": [
      "How do we make CSV output like this?\r\n\r\n    var,section,x\r\n    \"1\",\"[1,2,3]\",\"test1\"\r\n    \"2\",\"[2,3,4]\",\"test2\"\r\n    \"3\",\"[3,4,5]\",\"test3\"",
      "Here\u2019s a variant that (a) produces a row of headers for all the keys in the first object, whatever they may be; and (b) is robust with respect to re-ordering the keys within the objects:\r\n\r\n```\r\n. as $in\r\n| ($in[0] | keys_unsorted) as $h\r\n| ($h, \r\n   ( $in[]\r\n   | ( [range(0; $h|length) as $i | getpath( [$h[$i]] )]\r\n     | map(if type == \"array\" then map(tonumber? // .) else . end)\r\n     | map(tostring) ) ))\r\n| @csv\r\n```",
      "produces the desired output, except for the header row."
    ],
    "utterance": "Create CSV output where array fields are encoded as stringified arrays in their cell, and include a header row with all keys in order.",
    "expressions": [
      ". as $in\n| ($in[0] | keys_unsorted) as $h\n| ($h,\n   ( $in[]\n   | ( [range(0; $h|length) as $i | getpath( [$h[$i]] )]\n     | map(if type == \"array\" then map(tonumber? // .) else . end)\n     | map(tostring) ) ))\n| @csv"
    ],
    "data": [
      {
        "input": [
          {
            "var": 1,
            "section": [
              "1",
              "2",
              "3"
            ],
            "x": "test1"
          },
          {
            "var": 2,
            "section": [
              "2",
              "3",
              "4"
            ],
            "x": "test2"
          },
          {
            "var": 3,
            "section": [
              "3",
              "4",
              "5"
            ],
            "x": "test3"
          }
        ],
        "output": [
          "\"var\",\"section\",\"x\"",
          "\"1\",\"[1,2,3]\",\"test1\"",
          "\"2\",\"[2,3,4]\",\"test2\"",
          "\"3\",\"[3,4,5]\",\"test3\""
        ]
      }
    ],
    "identifier": 41537235
  },
  {
    "context": [
      "How can I select all \"id\" values for each object containing a tag where \"my.key\" is \"true\"?",
      "You can use a `select` with `.tags[\"my.key\"] == \"true\"` and get only the `id` field :",
      "jq '.[] | select(.tags[\"my.key\"] == \"true\") | .id' data.json"
    ],
    "utterance": "Select the id values of objects whose tags contain the key my.key with value true.",
    "expressions": [
      ".[] | select(.tags[\"my.key\"] == \"true\") | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "one",
            "tags": {
              "my.key": "true"
            }
          },
          {
            "id": "two"
          }
        ],
        "output": [
          "one"
        ]
      }
    ],
    "identifier": 41369982
  },
  {
    "context": [
      "How can I make it like **[false,true,false]** as a record?",
      "Just try wrap the whole expression within an array constructor, `[]`",
      "jq '[.[] | select(.name ==\"XML\") | .good]'",
      "jq --compact-output '[.[] | select(.name ==\"XML\") | .good ]'",
      "$ jq -c 'map( select(.name ==\"XML\") | .good )'",
      "Output:",
      "[false,true,false]"
    ],
    "utterance": "Extract all values of 'good' where 'name' equals 'XML' and output them as an array.",
    "expressions": [
      "[.[] | select(.name == \"XML\") | .good]",
      "map(select(.name == \"XML\") | .good)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "JSON",
            "good": true
          },
          {
            "name": "XML",
            "good": false
          },
          {
            "name": "JSON",
            "good": false
          },
          {
            "name": "HTML",
            "good": false
          },
          {
            "name": "XML",
            "good": true
          },
          {
            "name": "XML",
            "good": false
          }
        ],
        "output": [
          false,
          true,
          false
        ]
      }
    ],
    "identifier": 42120456
  },
  {
    "context": [
      "to add more data say `{\"baz\": [\"bing\", \"bop\"]}` to the parent of A if A=1. Assuming I don't know the parent key while leaving the rest of the json untouched.",
      "The result, in this case, that I would like to see is:",
      "Select only fields that are of type `object` and that match your condition (`A == 1`) :",
      "jq '(.foobar | .. | select(type == \"object\" and .A == 1)) |= .+ {\"baz\": [\"bing\", \"bop\"]}' test.json",
      "In general it is better to avoid `..` if possible, for reasons of efficiency. In the present case, the following will do the job:",
      "(.foobar[][] | select(.A == 1)) |= .+ {\"baz\":[\"bing\", \"bop\"]}"
    ],
    "utterance": "Add {\"baz\": [\"bing\", \"bop\"]} to objects where A equals 1, without knowing the parent key, leaving the rest of the structure unchanged.",
    "expressions": [
      "(.foobar | .. | select(type == \"object\" and .A == 1)) |= .+ {\"baz\": [\"bing\", \"bop\"]}",
      "(.foobar[][] | select(.A == 1)) |= .+ {\"baz\":[\"bing\", \"bop\"]}"
    ],
    "data": [
      {
        "input": {
          "foobar": {
            "a": {
              "adkjfe": {
                "A": 1,
                "foo": "bar"
              }
            },
            "b": {
              "ekjaei": {
                "A": 2,
                "bar": "foo"
              }
            }
          }
        },
        "output": {
          "foobar": {
            "a": {
              "adkjfe": {
                "A": 1,
                "foo": "bar",
                "baz": [
                  "bing",
                  "bop"
                ]
              }
            },
            "b": {
              "ekjaei": {
                "A": 2,
                "bar": "foo"
              }
            }
          }
        }
      }
    ],
    "identifier": 41369121
  },
  {
    "context": [
      "echo '\"\\ud83d\"' | jq .",
      "parse error: Invalid \\uXXXX\\uXXXX surrogate pair escape at line 1, column 14862268",
      "you could probably use regular expressions to scan through the data to search for mismatched surrogates. Something like this:",
      "\\\\u[Dd][89ABab][0-9A-Fa-f]{2}(?!\\\\u[Dd][C-Fc-f][0-9A-Fa-f]{2})",
      "|",
      "(?<!\\\\u[Dd][89ABab][0-9A-Fa-f]{2})\\\\u[Dd][C-Fc-f][0-9A-Fa-f]{2}"
    ],
    "utterance": "Identify and remove unpaired Unicode surrogate escapes, such as '\\ud83d', from data before query processing to prevent parsing errors.",
    "expressions": [],
    "data": [
      {
        "input": "\"\\ud83d\"",
        "output": "parse error: Invalid \\uXXXX\\uXXXX surrogate pair escape at line 1, column 2"
      }
    ],
    "identifier": 42457416
  },
  {
    "context": [
      "Assuming that each log entry is exactly one line, you can use the `-R` or `--raw-input` option to tell jq to leave the lines unparsed, after which you can prepend `fromjson? |` to your filter to make jq try to parse each line as JSON and throw away the ones that error.",
      "jq -R '. as $line | try (fromjson) catch $line'",
      "cat file_to_clean.jsonl | jq -R \"fromjson? | . \" -c > clean_file.jsonl",
      "tail -f log | jq -R 'try fromjson catch .'"
    ],
    "utterance": "For each line in a log file, output the parsed data if the line is valid; otherwise, ignore or output the original unparseable line.",
    "expressions": [
      "jq -R 'fromjson?'",
      "jq -R '. as $line | try (fromjson) catch $line'",
      "jq -R 'try fromjson catch .'"
    ],
    "data": [
      {
        "input": [
          "{\"level\":\"info\",\"msg\":\"something happened\"}",
          "not a json line",
          "{\"level\":\"error\",\"msg\":\"oops\"}"
        ],
        "output": [
          {
            "level": "info",
            "msg": "something happened"
          },
          null,
          {
            "level": "error",
            "msg": "oops"
          }
        ]
      }
    ],
    "identifier": 41599314
  },
  {
    "context": [
      "I have several large json objects (think GB scale), where the object values in some of the innermost levels are arrays of objects.",
      "I'm trying to break these arrays into individual objects, each of which will have a key such as g__0 or g__1, where the numbers correspond to the index in the original array, as returned by the `keys` function. The number of objects in each array may be arbitrarily large (in my example it is equal to 3). At the same time I want to keep the remaining structure.",
      "What I have:\n\n    {\n     \"port\": 4500,\n     \"notes\": \"This is an example\",\n     \"seeds\": [\n      {\n        \"seed\": 12,\n        \"guid\": \"eaf612\"\n      },\n      {\n        \"seed\": 23,\n        \"guid\": \"bea143\"\n      },\n      {\n        \"seed\": 38,\n        \"guid\": \"efk311\"\n      }\n      ]\n    }",
      "What I am hoping to achieve:\n\n    {\n      \"port\": 4500,\n      \"notes\": \"This is an example\",\n      \"seeds\": {\n        \"g__0\": {\n          \"seed\": 12,\n          \"guid\": \"eaf612\"\n        },\n        \"g__1\": {\n          \"seed\": 23,\n          \"guid\": \"bea143\"\n        },\n        \"g__2\": {\n          \"seed\": 38,\n          \"guid\": \"efk311\"\n        }\n      }\n    }",
      "The following jq program should do the trick.  At least it produces the desired results for the given JSON.  The program is so short and straightforward that I'll let it speak for itself:\n\n    def array2object(prefix):\n      . as $in\n      | reduce range(0;length) as $i ({}; .[\"\\(prefix)_\\($i)\"] = $in[$i]);\n    \n    .seeds |= array2object(\"g__\")"
    ],
    "utterance": "Transform an array at the 'seeds' key into an object whose keys are 'g__' plus the array index, keeping the rest of the structure intact.",
    "expressions": [
      "def array2object(prefix): . as $in | reduce range(0;length) as $i ({}; .[\"\\(prefix)_\\($i)\"] = $in[$i]);\n.seeds |= array2object(\"g__\")"
    ],
    "data": [
      {
        "input": {
          "port": 4500,
          "notes": "This is an example",
          "seeds": [
            {
              "seed": 12,
              "guid": "eaf612"
            },
            {
              "seed": 23,
              "guid": "bea143"
            },
            {
              "seed": 38,
              "guid": "efk311"
            }
          ]
        },
        "output": {
          "port": 4500,
          "notes": "This is an example",
          "seeds": {
            "g__0": {
              "seed": 12,
              "guid": "eaf612"
            },
            "g__1": {
              "seed": 23,
              "guid": "bea143"
            },
            "g__2": {
              "seed": 38,
              "guid": "efk311"
            }
          }
        }
      }
    ],
    "identifier": 42701295
  }
]