[
  {
    "context": [
      "echo \"IP_GAT=$(terraform output -json gatewayStaticIp | jq -r .)\" >> $GITHUB_ENV",
      "Apparently there is some problem with jq even it seems to be exactly like in example",
      "- name: Extract gateway ip\n  run: |\n    terraform init    \n    echo \"IP_GAT=$(terraform output -json gatewayStaticIp | jq -r .)\" >> $GITHUB_ENV\n  working-directory: ${{ env.my_dir }}",
      "Disabling the wrapper will make it work",
      "terraform_wrapper: false"
    ],
    "utterance": "Extract the value of the gatewayStaticIp Terraform output as a string and save it to an environment variable.",
    "expressions": [
      "jq -r ."
    ],
    "identifier": 65170927
  },
  {
    "context": [
      "And I want to get the key (ABCD-12345) and the updated (2020-12-03T13:16:17.000+0200).",
      "This should achieve what you wanted :",
      "jq -r '.issues[] | .key+\" \"+.fields.updated'"
    ],
    "utterance": "Return each issue's key and its updated field together, separated by a space.",
    "expressions": [
      ".issues[] | .key+\" \"+.fields.updated"
    ],
    "data": [
      {
        "input": {
          "expand": "names, schema",
          "startAt": 0,
          "maxResults": 1,
          "total": 46,
          "issues": [
            {
              "key": "ABCD-12345",
              "fields": {
                "updated": "2020-12-03T13:16:17.000+0200",
                "customfield_18484": null,
                "customfield_14687": null,
                "customfield_14688": null,
                "customfield_18800": null,
                "customfield_23380": "",
                "customfield_18480": "off"
              }
            }
          ]
        },
        "output": "ABCD-12345 2020-12-03T13:16:17.000+0200"
      }
    ],
    "identifier": 65167312
  },
  {
    "context": [
      "Basically want to add/append objects to the nested **profiles** array.",
      "jq --arg name \"$name\" --arg car \"$car\" --arg colour \"$colour\" ' .profiles += [{ $name, $car, $colour}] ' profiles.json | sponge profiles.json",
      "the jq variable $profiles now holds a JSON string, which is not what you want. You could chase this rabbit down its rabbit hole by using `--argjson`, but to what end?"
    ],
    "utterance": "Append an object to the profiles array, which is nested inside a larger object that includes other non-array keys.",
    "expressions": [
      ".profiles += [{\"name\": $name, \"car\": $car, \"colour\": $colour}]"
    ],
    "data": [
      {
        "input": {
          "profiles": [
            {
              "name": "Paul",
              "car": "Nissan",
              "colour": "Black"
            }
          ]
        },
        "output": {
          "profiles": [
            {
              "name": "Joe",
              "car": "BMW",
              "colour": "Blue"
            },
            {
              "name": "Paul",
              "car": "Nissan",
              "colour": "Black"
            }
          ]
        }
      }
    ],
    "identifier": 65144289
  },
  {
    "context": [
      "Is it possible to use a variable to hold a dot notation path?",
      "I've tried various parens and quotes with increasing literal results ('.names.given' and '$ng')",
      "jq does support `path expressions` in the form of arrays of strings and/or non-negative integers. These can be used to access values in conjunction with the built-in `getpath/1`.",
      "So you could, for example, write something along the lines of:",
      "[\"names\", \"given\"] as $ng\n| .people[]\n| select(.id==47)\n| getpath($ng)",
      "the assignment to $ng above could be written as:\n\n    (null | path(.names.given)) as $ng"
    ],
    "utterance": "Extract the value at the path 'names.given' from any object in 'people' where 'id' equals 47, where the path is stored in a variable.",
    "expressions": [
      "[\"names\", \"given\"] as $ng | .people[] | select(.id==47) | getpath($ng)",
      "(null | path(.names.given)) as $ng | .people[] | select(.id==47) | getpath($ng)"
    ],
    "data": [
      {
        "input": {
          "people": [
            {
              "names": {
                "given": "Alice",
                "family": "Smith"
              },
              "id": 47
            },
            {
              "id": 42
            }
          ]
        },
        "output": "Alice"
      }
    ],
    "identifier": 65151836
  },
  {
    "context": [
      "My goal is to delete ***all*** the objects in the root JSON array if the ***artifact_location*** property of the a object contains the string value ***\"foo\"***.",
      "del(.[] | select(.artifact_location | test(\"foo\")))",
      "test is not defined",
      "contains/1 could be used in this case.",
      "del(.[] | select(.artifact_location | contains(\"foo\")))",
      "I would rather approach this as filtering out the objects, rather than deleting them. Select objects that does not contain \"foo\".",
      "map(select(.artifact_location | contains(\"foo\") | not))"
    ],
    "utterance": "Remove all objects whose artifact_location contains the string \"foo\".",
    "expressions": [
      "del(.[] | select(.artifact_location | contains(\"foo\")))",
      "map(select(.artifact_location | contains(\"foo\") | not))"
    ],
    "data": [
      {
        "input": [
          {
            "action": "copy",
            "artifact_location": "one foo one"
          },
          {
            "action": "copy",
            "artifact_location": "one bar one"
          },
          {
            "action": "remove",
            "artifact_location": "two foo two"
          }
        ],
        "output": [
          {
            "action": "copy",
            "artifact_location": "one bar one"
          }
        ]
      }
    ],
    "identifier": 65139338
  },
  {
    "context": [
      "My goal is to output the content of the *my.json* file as it as after using the map function.",
      "If I combine the ***add*** function as follows.\n\n    jq -r 'map(to_entries | map({(.key): .value}) | add )' my.json\n\nIt **changes the previously sorted order** of properties similar to the output below.",
      "jq 1.3 makes no guarantees about the ordering of keys within an object."
    ],
    "utterance": "Return the objects from the array with their properties in the original order, not reordered.",
    "expressions": [
      "map(.)"
    ],
    "data": [
      {
        "input": [
          {
            "action": "copy",
            "artifact_location": "one foo one"
          },
          {
            "action": "copy",
            "artifact_location": "one bar one"
          },
          {
            "action": "remove",
            "artifact_location": "two foo two"
          }
        ],
        "output": [
          {
            "action": "copy",
            "artifact_location": "one foo one"
          },
          {
            "action": "copy",
            "artifact_location": "one bar one"
          },
          {
            "action": "remove",
            "artifact_location": "two foo two"
          }
        ]
      }
    ],
    "identifier": 65148220
  },
  {
    "context": [
      "I need to parse a json file (input.json) and create json file as output (output.json) after removing few lines.",
      "it gives the complete list But don't know how to get values under ubuntu and centos.",
      "`jq 'del(.. | .sourceUrl?)' input.json`",
      "Output:",
      "[{'Version': '1.0', 'ubuntu': {'ver': '1.0.0', 'filename': '1_0_0.log'}}, ...]"
    ],
    "utterance": "Remove all sourceUrl fields from all objects at any nesting level.",
    "expressions": [
      "del(.. | .sourceUrl?)"
    ],
    "data": [
      {
        "input": [
          {
            "Version": "1.0",
            "ubuntu": {
              "ver": "1.0.0",
              "filename": "1_0_0.log",
              "sourceUrl": "https://example.com/log/1_0_0.log"
            }
          },
          {
            "Version": "1.1",
            "ubuntu": {
              "ver": "1.0.1",
              "filename": "1_0_1.log",
              "sourceUrl": "https://example.com/log/1_0_1.log"
            }
          },
          {
            "Version": "1.4",
            "ubuntu": {
              "ver": "1.0.4",
              "filename": "1_0_4.log",
              "sourceUrl": "https://example.com/log/1_0_4.log"
            },
            "centos": {
              "ver": "1.0.4",
              "filename": "1_0_4.pdf",
              "sourceUrl": "https://example.com/log/1_0_4.pdf"
            }
          }
        ],
        "output": [
          {
            "Version": "1.0",
            "ubuntu": {
              "ver": "1.0.0",
              "filename": "1_0_0.log"
            }
          },
          {
            "Version": "1.1",
            "ubuntu": {
              "ver": "1.0.1",
              "filename": "1_0_1.log"
            }
          },
          {
            "Version": "1.4",
            "ubuntu": {
              "ver": "1.0.4",
              "filename": "1_0_4.log"
            },
            "centos": {
              "ver": "1.0.4",
              "filename": "1_0_4.pdf"
            }
          }
        ]
      }
    ],
    "identifier": 65144624
  },
  {
    "context": [
      "And I need to get the following output:  \r\n1+2+3 i|ii|iii   \r\n4+5+6 iv|v|vi",
      "jq -r '.data[] | [ ( map(.a) | join(\"+\") ), ( map(.b) | join(\"|\") ) ] | @tsv'"
    ],
    "utterance": "For each sub-array in 'data', output a line with all values of 'a' joined by '+', followed by all values of 'b' joined by '|', separated by a tab.",
    "expressions": [
      ".data[] | [ ( map(.a) | join(\"+\") ), ( map(.b) | join(\"|\") ) ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "data": [
            [
              {
                "a": "1",
                "b": "i"
              },
              {
                "a": "2",
                "b": "ii"
              },
              {
                "a": "3",
                "b": "iii"
              }
            ],
            [
              {
                "a": "4",
                "b": "iv"
              },
              {
                "a": "5",
                "b": "v"
              },
              {
                "a": "6",
                "b": "vi"
              }
            ]
          ]
        },
        "output": "1+2+3\ti|ii|iii\n4+5+6\tiv|v|vi"
      }
    ],
    "identifier": 65184635
  },
  {
    "identifier": 65202170
  },
  {
    "context": [
      "I want to have a single row with the name, date of the first row, and the date of the 20th row.",
      "You could use the `group_by()` function for this. First by `.name` and then `sort` by the `.date` field.",
      "[ inputs ]        | \ngroup_by(.name)[] | \nsort_by(.date)    | \n[ last, first ]   | \n[ .[0].date, \n  .[1].date, \n  .[0].name \n]                 | \n@csv",
      "or if the requirement is strictly look for the object with `.pos` as 20, do an explicit `select()`",
      "[ inputs ]        | \ngroup_by(.name)[] | \nsort_by(.date)    | \nmap(select(.pos == 1 or .pos == 20)) \n[ .[0].date, \n  .[1].date // \"\", \n  .[0].name \n]                 | \n@csv"
    ],
    "utterance": "For each unique name, output a single row containing the date of the first row, the date of the 20th row, and the name.",
    "expressions": [
      "[inputs] | group_by(.name)[] | sort_by(.date) | [last, first] | [.[0].date, .[1].date, .[0].name] | @csv",
      "[inputs] | group_by(.name)[] | sort_by(.date) | map(select(.pos == 1 or .pos == 20)) | [.[0].date, .[1].date // \"\", .[0].name] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "pos": 1,
            "date": "2020-12-04",
            "name": "ABC"
          },
          {
            "pos": 2,
            "date": "2020-12-03",
            "name": "ABC"
          },
          {
            "pos": 20,
            "date": "2020-11-04",
            "name": "ABC"
          },
          {
            "pos": 1,
            "date": "2020-11-14",
            "name": "DEF"
          },
          {
            "pos": 20,
            "date": "2020-10-12",
            "name": "DEF"
          }
        ],
        "output": [
          "\"2020-12-04\",2020-11-04,\"ABC\"",
          "\"2020-11-14\",2020-10-12,\"DEF\""
        ]
      }
    ],
    "identifier": 65181506
  },
  {
    "context": [
      "i am trying to extract values for version and filename.",
      "i want to know how this can be done using single command to extract it. something similar to   jq '[.[].*.version]' input.json"
    ],
    "utterance": "Extract all version and filename values from every nested object in each top-level array element, in a single command.",
    "expressions": [
      ".[].[] | {version, filename}",
      "[.[].[] | {version, filename}]"
    ],
    "data": [
      {
        "input": [
          {
            "Ver": "1.0",
            "ubuntu": {
              "version": "1.0.0",
              "filename": "1_0_0.log"
            }
          },
          {
            "Ver": "1.1",
            "ubuntu": {
              "version": "1.0.1",
              "filename": "1_0_1.log"
            }
          },
          {
            "Ver": "1.4",
            "ubuntu": {
              "version": "1.0.4",
              "filename": "1_0_4.log"
            },
            "centos": {
              "version": "1.0.4",
              "filename": "1_0_4.pdf"
            }
          }
        ],
        "output": [
          {
            "version": "1.0.0",
            "filename": "1_0_0.log"
          },
          {
            "version": "1.0.1",
            "filename": "1_0_1.log"
          },
          {
            "version": "1.0.4",
            "filename": "1_0_4.log"
          },
          {
            "version": "1.0.4",
            "filename": "1_0_4.pdf"
          }
        ]
      }
    ],
    "identifier": 65197341
  },
  {
    "context": [
      "I am trying to create a command (preferable one liner) to return key pairs that only have string values. So for the above it would return:\n{\n  \"1\": \"a-secret\",\n  \"A\": \"b-secret\"\n}",
      "You are looking for [`map_values`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)).\n$ jq 'map_values(strings)' file",
      "As an alternate solution, especially on versions prior to `jq-1.6` you could use `with_entries` to filter on values whose type is `string`\nwith_entries(select(.value | type == \"string\"))"
    ],
    "utterance": "Extract only key-value pairs from the top-level object where the value is a string.",
    "expressions": [
      "map_values(strings)",
      "with_entries(select(.value | type == \"string\"))"
    ],
    "data": [
      {
        "input": {
          "1": "a-secret",
          "A": "b-secret",
          "2": {
            "3": "ab-secret",
            "4": {
              "5": "adc-secret"
            },
            "6": {
              "7": "abdc-secret"
            }
          }
        },
        "output": {
          "1": "a-secret",
          "A": "b-secret"
        }
      }
    ],
    "identifier": 65201631
  },
  {
    "context": [
      "now consider these demonstrative examples(takes no  input):",
      "1. adding *nothing*",
      "here we have empty object, which we update with nothing:",
      "    {} | . |= . + ({} | select (.foo == 123))",
      "which results in ",
      "    null",
      "2. adding *null*",
      "same template but with alternative operator to substitute *nothing* to *null*:",
      "    {} | . |= . + ({} | select (.foo == 123)//null)",
      "which results in",
      "    {}",
      "Take a look at these for example (`empty` is a filter that returns nothing):",
      "    $ jq -n '[null] | length'",
      "    1",
      "    $ jq -n '[empty] | length'",
      "    0"
    ],
    "utterance": "Update an empty object by adding the result of selecting objects with .foo == 123; compare the behavior when the selector yields nothing versus when nothing is replaced with null.",
    "expressions": [
      "{} | . |= . + ({} | select (.foo == 123))",
      "{} | . |= . + ({} | select (.foo == 123)//null)"
    ],
    "data": [
      {
        "input": {},
        "output": null
      },
      {
        "input": {},
        "output": {}
      }
    ],
    "identifier": 65199084
  },
  {
    "context": [
      "But no i want to determine the value of \"yes\" or \"no\" depending on the file-value. Do you know how to edit the command so it checks the file-value in order to determine the critical-value?",
      "It should decide like this:",
      "Filepath1, Filepath3 leads to `\"critical\" : \"No\"`",
      "Filepath2, Filepath4, Filepath5 leads to `\"critical\" : \"Yes\"`",
      "jq '.[] |= . + {\"critical\": (if .file == \"FilePath1\" or .file == \"FilePath3\" then \"no\" else \"yes\" end)}'",
      "map(. + {critical: (if .file | IN(\"FilePath1\", \"FilePath3\") then \"no\" else \"yes\" end) })",
      "map(. + {critical: ((.file | select(IN(\"FilePath1\", \"FilePath3\")) | \"no\") // \"yes\" )})"
    ],
    "utterance": "Add a property critical with value 'no' if file is FilePath1 or FilePath3, otherwise 'yes', to each object in the array.",
    "expressions": [
      ".[] |= . + {\"critical\": (if .file == \"FilePath1\" or .file == \"FilePath3\" then \"no\" else \"yes\" end)}",
      "map(. + {critical: (if .file | IN(\"FilePath1\", \"FilePath3\") then \"no\" else \"yes\" end) })",
      "map(. + {critical: ((.file | select(IN(\"FilePath1\", \"FilePath3\")) | \"no\") // \"yes\" )})"
    ],
    "data": [
      {
        "input": [
          {
            "key": "Key1",
            "file": "FilePath1",
            "line": 10,
            "rule": "csharpsquid:S1643",
            "message": "Use a StringBuilder instead.",
            "type": "CODE_SMELL"
          },
          {
            "key": "Key2",
            "file": "FilePath2",
            "line": 12,
            "rule": "csharpsquid:S1643",
            "message": "Use a StringBuilder instead.",
            "type": "CODE_SMELL"
          }
        ],
        "output": [
          {
            "key": "Key1",
            "file": "FilePath1",
            "line": 10,
            "rule": "csharpsquid:S1643",
            "message": "Use a StringBuilder instead.",
            "type": "CODE_SMELL",
            "critical": "no"
          },
          {
            "key": "Key2",
            "file": "FilePath2",
            "line": 12,
            "rule": "csharpsquid:S1643",
            "message": "Use a StringBuilder instead.",
            "type": "CODE_SMELL",
            "critical": "yes"
          }
        ]
      }
    ],
    "identifier": 65197711
  },
  {
    "context": [
      "ss=\"mango\"",
      "jq -n '{\"name\": {\"S\": $ID}}' --arg ID 'partridge in a $ss tree'",
      "expected output:",
      "{",
      "  \"name\": {",
      "    \"S\": \"partridge in a mango tree\"",
      "  }",
      "}",
      "Try `--arg ID \"value\"` in double quote like following:",
      "ss=\"mango\"",
      "jq -n '{\"name\": {\"S\": $ID}}' --arg ID \"partridge in a $ss tree\""
    ],
    "utterance": "Create an object with key name mapping to an object with key S and value 'partridge in a mango tree', where 'mango' is from a shell variable.",
    "expressions": [
      "jq -n '{\"name\": {\"S\": $ID}}' --arg ID \"partridge in a $ss tree\""
    ],
    "data": [
      {
        "input": "ss=\"mango\"",
        "output": {
          "name": {
            "S": "partridge in a mango tree"
          }
        }
      }
    ],
    "identifier": 65211894
  },
  {
    "context": [
      "My output is, and I need remove this empty values like `{\"{#PARAMETER}\":\"\"}`:",
      "jq '.data[] |= select((.\"{#PARAMETER}\" | length) > 0)' file.json"
    ],
    "utterance": "Remove objects from the data array where the {#PARAMETER} field is an empty string.",
    "expressions": [
      ".data |= map(select(.\"{#PARAMETER}\" != \"\"))",
      ".data |= map(select((.\"{#PARAMETER}\" | length) > 0))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "{#PARAMETER}": ""
            },
            {
              "{#PARAMETER}": "test1"
            },
            {
              "{#PARAMETER}": "test2"
            },
            {
              "{#PARAMETER}": "test3"
            },
            {
              "{#PARAMETER}": "test4"
            },
            {
              "{#PARAMETER}": ""
            }
          ]
        },
        "output": {
          "data": [
            {
              "{#PARAMETER}": "test1"
            },
            {
              "{#PARAMETER}": "test2"
            },
            {
              "{#PARAMETER}": "test3"
            },
            {
              "{#PARAMETER}": "test4"
            }
          ]
        }
      }
    ],
    "identifier": 65207770
  },
  {
    "context": [
      "I want to get the value of the field `id`, but only for the element which has `repoTags` = \"3.0.0\".",
      "Here is a filter I think will help",
      ".[] | select(.repoTags | any(keys[] == \"3.0.0\")) | .id",
      "with your input it produces",
      "\"002\""
    ],
    "utterance": "Return the id value for the element where repoTags contains the key 3.0.0.",
    "expressions": [
      ".[] | select(.repoTags | any(keys[] == \"3.0.0\")) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "001",
            "repoTags": {
              "docker/alpine": {
                "2.1.9": {
                  "vulnerable": "true",
                  "vulnerabilityCount": 19
                },
                "stable": {
                  "vulnerable": "true",
                  "vulnerabilityCount": 19
                }
              }
            }
          },
          {
            "id": "002",
            "repoTags": {
              "docker/alpine": {
                "3.0.0": {
                  "vulnerable": "false",
                  "vulnerabilityCount": 0
                }
              }
            }
          }
        ],
        "output": "002"
      }
    ],
    "identifier": 65225889
  },
  {
    "context": [
      "How do I print objects where prop contains at least one of kiwi and orange?",
      "I think you&#39;re looking for [`IN/2`](https://stedolan.github.io/jq/manual/#SQL-StyleOperators).",
      "select(IN(.prop[]; \"kiwi\", \"orange\"))",
      "So we are led to:\n\n    select( any( .prop[]; . == \"kiwi\" or . == \"orange\" ))",
      "or more succinctly:\n\n    select( any(.prop[]; IN(\"kiwi\", \"orange\")))",
      "If the values of interest are provided as a JSON array, say $whitelist, you could tweak the above by substituting `$whitelist[]` for the explicit stream of values:\n\n    select( any(.prop[]; IN($whitelist[]) ))"
    ],
    "utterance": "Select all objects where the prop array contains at least one of the values kiwi or orange.",
    "expressions": [
      "select(IN(.prop[]; \"kiwi\", \"orange\"))",
      "select(any(.prop[]; . == \"kiwi\" or . == \"orange\"))",
      "select(any(.prop[]; IN(\"kiwi\", \"orange\")))",
      "select(any(.prop[]; IN($whitelist[])))"
    ],
    "data": [
      {
        "input": [
          {
            "prop": [
              "apple",
              "banana"
            ]
          },
          {
            "prop": [
              "kiwi",
              "banana"
            ]
          },
          {
            "prop": [
              "cherry",
              "orange"
            ]
          }
        ],
        "output": [
          {
            "prop": [
              "kiwi",
              "banana"
            ]
          },
          {
            "prop": [
              "cherry",
              "orange"
            ]
          }
        ]
      }
    ],
    "identifier": 65232444
  },
  {
    "context": [
      "How can jq get convinced to return results in one row?",
      "I would like to have it in one row:",
      "--compact-output / -c:\n> By default, jq pretty-prints JSON output. Using this option will result in more compact output by instead putting each JSON object on a single line.",
      "echo '{\"name\":\"New release\",\"description\":\"Super nice release\",\"milestones\":[\"v1.0\",\"v1.0-rc\"]}' | jq -c '.milestones'",
      "echo '{\"name\":\"New release\",\"description\":\"Super nice release\",\"milestones\":[\"v1.0\",\"v1.0-rc\"]}' | jq '.milestones' -c"
    ],
    "utterance": "Output the value of the milestones key as a compact, single-line array.",
    "expressions": [
      "jq -c '.milestones'",
      "jq '.milestones' -c"
    ],
    "data": [
      {
        "input": {
          "name": "New release",
          "description": "Super nice release",
          "milestones": [
            "v1.0",
            "v1.0-rc"
          ]
        },
        "output": [
          "v1.0",
          "v1.0-rc"
        ]
      }
    ],
    "identifier": 65251540
  },
  {
    "context": [
      "Ideally I'd like to merge the files so the original file includes the extra values from the other file eg:",
      "As you can see the common value key between File 1 and File 2 is \"NAME\".",
      "First construct a dictionary, and then use it to perform the update:",
      "jq --argfile new 2.json '\n ($new | INDEX(.NAME)) as $dict\n | .objects.ne_110m_admin_0_countries.geometries[].properties\n     |= (if $dict[.NAME] then . + $dict[.NAME] else . end)\n' 1.json",
      "Another possibility would have been to blindly update every value associated with \"properties\":",
      "($new | INDEX(.NAME)) as $dict\n| walk(if type == \"object\" and .properties\n       then .properties |= . + $dict[.NAME]\n       else . end)"
    ],
    "utterance": "Add fields from a second file to each country's properties if their NAME value matches.",
    "expressions": [
      "jq --argfile new 2.json '($new | INDEX(.NAME)) as $dict | .objects.ne_110m_admin_0_countries.geometries[].properties |= (if $dict[.NAME] then . + $dict[.NAME] else . end)' 1.json",
      "jq --argfile new 2.json '($new | INDEX(.NAME)) as $dict | walk(if type == \"object\" and .properties then .properties |= . + $dict[.NAME] else . end)' 1.json"
    ],
    "identifier": 65234659
  },
  {
    "context": [
      "I have a CSV file (parent child format). Is it possible to convert to JSON format by using JQ ?",
      "id  parent_id   text",
      "1   NULL        engine",
      "2   1           exhaust",
      "3   1           cooling",
      "4   3           cooling fan",
      "5   3           water pump",
      "6   NULL        frame",
      "7   6           wheels",
      "8   6           brakes",
      "9   8           brake calipers",
      "10  6           cables",
      "JSON file",
      "[{ \"id\": \"1\", \"text\": \"engine\", \"children\": [{ \"id\": \"2\", \"text\": \"exhaust\", \"children\": [] }, { \"id\": \"3\", \"text\": \"cooling\", \"children\": [{ \"id\": \"4\", \"text\": \"cooling fan\", \"children\": [] }, { \"id\": \"5\", \"text\": \"water pump\", \"children\": [] }] }] }, { \"id\": \"6\", \"text\": \"frame\", \"children\": [{ \"id\": \"7\", \"text\": \"wheels\", \"children\": [] }, { \"id\": \"8\", \"text\": \"brakes\", \"children\": [{ \"id\": \"9\", \"text\": \"brake calipers\", \"children\": [] }] }, { \"id\": \"10\", \"text\": \"cables\", \"children\": [] }] }]",
      "The solution here is based on the construction of a dictionary of \"children\".",
      "def obj($headers):\n  . as $in\n  | reduce range(0; $headers|length) as $i ({}; \n      .[$headers[$i]] = $in[$i]);",
      "split(\",\") as $headers\n| [ inputs\n    | split(\",\")\n    | map_values(if . == \"NULL\" then null else . end)\n    | obj($headers) ]\n| (reduce .[] as $row ({};\n      if $row.parent_id\n      then .[$row.parent_id] += [$row.id]\n      else . end ) ) as $children\n| map( del(.parent_id) | .children = ($children[.id] // []) )"
    ],
    "utterance": "Convert a CSV where rows have id, parent_id, and text columns into a nested array where each item includes its children recursively based on parent_id relationships, matching the specified tree structure.",
    "expressions": [
      "def obj($headers):\n  . as $in\n  | reduce range(0; $headers|length) as $i ({}; \n      .[$headers[$i]] = $in[$i]);\n\nsplit(\",\") as $headers\n| [ inputs\n    | split(\",\")\n    | map_values(if . == \"NULL\" then null else . end)\n    | obj($headers) ]\n| (reduce .[] as $row ({};\n      if $row.parent_id\n      then .[$row.parent_id] += [$row.id]\n      else . end ) ) as $children\n| map( del(.parent_id) | .children = ($children[.id] // []) )"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "parent_id": null,
            "text": "engine"
          },
          {
            "id": "2",
            "parent_id": "1",
            "text": "exhaust"
          },
          {
            "id": "3",
            "parent_id": "1",
            "text": "cooling"
          },
          {
            "id": "4",
            "parent_id": "3",
            "text": "cooling fan"
          },
          {
            "id": "5",
            "parent_id": "3",
            "text": "water pump"
          },
          {
            "id": "6",
            "parent_id": null,
            "text": "frame"
          },
          {
            "id": "7",
            "parent_id": "6",
            "text": "wheels"
          },
          {
            "id": "8",
            "parent_id": "6",
            "text": "brakes"
          },
          {
            "id": "9",
            "parent_id": "8",
            "text": "brake calipers"
          },
          {
            "id": "10",
            "parent_id": "6",
            "text": "cables"
          }
        ],
        "output": [
          {
            "id": "1",
            "text": "engine",
            "children": [
              {
                "id": "2",
                "text": "exhaust",
                "children": []
              },
              {
                "id": "3",
                "text": "cooling",
                "children": [
                  {
                    "id": "4",
                    "text": "cooling fan",
                    "children": []
                  },
                  {
                    "id": "5",
                    "text": "water pump",
                    "children": []
                  }
                ]
              }
            ]
          },
          {
            "id": "6",
            "text": "frame",
            "children": [
              {
                "id": "7",
                "text": "wheels",
                "children": []
              },
              {
                "id": "8",
                "text": "brakes",
                "children": [
                  {
                    "id": "9",
                    "text": "brake calipers",
                    "children": []
                  }
                ]
              },
              {
                "id": "10",
                "text": "cables",
                "children": []
              }
            ]
          }
        ]
      }
    ],
    "identifier": 65190223
  },
  {
    "context": [
      "If I set the variable to a comma delimited list of values and pass it in it returns no results",
      "You can instead format your list as a valid JSON list, and use `--argjson`:",
      "jq --argjson TESTVALUES \"$testValues\" '.[] | select(.name==($TESTVALUES[]))' file.json",
      "Or perhaps even better, specify some delimiter and have jq split up your string instead, so you don't have to worry about JSON escaping:",
      "jq --arg TESTVALUES \"$testValues\" '.[] | select(.name==($TESTVALUES | split(\",\")[]))' file.json"
    ],
    "utterance": "Filter objects whose name is one of multiple values provided dynamically as a list from a Bash variable.",
    "expressions": [
      ".[] | select(.name==($TESTVALUES[]))",
      ".[] | select(.name==($TESTVALUES | split(\",\")[]))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "value1",
            "test": "blah1"
          },
          {
            "name": "value2",
            "test": "blah2"
          }
        ],
        "output": [
          {
            "name": "value1",
            "test": "blah1"
          },
          {
            "name": "value2",
            "test": "blah2"
          }
        ]
      }
    ],
    "identifier": 65260018
  },
  {
    "context": [
      "How can I change all versions to \"latest\" without enumerating individual keys ?",
      "Like this:\r\n\r\n    jq '.dependencies[]=\"latest\"' package.json",
      "A succinct, precise, and easy-to-read solution:\r\n\r\n    .dependencies |= map_values(\"latest\")"
    ],
    "utterance": "Set all values within the 'dependencies' object to 'latest' without specifying each key individually.",
    "expressions": [
      ".dependencies[]=\"latest\"",
      ".dependencies |= map_values(\"latest\")"
    ],
    "data": [
      {
        "input": {
          "dependencies": {
            "body-parser": "^1.19.0",
            "eslint": "^7.15.0",
            "express": "^4.17.1"
          }
        },
        "output": {
          "dependencies": {
            "body-parser": "latest",
            "eslint": "latest",
            "express": "latest"
          }
        }
      }
    ],
    "identifier": 65260214
  },
  {
    "context": [
      "I want to produce a JSON object from it like this:\n{\n  \"alpha\": 1,\n  \"beta\": 2,\n  ...\n}",
      "sometimes the object with \"name\": \"alpha\" (or \"name\": \"beta\", etc.) won't actually exist in the input array! In that case, I want to print \"alpha\": null or \"alpha\": \"\". But I can't figure out how to integrate that into my select() call.",
      "[.[] | { (.name): .value }] | add",
      "| {alpha, beta, gamma}",
      "jq 'from_entries | {alpha, beta, gamma}' input.json",
      "from_entries as $in\n| reduce $keylist[] as $key ({}; .[$key]=$in[$key])",
      "from_entries as $in\n| reduce $keylist[] as $key ({}; .[$key] = $in[$key] // $default)",
      "from_entries as $in\n| reduce $keylist[] as $key ({};\n    .[$key] = if ($in | has($key)) then $in[$key] else $default end)"
    ],
    "utterance": "Convert an array of objects with 'name' and 'value' fields into an object mapping selected names to their values, using a fallback such as null when a name is missing.",
    "expressions": [
      "[.[] | { (.name): .value }] | add | {alpha, beta, gamma}",
      "from_entries | {alpha, beta, gamma}",
      "from_entries as $in | reduce $keylist[] as $key ({}; .[$key]=$in[$key])",
      "from_entries as $in | reduce $keylist[] as $key ({}; .[$key] = $in[$key] // $default)",
      "from_entries as $in | reduce $keylist[] as $key ({}; .[$key] = if ($in | has($key)) then $in[$key] else $default end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "alpha",
            "value": 1
          },
          {
            "name": "beta",
            "value": 2
          }
        ],
        "output": {
          "alpha": 1,
          "beta": 2,
          "gamma": null
        }
      }
    ],
    "identifier": 65260809
  },
  {
    "context": [
      "ls mydir | jq -R '[.]'",
      "ls mydir | jq -sR '[split(\"\\n\")[]|select(.|length>0)]'",
      "printf '%s\\0' * | jq -Rn 'inputs | split(\"\\u0000\")'",
      "for file in *; do \n  [ -f \"$file\" ] && printf '%s\\0' \"$file\"\ndone | jq -Rn 'inputs | split(\"\\u0000\")'",
      "find . -type f -maxdepth 1 -print0 |\n  jq -Rs 'split(\"\\u0000\") | map(sub(\"./\";\"\"))'",
      "ls mydir | jq -sR 'split(\"\\n\")[0:-1]'"
    ],
    "utterance": "Produce a single array containing all filenames in a directory, handling filenames with special characters, such as newlines or spaces.",
    "expressions": [
      "printf '%s\\0' * | jq -Rn 'inputs | split(\"\\u0000\")'",
      "for file in *; do [ -f \"$file\" ] && printf '%s\\0' \"$file\"; done | jq -Rn 'inputs | split(\"\\u0000\")'",
      "find . -type f -maxdepth 1 -print0 | jq -Rs 'split(\"\\u0000\") | map(sub(\"./\";\"\"))'",
      "ls mydir | jq -sR 'split(\"\\n\")[0:-1]'"
    ],
    "identifier": 65290874
  },
  {
    "context": [
      "I am trying to create the following JSON object structure:",
      "{\n  \"hard-coded-value\": false,\n  \"dynamic-value-1\": true,\n  \"dynamic-value-2\": true,\n  \"dynamic-value-3\": true\n}",
      "What I want is this output to look like the output outlined at the top of this question, but I can't figure out how to tell jq to append to the root JSON object instead of creating a bunch of objects.",
      "You don't need a loop there.",
      "$ printf '%s\\n' \"${dynamic_values[@]}\" | jq -nR '{hardcoded_value: false} | .[inputs] = true'",
      "$ jq -n '{hardcoded_value: false} | .[$ARGS.positional[]] = true' --args \"${dynamic_values[@]}\""
    ],
    "utterance": "Construct an object with a fixed key-value pair \"hard-coded-value\": false and multiple keys from a list (e.g., \"dynamic-value-1\", \"dynamic-value-2\", \"dynamic-value-3\"), each set to true.",
    "expressions": [
      "{\"hard-coded-value\": false} | .[inputs] = true",
      "{\"hard-coded-value\": false} | .[$ARGS.positional[]] = true"
    ],
    "data": [
      {
        "input": [
          "dynamic-value-1",
          "dynamic-value-2",
          "dynamic-value-3"
        ],
        "output": {
          "hard-coded-value": false,
          "dynamic-value-1": true,
          "dynamic-value-2": true,
          "dynamic-value-3": true
        }
      }
    ],
    "identifier": 65283527
  },
  {
    "context": [
      "This data i&#39;m trying to extract fields like &quot;n&quot;,&quot;fn&quot; however its weird i can&#39;t using jq",
      "jq -r &#39;[.n, .fn]",
      "Using this approach with your BSON and query, invoking jq with the -n option yields:\r\n[\r\n  &quot;Rahul Joshi&quot;,\r\n  &quot;Rahul&quot;\r\n]"
    ],
    "utterance": "Extract the values of the fields n and fn from the data.",
    "expressions": [
      "[.n, .fn]"
    ],
    "data": [
      {
        "input": {
          "_id": "ObjectId(\"575a7c43df2e246028c9c0d2\")",
          "_class": "com.go.next.cms.entity.User",
          "n": "Rahul Joshi",
          "fn": "Rahul",
          "ln": "Joshi",
          "un": "1198383883",
          "p": "av3o1fo6h236j5bu9ue8oq380jm1t7p",
          "e": "a@gmail.com",
          "emailVerified": true,
          "k": "55394505-dd92-4b1a-b96a-a1c433662abc",
          "o_tokens": {
            "575a7c43df2e246028c9c0d2~iximacb~411e35964795733b": "6dghooxc0bxhsj9vmw2e4bu5aav3o1fo6h236j5bu9ue8oq3w13r2jd73ku8hbjhkjesa80jm1t7pmsaarmaupndhcb1disieobpkarokhc29880suct42kppmrfqjy948ufmhifdew9depicf9y5wqchlba66nl5roww35ee0b4jqwkm04b9rb8one1u4h7dlp",
            "575a7c43df2e246028c9c0d2~iximaad~411e35964795733b": "liwscmgb9an3111y2oxu0xabu3qcrmxwjpjntof3r6ax7pmp0hx65xpyp5jm0bkogq0ddkg18gnlr5nofssge6lodlk3focpwee1tlilye4n9h01m5u9odxpkma2kovl4ilgseoijl99y680j6i57643jm8t0dqcwxm0pde7w1rngusb0voljn2xwp8vbwbdnqx",
            "575a7c43df2e246028c9c0d2~iximatr~8577b27bf06cd78": "j8vs2ymueh03hifiowfhij79sd2gcng2gd3sgb6frxs09xi443xumwe9rfvs2ps3o1ol63pib7aqhqit3eg0evjq6dawu9a3uj70cd0kf2i41bnp3n0q7ry3vblso0bb51y3ktvyq390h8192uusupe1pwui7h76fyq9a8ryo8jbspaomsl147ifp1npcpsrte2",
            "575a7c43df2e246028c9c0d2~iximaad~8577b27bf06cd78": "m8gnne9cwadtwq0s0r43p7788h43hn3f9m3g1h6hagvdm8v9x6d7mvfuyuq97rhx6axobs8p2fac5wrie3a6pyaia5aq320eeh60lggbtuu816rhfg42rg3b46x356dujeo1fyeu1cawlupst78hudmx283dtg76wdalsfhij34pjx1i8tdydpihipsjysctwio"
          },
          "wc": 0,
          "role": [
            "registered_user"
          ],
          "metaUserId": 1980469,
          "t": "ya29.GlslBaPrIStUyWrejOrmxAui7DkbLRg8wzAE1Aj73U-X7rhxFLekZWPu-z_ywUS-OWO2VVcbTIPC37XorBHg-2vvkJmpqov1uPCmR5HKHW_gbcEKU6FZApW4wJYq",
          "rt": "1/isjRuytVLOeMVAytcvNVTWp_radi88Nc40IqzXOJQGvhufKyPjE99hZyGUzbWFmd",
          "up": "https://lh5.googleusercontent.com/DpBXPPCkSk0/photo.jpg",
          "ad": {
            "_id": null,
            "countryCode": "in",
            "_v": 0,
            "_cd": "Date(1465547843305)",
            "_ugc": false,
            "_inflow": false
          },
          "au": false,
          "po": 0,
          "friends": 0,
          "rejectedReviews": 0,
          "ex": false,
          "usrc": "iximaad",
          "ld": "Date(1480425174813)",
          "age": 0,
          "contactNumber": {
            "number": "931128098",
            "prefix": "91",
            "emailId": "a@gmail.com"
          },
          "contactNumberVerified": true,
          "travellers": [
            {
              "_id": "ObjectId(\"5a366b73ba9e7f124f496060\")",
              "travellerType": "Adult",
              "title": "Mr",
              "firstName": "Rahul ",
              "lastName": "Joshi",
              "editableTraveller": true,
              "primary": false,
              "frequentFlierNumberList": [],
              "seniorCitizen": false,
              "_v": 0,
              "_cd": "Date(1513515891223)",
              "_ugc": false,
              "_inflow": false
            },
            {
              "_id": "ObjectId(\"5a366ba14f173f177ebda9ec\")",
              "travellerType": "Adult",
              "title": "Mr",
              "firstName": "Pritash",
              "lastName": "Thakar ",
              "editableTraveller": true,
              "primary": false,
              "frequentFlierNumberList": [],
              "seniorCitizen": false,
              "_v": 0,
              "_cd": "Date(1513515937071)",
              "_ugc": false,
              "_inflow": false
            }
          ],
          "totalRewardPoints": 0,
          "reedemedRewardPoints": 0,
          "activityRewardPoints": {},
          "activityTotalRewardPoints": {},
          "ltc": false,
          "loginType": "signup",
          "otpVerified": true,
          "verifiedNumber": "9320119998",
          "gcmId": [],
          "prc": 0,
          "accounts": {},
          "en": true,
          "migrated": false,
          "mailAccounts": {},
          "partnerUserParams": {
            "go": {
              "partnerUserId": "118108096894957046911"
            }
          },
          "places": {},
          "_v": 0,
          "_cd": "Date(1465547843305)",
          "_ugc": false,
          "_inflow": false
        },
        "output": [
          "Rahul Joshi",
          "Rahul"
        ]
      }
    ],
    "identifier": 65249952
  },
  {
    "context": [
      "I tried to get the following format, without success. Really appreciate for some advice. ... If it is a parent (has a child under), only show ID. If it is a child, then show ID and Size.",
      "To fill in the details about children recursively can most easily be accomplished using a recursive function -- here `closure/2`, which is written so as to be quite efficient.",
      "tidy up:\n| walk(if type==\"object\" \n       then if .children and (.children|length) > 0 \n            then del(.size)\n            else . end\n       | del(.parent_id)\n       else . end)"
    ],
    "utterance": "Build a hierarchical structure from records with id, parent_id, and size, arranging items under their parent by id, showing only id for parents with children and both id and size for leaves.",
    "expressions": [
      "def obj($headers):\n  . as $in\n  | reduce range(0; $headers|length) as $i ({}; \n      .[$headers[$i]] = $in[$i]);\n\ndef closure($dictionary; $children):\n  def c: \n    if type == \"string\" then $dictionary[.] | c\n    elif type==\"object\"\n    then if has(\"children\")\n         then if (.children|length)>0 then .children = map(c) else . end\n         elif $children[.id] then .children = ($children[.id] | map(c))\n         else . end\n    else . end;\n  c;\n\nsplit(\",\") as $headers\n| [ inputs\n    | split(\",\")\n    | map_values(if . == \"Null\" then null else . end)\n    | obj($headers) ]\n| INDEX(.[]; .id) as $ids   # a dictionary mapping id => object\n| (reduce .[] as $row ({};\n      if $row.parent_id\n      then .[$row.parent_id] += [$row.id]\n      else . end ) ) as $children  # string => [ string ]\n| map(closure($ids; $children) )\n| walk(if type==\"object\" \n       then if .children and (.children|length) > 0 \n            then del(.size)\n            else . end\n       | del(.parent_id)\n       else . end)"
    ],
    "data": [
      {
        "input": [
          "id,parent_id,size",
          "Subject,Null,1",
          "analytics,Subject,1",
          "cluster,analytics,1",
          "AgglomerativeCluster,cluster,1",
          "MergeEdge,cluster,2",
          "animate,Subject,1",
          "Easing,animate,3",
          "interpolate,animate,1",
          "ArrayInterpolator,interpolate,4",
          "RectangleInterpolator,interpolate,5",
          "Tween,animate,6"
        ],
        "output": {
          "ID": "Subject",
          "children": [
            {
              "ID": "analytics",
              "children": [
                {
                  "ID": "cluster",
                  "children": [
                    {
                      "ID": "AgglomerativeCluster",
                      "size": 1
                    },
                    {
                      "ID": "MergeEdge",
                      "size": 2
                    }
                  ]
                }
              ]
            },
            {
              "ID": "animate",
              "children": [
                {
                  "ID": "Easing",
                  "size": 3
                },
                {
                  "ID": "interpolate",
                  "children": [
                    {
                      "ID": "ArrayInterpolator",
                      "size": 4
                    },
                    {
                      "ID": "RectangleInterpolator",
                      "size": 5
                    }
                  ]
                },
                {
                  "ID": "Tween",
                  "size": 6
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 65278602
  },
  {
    "context": [
      "When I use jq '.\"59.79.71.205:26969\"' it give me the value only, is there a way to get the key-value from the object into an object like the example \n\n    {\n     \"59.79.71.205:26969\": 1\n    }\n",
      "The answer is in the Object Construction section of the [manual](https://stedolan.github.io/jq/manual/v1.6/#TypesandValues).\n\n    jq '{\"59.79.71.205:26969\"}'"
    ],
    "utterance": "Extract the specified key-value pair where the key is \"59.79.71.205:26969\" as a single-entry object.",
    "expressions": [
      "{\"59.79.71.205:26969\"}"
    ],
    "data": [
      {
        "input": {
          "138.68.226.120:26969": 1,
          "178.128.50.37:26969": 1,
          "207.180.218.133:26969": 1,
          "66.42.67.157:26969": 1,
          "140.82.14.193:26969": 1,
          "51.15.39.62:26969": 1,
          "144.217.91.232:26969": 1,
          "144.217.81.95:26969": 1,
          "68.183.105.143:26969": 1,
          "192.99.246.177:26969": 1,
          "167.99.98.151:26969": 1,
          "59.79.71.205:26969": 1
        },
        "output": {
          "59.79.71.205:26969": 1
        }
      }
    ],
    "identifier": 65298839
  },
  {
    "context": [
      "Say I have the following CSV data in `input.txt`: ... And I'd like to transform it into the following JSON:",
      "Here's a jq solution that assumes the CSV input is very simple (e.g., no field has embedded commas), followed by a brief explanation.",
      "split(\",\") as $headers\n| [inputs\n   | split(\",\")\n   | obj($headers)\n  ]\n| gather_by(\"broker\"; \"clients\")\n| .brokers[].clients |= (gather_by(\"client\"; \"contracts\") | .clients)\n| .brokers[].clients[].contracts |= (gather_by(\"contract_id\"; \"documents\") | .contract_ids)\n| .brokers[].clients[].contracts[].documents |= (gather_by(\"task_type\"; \"doc_names\")  | .task_types)\n| .brokers[].clients[].contracts[].documents[].doc_names |= map(.doc_names)\n| .brokers"
    ],
    "utterance": "Convert CSV rows of broker, client, contract, task, and doc names into a deeply nested structure: broker \u2192 clients \u2192 contracts \u2192 documents (grouped by task_type) \u2192 doc_names (as arrays grouped by task_type), preserving the ordering.",
    "expressions": [
      "# sort-free plug-in replacement for the built-in group_by/1\ndef GROUP_BY(f): \n   reduce .[] as $x ({};\n     ($x|f) as $s\n     | ($s|type) as $t\n     | (if $t == \"string\" then $s else ($s|tojson) end) as $y\n     | .[$t][$y] += [$x] )\n   | [.[][]]\n   ;\n\ndef obj($keys):\n  . as $in | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = $in[$i]);\n\ndef gather_by($keyname; $newkey):\n  ($keyname + \"s\") as $plural\n  | GROUP_BY(.[$keyname])\n  | {($plural): map({($keyname): .[0][$keyname], \n                     ($newkey) : map(del(.[$keyname])) } ) }\n  ;\n\nsplit(\",\") as $headers\n| [inputs\n   | split(\",\")\n   | obj($headers)\n  ]\n| gather_by(\"broker\"; \"clients\")\n| .brokers[].clients |= (gather_by(\"client\"; \"contracts\") | .clients)\n| .brokers[].clients[].contracts |= (gather_by(\"contract_id\"; \"documents\") | .contract_ids)\n| .brokers[].clients[].contracts[].documents |= (gather_by(\"task_type\"; \"doc_names\")  | .task_types)\n| .brokers[].clients[].contracts[].documents[].doc_names |= map(.doc_names)\n| .brokers"
    ],
    "data": [
      {
        "input": "broker,client,contract_id,task_type,doc_names\nalice@company.com,John Doe,33333,prove-employment,important-doc-pdf\nalice@company.com,John Doe,33333,prove-employment,paperwork-pdf\nalice@company.com,John Doe,33333,submit-application,blah-pdf\nalice@company.com,John Doe,00000,prove-employment,test-pdf\nalice@company.com,John Doe,00000,submit-application,test-pdf\nalice@company.com,Jane Smith,11111,prove-employment,important-doc-pdf\nalice@company.com,Jane Smith,11111,submit-application,paperwork-pdf\nalice@company.com,Jane Smith,11111,submit-application,unimportant-pdf\nbob@company.com,John Doe,66666,submit-application,pdf-I-pdf\nbob@company.com,John Doe,77777,submit-application,pdf-J-pdf",
        "output": [
          {
            "broker": "alice@company.com",
            "clients": [
              {
                "client": "John Doe",
                "contracts": [
                  {
                    "contract_id": "33333",
                    "documents": [
                      {
                        "task_type": "prove-employment",
                        "doc_names": [
                          "important-doc-pdf",
                          "paperwork-pdf"
                        ]
                      },
                      {
                        "task_type": "submit-application",
                        "doc_names": [
                          "blah-pdf"
                        ]
                      }
                    ]
                  },
                  {
                    "contract_id": "00000",
                    "documents": [
                      {
                        "task_type": "prove-employment",
                        "doc_names": [
                          "test-pdf"
                        ]
                      },
                      {
                        "task_type": "submit-application",
                        "doc_names": [
                          "test-pdf"
                        ]
                      }
                    ]
                  }
                ]
              },
              {
                "client": "Jane Smith",
                "contracts": [
                  {
                    "contract_id": "11111",
                    "documents": [
                      {
                        "task_type": "prove-employment",
                        "doc_names": [
                          "important-doc-pdf"
                        ]
                      },
                      {
                        "task_type": "submit-application",
                        "doc_names": [
                          "paperwork-pdf",
                          "unimportant-pdf"
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "broker": "bob@company.com",
            "clients": [
              {
                "client": "John Doe",
                "contracts": [
                  {
                    "contract_id": "66666",
                    "documents": [
                      {
                        "task_type": "submit-application",
                        "doc_names": [
                          "pdf-I-pdf"
                        ]
                      }
                    ]
                  },
                  {
                    "contract_id": "77777",
                    "documents": [
                      {
                        "task_type": "submit-application",
                        "doc_names": [
                          "pdf-J-pdf"
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 65175826
  },
  {
    "context": [
      "parameters=($(jq -r '.Parameters | keys[] as $k | \"\\($k)=\\(.[$k])\"' \"dev.json\"))",
      "The problem is one array value is `cron(0 20-6 * * ? *)`.",
      "The deploy.sh will convert the `*` as current directory file names such as `cron(0 20-6 CODEOWNERS README.md CODEOWNERS README.md ? *)`"
    ],
    "utterance": "Produce key=value pairs from the 'Parameters' object such that a value containing '*' does not trigger wildcard expansion when used in the shell.",
    "expressions": [
      ".Parameters | keys[] as $k | \"\u001b[31m\\($k)=\\(.[$k]|@sh)\u001b[0m\""
    ],
    "data": [
      {
        "input": {
          "Parameters": {
            "Environment": "dev",
            "CrawlerScheduleExpression": "cron(0 20-6 * * ? *)"
          },
          "Tags": {
            "Severity": "High",
            "Environment": "dev",
            "DeletionPolicy": "Retain"
          }
        },
        "output": [
          "Environment='dev'",
          "CrawlerScheduleExpression='cron(0 20-6 * * ? *)'"
        ]
      }
    ],
    "identifier": 65302856
  },
  {
    "context": [
      "I wanted just the files in 'Schemas' for 'Sys1'. The desired output would be:\n\n``` [\"Filename1S\",\"Filename2S\"] ```\n\nfrom this section:\n\n```\nInventory > Sys1 > folder > Schemas\n```",
      "You don't need a `select()` at all here. Consider:\n\n```\njq '.DBInventory.Inventory[0][].folder[].Schemas?.files // empty'\n```",
      "or simply:\n```\ntry (.DBInventory.Inventory[].Sys1.folder[].Schemas.files) // empty\n```"
    ],
    "utterance": "Retrieve all file names listed under 'Schemas' in 'Sys1'.",
    "expressions": [
      ".DBInventory.Inventory[0][].folder[].Schemas?.files // empty",
      ".DBInventory.Inventory[].Sys1.folder[].Schemas.files // empty",
      "try (.DBInventory.Inventory[].Sys1.folder[].Schemas.files) // empty"
    ],
    "data": [
      {
        "input": {
          "DBInventory": {
            "InventoryID": "ABSCBD",
            "Inventory": [
              {
                "Sys1": {
                  "folder": [
                    {
                      "Scripts": {
                        "files": [
                          "FileName1O",
                          "FileName2O"
                        ]
                      }
                    },
                    {
                      "Schemas": {
                        "files": [
                          "FileName1S",
                          "FileName2S"
                        ]
                      }
                    },
                    {
                      "StoredProcedures": {
                        "files": [
                          "FileName1SP",
                          "FileName2SP",
                          "FileName3SP"
                        ]
                      }
                    },
                    {
                      "Tables": {
                        "files": [
                          "FileName1T",
                          "FileName2T"
                        ]
                      }
                    }
                  ]
                }
              },
              {
                "Sys2": {
                  "folder": [
                    {
                      "MaintScripts": {
                        "files": [
                          "FileName1",
                          "FileName2"
                        ]
                      }
                    },
                    {
                      "Schemas": {
                        "files": [
                          "FileName1",
                          "FileName2"
                        ]
                      }
                    },
                    {
                      "StoredProcedures": {
                        "files": [
                          "FileName1",
                          "FileName2"
                        ]
                      }
                    },
                    {
                      "Tables": {
                        "files": [
                          "FileName1",
                          "FileName2"
                        ]
                      }
                    },
                    {
                      "ExternalTables": {
                        "files": [
                          "FileName1",
                          "FileName2"
                        ]
                      }
                    },
                    {
                      "Scripts": {
                        "files": [
                          "FileName1",
                          "FileName2"
                        ]
                      }
                    },
                    {
                      "Views": {
                        "files": [
                          "FileName1v",
                          "FileName2v"
                        ]
                      }
                    }
                  ]
                }
              }
            ]
          }
        },
        "output": [
          "FileName1S",
          "FileName2S"
        ]
      }
    ],
    "identifier": 65296079
  },
  {
    "context": [
      "I am working with this [example][1] for the following input JSON document using `cat input.json | jq --arg REGION \"ap-south-1\" --arg ACCOUNTID \"46311000000\" --arg QNAME \"orders\"`. However, the output does not show any transformation.",
      "With JQ 1.6, you can use **$ARGS** builtin variable in conjunction with **gsub** and a named capturing group to achieve this.",
      "walk(\n  if type == \"string\" \n  then gsub(\"\\\\$(?<<name>\\\\w+)\"; $ARGS.named[.name])\n  else . end\n)"
    ],
    "utterance": "Replace all string values with variables in the form $REGION, $ACCOUNTID, or $QNAME in the data structure with the corresponding argument values: REGION=ap-south-1, ACCOUNTID=46311000000, QNAME=orders.",
    "expressions": [
      "walk(if type == \"string\" then gsub(\"\\$(?<name>\\w+)\"; $ARGS.named[.name]) else . end)"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-10-17",
          "Id": "policy-15122020",
          "Statement": [
            {
              "Sid": "1",
              "Effect": "Allow",
              "Principal": {
                "AWS": "*"
              },
              "Action": [
                "sqs:ReceiveMessage",
                "sqs:SendMessage"
              ],
              "Resource": "arn:aws:sqs:$REGION:$ACCOUNTID:$QNAME",
              "Condition": {
                "StringEquals": {
                  "aws:SourceAccount": "$ACCOUNTID"
                }
              }
            }
          ]
        },
        "output": {
          "Version": "2012-10-17",
          "Id": "policy-15122020",
          "Statement": [
            {
              "Sid": "1",
              "Effect": "Allow",
              "Principal": {
                "AWS": "*"
              },
              "Action": [
                "sqs:ReceiveMessage",
                "sqs:SendMessage"
              ],
              "Resource": "arn:aws:sqs:ap-south-1:46311000000:orders",
              "Condition": {
                "StringEquals": {
                  "aws:SourceAccount": "46311000000"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 65299626
  },
  {
    "context": [
      "I have a json with repeated parent objects. I need to merge all childs under one parent using jq in bash.",
      "I need to take a single parent item and merge it with all child items.",
      "Is it possible with jq?",
      "jq has a handy group-by operator.",
      "the goal of this question is to know how to perform grouping, and the exact output format is secondary, an example of such grouping would be:",
      "jq 'group_by(.source?.id // \"\") | [.[] | {\"\\(.[0].source?.id)\": [.[].target.id]}] | add'"
    ],
    "utterance": "Group all items by parent id and collect their child target ids under each parent.",
    "expressions": [
      "group_by(.source?.id // \"\") | [.[] | {\"\\(.[0].source?.id)\": [.[].target.id]}] | add"
    ],
    "data": [
      {
        "input": [
          {
            "source": null,
            "target": {
              "id": 1
            }
          },
          {
            "source": {
              "id": 1
            },
            "target": {
              "id": 2
            }
          },
          {
            "source": {
              "id": 1
            },
            "target": {
              "id": 3
            }
          },
          {
            "source": {
              "id": 1
            },
            "target": {
              "id": 10
            }
          },
          {
            "source": {
              "id": 1
            },
            "target": {
              "id": 11
            }
          }
        ],
        "output": {
          "1": [
            2,
            3,
            10,
            11
          ],
          "null": [
            1
          ]
        }
      }
    ],
    "identifier": 65307236
  },
  {
    "context": [
      "I would like to get \"current\" config with bash and jq.",
      "Is there a direct jq filter/key trick to obtain the same result?",
      "You just need to use the `.[]` [object value iterator][1] syntax to first let `.current` expand to its constituent value and then the expression becomes `.\"config1\"` which matches the `config1` key",
      "jq '[.current]'",
      "jq '[.current]'"
    ],
    "utterance": "Select the object whose key matches the value of the current field.",
    "expressions": [
      ".[.current]"
    ],
    "data": [
      {
        "input": {
          "current": "config1",
          "config1": {
            "p1": "val1-1",
            "p2": "val1-2"
          },
          "config2": {
            "p1": "val2-1",
            "p2": "val2-2"
          }
        },
        "output": {
          "p1": "val1-1",
          "p2": "val1-2"
        }
      }
    ],
    "identifier": 65323254
  },
  {
    "context": [
      "I have a command that outputs multiple simple json objects like this ... {\"a\": \"b\"} {\"a\": \"e\"} {\"a\": \"f\"}",
      "Now I would like to get it formatted like this:\n{\n  \"a\": [\"b\", \"e\", \"f\"]\n}",
      "jq --slurp --compact-output '{ a: map(.a) }' foo.txt",
      "$ jq -n '.a = [inputs.a]' foo.txt"
    ],
    "utterance": "Combine several objects, each with an 'a' property, into a single object whose 'a' property is an array of all values from those objects.",
    "expressions": [
      "jq --slurp '{ a: map(.a) }' foo.txt",
      "jq -n '.a = [inputs.a]' foo.txt"
    ],
    "data": [
      {
        "input": [
          {
            "a": "b"
          },
          {
            "a": "e"
          },
          {
            "a": "f"
          }
        ],
        "output": {
          "a": [
            "b",
            "e",
            "f"
          ]
        }
      }
    ],
    "identifier": 65310051
  },
  {
    "context": [
      "batch=$(jq --argjson json \"$json\" '. + [$json]' <<< \"$batch\")",
      "If there were other actions to be taken on each data element that jq cannot readily handle:\nbatch=$(\n   (\n       for data_object in \"${data[@]}\"; do\n           jq -n --argjson inf \"$data_object\" '{data: $inf}'\n       done\n   ) | jq -s .\n)"
    ],
    "utterance": "Append an object to an existing array variable, where the object is generated programmatically.",
    "expressions": [
      "jq --argjson json \"$json\" '. + [$json]' <<< \"$batch\""
    ],
    "data": [
      {
        "input": [
          {
            "data": 10.4
          },
          {
            "data": 100.23
          }
        ],
        "output": [
          {
            "data": 10.4
          },
          {
            "data": 100.23
          },
          {
            "data": 20.02
          }
        ]
      }
    ],
    "identifier": 65311888
  },
  {
    "context": [
      "I am trying to say 'give me all partitions where mount is not null, sort them by mount, but include their device name in the output'.",
      "However, I would like to pull in the parent device as such:\n\n{\"type\": \"xfs\", \"mount\": \"/\", \"device\": \"/sdb\"}\n{\"type\": \"ext4\", \"mount\": \"/boot\", \"device\": \"/sda\"}\n{\"type\": \"fat32\", \"mount\": \"/efi\", \"device\": \"/sda\"}",
      "You can enrich the partitions with the device and filter the enriched partitions:\n```\njq '.disk[]\n    | .device as $d\n    | .partitions[] += { device: $d }\n    | .partitions[]\n    | select(.mount != null)\n    '\n```",
      "Just get a copy of it, select partitions, and add them together.\n```\n.disk\n| map((.partitions[] | select(.mount != null)) + {device})\n| sort_by(.mount)[]\n```"
    ],
    "utterance": "List all partitions with a non-null mount, including their corresponding device name, and sort the results by mount.",
    "expressions": [
      ".disk[] | .device as $d | .partitions[] += { device: $d } | .partitions[] | select(.mount != null)",
      ".disk | map((.partitions[] | select(.mount != null)) + {device}) | sort_by(.mount)[]"
    ],
    "data": [
      {
        "input": {
          "disk": [
            {
              "device": "/dev/sda",
              "partitions": [
                {
                  "type": "fat32",
                  "mount": "/efi"
                },
                {
                  "type": "ext4",
                  "mount": "/boot"
                }
              ]
            },
            {
              "device": "/dev/sdb",
              "partitions": [
                {
                  "type": "xfs",
                  "mount": "/"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "type": "xfs",
            "mount": "/",
            "device": "/dev/sdb"
          },
          {
            "type": "ext4",
            "mount": "/boot",
            "device": "/dev/sda"
          },
          {
            "type": "fat32",
            "mount": "/efi",
            "device": "/dev/sda"
          }
        ]
      }
    ],
    "identifier": 65310490
  },
  {
    "context": [
      "I was just wondering if there is a way to reference the query we are doing?",
      "is there some way I can get a look at the string that jq parses?",
      "If you use the -n command-line option, then the JSON that jq is currently parsing is none other than `input`; otherwise, it is `.`.",
      "So you could for example write:",
      "jq '. as $json | ....'",
      "where .... can contain `$json`."
    ],
    "utterance": "Retrieve the data currently being parsed during query execution.",
    "expressions": [
      ". as $json | $json"
    ],
    "identifier": 65328491
  },
  {
    "context": [
      "And in my real life scenario case that `jq` selector is really long (think about 10 exports), how can I break them into multiple lines or something? I tried using `\\` as a separator at the end of the lines but it doesn&#39;t work unfortunately.",
      "jq -r '\n  \"export\"+(\n    to_entries|\n      map(\n          \" \" +\n          (.key|ascii_upcase) +\n          \"=\" +\n          (.value|@sh)\n        ) | add\n      )\n' <<<'{\"foo\":\"John\",\"bar\":\"Smith\"}'"
    ],
    "utterance": "Output a long assignment list where each key's value is exported as a shell variable, with the expression formatted across multiple lines for readability.",
    "expressions": [
      "\"export \"+(to_entries|map((.key|ascii_upcase)+\"=\"+(.value|@sh))|.[])",
      "\"export\"+(\n  to_entries|\n    map(\n        \" \" +\n        (.key|ascii_upcase) +\n        \"=\" +\n        (.value|@sh)\n      ) | add\n    )"
    ],
    "data": [
      {
        "input": {
          "foo": "John",
          "bar": "Smith"
        }
      }
    ],
    "identifier": 65328195
  },
  {
    "context": [
      "cat test1.json | jq -r '.entries | map(.id +\" | \"+ .title) | join(\"\\n\")'",
      "So I modified the command to for cmd.exe (Windows 10):",
      "cat test1.json | jq -r \".[] | map(.id +\\\" | \\\" + .title) | join(\\\" \\n \\\" )\"",
      "One of the important details that is missing is that the caret character `^` serves as an escape character for symbols such as `|`. So you could write:",
      ".entries ^| map(.id +^\" ^| ^\"+ .title) ^| join(^\"\\n^\")",
      "Alternatively - and a bit more mysteriously - you could write:",
      "\".entries | map(.id +\\\" ^| \\\"+ .title) | join(\\\"\\n\\\")\""
    ],
    "utterance": "Print each entry's id and title separated by ' | ', joining all entries with newlines.",
    "expressions": [
      ".entries | map(.id + \" | \" + .title) | join(\"\\n\")",
      ".entries ^| map(.id +^\" ^| ^\"+ .title) ^| join(^\"\\n^\")",
      ".entries | map(.id +\\\" ^| \\\"+ .title) | join(\\\"\\n\\\")"
    ],
    "data": [
      {
        "input": {
          "entries": [
            {
              "duration": 478,
              "id": "uCPPyitzI",
              "title": "Why | TV",
              "description": null,
              "uploader": null,
              "view_count": null,
              "ie_key": "Youtube",
              "url": "uCPPyitzI",
              "_type": "url_transparent"
            },
            {
              "duration": 245,
              "id": "F9ClW8Dv0",
              "title": "Kejrixxxx | TV",
              "description": null,
              "uploader": null,
              "view_count": null,
              "ie_key": "Youtube",
              "url": "F9ClW8Dv0",
              "_type": "url_transparent"
            },
            {
              "duration": 990,
              "id": "JchBXwZ8o",
              "title": "Battle Of xxxx: | Dr. cccccc | TV",
              "description": null,
              "uploader": null,
              "view_count": null,
              "ie_key": "Youtube",
              "url": "JchBXwZ8o",
              "_type": "url_transparent"
            },
            {
              "duration": 1178,
              "id": "4x9dWcG2c",
              "title": "Dirty Politics | Dr. xxxxx | TV",
              "description": null,
              "uploader": null,
              "view_count": null,
              "ie_key": "Youtube",
              "url": "4x9dWcd2c",
              "_type": "url_transparent"
            }
          ],
          "uploader_id": "xxxx",
          "webpage_url": "https://www.youtube.com/playlist?list=xxx",
          "title": ".aabbcc",
          "extractor": "xxx:xxx",
          "uploader": "xxxxxx",
          "uploader_url": "https://www.youtube.com/channel/xxxx",
          "id": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
          "extractor_key": "xxxxx",
          "webpage_url_basename": "xxxxxx",
          "_type": "playlist"
        },
        "output": "uCPPyitzI | Why | TV\nF9ClW8Dv0 | Kejrixxxx | TV\nJchBXwZ8o | Battle Of xxxx: | Dr. cccccc | TV\n4x9dWcG2c | Dirty Politics | Dr. xxxxx | TV"
      }
    ],
    "identifier": 65317996
  },
  {
    "context": [
      "$ cat sax.json | jq  '.sax[] | select(.name | contains(\"mex\"))' | jq .id",
      "\"e49887\"\n\"e6de26\"\n\"6cc093\"\n\"89e0fe\"",
      "In the first query, there is no need to call jq twice; you can also avoid the UUOC:\n```\n< sax.json jq '.sax[] | select(.name | contains(\"mex\")) | .id' \n```"
    ],
    "utterance": "Extract the id fields for all elements where name contains the substring 'mex'.",
    "expressions": [
      ".sax[] | select(.name | contains(\"mex\")) | .id"
    ],
    "data": [
      {
        "input": {
          "sax": [
            {
              "name": "mex20",
              "links": {
                "self": "http://website/catalog/sax/e49887"
              },
              "tags": null,
              "enabled": true,
              "id": "e49887",
              "description": null
            },
            {
              "name": "mex15",
              "links": {
                "self": "http://website/catalog/sax/e6de26"
              },
              "tags": null,
              "enabled": true,
              "id": "e6de26",
              "description": null
            },
            {
              "name": "mex56",
              "links": {
                "self": "http://website/catalog/sax/6cc093"
              },
              "tags": null,
              "enabled": true,
              "id": "6cc093",
              "description": null
            },
            {
              "name": "mex82",
              "links": {
                "self": "http://website/catalog/sax/89e0fe"
              },
              "tags": null,
              "enabled": true,
              "id": "89e0fe",
              "description": null
            }
          ]
        },
        "output": [
          "e49887",
          "e6de26",
          "6cc093",
          "89e0fe"
        ]
      }
    ],
    "identifier": 65330282
  },
  {
    "context": [
      "So how do I grab specific values from the first X elements of an array?  (*I dont really need the keys, just the values.*)",
      "To select just the values as CSV:\n.properties.periods[:3][]\n| {shortForecast, temperature}\n| [.[]]\n| @csv",
      "You might like to use `@tsv` instead, or `join(\" \")`, or ....",
      "Sample:\n\"2020-12-16T14:00:00-05:00\" 30 \"Chance Light Snow\"\n\"2020-12-16T15:00:00-05:00\" 30 \"Snow\"\n\"2020-12-16T16:00:00-05:00\" 29 \"Heavy Snow\""
    ],
    "utterance": "Extract the startTime, temperature, and shortForecast values from the first three elements of the periods array, with each element's values on a single line.",
    "expressions": [
      ".properties.periods[:3][] | [.startTime, .temperature, .shortForecast] | @tsv",
      ".properties.periods[:3][] | [.startTime, .temperature, .shortForecast] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "properties": {
            "periods": [
              {
                "number": 1,
                "startTime": "2020-12-16T14:00:00-05:00",
                "temperature": 30,
                "shortForecast": "Chance Light Snow"
              },
              {
                "number": 2,
                "startTime": "2020-12-16T15:00:00-05:00",
                "temperature": 30,
                "shortForecast": "Snow"
              },
              {
                "number": 3,
                "startTime": "2020-12-16T16:00:00-05:00",
                "temperature": 29,
                "shortForecast": "Heavy Snow"
              }
            ]
          }
        },
        "output": "2020-12-16T14:00:00-05:00\t30\tChance Light Snow\n2020-12-16T15:00:00-05:00\t30\tSnow\n2020-12-16T16:00:00-05:00\t29\tHeavy Snow"
      }
    ],
    "identifier": 65330108
  },
  {
    "context": [
      "$ apiDefinitionString=`jq -r '. | tojson' api.json`",
      "$ jq --arg definition \"$apiDefinitionString\" '.apiDefinition = $definition' api-new.json > api-spec.json",
      "Even though the --argfile option is deprecated, I would suggest you begin by trying to use it in the simplest possible way, e.g. by first writing the contents of your shell variable to a file, perhaps along the lines of:",
      "jq -r 'tojson' api.json > out.tmp",
      "jq --argfile definition out.tmp '.apiDefinition = $definition' api-new.json > api-spec.json",
      "Better yet, you should be able to combine the two calls to jq into one:",
      "jq --argfile definition api.json '.apiDefinition = ($definition|tojson)' api-new.json > api-spec.json"
    ],
    "utterance": "Set the .apiDefinition field in one file to the serialized contents of another, regardless of input size limitations.",
    "expressions": [
      "jq --argfile definition api.json '.apiDefinition = ($definition|tojson)' api-new.json > api-spec.json"
    ],
    "identifier": 65350355
  },
  {
    "context": [
      "I need to execute `cat build.json | jq '.Stage*.Name'` for 5 times, where `*` is a number from 1 to 5.",
      "cat build.json | jq '.Stage${c}.Name'",
      "jq: error: syntax error, unexpected '$', expecting $end (Unix shell quoting issues?) at <top-level>, line 1:\n.Stage${c}.Name      \njq: 1 compile error",
      "jq --arg i $i '.data.stage'$i'.name' < json.json",
      "Producing the following output:\ni: 1\n1\ni: 2\n2\ni: 3\n3\ni: 4\n4\ni: 5\n5"
    ],
    "utterance": "Extract the name value for each stage numbered from 1 to 5 by dynamically constructing the key using a shell loop variable.",
    "expressions": [
      ".data[\"stage\",",
      "jq --arg i \"$i\" '.data[\"stage\",",
      "jq --arg i \"$i\" '.data[\"stage\",",
      "jq --arg i \"$i\" \".data[\\\"stage${i}\\\"].name\""
    ],
    "data": [
      {
        "input": {
          "data": {
            "stage1": {
              "name": 1
            },
            "stage2": {
              "name": 2
            },
            "stage3": {
              "name": 3
            },
            "stage4": {
              "name": 4
            },
            "stage5": {
              "name": 5
            }
          }
        },
        "output": [
          1,
          2,
          3,
          4,
          5
        ]
      }
    ],
    "identifier": 65337689
  },
  {
    "context": [
      "I want to select `hero` and `superpowers`, and keep only `name` and `des` keys within `superpowers`, like:\n \n[\n  {\n    \"hero\": \"Superman\",\n    \"superpowers\": [\n      {\n        \"name\": \"speed\",\n        \"des\": \"Faster than a speeding bullet.\"\n      },\n      {\n        \"name\": \"strength\",\n        \"des\": \"More powerful than a locomotive.\"\n      }\n    ]\n  },\n  {\n    \"hero\": \"Batman\",\n    \"superpowers\": [\n ...",
      "`jq '[.[] | {hero, superpowers: [ .superpowers[] | {name, des} ] } ]'`"
    ],
    "utterance": "For each element, return only the hero name and an array of each superpower's name and description.",
    "expressions": [
      "[.[] | {hero, superpowers: [ .superpowers[] | {name, des} ] } ]"
    ],
    "data": [
      {
        "input": [
          {
            "hero": "Superman",
            "id": "123",
            "realName": "Clark Kent",
            "age": "?",
            "superpowers": [
              {
                "name": "speed",
                "num": "1",
                "des": "Faster than a speeding bullet.",
                "value": "50"
              },
              {
                "name": "strength",
                "num": "2",
                "des": "More powerful than a locomotive.",
                "value": "100"
              }
            ],
            "weakness": "kryptonite"
          },
          {
            "hero": "Batman",
            "id": "456",
            "realName": "Bruce Wayne",
            "age": "?",
            "superpowers": [
              {
                "name": "intelligence",
                "num": "1",
                "des": "World's greatest detective.",
                "value": "99"
              }
            ],
            "weakness": "none"
          }
        ],
        "output": [
          {
            "hero": "Superman",
            "superpowers": [
              {
                "name": "speed",
                "des": "Faster than a speeding bullet."
              },
              {
                "name": "strength",
                "des": "More powerful than a locomotive."
              }
            ]
          },
          {
            "hero": "Batman",
            "superpowers": [
              {
                "name": "intelligence",
                "des": "World's greatest detective."
              }
            ]
          }
        ]
      }
    ],
    "identifier": 65366371
  },
  {
    "context": [
      "my bash script",
      "array=( \"111\" \"222\" etc...)",
      "for i in \"${array[@]}\"; do\n   my_power=$(\n      curl -s -X GET -H \"Content-Type: application/json\" http://website/list |\n         jq -r '.magic[] | select(.id == \"$i\") | .name'\n   )",
      "$magic_array is empty. The echo prints nothing.",
      "$ curl -s -X GET -H \"Content-Type: application/json\" http://website/list |\n   jq -r '.magic[] | select(.id == \"111\") | .name'\nfly",
      "In the jq program, $i refers to the jq variable $i, not the bash variable $i.",
      "jq -r --arg i \"$i\" '.magic[] | select(.id == $i) | .name'"
    ],
    "utterance": "Retrieve the name value where id matches a given value, using that value from a bash variable in a loop.",
    "expressions": [
      ".magic[] | select(.id == $i) | .name"
    ],
    "data": [
      {
        "input": {
          "magic": [
            {
              "name": "fly",
              "links": {
                "self": "http://website/111"
              },
              "tags": null,
              "enabled": true,
              "id": "111",
              "description": null
            },
            {
              "name": "sleep",
              "links": {
                "self": "http://website/222"
              },
              "tags": null,
              "enabled": true,
              "id": "222",
              "description": null
            }
          ],
          "links": {
            "self": "http://website/list",
            "previous": null,
            "next": null
          }
        },
        "output": "fly"
      }
    ],
    "identifier": 65382515
  },
  {
    "context": [
      "I want to display the two values in each object under the appservice array, and list both values per block on one line along with the relevant IP and name.",
      "and I want to end up like this:\n\n192.168.1.2 resourcegroup1 resource1 username1\n192.168.1.2 resourcegroup2 resource2 username1\n\n192.168.1.3 resourcegroup5 resource5 username2\n192.168.1.3 resourcegroup6 resource6 username2",
      "jq -r '.allow[] | {ipstart,name} + .resources[].appservice[]? | \"\\(.ipstart) \\(.resourcegroup) \\(.resource) \\(.name)\"' file.json",
      "jq -r '.allow[] | [.ipstart]  + (.resources[].appservice[]? | [.resourcegroup, .resource])  + [.name] | join(\" \") ' file.json"
    ],
    "utterance": "Output a line for each appservice entry containing the corresponding ipstart, resourcegroup, resource, and name values from each allow object.",
    "expressions": [
      ".allow[] | {ipstart,name} + .resources[].appservice[]? | \"\\(.ipstart) \\(.resourcegroup) \\(.resource) \\(.name)\"",
      ".allow[] | [.ipstart] + (.resources[].appservice[]? | [.resourcegroup, .resource]) + [.name] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "allow": [
            {
              "name": "username1",
              "scm": "true",
              "ipstart": "192.168.1.2",
              "ipend": "192.168.1.2",
              "cidr": "/32",
              "resources": [
                {
                  "appservice": [
                    {
                      "resourcegroup": "resourcegroup1",
                      "resource": "resource1"
                    },
                    {
                      "resourcegroup": "resourcegroup2",
                      "resource": "resource2"
                    }
                  ]
                },
                {
                  "sqlserver": [
                    {
                      "resourcegroup": "resourcegroup3",
                      "resource": "resource3"
                    },
                    {
                      "resourcegroup": "resourcegroup4",
                      "resource": "resource4"
                    }
                  ]
                }
              ]
            },
            {
              "name": "username2",
              "scm": "true",
              "ipstart": "192.168.1.3",
              "ipend": "192.168.1.3",
              "cidr": "/32",
              "resources": [
                {
                  "appservice": [
                    {
                      "resourcegroup": "resourcegroup5",
                      "resource": "resource5"
                    },
                    {
                      "resourcegroup": "resourcegroup6",
                      "resource": "resource6"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "192.168.1.2 resourcegroup1 resource1 username1",
          "192.168.1.2 resourcegroup2 resource2 username1",
          "192.168.1.3 resourcegroup5 resource5 username2",
          "192.168.1.3 resourcegroup6 resource6 username2"
        ]
      }
    ],
    "identifier": 65341026
  },
  {
    "context": [
      "Given the data below, what jq invocation would return the French name of planets whose moon(s) have been spoiled?",
      "The program below selects planets whose moons have all been spoiled. As each *parameter* is a name-value pair, we can use `from_entries` to transform the array of parameters into an object and retrieve the *unspoiled* status with just `.unspoiled`, and thus avoid another `select` to find the parameter we're interested in.",
      "If a single spoiled moon is enough, change `all` to `any`."
    ],
    "utterance": "Return the French name of any planet that has at least one moon with the parameter 'unspoiled' set to 'no'.",
    "expressions": [
      ".Planets[] | select(.satellites | any(.parameters | from_entries .unspoiled == \"no\")) .names.french"
    ],
    "data": [
      {
        "input": {
          "kind": "solarsystem",
          "name": "Sol",
          "Planets": [
            {
              "kind": "habitable",
              "names": {
                "english": "Earth",
                "french": "Terre"
              },
              "satellites": [
                {
                  "name": "The Moon",
                  "parameters": [
                    {
                      "name": "diameter",
                      "intValue": "3476"
                    },
                    {
                      "name": "diameter_units",
                      "value": "km"
                    },
                    {
                      "name": "unspoiled",
                      "value": "no"
                    }
                  ]
                }
              ]
            },
            {
              "kind": "uninhabitable",
              "names": {
                "english": "Mars",
                "french": "Mars"
              },
              "satellites": [
                {
                  "name": "Phobos",
                  "parameters": [
                    {
                      "name": "diameter",
                      "intValue": "2200"
                    },
                    {
                      "name": "diameter_units",
                      "value": "m"
                    },
                    {
                      "name": "unspoiled",
                      "value": "yes"
                    }
                  ]
                },
                {
                  "name": "Deimos",
                  "parameters": [
                    {
                      "name": "diameter",
                      "intValue": "1200"
                    },
                    {
                      "name": "diameter_units",
                      "value": "m"
                    },
                    {
                      "name": "unspoiled",
                      "value": "yes"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "Terre"
      }
    ],
    "identifier": 65388388
  },
  {
    "context": [
      "Can you please show me how to define `reduce` operation using `foreach`?",
      "reduce SOURCE as $VAR (INIT; REDUCTION) is equivalent to [ foreach SOURCE as $VAR (INIT; REDUCTION; .) ] | last"
    ],
    "utterance": "Produce the same result as a reduce operation by using foreach so that iterating over a source, an initial value, and a reduction function yields the final accumulated value.",
    "expressions": [
      "[ foreach SOURCE as $VAR (INIT; REDUCTION; .) ] | last"
    ],
    "identifier": 65391586
  },
  {
    "context": [
      "Now, I want to display some lines :",
      "- network",
      "- ipAddressTab",
      "- foo1",
      "- foo3",
      "Some one to show me how to display each elements that I need ?",
      "First select the fields, then modify `ipAddressTab`.",
      "map({network, ipAddressTab, full}\n    | .ipAddressTab[] |= {foo1, foo3})"
    ],
    "utterance": "Show only the fields network and ipAddressTab, but within ipAddressTab display only foo1 and foo3 for each element.",
    "expressions": [
      "map({network, ipAddressTab, full} | .ipAddressTab[] |= {foo1, foo3})"
    ],
    "data": [
      {
        "input": [
          {
            "network": "X.X.X.1",
            "defaultGateway": "X.X.X.X",
            "ipAddressTab": [
              {
                "foo1": "10.0.0.1",
                "foo2": "network",
                "foo3": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.2",
                "foo2": "network",
                "foo3": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.3",
                "foo2": "network",
                "foo3": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.4",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.5",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.6",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.7",
                "foo3": "available"
              }
            ],
            "full": false,
            "id": "xxx"
          },
          {
            "network": "X.X.X.2",
            "defaultGateway": "X.X.X.X",
            "ipAddressTab": [
              {
                "foo1": "10.0.0.1",
                "foo2": "network",
                "foo3": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.2",
                "foo2": "network",
                "foo3": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.3",
                "foo2": "network",
                "foo3": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.4",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.5",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.6",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.7",
                "foo3": "available"
              }
            ],
            "full": false,
            "id": "xxx"
          }
        ],
        "output": [
          {
            "network": "X.X.X.1",
            "ipAddressTab": [
              {
                "foo1": "10.0.0.1",
                "foo3": "reserved"
              },
              {
                "foo1": "10.0.0.2",
                "foo3": "reserved"
              },
              {
                "foo1": "10.0.0.3",
                "foo3": "reserved"
              },
              {
                "foo1": "10.0.0.4",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.5",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.6",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.7",
                "foo3": "available"
              }
            ],
            "full": false
          },
          {
            "network": "X.X.X.2",
            "ipAddressTab": [
              {
                "foo1": "10.0.0.1",
                "foo3": "reserved"
              },
              {
                "foo1": "10.0.0.2",
                "foo3": "reserved"
              },
              {
                "foo1": "10.0.0.3",
                "foo3": "reserved"
              },
              {
                "foo1": "10.0.0.4",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.5",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.6",
                "foo3": "available"
              },
              {
                "foo1": "10.0.0.7",
                "foo3": "available"
              }
            ],
            "full": false
          }
        ]
      }
    ],
    "identifier": 65277686
  },
  {
    "context": [
      "How can I extract the value `\"0.9212835072256392\"` from the `value` array with jq?",
      "I tried different solutions such as `jq '.result.value[1]'`. This gives me the error message `jq: error (at <stdin>:1): Cannot index array with string \"value\"`.",
      "If you can use *hardcoded* index in the `value` array, you can use:\n```\n.result[] | .value[1]\n```",
      "Or, as [...] suggested, using `.value[-1]` to get the **last index**:\n```\n.result[] | .value[-1]\n```"
    ],
    "utterance": "Extract the string value at index 1 from the value array inside each object in the result array.",
    "expressions": [
      ".result[] | .value[1]",
      ".result[] | .value[-1]"
    ],
    "data": [
      {
        "input": {
          "resultType": "vector",
          "result": [
            {
              "metric": {},
              "value": [
                1608561506.684,
                "0.9212835072256392"
              ]
            }
          ]
        },
        "output": "0.9212835072256392"
      }
    ],
    "identifier": 65395098
  },
  {
    "context": [
      "how do I add new field to each object, which value would be index in array? Producing:\r\n\r\n    [\r\n      {\r\n        \"a\": 1,\r\n        \"index\": 0\r\n      },\r\n      {\r\n        \"a\": 2,\r\n        \"index\": 1\r\n      },\r\n      {\r\n        \"a\": 7,\r\n        \"index\": 2\r\n      }\r\n    ]",
      "Using `reduce`, without disassembling/reassembling the input:\r\n```\r\nreduce range(length) as $index (.; .[$index] += {$index})\r\n```",
      "Store the structure into a variable, then use `keys` to get the indices, retrieve the corresponding object from the variable using the index and add the index to it:\r\n\r\n    jq '[ . as $d | keys[] | $d[.] + {index:.} ]' file.json",
      "jq 'to_entries | map(.value+{index:.key})' file.json",
      "### results\r\n```json\r\n[\r\n  {\r\n    \"a\": 1,\r\n    \"index\": 0\r\n  },\r\n  {\r\n    \"a\": 2,\r\n    \"index\": 1\r\n  },\r\n  {\r\n    \"a\": 7,\r\n    \"index\": 2\r\n  }\r\n]\r\n```"
    ],
    "utterance": "Add a field named \"index\" to each object in the array, where the value is the object's position in the array.",
    "expressions": [
      "reduce range(length) as $index (.; .[$index] += {$index})",
      "[ . as $d | keys[] | $d[.] + {index:.} ]",
      "to_entries | map(.value + {index: .key})"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "a": 2
          },
          {
            "a": 7
          }
        ],
        "output": [
          {
            "a": 1,
            "index": 0
          },
          {
            "a": 2,
            "index": 1
          },
          {
            "a": 7,
            "index": 2
          }
        ]
      }
    ],
    "identifier": 65391557
  },
  {
    "context": [
      "How do a query a variable which has json value using jq.",
      "The first command assigns the JSON to the `activity` variable.",
      "The second command, need's to be altert to 'feed' the json through the pipe since in `activityCause=$activity` `$activity` is interpreted as a command, and not the JSON;",
      "activityCause=$(jq -r '.Activities[].Cause' <<< \"$activity\")",
      "activityCause=$(echo \"$activity\" | jq -r '.Activities[].Cause')"
    ],
    "utterance": "Extract the value(s) of the Activities[].Cause property from data stored in a shell variable named activity.",
    "expressions": [
      "jq -r '.Activities[].Cause' <<< \"$activity\"",
      "echo \"$activity\" | jq -r '.Activities[].Cause'"
    ],
    "identifier": 65408895
  },
  {
    "context": [
      "Now I&#39;m looking for a tip to count and display some values. For example, I would like to display the number of reserved, allocated and available like that :",
      "[\r\n  {\r\n    \"network\": \"X.X.X.1\",\r\n    \"full\": false\r\n    reserved: 3\r\n    available: 4\r\n\r\n    \r\n\r\n  },\r\n  {\r\n    \"network\": \"X.X.X.2\",\r\n    \"full\": false\r\n    reserved: 3\r\n    available: 4\r\n\r\n  }\r\n]",
      "Use `reduce` to count statuses.",
      "map({network, full} +\r\n  reduce .ipAddressTab[].status as $s ({}; .[$s] += 1))",
      "The function `f` takes a path and the status string to be looked-up then gets the length of the objects in the array.",
      "map({network, full, reserved: f(.ipAddressTab; \"reserved\"), available: f(.ipAddressTab; \"available\")})",
      "map({network,\r\n    full,\r\n    reserved:   count(.ipAddressTab[] | select(.status == \"reserved\")),\r\n    available:  count(.ipAddressTab[] | select(.status == \"available\"))\r\n    })"
    ],
    "utterance": "For each network object, output the network, full, and the count of reserved and available ipAddressTab entries as keys.",
    "expressions": [
      "map({network, full} + reduce .ipAddressTab[].status as $s ({}; .[$s] += 1))",
      "def f($val): map(select(.status == $val)) | length; map({network, full} + (.ipAddressTab | { reserved: f(\"reserved\"), available: f(\"available\")}))",
      "map({network, full, reserved: ([.ipAddressTab[] | select(.status == \"reserved\")] | length), available: ([.ipAddressTab[] | select(.status == \"available\")] | length)})",
      "map({network, full, reserved: count(.ipAddressTab[] | select(.status == \"reserved\")), available: count(.ipAddressTab[] | select(.status == \"available\"))})"
    ],
    "data": [
      {
        "input": [
          {
            "network": "X.X.X.1",
            "defaultGateway": "X.X.X.X",
            "ipAddressTab": [
              {
                "foo1": "10.0.0.1",
                "foo2": "network",
                "status": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.2",
                "foo2": "network",
                "status": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.3",
                "foo2": "network",
                "status": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.4",
                "status": "available"
              },
              {
                "foo1": "10.0.0.5",
                "status": "available"
              },
              {
                "foo1": "10.0.0.6",
                "status": "available"
              },
              {
                "foo1": "10.0.0.7",
                "status": "available"
              }
            ],
            "full": false,
            "id": "xxx"
          },
          {
            "network": "X.X.X.2",
            "defaultGateway": "X.X.X.X",
            "ipAddressTab": [
              {
                "foo1": "10.0.0.1",
                "foo2": "network",
                "status": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.2",
                "foo2": "network",
                "status": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.3",
                "foo2": "network",
                "status": "reserved",
                "foo4": null,
                "foo5": null,
                "foo6": null,
                "foo7": null,
                "foo8": null,
                "foo9": null,
                "foo10": null,
                "foo11": null
              },
              {
                "foo1": "10.0.0.4",
                "status": "available"
              },
              {
                "foo1": "10.0.0.5",
                "status": "available"
              },
              {
                "foo1": "10.0.0.6",
                "status": "available"
              },
              {
                "foo1": "10.0.0.7",
                "status": "available"
              }
            ],
            "full": false,
            "id": "xxx"
          }
        ],
        "output": [
          {
            "network": "X.X.X.1",
            "full": false,
            "reserved": 3,
            "available": 4
          },
          {
            "network": "X.X.X.2",
            "full": false,
            "reserved": 3,
            "available": 4
          }
        ]
      }
    ],
    "identifier": 65288238
  },
  {
    "context": [
      "I want to get the index of `\"b\"` (here, this index is 1).",
      "echo '[\"a\",\"b\",\"c\"]' | jq 'to_entries[] | select(.value == \"a\") | .key'"
    ],
    "utterance": "Get the index of the element with value \"b\" in the array.",
    "expressions": [
      "to_entries[] | select(.value == \"b\") | .key"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": 1
      }
    ],
    "identifier": 65435339
  },
  {
    "context": [
      "Is there a way to sort the values to keep consistency? That way it can look like this:\n\n[\n  \"ed37ba0ea1f31d62ff48ef817addd30c8be9952c\",\n  \"build.160\"\n]\n[\n  \"5cd7190a96f633cfb8b5fa0f876f147dbe700dad\",\n  \"build.161\"\n]\n[\n  \"9a9f030fcf7544565b9ebf8ba37330b649e156ba\",\n  \"build.159\"\n]",
      "You can do `sort_by` on the length of the strings in the array and reverse the order to keep the longest string first. Remove the `reverse` function to keep the shortest string first",
      "sort_by(length) | reverse"
    ],
    "utterance": "Sort each array so that the longest string appears first.",
    "expressions": [
      "sort_by(length) | reverse"
    ],
    "data": [
      {
        "input": [
          [
            "build.160",
            "ed37ba0ea1f31d62ff48ef817addd30c8be9952c"
          ],
          [
            "5cd7190a96f633cfb8b5fa0f876f147dbe700dad",
            "build.161"
          ],
          [
            "9a9f030fcf7544565b9ebf8ba37330b649e156ba",
            "build.159"
          ]
        ],
        "output": [
          [
            "ed37ba0ea1f31d62ff48ef817addd30c8be9952c",
            "build.160"
          ],
          [
            "5cd7190a96f633cfb8b5fa0f876f147dbe700dad",
            "build.161"
          ],
          [
            "9a9f030fcf7544565b9ebf8ba37330b649e156ba",
            "build.159"
          ]
        ]
      }
    ],
    "identifier": 65430770
  },
  {
    "context": [
      "The command I'm using for that is\n\n    repo_list=$(cat repo.json | jq '.[] | .slug ' | sed 's/\"//g')",
      "The error msg I'm getting is \n   \n    Cannot index number with string \"slug\"",
      "Expected result is \n\n    ecomm-dist-cache\n    mqfte_ecommoutboundtransfertoweddingchannel",
      "jq -r '.values[].slug' repo.json\n\n-r will remove the quotation marks and so there is no need to pipe through to sed."
    ],
    "utterance": "Extract the slug property from every repository listed under the values array.",
    "expressions": [
      ".values[].slug",
      "jq -r '.values[].slug' repo.json"
    ],
    "data": [
      {
        "input": {
          "pagelen": 100,
          "size": 494,
          "values": [
            {
              "scm": "git",
              "website": "",
              "fork_policy": "no_public_forks",
              "full_name": "org_name/ecomm-dist-cache",
              "name": "ecomm-dist-cache",
              "language": "java",
              "created_on": "2014-11-18T19:01:25.741787+00:00",
              "mainbranch": {
                "type": "branch",
                "name": "master"
              },
              "workspace": {
                "slug": "org_name",
                "type": "workspace",
                "name": "Org Name ",
                "uuid": "{xxxxxxxxxxxxx}"
              },
              "has_issues": true,
              "updated_on": "2018-06-06T22:17:02.947496+00:00",
              "size": 105095621,
              "type": "repository",
              "slug": "ecomm-dist-cache",
              "is_private": true,
              "description": "Initial Migration of ecomm-dist-cache"
            },
            {
              "scm": "git",
              "website": "",
              "full_name": "org_name/mqfte_ecommoutboundtransfertoweddingchannel",
              "name": "MQFTE_ECOMMOutboundTransferToWeddingChannel",
              "language": "",
              "mainbranch": {
                "type": "branch",
                "name": "master"
              },
              "workspace": {
                "slug": "org_name",
                "type": "workspace",
                "name": "Org Name ",
                "uuid": "{xxxxxxxxxxxxx}"
              },
              "has_issues": false,
              "size": 99549,
              "type": "repository",
              "slug": "mqfte_ecommoutboundtransfertoweddingchannel",
              "is_private": true,
              "description": ""
            }
          ],
          "page": 1,
          "next": "https://api.bitbucket.org/2.0/repositories/org_name? pagelen=100&page=2"
        },
        "output": [
          "ecomm-dist-cache",
          "mqfte_ecommoutboundtransfertoweddingchannel"
        ]
      }
    ],
    "identifier": 65437796
  },
  {
    "context": [
      "I want to get the value of `RandomKey1`. As you may have guessed, the name of the key changes every time when I load the page, so I need to get the value of the 0th key. It is guaranteed to be at the 0th position",
      "Is there any way to get the 0th value from this string when the key name is unknown ?",
      "You can use the `to_entries` function to get there!\n\n```\njq 'to_entries|.[0].value' file.json\n```",
      "You're looking for [`first/1`](https://stedolan.github.io/jq/manual/#first,last,nth(n)).\n```\nfirst(.[])\n```",
      "You could use the `keys_unsorted` function like so:\n```\n.[keys_unsorted[0]]\n```"
    ],
    "utterance": "Extract the value of the first key in an object when the key name is unknown but the first position is guaranteed.",
    "expressions": [
      "to_entries | .[0].value",
      "first(.[])",
      ".[keys_unsorted[0]]"
    ],
    "data": [
      {
        "input": {
          "RandomKey1": "3.1.44.0",
          "Common": {
            "Services": "3.50.103.0",
            "Common": "3.50.103.0"
          }
        },
        "output": "3.1.44.0"
      }
    ],
    "identifier": 65449514
  },
  {
    "context": [
      "I want the output like this \n\n```\nBTC_BTS : 14 : 0.00000111 : 0.00000112 : 0.00000110 : 0.09900990 : 3.12079869 : 2318738.79293715 : 0 : 0.00000152 : 0.00000098\n...\nUSDT_GRT : 497 : 0.72428700 : 0.75999958 : 0.72630001 : 0.47813685 : 133968.74968533 : 194695.96886712 : 0 : 0.79000000 : 0.45000020\nTRX_SUN : 498 : 500.00000000 : 449.99999999 : 100.00000000 : 0.00000000 : 0.00000000 : 0.00000000 : 0 : 0.00000000 : 0.00000000\n```",
      "I am using jq and my problem is accesing the currency pair name.",
      "jq -r 'to_entries[] | [ .key, .value[] ] | join(\" : \")'",
      "To be safe, it might be better not to assume that the ordering of the keys is the same in all the inner objects.  Ergo:",
      "keys_unsorted as $outer\n| (.[$outer[0]] | keys_unsorted) as $keys\n| $outer[] as $k\n| [ $k, .[$k][$keys[]] ]\n| join(\" : \")"
    ],
    "utterance": "Print each currency pair name followed by all its values as a colon-separated line, preserving column order per pair.",
    "expressions": [
      "to_entries[] | [ .key, .value[] ] | join(\" : \")",
      "keys_unsorted as $outer | (.[$outer[0]] | keys_unsorted) as $keys | $outer[] as $k | [ $k, .[$k][$keys[]] ] | join(\" : \")"
    ],
    "data": [
      {
        "input": {
          "BTC_BTS": {
            "id": 14,
            "last": "0.00000111",
            "lowestAsk": "0.00000112",
            "highestBid": "0.00000110",
            "percentChange": "0.09900990",
            "baseVolume": "3.12079869",
            "quoteVolume": "2318738.79293715",
            "isFrozen": "0",
            "high24hr": "0.00000152",
            "low24hr": "0.00000098"
          },
          "USDT_GRT": {
            "id": 497,
            "last": "0.72811272",
            "lowestAsk": "0.75999916",
            "highestBid": "0.72740000",
            "percentChange": "0.48594450",
            "baseVolume": "133995.43411815",
            "quoteVolume": "194721.36672887",
            "isFrozen": "0",
            "high24hr": "0.79000000",
            "low24hr": "0.45000020"
          }
        },
        "output": [
          "BTC_BTS : 14 : 0.00000111 : 0.00000112 : 0.00000110 : 0.09900990 : 3.12079869 : 2318738.79293715 : 0 : 0.00000152 : 0.00000098",
          "USDT_GRT : 497 : 0.72811272 : 0.75999916 : 0.72740000 : 0.48594450 : 133995.43411815 : 194721.36672887 : 0 : 0.79000000 : 0.45000020"
        ]
      }
    ],
    "identifier": 65384888
  },
  {
    "context": [
      "My desired output looks something like follows, where I want to insert a new field `color` into `data.json` into each line with values from `values.txt`.",
      "Interlace data with values and stream to JQ, there you can add each pair together.\n```\n$ paste -d '\\n' data.json values.txt | jq -Rc 'fromjson + {color: input}'\n{\"_id\":1,\"content\":\"apple\",\"color\":\"red\"}\n{\"_id\":2,\"content\":\"banana\",\"color\":\"yellow\"}\n```",
      "A simple jq-only solution:\n```\n< values.txt jq -nR --slurpfile json data.json '[ $json, [{color: inputs}] ] | transpose | map(add)[]'\n```\nDrop the trailing `[]` if you want the result as an array.",
      "An efficient jq-only solution:\n```\n< data.json jq -n --rawfile values values.txt '($values | split(\"\\n\")) as $values | foreach inputs as $in (-1; .+1; $in + {color: $values[.] })\n```"
    ],
    "utterance": "Add a color field to each object in data.json using the corresponding line from values.txt as the value.",
    "expressions": [
      "paste -d '\\n' data.json values.txt | jq -Rc 'fromjson + {color: input}'",
      "< values.txt jq -nR --slurpfile json data.json '[ $json, [{color: inputs}] ] | transpose | map(add)[]'",
      "< data.json jq -n --rawfile values values.txt '($values | split(\"\\n\")) as $values | foreach inputs as $in (-1; .+1; $in + {color: $values[.] })'"
    ],
    "data": [
      {
        "input": [
          "{\"_id\": 1, \"content\": \"apple\"}",
          "{\"_id\": 2, \"content\": \"banana\"}"
        ],
        "output": [
          "{\"_id\": 1, \"content\": \"apple\", \"color\": \"red\"}",
          "{\"_id\": 2, \"content\": \"banana\", \"color\": \"yellow\"}"
        ]
      },
      {
        "input": [
          "red",
          "yellow"
        ]
      }
    ],
    "identifier": 65442426
  },
  {
    "context": [
      "I&#39;d like to take some covid 19 JSON data and sort the results by date and time but the date and time are 2 separate keys.",
      "You could use `sort_by/1` on the fields, you&#39;ll have to either normalize the date/time formats or conditionally parse them out using `strptime/1`. It returns an array of the date fields in significant order combine to a single array and sort_by will do the rest.",
      ".data.monitor | sort_by([\n  (.Date | strptime(\"%A %d %B %Y\")),\n  (.Time | split(\" \")[0] | if contains(\":\") then\n    strptime(\"%I:%M%p\")\n  else\n    strptime(\"%I%p\")\n  end)\n])",
      "def mysort:\n   map(\n      .epoch =\n         try (\n            [\n               ( .Date | split(\" \")[0:4] | .[] ),\n               ( .Time | split(\" \")[0] | if . == \"All\" then \"12am\" else . end )\n            ] | join(\" \") |\n            strptime(\n               if contains(\":\") then\n                  \"%A %d %B %Y %I:%M%p\"\n               else\n                  \"%A %d %B %Y %I%p\"\n               end\n            ) |\n            mktime\n         )\n         catch -1\n   ) |\n   sort_by(.epoch) |\n   map( del(.epoch) );\n\n.data[] |= mysort"
    ],
    "utterance": "Sort entries by the combined date and time fields where date is in '.Date' and time is in '.Time', even though they are in separate keys.",
    "expressions": [
      ".data.monitor | sort_by([\n  (.Date | strptime(\"%A %d %B %Y\")),\n  (.Time | split(\" \")[0] | if contains(\":\") then\n    strptime(\"%I:%M%p\")\n  else\n    strptime(\"%I%p\")\n  end)\n])",
      "def mysort:\n   map(\n      .epoch =\n         try (\n            [\n               ( .Date | split(\" \")[0:4] | .[] ),\n               ( .Time | split(\" \")[0] | if . == \"All\" then \"12am\" else . end )\n            ] | join(\" \") |\n            strptime(\n               if contains(\":\") then\n                  \"%A %d %B %Y %I:%M%p\"\n               else\n                  \"%A %d %B %Y %I%p\"\n               end\n            ) |\n            mktime\n         )\n         catch -1\n   ) |\n   sort_by(.epoch) |\n   map( del(.epoch) );\n\n.data[] |= mysort"
    ],
    "data": [
      {
        "input": {
          "date": "2020-12-24",
          "title": "Venues",
          "data": {
            "monitor": [
              {
                "Venue": "Hungry Ghost Caf\u00e9",
                "Address": "20 Avalon Parade, Avalon, NSW 2107",
                "Date": "Sunday 13 December 2020",
                "Time": "9:30am to 11am"
              },
              {
                "Venue": "Hungry Ghost Caf\u00e9",
                "Address": "20 Avalon Parade, Avalon, NSW 2107",
                "Date": "Tuesday 15 December 2020",
                "Time": "9:30am to 11am",
                "Alert": "Monitor for symptoms"
              },
              {
                "Venue": "Woolworths",
                "Address": "74 Old Barrenjoey Road, Avalon Beach, NSW 2107",
                "Date": "Saturday 12 December 2020",
                "Time": "12pm to 12:15pm"
              }
            ]
          }
        }
      }
    ],
    "identifier": 65439322
  },
  {
    "context": [
      "output should be:\r\n\r\n{\r\n  \"author\": \"A C Doyle\",\r\n  \"totalpages\": 436,\r\n  \"books\": [\r\n    {\r\n      \"title\": \"The Lost World\",\r\n      \"year\": 1912\r\n    },\r\n    {\r\n      \"title\": \"A Study in Scarlet\",\r\n      \"year\": 1887\r\n    }\r\n  ]\r\n}\r\n{\r\n  \"author\": \"H G Wells\",\r\n  \"totalpages\": 2339,\r\n  \"books\": [\r\n    {\r\n      \"title\": \"War of the worlds\",\r\n      \"year\": 1896\r\n    },\r\n    {\r\n      \"title\": \"The invisible man\",\r\n      \"year\": 1895\r\n    }\r\n  ]\r\n}\r\n{\r\n  \"author\": \"J Verne\",\r\n  \"totalpages\": 450,\r\n  \"books\": [\r\n    {\r\n      \"title\": \"20,000 leagues under the sea\",\r\n      \"year\": 1870\r\n    }\r\n  ]\r\n}",
      "[ inputs ] | \r\ngroup_by(.author) | \r\nmap\r\n( \r\n  { \r\n    author: .[0].author, \r\n    totalpages: ( map(.pages) | add ), \r\n    books: ( map( { title, year } ) ) \r\n  }\r\n)"
    ],
    "utterance": "Group input objects by author, calculate total pages per author, and aggregate books as title and year for each author.",
    "expressions": [
      "[ inputs ] | group_by(.author) | map({ author: .[0].author, totalpages: ( map(.pages) | add ), books: ( map( { title, year } ) ) })"
    ],
    "data": [
      {
        "input": [
          {
            "title": "War of the worlds",
            "author": "H G Wells",
            "year": 1896,
            "pages": 203
          },
          {
            "title": "The invisible man",
            "author": "H G Wells",
            "year": 1895,
            "pages": 2136
          },
          {
            "title": "The Lost World",
            "author": "A C Doyle",
            "year": 1912,
            "pages": 185
          },
          {
            "title": "A Study in Scarlet",
            "author": "A C Doyle",
            "year": 1887,
            "pages": 251
          },
          {
            "title": "20,000 leagues under the sea",
            "author": "J Verne",
            "year": 1870,
            "pages": 450
          }
        ],
        "output": [
          {
            "author": "A C Doyle",
            "totalpages": 436,
            "books": [
              {
                "title": "The Lost World",
                "year": 1912
              },
              {
                "title": "A Study in Scarlet",
                "year": 1887
              }
            ]
          },
          {
            "author": "H G Wells",
            "totalpages": 2339,
            "books": [
              {
                "title": "War of the worlds",
                "year": 1896
              },
              {
                "title": "The invisible man",
                "year": 1895
              }
            ]
          },
          {
            "author": "J Verne",
            "totalpages": 450,
            "books": [
              {
                "title": "20,000 leagues under the sea",
                "year": 1870
              }
            ]
          }
        ]
      }
    ],
    "identifier": 65454644
  },
  {
    "context": [
      "I have a json response from a get request that looks like:\n[\n  {\n    \"vs\": {\n      \"name\": \"vs_name\",\n      \"pool\": {\n        \"p_id_name\": \"XYZ\",\n        \"members\": [\n          {\n            \"m_name\": \"XXX1\",\n            \"id_name\": \"YYY1\",\n            \"address\": \"ZZZ1\"\n          },\n          {\n            \"m_name\": \"XXX2\",\n            \"id_name\": \"YYY2\",\n            \"address\": \"ZZZ2\"\n          }\n        ]\n      }\n    }\n  }\n]",
      "I'm trying to get an output that looks like (repating the `p_id_name` for each `m_name`):\nXYZ, XXX1\nXYZ, XXX2",
      ".[].vs.pool | \"\\(.p_id_name), \\(.members[].m_name)\"",
      "If you want to output arrays, you need to create a separate array for each `m_name`.\n.[].vs.pool | [.p_id_name] + (.members[] | [.m_name])"
    ],
    "utterance": "Output a line for each member's m_name paired with its p_id_name as 'XYZ, XXX1' and 'XYZ, XXX2'.",
    "expressions": [
      ".[].vs.pool | \"\\(.p_id_name), \\(.members[].m_name)\"",
      ".[].vs.pool | [.p_id_name] + (.members[] | [.m_name])"
    ],
    "data": [
      {
        "input": [
          {
            "vs": {
              "name": "vs_name",
              "pool": {
                "p_id_name": "XYZ",
                "members": [
                  {
                    "m_name": "XXX1",
                    "id_name": "YYY1",
                    "address": "ZZZ1"
                  },
                  {
                    "m_name": "XXX2",
                    "id_name": "YYY2",
                    "address": "ZZZ2"
                  }
                ]
              }
            }
          }
        ],
        "output": [
          "XYZ, XXX1",
          "XYZ, XXX2"
        ]
      }
    ],
    "identifier": 65476564
  },
  {
    "context": [
      "So what I ideally want is the above to be transformed correctly. I see two difficulties here:\n 1. the article number is an \"unknown\" key\n 2. the JSON result doesn't seem to be an array itself?",
      "With **-n**/**--null-input** option on the command line, this program produces the expected output.\n```\n{\n  \"ns:inputArticleItemList\": {\n    \"#namespaces\": {\n      \"ns\": \"http://www.unknown.com/ccp/basit/service/article/api\"\n    },\n    \"articles\": [\n      { \n        \"articleID\": (inputs | keys_unsorted[]),\n        \"insertCode\": \"62\",\n        \"calculatePrice\": true,\n        \"checkAvailability\": true,\n        \"findExclusions\": true\n      }\n    ]\n  }\n}\n```",
      "You can merge the combine the inputs into an array using slurp mode (`--slurp`/`-s`) and the following program:\n\n```jq\n{\n   \"ns:inputArticleItemList\": {\n      \"#namespaces\": {\n         \"ns\": \"http://www.unknown.com/ccp/basit/service/article/api\"\n      },\n      articles: [\n         {\n            \"articleID\": ( .[] | keys_unsorted[] ),\n            \"insertCode\": \"62\",\n            \"calculatePrice\": true,\n            \"checkAvailability\": true,\n            \"findExclusions\": true\n         }\n      ]\n   }\n}\n```"
    ],
    "utterance": "Combine objects where the article number is the key into a single object with an articles array, each containing articleID as the key, and static fields insertCode 62, calculatePrice true, checkAvailability true, and findExclusions true, wrapped with a given namespaces structure.",
    "expressions": [
      "{\n  \"ns:inputArticleItemList\": {\n    \"#namespaces\": {\n      \"ns\": \"http://www.unknown.com/ccp/basit/service/article/api\"\n    },\n    \"articles\": [\n      { \n        \"articleID\": (inputs | keys_unsorted[]),\n        \"insertCode\": \"62\",\n        \"calculatePrice\": true,\n        \"checkAvailability\": true,\n        \"findExclusions\": true\n      }\n    ]\n  }\n}",
      "{\n  \"ns:inputArticleItemList\": {\n    \"#namespaces\": {\n      \"ns\": \"http://www.unknown.com/ccp/basit/service/article/api\"\n    },\n    articles: [\n      {\n        \"articleID\": (.[] | keys_unsorted[]),\n        \"insertCode\": \"62\",\n        \"calculatePrice\": true,\n        \"checkAvailability\": true,\n        \"findExclusions\": true\n      }\n    ]\n  }\n}"
    ],
    "data": [
      {
        "input": [
          {
            "2201299": {
              "title": "this is the product description for article 2201299",
              "prop1": "value1",
              "prop2": "value2",
              "prop3": "value3"
            }
          },
          {
            "2240002": {
              "title": "this is the product description for article 2240002",
              "prop1": "value1",
              "prop2": "value2",
              "prop3": "value3"
            }
          }
        ],
        "output": {
          "ns:inputArticleItemList": {
            "#namespaces": {
              "ns": "http://www.unknown.com/ccp/basit/service/article/api"
            },
            "articles": [
              {
                "articleID": "2201299",
                "insertCode": "62",
                "calculatePrice": true,
                "checkAvailability": true,
                "findExclusions": true
              },
              {
                "articleID": "2240002",
                "insertCode": "62",
                "calculatePrice": true,
                "checkAvailability": true,
                "findExclusions": true
              }
            ]
          }
        }
      }
    ],
    "identifier": 65454482
  },
  {
    "context": [
      "Is it possible to pipe the output through `jq` ONLY if it is valid JSON?",
      "The following works:\n\necho $x | jq . 2>/dev/null  || echo $x",
      "Test:\n> x='{\"foo\":123}'; echo $x | jq . 2>/dev/null || echo \"Invalid: $x\"\n{\n  \"foo\": 123\n}\n\n> x='}'; echo $x | jq . 2>/dev/null || echo \"Invalid: $x\"\nInvalid: }",
      "if jq --exit-status type >/dev/null 2>&1 <<<\"$response\"; then\n    # Parsed JSON successfully and got something other than false/null\n    echo \"$response\" | jq .",
      "printf \"%s\" \"$x\" | jq . 2> /dev/null || printf \"%s\\n\" \"$x\";"
    ],
    "utterance": "Print the value, parsed if it is valid, otherwise print the raw value, only parsing if it is valid.",
    "expressions": [
      "echo \"$x\" | jq . 2>/dev/null || echo \"$x\"",
      "printf \"%s\" \"$x\" | jq . 2>/dev/null || printf \"%s\\n\" \"$x\""
    ],
    "data": [
      {
        "input": "{\"foo\":123}",
        "output": "{\n  \"foo\": 123\n}"
      },
      {
        "input": "}",
        "output": "Invalid: }"
      }
    ],
    "identifier": 65530726
  },
  {
    "context": [
      "Ideally I would like to have a shortened json like this:\r\n\r\n```\r\n{\r\n\t\"data\": [\r\n\t\t{\r\n\t\t\t\"id\": \"abcdef\",\r\n\t\t\t\"title\": \"Boring Title One\",\r\n            \"url\": \"https://example.com/somefiles_1.jpg\"\r\n\t\t},\r\n\t\t{\r\n\t\t\t\"id\": \"ghijkl\",\r\n\t\t\t\"title\": \"Boring Title Two\",\r\n            \"url\": \"https://example.com/somefiles_2.jpg\"\r\n\t\t}, ...",
      "A simple solution to the main question is:\r\n\r\n```\r\n{data: [.data.children[]\r\n        | .data\r\n        | {id, title, url: .preview.images[0].source.url} ]}\r\n```"
    ],
    "utterance": "Extract an array of objects each containing id, title, and the URL from the first image in the preview images array.",
    "expressions": [
      "{data: [.data.children[] | .data | {id, title, url: .preview.images[0].source.url}]}"
    ],
    "data": [
      {
        "input": {
          "data": {
            "children": [
              {
                "data": {
                  "id": "abcdef",
                  "preview": {
                    "images": [
                      {
                        "source": {
                          "url": "https://example.com/somefiles_1.jpg"
                        }
                      }
                    ]
                  },
                  "title": "Boring Title One"
                }
              },
              {
                "data": {
                  "id": "ghijkl",
                  "preview": {
                    "images": [
                      {
                        "source": {
                          "url": "https://example.com/somefiles_2.jpg"
                        }
                      }
                    ]
                  },
                  "title": "Boring Title Two"
                }
              },
              {
                "data": {
                  "id": "mnopqr",
                  "preview": {
                    "images": [
                      {
                        "source": {
                          "url": "https://example.com/somefiles_3.jpg"
                        }
                      }
                    ]
                  },
                  "title": "Boring Title Three"
                }
              },
              {
                "data": {
                  "id": "stuvwx",
                  "preview": {
                    "images": [
                      {
                        "source": {
                          "url": "https://example.com/somefiles_4.jpg"
                        }
                      }
                    ]
                  },
                  "title": "Boring Title Four"
                }
              }
            ]
          }
        },
        "output": {
          "data": [
            {
              "id": "abcdef",
              "title": "Boring Title One",
              "url": "https://example.com/somefiles_1.jpg"
            },
            {
              "id": "ghijkl",
              "title": "Boring Title Two",
              "url": "https://example.com/somefiles_2.jpg"
            },
            {
              "id": "mnopqr",
              "title": "Boring Title Three",
              "url": "https://example.com/somefiles_3.jpg"
            },
            {
              "id": "stuvwx",
              "title": "Boring Title Four",
              "url": "https://example.com/somefiles_4.jpg"
            }
          ]
        }
      }
    ],
    "identifier": 65435240
  },
  {
    "context": [
      "Here I want to merge some specified key(s) into an array. In this example, I like to merge `stargazers_count`, so the expected json to be resulted is like follows.",
      "Define a function to merge inputs by path(s) as follows.\ndef f(p):\n  reduce inputs as $in (p |= [.];\n    reduce path(p) as $p (.;\n      setpath($p; getpath($p) + [$in | getpath($p)])\n    )\n  );",
      "Then you can simply do:\nf(.stargazers_count)",
      "If you want to write a script that expects an argument specifying the field to be aggregated, you could use the following as a guide:\n\njq --argfile f1 f1.json --arg field stargazers_count '\n  .[$field] |= [., $f1[$field]]\n' f2.json"
    ],
    "utterance": "Merge two objects so that only stargazers_count is turned into an array containing both values, leaving other fields unchanged.",
    "expressions": [
      "def f(p): reduce inputs as $in (p |= [.]; reduce path(p) as $p (.; setpath($p; getpath($p) + [$in | getpath($p)]))); f(.stargazers_count)",
      ".stargazers_count |= [., input.stargazers_count]"
    ],
    "data": [
      {
        "input": [
          {
            "full_name": "clbr/n64bootloader",
            "description": null,
            "html_url": "https://github.com/clbr/n64bootloader",
            "created_at": "2020-12-25T16:19:12Z",
            "language": "C",
            "stargazers_count": 199,
            "watchers_count": 199,
            "forks_count": 10,
            "url": "https://api.github.com/repos/clbr/n64bootloader"
          },
          {
            "full_name": "clbr/n64bootloader",
            "description": null,
            "html_url": "https://github.com/clbr/n64bootloader",
            "created_at": "2020-12-25T16:19:12Z",
            "language": "C",
            "stargazers_count": 220,
            "watchers_count": 220,
            "forks_count": 10,
            "url": "https://api.github.com/repos/clbr/n64bootloader"
          }
        ],
        "output": {
          "full_name": "clbr/n64bootloader",
          "description": null,
          "html_url": "https://github.com/clbr/n64bootloader",
          "created_at": "2020-12-25T16:19:12Z",
          "language": "C",
          "stargazers_count": [
            199,
            220
          ],
          "watchers_count": 220,
          "forks_count": 10,
          "url": "https://api.github.com/repos/clbr/n64bootloader"
        }
      }
    ],
    "identifier": 65483160
  },
  {
    "context": [
      "I want to use `jq` to output all id's that are valid (`\"valid\"`=true) and have the output sorted by id.",
      "So in this example, I would like the output to be:\nHappy\nNew\nYear",
      "jq --raw-output '.peace | map(select(.valid).id) | sort[]' <f.json>"
    ],
    "utterance": "Output the id values where valid is true, sorted by id.",
    "expressions": [
      ".peace | map(select(.valid).id) | sort[]"
    ],
    "data": [
      {
        "input": {
          "world": 583,
          "peace": [
            {
              "id": "Happy",
              "valid": true,
              "version": "9"
            },
            {
              "id": "Old",
              "valid": false,
              "version": "2020"
            },
            {
              "id": "New",
              "valid": true,
              "version": "2021"
            },
            {
              "id": "Year",
              "valid": true,
              "version": "5"
            }
          ]
        },
        "output": [
          "Happy",
          "New",
          "Year"
        ]
      }
    ],
    "identifier": 65533453
  },
  {
    "context": [
      "I want to count how much increment backups were added since the last full backup.",
      "I try to select max timestamp of the record with type \"full\" so after that i will count how much records with type \"incr\" has the bigger timestamp.",
      "[ .backup[] | select( .type == \"full\" ).timestamp.stop ] | max",
      "def count(s): reduce s as $x (0; .+1);\n\n.backup\n| (map( select( .type == \"full\" ).timestamp.stop) | max) as $max\n| count(.[] | select( .type == \"incr\" and  .timestamp.start > $max))",
      "jq '(.[0] |[.backup[] | select(.type==\"full\").timestamp.stop]|max) as $i| [.[0] |.backup[] | select(.type==\"incr\" and .timestamp.stop>$i)]|length"
    ],
    "utterance": "Count how many backups of type 'incr' have a timestamp greater than the latest backup of type 'full'.",
    "expressions": [
      "[ .backup[] | select( .type == \"full\" ).timestamp.stop ] | max",
      ".backup | map( select( .type == \"full\" ).timestamp.stop ) | max",
      "def count(s): reduce s as $x (0; .+1);\n\n.backup\n| (map( select( .type == \"full\" ).timestamp.stop) | max) as $max\n| count(.[] | select( .type == \"incr\" and  .timestamp.start > $max))",
      "(.[0] |[.backup[] | select(.type==\"full\").timestamp.stop]|max) as $i| [.[0] |.backup[] | select(.type==\"incr\" and .timestamp.stop>$i)]|length"
    ],
    "data": [
      {
        "input": {
          "archive": [
            {
              "database": {
                "id": 1
              },
              "id": "11-1",
              "max": "0000000A000018B90000006A",
              "min": "0000000A0000167D000000C7"
            }
          ],
          "backup": [
            {
              "archive": {
                "start": "0000000A0000181600000030",
                "stop": "0000000A0000181C00000083"
              },
              "backrest": {
                "format": 5,
                "version": "2.28"
              },
              "database": {
                "id": 1
              },
              "info": {
                "delta": 417875448942,
                "repository": {
                  "delta": 67466720725,
                  "size": 67466720725
                },
                "size": 417875448942
              },
              "label": "20201213-200009F",
              "prior": null,
              "reference": null,
              "timestamp": {
                "start": 1607878809,
                "stop": 1607896232
              },
              "type": "full"
            },
            {
              "archive": {
                "start": "0000000A0000182900000065",
                "stop": "0000000A0000182F00000069"
              },
              "backrest": {
                "format": 5,
                "version": "2.28"
              },
              "database": {
                "id": 1
              },
              "info": {
                "delta": 122520170241,
                "repository": {
                  "delta": 19316550760,
                  "size": 67786280115
                },
                "size": 416998156028
              },
              "label": "20201213-200009F_20201214-200009I",
              "prior": "20201213-200009F",
              "reference": [
                "20201213-200009F"
              ],
              "timestamp": {
                "start": 1607965209,
                "stop": 1607974161
              },
              "type": "incr"
            },
            {
              "archive": {
                "start": "0000000A0000185B000000DD",
                "stop": "0000000A0000185B000000F4"
              },
              "backrest": {
                "format": 5,
                "version": "2.28"
              },
              "database": {
                "id": 1
              },
              "info": {
                "delta": 126982395984,
                "repository": {
                  "delta": 19541379733,
                  "size": 67993072945
                },
                "size": 421395153101
              },
              "label": "20201213-200009F_20201217-200105I",
              "prior": "20201213-200009F_20201214-200009I",
              "reference": [
                "20201213-200009F",
                "20201213-200009F_20201214-200009I"
              ],
              "timestamp": {
                "start": 1608224465,
                "stop": 1608233408
              },
              "type": "incr"
            }
          ]
        },
        "output": 2
      }
    ],
    "identifier": 65392957
  },
  {
    "context": [
      "I need these key value pairs to a bash array of strings like this - bashArray = [ { \"key\" : \"value\" }  { \"key\" : \"value\" }  { \"key  : \"value\" } ]",
      "done < <(json | jq -c .[])"
    ],
    "utterance": "Extract each object from the top-level array as a compact string, one per line.",
    "expressions": [
      ".[]",
      ".[] | @json"
    ],
    "data": [
      {
        "input": [
          {
            "key": "value1"
          },
          {
            "key": "value2"
          },
          {
            "key": "value3"
          }
        ],
        "output": [
          "{\"key\":\"value1\"}",
          "{\"key\":\"value2\"}",
          "{\"key\":\"value3\"}"
        ]
      }
    ],
    "identifier": 65536970
  },
  {
    "context": [
      "I'm trying to change `#` to `%23` in every `context` value, but I&#39;m having problem with null values.",
      "the problem is that I need to get in return full edited file. How could I achieve that?",
      "(.results[].suites[].tests[].context | strings) |= sub(\"#\"; \"%23\")",
      "walk( if type==\"object\" and (.context|type)==\"string\"\n      then .context |= gsub(\"#\"; \"%23\")\n      else . end )"
    ],
    "utterance": "Replace all occurrences of # with %23 in every context field, keeping the structure and preserving null values.",
    "expressions": [
      "(.results[].suites[].tests[].context | strings) |= sub(\"#\"; \"%23\")",
      "walk( if type==\"object\" and (.context|type)==\"string\" then .context |= gsub(\"#\"; \"%23\") else . end )"
    ],
    "data": [
      {
        "input": {
          "stats": {
            "suites": 1
          },
          "results": [
            {
              "uuid": "676-a46b-47a1-a49f-4da4e46c1120",
              "title": "",
              "suites": [
                {
                  "uuid": "gghjh-56a9-4713-b139-0d5b36bc7fbc",
                  "title": "Login process",
                  "tests": [
                    {
                      "pass": false,
                      "fail": true,
                      "pending": false,
                      "context": "\"screenshots/login.spec.js/Login process -- should login #11 (failed).png\""
                    },
                    {
                      "pass": false,
                      "fail": false,
                      "pending": true,
                      "context": null
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "stats": {
            "suites": 1
          },
          "results": [
            {
              "uuid": "676-a46b-47a1-a49f-4da4e46c1120",
              "title": "",
              "suites": [
                {
                  "uuid": "gghjh-56a9-4713-b139-0d5b36bc7fbc",
                  "title": "Login process",
                  "tests": [
                    {
                      "pass": false,
                      "fail": true,
                      "pending": false,
                      "context": "\"screenshots/login.spec.js/Login process -- should login %2311 (failed).png\""
                    },
                    {
                      "pass": false,
                      "fail": false,
                      "pending": true,
                      "context": null
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 65490789
  },
  {
    "context": [
      "Is there an easier way to replicate a list in jq N times?",
      "So I had to do something like\n[range(N)|...]|add",
      "The syntax you're looking for does not exist. Your best bet would be to define a function to repeat the value for a reusable option.\n\ndef repeat($n):\n    . as $val | range($n) | $val;\n",
      "In your case, to create an array which repeats the contents of another array N times, you could use the above to do this:\n\n[repeat($N)[]]\n\nfor some number $N."
    ],
    "utterance": "Repeat the contents of an array a specified number of times.",
    "expressions": [
      "[range(N) | .[]] | add",
      "def repeat($n): . as $val | range($n) | $val; [repeat($N)[]]"
    ],
    "identifier": 65539821
  },
  {
    "context": [
      "I want the output to be a single array with all the nested objects, like below. Using the JSON input above, how do you use jq to produce the following output?",
      "`[ .[][] ]` works for your example (go down two levels from the root and put everything found into an array), or perhaps `[ .. | objects ]`, which is insensitive to the depth of the array nesting (but does assume that none of your objects contain sub-objects... it just finds all objects at any depth).",
      "Just use the `flatten` filter. See demo with your data: https://jqplay.org/s/kBxBJLxDKH",
      "You can use it in a command like: `jq flatten input_file`."
    ],
    "utterance": "Combine all objects from nested arrays into a single top-level array.",
    "expressions": [
      "[ .[][] ]",
      "flatten",
      "[ .. | objects ]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "instance_id": "i-35345353453",
              "account": "12344",
              "az": "ca-central-1a"
            },
            {
              "instance_id": "i-35345353453",
              "account": "12344",
              "az": "ca-central-1b"
            }
          ],
          [
            {
              "instance_id": "i-35345353453",
              "account": "12344",
              "az": "us-east-1d"
            },
            {
              "instance_id": "i-35345353453",
              "account": "12344",
              "az": "us-east-1d"
            }
          ],
          [
            {
              "instance_id": "i-35343453453",
              "account": "12344",
              "az": "eu-central-1a"
            }
          ]
        ],
        "output": [
          {
            "instance_id": "i-35345353453",
            "account": "12344",
            "az": "ca-central-1a"
          },
          {
            "instance_id": "i-35345353453",
            "account": "12344",
            "az": "ca-central-1b"
          },
          {
            "instance_id": "i-35345353453",
            "account": "12344",
            "az": "us-east-1d"
          },
          {
            "instance_id": "i-35345353453",
            "account": "12344",
            "az": "us-east-1d"
          },
          {
            "instance_id": "i-35343453453",
            "account": "12344",
            "az": "eu-central-1a"
          }
        ]
      }
    ],
    "identifier": 65536023
  },
  {
    "context": [
      "Desired Output:\r\n\r\n    [\r\n      {\r\n        \"email\": \"email1@mydomain.com\",\r\n        \"free\": \"0\",\r\n        \"used\": \"0\"\r\n      },\r\n      ...",
      "I guess it should be something like `+= {\"free\": \"0\"}`",
      "You can replace your current `jq` command by the following :\r\n\r\n```bash\r\njq --slurp --raw-input 'split(\"\\n\")[:-1] | map({email: ., free: 0, used: 0})'\r\n```"
    ],
    "utterance": "For each string in an array, produce an object with the email as a key and add keys 'free' and 'used' both set to 0.",
    "expressions": [
      "split(\"\\n\")[:-1] | map({email: ., free: 0, used: 0})"
    ],
    "data": [
      {
        "input": [
          "email1@mydomain.com",
          "email2@mydomain.com",
          "email3@mydomain.com",
          "email4@mydomain.com"
        ],
        "output": [
          {
            "email": "email1@mydomain.com",
            "free": 0,
            "used": 0
          },
          {
            "email": "email2@mydomain.com",
            "free": 0,
            "used": 0
          },
          {
            "email": "email3@mydomain.com",
            "free": 0,
            "used": 0
          },
          {
            "email": "email4@mydomain.com",
            "free": 0,
            "used": 0
          }
        ]
      }
    ],
    "identifier": 65556130
  },
  {
    "context": [
      "I have no problem with reading numeric values from it.",
      "But I could not figure out how to modify them.",
      "Thing what I want is",
      "[ { \"key1\": 0, \"key2\": \"2\" }, { \"key3\": \"3\", \"key4\": 4 } ]",
      "If your goal is to subtract 1 from `key1`, but leave all other values the same, that might look like:",
      "jq '.[] |= if .key1? != null then .key1 = .key1 - 1 else . end'",
      "You can use the has(key) function. From there on, you can use a regular if-then-else block to alter the dictionary (subtract 1 from the value associated with `key1`) if the condition is true or leave it unchanged if the condition is not met.",
      "jq '.[] |= if has(\"key1\") then .key1 = .key1 - 1 else . end '",
      "if for example you wanted to update all occurrences of numeric `key1` values in the top-level objects in the array, you could go with:",
      ".[] |= if (.key1|type) == \"number\" then .key1 += -1 else . end"
    ],
    "utterance": "Subtract 1 from all numeric values of key1 in each object of an array and leave other values unchanged.",
    "expressions": [
      ".[] |= if .key1? != null then .key1 = .key1 - 1 else . end",
      ".[] |= if has(\"key1\") then .key1 = .key1 - 1 else . end",
      ".[] |= if (.key1|type) == \"number\" then .key1 += -1 else . end"
    ],
    "data": [
      {
        "input": [
          {
            "key1": 1,
            "key2": "2"
          },
          {
            "key3": "3",
            "key4": 4
          }
        ],
        "output": [
          {
            "key1": 0,
            "key2": "2"
          },
          {
            "key3": "3",
            "key4": 4
          }
        ]
      }
    ],
    "identifier": 65566508
  },
  {
    "context": [
      "I have the following two arrays that I would like to reduce / combine. EMAIL should be unique.",
      "`jq -s 'add'` combines the array. I did some research on `unique` and `reduce` but I can\u2019t get it to work.",
      "Desired Output:",
      "[ { \"EMAIL\": \"email1@myDomain.com\", \"FREE\": \"1\", \"INUSE\": \"1\" }, ... ]",
      "You are looking for `group_by`, not `unique`. After concatenating inputs, group resulting array's elements by `.EMAIL`, and merge members of each group to get the desired outcome.",
      "jq -s 'add | group_by(.EMAIL) | map(add)'"
    ],
    "utterance": "Merge two arrays into a single array where each element is unique by EMAIL, combining fields for matching EMAILs.",
    "expressions": [
      "add | group_by(.EMAIL) | map(add)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "EMAIL": "email1@myDomain.com",
              "INUSE": "1"
            },
            {
              "EMAIL": "email4@myDomain.com",
              "INUSE": "1"
            },
            {
              "EMAIL": "email7@myDomain.com",
              "INUSE": "1"
            },
            {
              "EMAIL": "email2@myDomain.com",
              "INUSE": "3"
            }
          ],
          [
            {
              "EMAIL": "email1@myDomain.com",
              "FREE": "1"
            },
            {
              "EMAIL": "email3@myDomain.com",
              "FREE": "2"
            },
            {
              "EMAIL": "email4@myDomain.com",
              "FREE": "2"
            }
          ]
        ],
        "output": [
          {
            "EMAIL": "email1@myDomain.com",
            "INUSE": "1",
            "FREE": "1"
          },
          {
            "EMAIL": "email4@myDomain.com",
            "INUSE": "1",
            "FREE": "2"
          },
          {
            "EMAIL": "email7@myDomain.com",
            "INUSE": "1"
          },
          {
            "EMAIL": "email2@myDomain.com",
            "INUSE": "3"
          },
          {
            "EMAIL": "email3@myDomain.com",
            "FREE": "2"
          }
        ]
      }
    ],
    "identifier": 65582653
  },
  {
    "context": [
      "I tried something like this\n\n    aws ecs describe-tasks --cluster $clusterName   --tasks $tasks | jq '.tasks[]| select(.group | contains( \"'$serviceName'\")) .containerInstanceArn'| jq '| unique'\n\nbut get error\n\n> jq: error (at <stdin>:1): Cannot iterate over string (\"arn:aws:ec...)\n\nwhat is the proper way to get unique value when using `select` with `contains` so that only one vaule come out as the output.",
      "`unique` expects an array as input, so you could tweak your query as follows:\n\n      [.tasks[] | select(.group | contains( \"'$serviceName'\")) .containerInstanceArn]\n      | unique[]"
    ],
    "utterance": "List the unique values of containerInstanceArn from tasks where group contains the given service name.",
    "expressions": [
      "[.tasks[] | select(.group | contains(\"'$serviceName'\")) .containerInstanceArn] | unique[]"
    ],
    "data": [
      {
        "input": {
          "tasks": [
            {
              "connectivityAt": "2021-01-04T08:01:14.585000+05:30",
              "containerInstanceArn": "arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/ed6292913912344553e236d96cc4fdf7",
              "group": "service:cb-myservice1-api-dev-ecs-cb-myservice1-api-man-1839134",
              "version": 2
            },
            {
              "connectivityAt": "2020-12-30T16:47:48.408000+05:30",
              "containerInstanceArn": "arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/d5d2a0608134533347563d8383e",
              "group": "service:cb-myservice2-api-dev-ecs-cb-myservice2-api-man-1816014",
              "version": 2
            },
            {
              "connectivityAt": "2021-01-04T08:02:35.266000+05:30",
              "containerInstanceArn": "arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/ed6292913912344553e236d96cc4fdf7",
              "group": "service:cb-myservice1-api-staging-ecs-cb-myservice1-api-man-1839116",
              "version": 2
            }
          ],
          "failures": []
        }
      }
    ],
    "identifier": 65557159
  },
  {
    "context": [
      "What I want to do is to rewrite only the value of the first json for the value of the second json for the **Date_and_Time**",
      "jq -n --argjson oldvals \"$(&lt; file1.json)\" --argjson newvals \"$(&lt; file2.json)\" ' reduce range($oldvals | length) as $idx ($oldvals; .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time)'"
    ],
    "utterance": "Replace each object's Date_and_Time field in the first array with the corresponding value from the second array.",
    "expressions": [
      "jq -n --argjson oldvals \"$(< file1.json)\" --argjson newvals \"$(< file2.json)\" 'reduce range($oldvals | length) as $idx ($oldvals; .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time)'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Date_and_Time": "Dec 29, 2017 15:35:37",
              "Componente": "Bar",
              "Country": "Brazil",
              "Age": "3"
            },
            {
              "Date_and_Time": "Dec 31, 2017 17:35:37",
              "Componente": "Foo",
              "Country": "France",
              "Id": "123456",
              "Car": "Ferrari"
            }
          ],
          [
            {
              "Date_and_Time": "Dec 31, 2017 17:35:37",
              "Age": "1",
              "Country": "France",
              "Id": "123456",
              "Car": "Ferrari"
            },
            {
              "Date_and_Time": "Mar 31, 2018 14:35:37",
              "Componente": "Foo",
              "Country": "Germany",
              "Id": "2468",
              "Genre": "Male"
            }
          ]
        ],
        "output": [
          {
            "Date_and_Time": "Dec 31, 2017 17:35:37",
            "Componente": "Bar",
            "Country": "Brazil",
            "Age": "3"
          },
          {
            "Date_and_Time": "Mar 31, 2018 14:35:37",
            "Componente": "Foo",
            "Country": "France",
            "Id": "123456",
            "Car": "Ferrari"
          }
        ]
      }
    ],
    "identifier": 65576106
  },
  {
    "context": [
      "I'm interested in transforming from json format to tfvars using `jq`, i.e.:",
      "Input:\n```\n{\n  \"foo\": \"aaa\",\n  \"bar\": \"bbb\",\n}\n```",
      "Desired output:\n```\nfoo = \"aaa\"\nbar = \"bbb\"\n```",
      "jq -r 'to_entries[] | \"\\(.key) = \\\"\\(.value)\\\"\"'",
      "jq -r '\n  def q:\n    if type | IN(\"string\", \"boolean\") then \"\\\"\\(tostring)\\\"\" \n    else .\n    end;\n  to_entries[] | \"\\(.key) = \\(.value|q)\"\n'"
    ],
    "utterance": "Convert an object with string values into lines with unquoted keys, equals sign, and quoted values, matching tfvars format.",
    "expressions": [
      "jq -r 'to_entries[] | \"\\(.key) = \\\"\\(.value)\\\"\"'",
      "jq -r '\n  def q:\n    if type | IN(\"string\", \"boolean\") then \"\\\"\\(tostring)\\\"\" \n    else .\n    end;\n  to_entries[] | \"\\(.key) = \\(.value|q)\"\n'"
    ],
    "data": [
      {
        "input": {
          "foo": "aaa",
          "bar": "bbb"
        },
        "output": "foo = \"aaa\"\nbar = \"bbb\""
      }
    ],
    "identifier": 65584633
  },
  {
    "context": [
      "I got the following string that I would like to convert to a json array.",
      "Desired Output:\r\n\r\n    [\r\n      {\r\n        \"email\": \"email1@myDomain.com\",\r\n        \"free\": 2,\r\n        \"used\": 0\r\n      },\r\n      {\r\n        \"email\": \"email2@myDomain.com\",\r\n        \"free\": 1,\r\n        \"used\": 0\r\n      },\r\n      {\r\n        \"email\": \"email3@myDomain.com\",\r\n        \"free\": 3,\r\n        \"used\": 0\r\n      }\r\n    ]",
      "I need to split the string on the white space, which I know is possible but I don\u2019t know the exact syntax.",
      "I figured it out.\r\n\r\n    jq --slurp --raw-input 'split(\"\\n\")[:-1] | map({email: split(\" \")[1], free: split(\" \")[0], used: 0})'",
      "It\u2019s almost always better to avoid \"slurping\" when possible, and it would be more efficient to split on spaces just once:",
      "jq -R '\n  [splits(\" +\")] \n  | {email: .[1],\n     free:  (.[0] | tonumber),\n     used: 0 }\n' input.txt"
    ],
    "utterance": "Transform lines in the format 'number email' into objects with 'email' as the address, 'free' as the number, and 'used' set to 0.",
    "expressions": [
      "jq --slurp --raw-input 'split(\"\\n\")[:-1] | map({email: split(\" \")[1], free: split(\" \")[0], used: 0})'",
      "jq -R '[split(\" +\")] | {email: .[1], free: (.[0] | tonumber), used: 0 }' input.txt"
    ],
    "data": [
      {
        "input": "   2 email1@myDomain.com\n   1 email2@myDomain.com\n   3 email3@myDomain.com\n",
        "output": [
          {
            "email": "email1@myDomain.com",
            "free": 2,
            "used": 0
          },
          {
            "email": "email2@myDomain.com",
            "free": 1,
            "used": 0
          },
          {
            "email": "email3@myDomain.com",
            "free": 3,
            "used": 0
          }
        ]
      }
    ],
    "identifier": 65577049
  },
  {
    "context": [
      "I want to combine and process together the multiple files into one. I can consume  various structures (e.g. a different json) or formats (e.g. CSV) as the output, but ideally I&#39;d end up with a one output file.",
      "But to process together everything (assuming I&#39;m supposed to slurp):",
      "Shows the error messsage \"Cannot index string with string \\\"result\\\"",
      "As you guessed, do not use the -s option",
      "Use `inputs` and the -n command-line option, e.g. as follows:",
      "reduce inputs as $in (null; . + $in.result.lead)"
    ],
    "utterance": "Combine the lead arrays from multiple files so that all lead entries are merged into a single array.",
    "expressions": [
      "reduce inputs as $in (null; . + $in.result.lead)"
    ],
    "identifier": 65595131
  },
  {
    "context": [
      "jq -c '.[]' < myfile.js |",
      "while read -r row",
      "do",
      "  echo \"$row\"",
      "done",
      "mongo myfile.js |",
      "jq -c '.[]' |",
      "while read -r row",
      "do",
      "  echo \"$row\"",
      "done",
      "while read -r line ; do .... done < <(mongo myfile.js | jq -c .[])"
    ],
    "utterance": "Iterate over each object in an array and output each object as a compact, single-line string.",
    "expressions": [
      ".[]",
      "-c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "blah blah"
          },
          {
            "id": 2,
            "name": "xxx"
          }
        ],
        "output": [
          {
            "id": 1,
            "name": "blah blah"
          },
          {
            "id": 2,
            "name": "xxx"
          }
        ]
      }
    ],
    "identifier": 65614234
  },
  {
    "context": [
      "how do I select all objects, which may be nested, with a desired value?",
      "How do I filter down to objects whose value is `\"b\"`?",
      "Conversely, how do I select objects whose value is __not__ `\"b\"`?",
      "reduce paths(. == \"b\") as $p ({}; setpath($p; \"b\"))",
      "reduce paths(. == \"b\") as $p (.; delpaths([$p]))",
      "delpaths( [ paths(. == \"b\") ] )"
    ],
    "utterance": "Filter nested objects to keep only keys with value \"b\", or alternatively, remove all keys with value \"b\".",
    "expressions": [
      "reduce paths(. == \"b\") as $p ({}; setpath($p; \"b\"))",
      "reduce paths(. == \"b\") as $p (.; delpaths([$p]))",
      "delpaths( [ paths(. == \"b\") ] )"
    ],
    "data": [
      {
        "input": {
          "a": "b",
          "c": {
            "d": {
              "e": "f",
              "z": "b"
            }
          }
        },
        "output": {
          "a": "b",
          "c": {
            "d": {
              "z": "b"
            }
          }
        }
      },
      {
        "input": {
          "a": "b",
          "c": {
            "d": {
              "e": "f",
              "z": "b"
            }
          }
        },
        "output": {
          "c": {
            "d": {
              "e": "f"
            }
          }
        }
      }
    ],
    "identifier": 65589348
  },
  {
    "context": [
      "What I'd like to do is use **jq** to read each variable definition and extract the variable name and value. Then, I'd build a string prefixed by \"**--variables**\" followed by a list of all the key/value pairs,  space-delimited as follows:\r\n\r\n**--variables app_container_environment=\"dev\" aws_region=\"us-west-2\"**",
      "jq -r '\r\n  .variables\r\n  | [to_entries[]\r\n     | \"\\(.key)=\\\"\\(.value.value|tostring)\\\"\"\r\n  | \"--variables \" + join(\" \")\r\n' sample.json",
      "--variables app_container_environment=\"dev\" aws_region=\"us-west-2\""
    ],
    "utterance": "Produce a space-delimited string starting with --variables, followed by each variable name and its value in the form key=\"value\" extracted from the variables object.",
    "expressions": [
      ".variables | [to_entries[] | \"\\(.key)=\\\"\\(.value.value|tostring)\\\"\"] | \"--variables \" + join(\" \")"
    ],
    "data": [
      {
        "input": {
          "authorized": true,
          "description": "test",
          "name": "TESTGROUP",
          "providerData": null,
          "type": "Vsts",
          "variables": {
            "app_container_environment": {
              "value": "dev"
            },
            "aws_region": {
              "value": "us-west-2"
            }
          }
        },
        "output": "--variables app_container_environment=\"dev\" aws_region=\"us-west-2\""
      }
    ],
    "identifier": 65619479
  },
  {
    "context": [
      "currently I call\n\n```\ncat my_file.json | jq\n```\n\nto pretty print json data. I am a bit surprised that I can't do\n\nI would like to avoid the extra `cat`; i.e.,\n\n```\njq my_file.json\n```\n\nCan I specify a file name?",
      "You need to specify the jq program to run:\n\n    jq . my_file.json"
    ],
    "utterance": "Pretty-print the contents of the file named my_file.json.",
    "expressions": [
      "jq . my_file.json"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "baz": [
            1,
            2,
            3
          ]
        },
        "output": "{\n  \"foo\": \"bar\",\n  \"baz\": [\n    1,\n    2,\n    3\n  ]\n}"
      }
    ],
    "identifier": 65646331
  },
  {
    "context": [
      "I have a json output file which contains the following output. I'm trying to get the value for the \"status\" keys but it did give me answer as `null` all the time using the following command.",
      "output.json",
      "{\n  \"executions\": [\n    {\n      \"executionArn\": \"execution:job-execution:1ddb41e1-0d71-4dde-9cd0-d55119be334d\",\n      \"stateMachineArn\": \"stateMachine:job-execution\",\n      \"name\": \"jjfjnsldfnowef\",\n      \"status\": \"RUNNING\",\n      \"startDate\": 1609918173.79\n    },\n    {\n      \"executionArn\": \"execution:job-execution:c07927bc-d871-4996-a58a-f9c89cbd351f\",\n      \"stateMachineArn\": \"stateMachine:job-execution\",\n      \"name\": \"c07927bc-23jjfnjfjs\",\n      \"status\": \"RUNNING\",\n      \"startDate\": 1609918124.174\n    }\n  ]\n}",
      "Can anyone help me to get that expected output below.",
      "\"status\": \"RUNNING\"",
      "You can get something pretty close with this code:",
      "cat output.json | jq \".executions[].status\"",
      "cat output.json | jq \"{status: .executions[].status}\"",
      "If you want to build strings instead (to get almost the exact output you asked for), you can do it by creating a formatted string with your \"status: \" text, also containing the query that will be interpolated.",
      "cat output.json | jq '@text \"status: \\(.executions[].status)\"'",
      "The output is:",
      "\"status: RUNNING\"",
      "\"status: RUNNING\""
    ],
    "utterance": "Extract all values for the 'status' field inside the 'executions' array and output them as formatted lines 'status: RUNNING'.",
    "expressions": [
      ".executions[].status",
      "{status: .executions[].status}",
      "@text \"status: \\(.executions[].status)\""
    ],
    "data": [
      {
        "input": {
          "executions": [
            {
              "executionArn": "execution:job-execution:1ddb41e1-0d71-4dde-9cd0-d55119be334d",
              "stateMachineArn": "stateMachine:job-execution",
              "name": "jjfjnsldfnowef",
              "status": "RUNNING",
              "startDate": 1609918173.79
            },
            {
              "executionArn": "execution:job-execution:c07927bc-d871-4996-a58a-f9c89cbd351f",
              "stateMachineArn": "stateMachine:job-execution",
              "name": "c07927bc-23jjfnjfjs",
              "status": "RUNNING",
              "startDate": 1609918124.174
            }
          ]
        },
        "output": [
          "status: RUNNING",
          "status: RUNNING"
        ]
      }
    ],
    "identifier": 65593818
  },
  {
    "context": [
      "I only want output for such elements.",
      "How can i avoid the \"\" output (there should be no output for other JSON elements)?",
      "You could use `empty` instead of \"\" to solve the problem, but using `select()` to filter out unwanted stream elements is a cleaner solution.",
      "jq --unbuffered '\n   select(\n      .remote_ip != null and\n      .method == \"POST\" and\n      .path == \"/users/sign_in\" and\n      .action == \"create\"\n   ) |\n   .ua + \" \" + .remote_ip\n'"
    ],
    "utterance": "Output the user agent and remote IP for entries where remote_ip exists, method is POST, path is /users/sign_in, and action is create; return nothing for all other entries.",
    "expressions": [
      "select(.remote_ip != null and .method == \"POST\" and .path == \"/users/sign_in\" and .action == \"create\") | .ua + \" \" + .remote_ip"
    ],
    "data": [
      {
        "input": {
          "method": "POST",
          "path": "/users/sign_in",
          "format": "html",
          "controller": "SessionsController",
          "action": "create",
          "status": 302,
          "duration": 146.22,
          "view": 0,
          "db": 16.64,
          "location": "https://maschm.ddnss.de/",
          "time": "2021-01-05T11:44:30.180Z",
          "params": [
            {
              "key": "utf8",
              "value": "\u2713"
            },
            {
              "key": "authenticity_token",
              "value": "[FILTERED]"
            },
            {
              "key": "user",
              "value": {
                "login": "root",
                "password": "[FILTERED]",
                "remember_me": "0"
              }
            }
          ],
          "remote_ip": "46.86.21.18",
          "user_id": 1,
          "username": "root",
          "ua": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0.2 Safari/605.1.15",
          "queue_duration": 7.3,
          "correlation_id": "JtnY93e2ti8"
        },
        "output": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0.2 Safari/605.1.15 46.86.21.18"
      }
    ],
    "identifier": 65625174
  },
  {
    "context": [
      "Im trying to use jq to extract information from Youtube json information with youtube-dl and format the output to look good.",
      "This is the output style I'm after.\n```\n- TITLE -\nCruising \u2013 Vendredi (No Copyright Music)\n\n- CHANNEL -\nAudio Library \u2014 Music for content creators\n\n- CHANNEL URL -\nhttps://www.youtube.com/watch?v=TWeRJdrpxEU\n```",
      "To emit the strings without quotation marks, simply use the `-r` command-line option.",
      "To add the headers, you could modify your filter as follows:\n\n```\n\"- TITLE -\", .title,\n\"- CHANNEL -\", .uploader,\n\"- CHANNEL URL -\", .webpage_url\n```"
    ],
    "utterance": "Produce output with section headers for the title, uploader, and webpage URL values, using plain text without quotation marks.",
    "expressions": [
      "\"- TITLE -\", .title, \"\\n- CHANNEL -\", .uploader, \"\\n- CHANNEL URL -\", .webpage_url"
    ],
    "data": [
      {
        "input": {
          "title": "Cruising \u2013 Vendredi (No Copyright Music)",
          "uploader": "Audio Library \u2014 Music for content creators",
          "webpage_url": "https://www.youtube.com/watch?v=TWeRJdrpxEU"
        },
        "output": "- TITLE -\nCruising \u2013 Vendredi (No Copyright Music)\n\n- CHANNEL -\nAudio Library \u2014 Music for content creators\n\n- CHANNEL URL -\nhttps://www.youtube.com/watch?v=TWeRJdrpxEU"
      }
    ],
    "identifier": 65648221
  },
  {
    "context": [
      "What I want to do is to rewrite only the value of the first json for the value of the second json for the Date_and_Time",
      "jq version summary:\r\n\r\nIt is basically all there except for the file input part.\r\n\r\n    $ jq -s '.[0] as $oldvals\n             |.[1] as $newvals\n             |reduce range($oldvals|length) as $idx\n             (\n               $oldvals;\n               .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time\n             )' file1.json file2.json > file3.json",
      "jq '\n  input as $in\n  | reduce range(length) as $i (.;\n      .[$i].Date_and_Time = $in[$i].Date_and_Time)\n' f1 f2",
      "jq -n '\n  input as $f2\n  | input\n  | reduce range(length) as $i (.;\n      .[$i].Date_and_Time = $f2[$i].Date_and_Time)\n' f2 f1"
    ],
    "utterance": "Replace each object's Date_and_Time field in the first array with the corresponding value from the second array, matching by array index.",
    "expressions": [
      "jq -s '.[0] as $oldvals | .[1] as $newvals | reduce range($oldvals|length) as $idx ( $oldvals; .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time )' file1.json file2.json",
      "jq 'input as $in | reduce range(length) as $i (.; .[$i].Date_and_Time = $in[$i].Date_and_Time)' f1 f2",
      "jq -n 'input as $f2 | input | reduce range(length) as $i (.; .[$i].Date_and_Time = $f2[$i].Date_and_Time)' f2 f1"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Date_and_Time": "Dec 29, 2017 15:35:37",
              "Componente": "Bar",
              "Country": "Brazil",
              "Age": "3"
            },
            {
              "Date_and_Time": "Dec 31, 2017 17:35:37",
              "Componente": "Foo",
              "Country": "France",
              "Id": "123456",
              "Car": "Ferrari"
            }
          ],
          [
            {
              "Date_and_Time": "Dec 31, 2017 17:35:37",
              "Age": "1",
              "Country": "France",
              "Id": "123456",
              "Car": "Ferrari"
            },
            {
              "Date_and_Time": "Mar 31, 2018 14:35:37",
              "Componente": "Foo",
              "Country": "Germany",
              "Id": "2468",
              "Genre": "Male"
            }
          ]
        ],
        "output": [
          {
            "Date_and_Time": "Dec 31, 2017 17:35:37",
            "Componente": "Bar",
            "Country": "Brazil",
            "Age": "3"
          },
          {
            "Date_and_Time": "Mar 31, 2018 14:35:37",
            "Componente": "Foo",
            "Country": "France",
            "Id": "123456",
            "Car": "Ferrari"
          }
        ]
      }
    ],
    "identifier": 65629369
  },
  {
    "context": [
      "And I would like to extract emails values : **mail@domain1.com** and **mail@domain2.com**",
      "If you only need to extract the emails from `.criteria.from` then this filter is enough as far as I can tell:",
      "jq --raw-output '.filter[].criteria.from' file.json"
    ],
    "utterance": "Extract the values of the 'from' property from all elements in the 'filter' array.",
    "expressions": [
      ".filter[].criteria.from"
    ],
    "data": [
      {
        "input": {
          "filter": [
            {
              "id": "id_1",
              "criteria": {
                "from": "mail@domain1.com",
                "subject": "subject_1"
              },
              "action": {
                "addLabelIds": [
                  "Label_id_1"
                ],
                "removeLabelIds": [
                  "INBOX",
                  "SPAM"
                ]
              }
            },
            {
              "id": "id_2",
              "criteria": {
                "from": "mail@domain2.com",
                "subject": "subject_1"
              },
              "action": {
                "addLabelIds": [
                  "Label_id_2"
                ],
                "removeLabelIds": [
                  "INBOX",
                  "SPAM"
                ]
              }
            }
          ]
        },
        "output": [
          "mail@domain1.com",
          "mail@domain2.com"
        ]
      }
    ],
    "identifier": 65670810
  },
  {
    "context": [
      "How can I replace the Image used in a Kubernetes Deployment manifest with jq?",
      "I tried using something like this `jq '.spec.template.spec.containers[0].image = \"myapp:v2\"'`. However, it always ends with a syntax or parse error."
    ],
    "utterance": "Replace the value of the image field for the first container in a Kubernetes Deployment manifest with a new image name, such as myapp:v2.",
    "expressions": [
      ".spec.template.spec.containers[0].image = \"myapp:v2\""
    ],
    "data": [
      {
        "input": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "metadata": {
            "labels": {
              "app": "myapp"
            },
            "name": "myapp-deployment"
          },
          "spec": {
            "replicas": 1,
            "template": {
              "spec": {
                "containers": [
                  {
                    "name": "myapp",
                    "image": "myapp:v1"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "metadata": {
            "labels": {
              "app": "myapp"
            },
            "name": "myapp-deployment"
          },
          "spec": {
            "replicas": 1,
            "template": {
              "spec": {
                "containers": [
                  {
                    "name": "myapp",
                    "image": "myapp:v2"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 65652129
  },
  {
    "context": [
      "The <filename.json> | JQ .[] command returns the array split into multiple items rather one for one \"Value\". How to write JQ Command to ensure that the returned parse value including special character, whitespace is not trimmed or splitted to new item of array.",
      "Example:  for \"location_art\":\"This is space string\" --> The value is getting split which I don't want. How to fix this issue.",
      "jq -r '.order_items[].print_locations[].location_art' response_1.json"
    ],
    "utterance": "Extract all location_art values, including those with spaces and special characters, and preserve each value as a single item.",
    "expressions": [
      ".order_items[].print_locations[].location_art",
      "-r .order_items[].print_locations[].location_art"
    ],
    "identifier": 65688908
  },
  {
    "context": [
      "how can we convert the output into JSON format and then store them in a variable.",
      "JQ does that for you and populates an internal variable called `ENV` with the result, which can be exported to a shell variable like so:",
      "var=$(jq -n '$ENV')",
      "To remove junk variables like `_`, `SHLVL`, etc. from the list you can use the [`del`](https://stedolan.github.io/jq/manual/#del(path_expression)) function.",
      "var=$(jq -n '$ENV | del(._, .SHLVL)')"
    ],
    "utterance": "Store the current shell's environment variables as a variable formatted as an object with keys and values, optionally removing variables like _ and SHLVL.",
    "expressions": [
      "jq -n '$ENV'",
      "jq -n '$ENV | del(._, .SHLVL)'"
    ],
    "identifier": 65707623
  },
  {
    "context": [
      "I tried to get jq to pull only the latest unique message based on the source but can't quite figure it out.",
      "For this example, the result should be:\n\n    [{\"source\":\"+13102345678\",\"message\":\"3\"},{\"source\":\"+13101234567\",\"message\":\"4\"},{\"source\":\"+13105678901\",\"message\":\"4\"}]",
      "[inputs.envelope\n | {source, \n    message: .dataMessage.message,\n    timestamp: .dataMessage.timestamp}]\n| group_by(.source)\n| [ .[] | max_by(.timestamp) | {source, message} ]"
    ],
    "utterance": "Output the most recent message and its corresponding source for each unique source, based on the highest timestamp.",
    "expressions": [
      "[inputs.envelope\n | {source, \n    message: .dataMessage.message,\n    timestamp: .dataMessage.timestamp}]\n| group_by(.source)\n| [ .[] | max_by(.timestamp) | {source, message} ]"
    ],
    "data": [
      {
        "input": [
          {
            "envelope": {
              "source": "+13101234567",
              "sourceDevice": 1,
              "relay": null,
              "timestamp": 1610256979995,
              "dataMessage": {
                "timestamp": 1610256979995,
                "message": "Yes",
                "expiresInSeconds": 0,
                "reaction": null,
                "quote": null,
                "mentions": [],
                "attachments": [],
                "groupInfo": null
              },
              "syncMessage": null,
              "callMessage": null,
              "receiptMessage": null
            }
          },
          {
            "envelope": {
              "source": "+13102345678",
              "sourceDevice": 1,
              "relay": null,
              "timestamp": 1610256985623,
              "dataMessage": {
                "timestamp": 1610256985623,
                "message": "1",
                "expiresInSeconds": 0,
                "reaction": null,
                "quote": null,
                "mentions": [],
                "attachments": [],
                "groupInfo": null
              },
              "syncMessage": null,
              "callMessage": null,
              "receiptMessage": null
            }
          },
          {
            "envelope": {
              "source": "+13102345678",
              "sourceDevice": 1,
              "relay": null,
              "timestamp": 1610256987736,
              "dataMessage": {
                "timestamp": 1610256987736,
                "message": "3",
                "expiresInSeconds": 0,
                "reaction": null,
                "quote": null,
                "mentions": [],
                "attachments": [],
                "groupInfo": null
              },
              "syncMessage": null,
              "callMessage": null,
              "receiptMessage": null
            }
          },
          {
            "envelope": {
              "source": "+13101234567",
              "sourceDevice": 1,
              "relay": null,
              "timestamp": 1610256990731,
              "dataMessage": {
                "timestamp": 1610256990731,
                "message": "4",
                "expiresInSeconds": 0,
                "reaction": null,
                "quote": null,
                "mentions": [],
                "attachments": [],
                "groupInfo": null
              },
              "syncMessage": null,
              "callMessage": null,
              "receiptMessage": null
            }
          },
          {
            "envelope": {
              "source": "+13105678901",
              "sourceDevice": 1,
              "relay": null,
              "timestamp": 1610256990731,
              "dataMessage": {
                "timestamp": 1610256990731,
                "message": "4",
                "expiresInSeconds": 0,
                "reaction": null,
                "quote": null,
                "mentions": [],
                "attachments": [],
                "groupInfo": null
              },
              "syncMessage": null,
              "callMessage": null,
              "receiptMessage": null
            }
          }
        ],
        "output": [
          {
            "source": "+13102345678",
            "message": "3"
          },
          {
            "source": "+13101234567",
            "message": "4"
          },
          {
            "source": "+13105678901",
            "message": "4"
          }
        ]
      }
    ],
    "identifier": 65650703
  },
  {
    "context": [
      "I need to extract each object using filename as key, which is done by",
      "jq -r \".[] | select(.file | contains(\"q2c\"))\"",
      "Unfortunately, there are conflicts and when objects are not unique, I need to merge them.",
      "for instance",
      "obtained answer:",
      "{\n  \"file\": \"PDF/Test_q2c.pdf\",\n  \"rotation\": \"90\",\n  \"fiducial\": \"true\",\n  \"nopdf\": \"true\"\n}\n{\n  \"file\": \"PDF/Test_q2c.pdf\",\n  \"rotation\": \"90\",\n  \"fiducial\": \"true\",\n  \"x\":\"false\"\n}",
      "expected answer",
      "{\n  \"file\": \"PDF/Test_q2c.pdf\",\n  \"rotation\": \"90\",\n  \"fiducial\": \"true\",\n  \"nopdf\": \"true\",\n  \"x\":\"false\"\n}",
      "jq --slurp 'add | map(select(.file | contains(\"q2c\"))) | add'",
      "reduce (inputs[] | select(.file|contains(\"q2c\"))) as $in (null;\n  .[$in.file] += $in)\n| .[]",
      "GROUPS_BY(inputs[] | select(.file|contains(\"q2c\")); .file)\n| add"
    ],
    "utterance": "Select all objects whose file name contains 'q2c' and merge objects with the same file name into a single object containing all unique fields.",
    "expressions": [
      "jq --slurp 'add | map(select(.file | contains(\"q2c\"))) | add'",
      "reduce (inputs[] | select(.file|contains(\"q2c\"))) as $in (null; .[$in.file] += $in) | .[]",
      "def GROUPS_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ; GROUPS_BY(inputs[] | select(.file|contains(\"q2c\")); .file) | add"
    ],
    "data": [
      {
        "input": [
          {
            "file": "PDF/College Louise Mich\u00e8le 402.pdf",
            "rotation": "-90",
            "fiducial": false
          }
        ],
        "output": null
      },
      {
        "input": [
          {
            "file": "PDF/Test_q2c.pdf",
            "rotation": "90",
            "fiducial": "true",
            "nopdf": "true"
          },
          {
            "file": "PDF/Test_q2c.pdf",
            "rotation": "90",
            "fiducial": "true",
            "x": "false"
          }
        ],
        "output": {
          "file": "PDF/Test_q2c.pdf",
          "rotation": "90",
          "fiducial": "true",
          "nopdf": "true",
          "x": "false"
        }
      }
    ],
    "identifier": 65651244
  },
  {
    "context": [
      "I am having the following array of objects that I would like to filter down. Like this:\r\n\r\n    1. LOGGEDIN == 0\r\n    2. Timestamp older than 5 minutes\r\n    3. IDLETIME > 60 && CPULOAD < 200",
      "I\u2019d like to wrap these up so that I end up with one array of objects, matching the filters and another array of objects, that do not.",
      "jq --arg TSCUT \"$( date --date='5 minutes ago' +%s )\" '\r\n   map(\r\n      ._f = (\r\n         .LOGGEDIN == \"0\" and\r\n         ( .TIMESTAMP | sub(\" \"; \"T\") + \"Z\" | fromdateiso8601 ) < $TSCUT and\r\n         ( .IDLETIME | tonumber ) > 60 and\r\n         ( .CPULOAD | tonumber ) < 200\r\n      )\r\n   ) |\r\n   . as $a |\r\n   {\r\n      \"matches\":     [ $a[] | select( ._f       ) | del(._f) ],\r\n      \"non-matches\": [ $a[] | select( ._f | not ) | del(._f) ]\r\n   }\r\n'",
      "Your timestamps are not valid ISO8601 timestamps, much less what `fromdateiso8601` expects."
    ],
    "utterance": "Separate the input array into two arrays: one with objects where LOGGEDIN equals \"0\", TIMESTAMP is older than 5 minutes, IDLETIME greater than 60, and CPULOAD less than 200, and another with the rest.",
    "expressions": [
      "map(\n  ._f = (\n    .LOGGEDIN == \"0\" and\n    (.TIMESTAMP | sub(\" \"; \"T\") + \"Z\" | fromdateiso8601 ) < $TSCUT and\n    (.IDLETIME | tonumber ) > 60 and\n    (.CPULOAD | tonumber ) < 200\n  )\n) |\n. as $a |\n{\n  matches:     [ $a[] | select( ._f ) | del(._f) ],\n  non-matches: [ $a[] | select( ._f | not ) | del(._f) ]\n}"
    ],
    "data": [
      {
        "input": [
          {
            "SERIAL": "XXXSERIAL1XXX",
            "TIMESTAMP": "2020-12-17 18:45:14",
            "EMAIL": "email1@mydomain.com",
            "LOGGEDIN": "0",
            "IDLETIME": "122",
            "CPULOAD": "2",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL2XXX",
            "TIMESTAMP": "2020-12-17 18:43:29",
            "EMAIL": "email2@mydomain.com",
            "LOGGEDIN": "1",
            "IDLETIME": "0",
            "CPULOAD": "0",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL3XXX",
            "TIMESTAMP": "2020-12-17 18:46:37",
            "EMAIL": "email1@mydomain.com",
            "LOGGEDIN": "1",
            "IDLETIME": "0",
            "CPULOAD": "0",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL4XXX",
            "TIMESTAMP": "2020-12-17 18:45:23",
            "EMAIL": "email3@mydomain.com",
            "LOGGEDIN": "0",
            "IDLETIME": "0",
            "CPULOAD": "13",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL5XXX",
            "TIMESTAMP": "2020-12-17 18:47:02",
            "EMAIL": "email2@mydomain.com",
            "LOGGEDIN": "1",
            "IDLETIME": "0",
            "CPULOAD": "0",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL6XXX",
            "TIMESTAMP": "2020-12-17 18:43:42",
            "EMAIL": "email3@mydomain.com",
            "LOGGEDIN": "1",
            "IDLETIME": "10",
            "CPULOAD": "20",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL7XXX",
            "TIMESTAMP": "2020-12-17 18:43:29",
            "EMAIL": "email4@mydomain.com",
            "LOGGEDIN": "1",
            "IDLETIME": "0",
            "CPULOAD": "0",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL8XXX",
            "TIMESTAMP": "2020-12-17 18:46:02",
            "EMAIL": "email4@mydomain.com",
            "LOGGEDIN": "0",
            "IDLETIME": "0",
            "CPULOAD": "0",
            "BLOCKED": "0"
          },
          {
            "SERIAL": "XXXSERIAL9XXX",
            "TIMESTAMP": "2020-12-17 18:45:23",
            "EMAIL": "email1@mydomain.com",
            "LOGGEDIN": "0",
            "IDLETIME": "443",
            "CPULOAD": "666",
            "BLOCKED": "0"
          }
        ]
      }
    ],
    "identifier": 65552017
  },
  {
    "context": [
      "Lets say I have the following declared in bash:\n```\nmcD=\"had_a_farm\"\neei=\"eeieeio\"\ndeclare -A animals=( [\"duck\"]=\"quack_quack\" [\"cow\"]=\"moo_moo\" [\"pig\"]=\"oink_oink\" )\n```",
      "and I want the following json:\n```\n{\n  \"oldMcD\": \"had a farm\",\n  \"eei\": \"eeieeio\",\n  \"onThisFarm\":[\n    {\n      \"duck\": \"quack_quack\",\n      \"cow\": \"moo_moo\",\n      \"pig\": \"oink_oink\"\n    }\n  ]\n}\n```",
      "How can I build a json like this in an efficient, logical manner?",
      "for i in \"${!animals[@]}\"; do\n    echo \"$i\"\n    echo \"${animals[$i]}\"\ndone |\njq -n -R --arg mcD \"$mcD\" --arg eei \"$eei\" 'reduce inputs as $i ({onThisFarm: [], mcD: $mcD, eei: $eei}; .onThisFarm[0] += {($i): (input | tonumber ? // .)})'",
      "for i in \"${!animals[@]}\"\ndo\n  printf \"%s\\n%s\\n\"  \"${i}\" \"${animals[$i]}\"\ndone | jq -nR --arg oldMcD \"$mcD\" --arg eei \"$eei\" '\n  def to_o:\n    . as $in\n    | reduce range(0;length;2) as $i ({}; \n        .[$in[$i]]= $in[$i+1]);\n\n  {$oldMcD, \n   $eei,\n   onthisfarm: [inputs] | to_o}\n'"
    ],
    "utterance": "Combine two scalar variables with an associative array of key-value pairs to create an object with the scalars and a nested array containing a single object with the key-value pairs.",
    "expressions": [
      "jq -n -R --arg mcD \"$mcD\" --arg eei \"$eei\" 'reduce inputs as $i ({onThisFarm: [], mcD: $mcD, eei: $eei}; .onThisFarm[0] += {($i): (input | tonumber ? // .)})'",
      "jq -nR --arg oldMcD \"$mcD\" --arg eei \"$eei\" '\n  def to_o:\n    . as $in\n    | reduce range(0;length;2) as $i ({}; \n        .[$in[$i]]= $in[$i+1]);\n\n  {$oldMcD, \n   $eei,\n   onthisfarm: [inputs] | to_o}\n'"
    ],
    "data": [
      {
        "input": {
          "mcD": "had_a_farm",
          "eei": "eeieeio",
          "animals": {
            "duck": "quack_quack",
            "cow": "moo_moo",
            "pig": "oink_oink"
          }
        },
        "output": {
          "oldMcD": "had_a_farm",
          "eei": "eeieeio",
          "onThisFarm": [
            {
              "duck": "quack_quack",
              "cow": "moo_moo",
              "pig": "oink_oink"
            }
          ]
        }
      }
    ],
    "identifier": 65678915
  },
  {
    "context": [
      "But the moment there's a null, this blows up.  Suppose I change my JSON:",
      "then when I run the same command, what I would expect to get would be something like ",
      "[ { \"author\": [ \"Scmoe\", \"Smith\" ], \"title\": \"I wrote words!\" }, { \"author\": [], \"title\": \"These are more words!\" } ]",
      "Is there any way I can get the value extraction to just handle nulls sensibly?",
      "A straightforward solution would be to test for `null`, e.g.",
      "[.[] | {author, title} | .author |= if . then map(.family) else [] end ]",
      "or similarly:",
      "map({author: (.author | if type == \"array\" then map(.family) else [] end), title} )"
    ],
    "utterance": "Extract the family names from the author field for each object, defaulting to an empty array if author is null, and return a list of objects containing these arrays and the title.",
    "expressions": [
      "[.[] | {author, title} | .author |= if . then map(.family) else [] end ]",
      "map({author: (.author | if type == \"array\" then map(.family) else [] end), title})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "JoeSchmoe2020",
            "abstract": "Here's some junk",
            "author": [
              {
                "family": "Scmoe",
                "given": "Joe"
              },
              {
                "family": "Smith",
                "given": "Sally"
              }
            ],
            "title": "I wrote words!"
          },
          {
            "id": "EdithJones2020",
            "abstract": "It's an abstract",
            "author": null,
            "title": "These are more words!"
          }
        ],
        "output": [
          {
            "author": [
              "Scmoe",
              "Smith"
            ],
            "title": "I wrote words!"
          },
          {
            "author": [],
            "title": "These are more words!"
          }
        ]
      }
    ],
    "identifier": 65694712
  },
  {
    "context": [
      "I want to extract data from the below JSON file:",
      "In case the image doesn't open this is how I want the data once delimited in excel sheet (pipe in below output represent the lines in excel sheet ).",
      "fellowId | srId            |belongingf2fAmount          | f2fAmount",
      "101777   | wfakfjaslkf7kev | g2gf2f                     |1247.0",
      "         |                 | prioritybelongingf2fAmount |1247.0 ",
      "         |                 | netPf2f                    |3743.6",
      "         |                 |bbelongingf2fAmount         |0.0",
      "         |                 |activitybelongingf2fAmount  |0.0",
      "         |                 |otherbelongingf2fAmount     |0.0",
      "Use jq and pipe the output to printf to format the data as required:"
    ],
    "utterance": "Extract the fields fellowId, srId, and, for each object under people.educationHistory[].fee7History[0].belongingf2fAmount, the keys g2gf2f, prioritybelongingf2fAmount, netPf2f, bbelongingf2fAmount, activitybelongingf2fAmount, otherbelongingf2fAmount, each with their f2fAmount values, in a tabular format with corresponding field names.",
    "expressions": [
      ".fellowId, .srId, \"g2gf2f\", .people.educationHistory[].fee7History[0].belongingf2fAmount.g2gf2f.f2fAmount, \"prioritybelongingf2fAmount\", .people.educationHistory[].fee7History[0].belongingf2fAmount.prioritybelongingf2fAmount.f2fAmount, \"netPf2f\", .people.educationHistory[].fee7History[0].belongingf2fAmount.netPf2f.f2fAmount, \"bbelongingf2fAmount\", .people.educationHistory[].fee7History[0].belongingf2fAmount.bbelongingf2fAmount.f2fAmount, \"activitybelongingf2fAmount\", .people.educationHistory[].fee7History[0].belongingf2fAmount.activitybelongingf2fAmount.f2fAmount, \"otherbelongingf2fAmount\", .people.educationHistory[].fee7History[0].belongingf2fAmount.otherbelongingf2fAmount.f2fAmount"
    ],
    "data": [
      {
        "input": {
          "fellowId": 101777,
          "srId": "wfakfjaslkf7kev",
          "goId": "x21akjsdfvg",
          "people": {
            "Date": "2020-10-30",
            "computerID": {
              "id": "772",
              "nameid": {
                "name": "student",
                "code": "std"
              }
            },
            "Data": {
              "personName": {
                "givenName": "john",
                "familyName": "doe"
              },
              "communication": {
                "telephones": [
                  {}
                ],
                "emails": [
                  {
                    "emailid": "john@doe.com"
                  }
                ],
                "ia": []
              },
              "address": {
                "lineOne": "124 Marie Drive",
                "cityName": "Lake",
                "sd1": {
                  "name": "MA"
                },
                "country": "LA",
                "postalCode": "12345"
              }
            },
            "educationHistory": [
              {
                "edu": "st mary high school",
                "EntityID": {
                  "EntityID": "3371",
                  "country": null
                },
                "sAddress": {
                  "lineOne": "PO Box 4463",
                  "cityName": "bridge",
                  "sd1": {
                    "name": "MA"
                  },
                  "country": "LA",
                  "postalCode": "74525"
                },
                "reopenDate": "2021-09-01",
                "workerStatusCode": {
                  "name": "Active",
                  "code": "A"
                },
                "durationCourse": {
                  "name": "Full time",
                  "code": "Full time"
                },
                "schoolStartDate": "2020-01-07",
                "Duration": "O0U4N2D",
                "Hours": 166,
                "feeSummary": [
                  {
                    "startyear": 2020,
                    "fee1": {
                      "f2fAmount": 9168.0,
                      "currency": "rs"
                    },
                    "activitybelongingf2fAmount": [
                      {
                        "type": "tution",
                        "rf2fAmount": {
                          "f2fAmount": 0.0,
                          "ccode": "ben"
                        }
                      },
                      {
                        "rTypeCode": "YTD sent",
                        "rf2fAmount": {
                          "f2fAmount": 0.0,
                          "ccode": "ben"
                        }
                      },
                      {
                        "rTypeCode": "YTD Others",
                        "rf2fAmount": {
                          "f2fAmount": 0.0,
                          "ccode": "ben"
                        }
                      }
                    ],
                    "totalf2fAmount": {
                      "f2fAmount": 9168.0,
                      "ccode": "ben"
                    },
                    "belongingablef2fAmount": {
                      "f2fAmount": 7487.2,
                      "ccode": "ben"
                    }
                  }
                ],
                "fee7History": [
                  {
                    "acadamyReedem": true,
                    "qDIndicator": null,
                    "belongingDate": "2020-10-30",
                    "belongingPeriod": {
                      "startDate": "2020-10-01",
                      "endDate": "2020-10-31"
                    },
                    "belongingf2fAmount": {
                      "g2gf2f": {
                        "f2fAmount": 1247.0,
                        "ccode": "ben"
                      },
                      "prioritybelongingf2fAmount": {
                        "f2fAmount": 1247.0,
                        "ccode": "ben"
                      },
                      "netPf2f": {
                        "f2fAmount": 3743.6,
                        "ccode": "ben"
                      },
                      "bbelongingf2fAmount": {
                        "f2fAmount": 0.0,
                        "ccode": "ben"
                      },
                      "activitybelongingf2fAmount": {
                        "f2fAmount": 0.0,
                        "ccode": "ben"
                      },
                      "otherbelongingf2fAmount": {
                        "f2fAmount": 0.0,
                        "ccode": "ben"
                      }
                    },
                    "durationHours": "166.0",
                    "BaCode": {
                      "name": "marks",
                      "code": null
                    },
                    "bPRate": {
                      "f2fAmount": 1247.0,
                      "ccode": "ben"
                    },
                    "CycleCode": {
                      "name": "yearly",
                      "code": "M"
                    },
                    "belongingDistributions": [
                      {
                        "depositf2fAmount": {
                          "f2fAmount": 3743.6,
                          "ccode": "ben"
                        },
                        "deAccount": {
                          "transportid": "260",
                          "studNumber": "1949",
                          "accountTypeCode": "geography"
                        }
                      }
                    ],
                    "donations": [
                      {
                        "dCode": {
                          "name": "secondary donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 852.16,
                          "ccode": "ben"
                        }
                      },
                      {
                        "dCode": {
                          "name": "house donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 220.56,
                          "ccode": "ben"
                        }
                      },
                      {
                        "dCode": {
                          "name": "cloths donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 0.0,
                          "ccode": "ben"
                        }
                      },
                      {
                        "dCode": {
                          "name": "Social donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 284.21,
                          "ccode": "ben"
                        }
                      },
                      {
                        "dCode": {
                          "name": "medical donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 66.47,
                          "ccode": "ben"
                        }
                      },
                      {
                        "dCode": {
                          "name": "uuui donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 0.0,
                          "ccode": "ben"
                        }
                      },
                      {
                        "dCode": {
                          "name": "food donations",
                          "code": null
                        },
                        "donationoff2fAmount": {
                          "f2fAmount": 0.0,
                          "ccode": "ben"
                        }
                      }
                    ]
                  }
                ]
              }
            ],
            "historySummary": {
              "availableStay": 1,
              "includedSourceCount": 1,
              "availableHistoryMonths": {
                "DataMonthCount": 1,
                "qDataMCount": 0
              }
            },
            "ffsaId": "21567-4565125-451284512-852741963",
            "stayProvider": "usssslad"
          }
        },
        "output": [
          "101777  | wfakfjaslkf7kev       | g2gf2f                        | 1247.0",
          "        |                       | prioritybelongingf2fAmount    | 1247.0",
          "        |                       | netPf2f                       | 3743.6",
          "        |                       | bbelongingf2fAmount           | 0.0",
          "        |                       | activitybelongingf2fAmount    | 0.0",
          "        |                       | otherbelongingf2fAmount       | 0.0"
        ]
      }
    ],
    "identifier": 65586855
  }
]