[
  {
    "identifier": 60389427
  },
  {
    "context": [
      "I need to merge into `master.json` contents of `\"a\"` key from `extra.json`, ignoring all other keys the second JSON may have.",
      "$ jq '.a += input.a' master.json extra.json ",
      "jq -s '[].a = ([].a|add|unique)|.[0]' master.json extra.json",
      "You can remove the `unique` part, if you are allowed to keep duplicate objects for the array."
    ],
    "utterance": "Combine the array under key 'a' from both files so that the result includes all elements of 'a' from each file, keeping all other keys from the first file and ignoring unrelated keys from the second file.",
    "expressions": [
      ".a += input.a",
      ".[].a = ([].a|add|unique)|.[0]",
      ".[].a = ([].a|add)|.[0]"
    ],
    "data": [
      {
        "input": {
          "master.json": {
            "a": [
              {
                "x": 1
              }
            ],
            "b": 1
          },
          "extra.json": {
            "a": [
              {
                "x": 2
              }
            ],
            "somekey2": 2,
            "somekey3": 3
          }
        },
        "output": {
          "a": [
            {
              "x": 1
            },
            {
              "x": 2
            }
          ],
          "b": 1
        }
      }
    ],
    "identifier": 60396693
  },
  {
    "context": [
      "Using JQ, how can import them into a json file like:",
      "{",
      "  \"pem\": \"-----BEGIN RSA PRIVATE KEY-----\\n...\\n-----END RSA PRIVATE KEY-----\",",
      "  \"pub\": \"ssh-rsa AAAAB3NzaC1yc2EAAA...\"",
      "}",
      "jq -Rs --rawfile pub id_rsa.pub '{pem: ., pub: $pub}' id_rsa"
    ],
    "utterance": "Combine the contents of two files, assigning one to the 'pem' key and the other to the 'pub' key in an object.",
    "expressions": [
      "jq -Rs --rawfile pub id_rsa.pub '{pem: ., pub: $pub}' id_rsa"
    ],
    "data": [
      {
        "input": {
          "id_rsa": "-----BEGIN RSA PRIVATE KEY-----\nabc123\n-----END RSA PRIVATE KEY-----\n",
          "id_rsa.pub": "ssh-rsa AAAAB3NzaC1yc2EAAAAB\n"
        },
        "output": {
          "pem": "-----BEGIN RSA PRIVATE KEY-----\nabc123\n-----END RSA PRIVATE KEY-----\n",
          "pub": "ssh-rsa AAAAB3NzaC1yc2EAAAAB\n"
        }
      }
    ],
    "identifier": 60418971
  },
  {
    "context": [
      "I have 2 files, both are lists of objects where one of them ha field references to object ids of the other one",
      "my goal would be to get a denormalized object list:",
      "I end up in headaches and looking forward to write a ineffective while routine in any language ... hopefully I would appreciate any help on this",
      "Transform the second file into an object where ids and names are paired and use it as a reference while updating the first file.",
      "`jq '(map({(.id): .}) | add) as $idx | input | map_values(.reference = $idx[.reference.id])' file2 file1`",
      "The following solution uses the same strategy as used in the solution by @OguzIsmail but uses the built-in function `INDEX/2` to construct the dictionary from the second file.",
      "INDEX($file2[]; .id) as $dict | map(.reference.id as $id | .reference = $dict[$id])"
    ],
    "utterance": "For each object in the first list, replace the reference field with the full object from the second list whose id matches reference.id, including all properties.",
    "expressions": [
      "(map({(.id): .}) | add) as $idx | input | map_values(.reference = $idx[.reference.id])",
      "INDEX($file2[]; .id) as $dict | map(.reference.id as $id | .reference = $dict[$id])"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "5b9f50ccdcdf200283f29052",
              "reference": {
                "id": "5de82d5072f4a72ad5d5dcc1"
              }
            }
          ],
          [
            {
              "id": "5de82d5072f4a72ad5d5dcc1",
              "name": "FooBar"
            }
          ]
        ],
        "output": [
          {
            "id": "5b9f50ccdcdf200283f29052",
            "reference": {
              "id": "5de82d5072f4a72ad5d5dcc1",
              "name": "FooBar"
            }
          }
        ]
      }
    ],
    "identifier": 60413215
  },
  {
    "context": [
      "to output:\r\n\r\n```\r\nb 1\r\nb 2\r\nd 1\r\nd 2\r\n```",
      "The following adaptation produces the desired output:\r\n\r\n```\r\necho '{\"a\":{\"value\":\"b\"}, \"c\":{\"value\":\"d\"}}' |\r\n  jq -r '\r\n    def addindex(start;lessthan): \r\n      range(start;lessthan) as $i | \"\\(.) \\($i)\";\r\n    . as $in\r\n    | keys[]\r\n    | $in[.].value\r\n    | addindex(1;3)'\r\n```"
    ],
    "utterance": "Produce one line for each value, pairing it with both 1 and 2 as in 'b 1', 'b 2', 'd 1', and 'd 2'.",
    "expressions": [
      "def addindex(start;lessthan): range(start;lessthan) as $i | \"\\(.) \\($i)\"; . as $in | keys[] | $in[.].value | addindex(1;3)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "value": "b"
          },
          "c": {
            "value": "d"
          }
        },
        "output": [
          "b 1",
          "b 2",
          "d 1",
          "d 2"
        ]
      }
    ],
    "identifier": 60420975
  },
  {
    "context": [
      "aws cloudwatch get-metric-statistics --metric-name CPUUtilization --start-time 2010-02-20T12:00:00 --end-time 2010-02-20T15:00:00 --period 60 --namespace AWS/EC2  --extended-statistics p80 --dimensions Name=InstanceId,Value=i-0b123423423",
      "aws cloudwatch get-metric-statistics ... | jq '.Datapoints[].ExtendedStatistics[]'",
      "How can i calculate and run operations from the values in above output to get results like below in using Bash scripting",
      "Instance above 70% \nInstance-ABC\nInstance-BCD",
      "Instances below 20% \nInstance-EFG\nInstance-HIJ"
    ],
    "utterance": "Extract all p80 values from ExtendedStatistics for each instance and identify instances where any p80 value is above 70 or below 20.",
    "expressions": [
      ".Datapoints[].ExtendedStatistics.p80",
      "map(select(.Datapoints[].ExtendedStatistics.p80 > 70 or .Datapoints[].ExtendedStatistics.p80 < 20)) | .[].InstanceId"
    ],
    "data": [
      {
        "input": {
          "Label": "CPUUtilization",
          "Datapoints": [
            {
              "Timestamp": "2020-02-20T12:15:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 19.514049550078127
              }
            },
            {
              "Timestamp": "2020-02-20T12:16:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 12.721997782508938
              }
            },
            {
              "Timestamp": "2020-02-20T12:17:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 13.318820949213313
              }
            },
            {
              "Timestamp": "2020-02-20T12:18:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 15.994192991030545
              }
            }
          ]
        },
        "output": [
          19.514049550078127,
          12.721997782508938,
          13.318820949213313,
          15.994192991030545
        ]
      }
    ],
    "identifier": 60401315
  },
  {
    "context": [
      "I have 2 json files.",
      "The key = **NetworkManager-libnm.x86_64** , **NetworkManager.x86_64** and **NetworkManager-ppp.x86_64** has different value in test2.json and **gcc** is new package. So these 3 packages comes to final json.",
      "I want to achieve this in shell script with help jq.",
      "jq -n --argfile one test1.json --argfile two test2.json '\n   $test2 | with_entries( select($test1[.key] != .value) )'"
    ],
    "utterance": "Find all key-value pairs in the second file where either the key does not exist in the first file or the value is different from the first file.",
    "expressions": [
      "jq -n --argfile test1 test1.json --argfile test2 test2.json '$test2 | with_entries(select($test1[.key] != .value))'"
    ],
    "data": [
      {
        "input": {
          "test1.json": {
            "GeoIP.x86_64": "1.5.0-14.el7",
            "NetworkManager.x86_64": "1:1.18.0-5.el7_7.1",
            "NetworkManager-libnm.x86_64": "1:1.18.0-5.el7_7.1",
            "NetworkManager-ppp.x86_64": "1:1.18.0-5.el7_7.1"
          },
          "test2.json": {
            "GeoIP.x86_64": "1.5.0-14.el7",
            "NetworkManager.x86_64": "1:2.18.0-5.el7_7.1",
            "NetworkManager-libnm.x86_64": "1:1.19.0-5.el7_7.1",
            "NetworkManager-ppp.x86_64": "1:1.19.0-5.el7_7.1",
            "gcc": "1:1.9.0-el7_7.1"
          }
        },
        "output": {
          "NetworkManager.x86_64": "1:2.18.0-5.el7_7.1",
          "NetworkManager-libnm.x86_64": "1:1.19.0-5.el7_7.1",
          "NetworkManager-ppp.x86_64": "1:1.19.0-5.el7_7.1",
          "gcc": "1:1.9.0-el7_7.1"
        }
      }
    ],
    "identifier": 60390634
  },
  {
    "context": [
      "I have a dictionary that looks like this:",
      "\"d6fc3e2b-0001a\"",
      "\"d6fc3e2b-0001a\",\"d6fc3e2b-0002a\",\"d6fc3e2b-0003a\"",
      "\"d6fc3e2b-0004a\"",
      "Expected Output:",
      "\"ABC Mgmt\"",
      "\"ABC Mgmt\",\"Server XYZ\",\"NTP Primary\"",
      "\"H-10.10.10.10\"",
      "the dictionary file is read using the `--slurpfile` command-line option, and the lines of \"text\" are read using `inputs` in conjunction with the -n command-line option.",
      "program.jq",
      "(INDEX($dict[]; .uid) | map_values(.name)) as $d",
      "| inputs",
      "| split(\",\")",
      "| map(fromjson)",
      "| map($d[.])",
      "| @csv"
    ],
    "utterance": "For each line of comma-separated quoted uids in a text file, output the corresponding names from the dictionary, formatted as comma-separated quoted strings.",
    "expressions": [
      "(INDEX($dict[]; .uid) | map_values(.name)) as $d | inputs | split(\",\") | map(fromjson) | map($d[.]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "uid": "d6fc3e2b-0001a",
            "name": "ABC Mgmt",
            "type": "host"
          },
          {
            "uid": "d6fc3e2b-0002a",
            "name": "Server XYZ",
            "type": "group"
          },
          {
            "uid": "d6fc3e2b-0003a",
            "name": "NTP Primary",
            "type": "host"
          },
          {
            "uid": "d6fc3e2b-0004a",
            "name": "H-10.10.10.10",
            "type": "host"
          }
        ],
        "output": [
          "\"ABC Mgmt\"",
          "\"ABC Mgmt\",\"Server XYZ\",\"NTP Primary\"",
          "\"H-10.10.10.10\""
        ]
      }
    ],
    "identifier": 60387047
  },
  {
    "context": [
      "I want the output to have only entries with rewrite_quality == '1', in this case only the first entry.",
      ".[] | select( .results | any(.judgments[]; .data.rewrite_quality == \"1\"))",
      ".[] | select( any(.. | objects | .rewrite_quality == \"1\"))"
    ],
    "utterance": "Return only the entries where any of the judgments has rewrite_quality equal to '1'.",
    "expressions": [
      ".[] | select(.results | any(.judgments[]; .data.rewrite_quality == \"1\"))",
      ".[] | select(any(.. | objects | .rewrite_quality == \"1\"))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 2400321267,
            "data": {
              "q": "quinoa black bean and shrimp r",
              "r": "quinoa black bean and shrimps r",
              "s": "3"
            },
            "job_id": 1413792,
            "results": {
              "judgments": [
                {
                  "id": 5022700047,
                  "unit_state": "good",
                  "data": {
                    "rewrite_quality": "1"
                  }
                }
              ]
            }
          },
          {
            "id": 2400321267,
            "data": {
              "q": "quinoa black bean and shrimp r",
              "r": "quinoa black bean and shrimps r",
              "s": "3"
            },
            "job_id": 1413792,
            "results": {
              "judgments": [
                {
                  "id": 5022700047,
                  "unit_state": "good",
                  "data": {
                    "rewrite_quality": "2"
                  }
                }
              ]
            }
          }
        ],
        "output": [
          {
            "id": 2400321267,
            "data": {
              "q": "quinoa black bean and shrimp r",
              "r": "quinoa black bean and shrimps r",
              "s": "3"
            },
            "job_id": 1413792,
            "results": {
              "judgments": [
                {
                  "id": 5022700047,
                  "unit_state": "good",
                  "data": {
                    "rewrite_quality": "1"
                  }
                }
              ]
            }
          }
        ]
      }
    ],
    "identifier": 60422639
  },
  {
    "context": [
      "I have the output of a bash script running like such\n\n{\"name\":\"abc/123\",\"tags\":[\"X-1\",\"X-2\",\"X-3\",\"X-4\"....... \"X-1099\"]}",
      "I'd like to find the highest value for X in this case `X-1099`. Can someone suggest an approach? Seems like jq might be a start.",
      "So I've made a bit of progress jq '.tags' gives the list of X values",
      "Using jq:\n\n    .tags | max_by(sub(\"X-\";\"\") | tonumber)\n"
    ],
    "utterance": "Find the tag with the highest numeric value following the 'X-' prefix in the tags array.",
    "expressions": [
      ".tags | max_by(sub(\"X-\"; \"\") | tonumber)"
    ],
    "data": [
      {
        "input": {
          "name": "abc/123",
          "tags": [
            "X-1",
            "X-2",
            "X-3",
            "X-4",
            "X-1099"
          ]
        },
        "output": "X-1099"
      }
    ],
    "identifier": 60444500
  },
  {
    "identifier": 60471460
  },
  {
    "context": [
      "But I need to specify the header names twice. Is there a way to just specify the header names once?",
      "Here&#39;s a relatively robust jq script for printing the TSV with headers using the key names in the first object:",
      "(.[0] | keys_unsorted) as $keys\n| $keys,  (.[] | [.[$keys[]]])\n| @tsv"
    ],
    "utterance": "Output a headed TSV using the keys from only the first object as headers without specifying them twice.",
    "expressions": [
      "(.[0] | keys_unsorted) as $keys | $keys, (.[] | [.[$keys[]]]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "h1": "x1",
            "h2": "x2"
          },
          {
            "h1": "y1",
            "h2": "y2"
          }
        ],
        "output": "h1\th2\nx1\tx2\ny1\ty2"
      }
    ],
    "identifier": 60455162
  },
  {
    "context": [
      "if both `.merchantDetails.name` and `.description.sanitized` exist then `.merchantDetails.name` has to take precedence when checking for the string \"DUMMY\". If not then check either `.merchantDetails.name` or `.description.sanitized` for the string \"DUMMY\".",
      "jq '\nmap (\n  objects |\n  if   has(\"merchantDetails\") and has(\"description\") then\n    select( .merchantDetails.name  | contains(\"DUMMY\"))\n  elif has(\"merchantDetails\") then\n    select( .merchantDetails.name  | contains(\"DUMMY\"))\n  elif has(\"description\") then\n    select( .description.sanitized | contains(\"DUMMY\"))\n  else empty\n  end\n)\n'"
    ],
    "utterance": "Filter all objects such that if both merchantDetails.name and description.sanitized exist, select the object if merchantDetails.name contains \"DUMMY\"; otherwise, select objects where either merchantDetails.name or description.sanitized contains \"DUMMY\".",
    "expressions": [
      "map (\n  objects |\n  if   has(\"merchantDetails\") and has(\"description\") then\n    select( .merchantDetails.name  | contains(\"DUMMY\"))\n  elif has(\"merchantDetails\") then\n    select( .merchantDetails.name  | contains(\"DUMMY\"))\n  elif has(\"description\") then\n    select( .description.sanitized | contains(\"DUMMY\"))\n  else empty\n  end\n)"
    ],
    "data": [
      {
        "input": [
          {
            "version": "v2",
            "transactionId": "10590541.2280012772",
            "description": {
              "original": "DUMMY",
              "sanitized": "DUMMY A.B. C"
            }
          }
        ],
        "output": [
          {
            "version": "v2",
            "transactionId": "10590541.2280012772",
            "description": {
              "original": "DUMMY",
              "sanitized": "DUMMY A.B. C"
            }
          }
        ]
      },
      {
        "input": [
          {
            "version": "v2",
            "transactionId": "10590541.2280012772",
            "description": {
              "original": "DUMMY",
              "sanitized": "DUMMY A.B. C"
            },
            "merchantDetails": {
              "name": "DUMMY"
            }
          }
        ],
        "output": [
          {
            "version": "v2",
            "transactionId": "10590541.2280012772",
            "description": {
              "original": "DUMMY",
              "sanitized": "DUMMY A.B. C"
            },
            "merchantDetails": {
              "name": "DUMMY"
            }
          }
        ]
      },
      {
        "input": [
          {
            "version": "v2",
            "transactionId": "10590541.2280012772",
            "merchantDetails": {
              "name": "DUMMY"
            }
          }
        ],
        "output": [
          {
            "version": "v2",
            "transactionId": "10590541.2280012772",
            "merchantDetails": {
              "name": "DUMMY"
            }
          }
        ]
      }
    ],
    "identifier": 60424763
  },
  {
    "context": [
      "I have a json file where a time series in stored under `data` key and and an object id is in `info` key:",
      "I would like to flatten the json and produce something similar to:",
      "[ {id: abc, time: 10, x: 5, y: 3}, {id: abc, time: 12, x: 6, y: 4}, # the rest of 5000 points ]",
      "[ (.data[] | {time: .[0], x: .[1], y: .[2]}) + {id: .info.id} ]"
    ],
    "utterance": "Flatten an object with 'info.id' and an array of arrays under 'data' into an array of objects where each object combines 'id', 'time', 'x', and 'y' fields from 'info.id' and each sub-array.",
    "expressions": [
      "[ (.data[] | {time: .[0], x: .[1], y: .[2]}) + {id: .info.id} ]"
    ],
    "data": [
      {
        "input": {
          "info": {
            "id": "abc"
          },
          "data": [
            [
              10,
              5,
              3
            ],
            [
              12,
              6,
              4
            ]
          ]
        },
        "output": [
          {
            "id": "abc",
            "time": 10,
            "x": 5,
            "y": 3
          },
          {
            "id": "abc",
            "time": 12,
            "x": 6,
            "y": 4
          }
        ]
      }
    ],
    "identifier": 60463005
  },
  {
    "context": [
      "I am trying to get an average of all the numbers",
      "How do i get a single number as output",
      "**Expected Output**",
      "3.216756656748",
      "jq '[.Datapoints[] | select(.ExtendedStatistics.p80>=0) | .ExtendedStatistics.p80] | add/length' file.json"
    ],
    "utterance": "Calculate the average of all p80 values in Datapoints where p80 is greater than or equal to zero.",
    "expressions": [
      "[.Datapoints[] | select(.ExtendedStatistics.p80>=0) | .ExtendedStatistics.p80] | add/length"
    ],
    "data": [
      {
        "input": {
          "Label": "CPUUtilization",
          "Datapoints": [
            {
              "Timestamp": "2020-02-20T18:35:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 7.39284928374
              }
            },
            {
              "Timestamp": "2020-02-20T18:00:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 2.234234
              }
            },
            {
              "Timestamp": "2020-02-20T18:45:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 2.4567
              }
            },
            {
              "Timestamp": "2020-02-20T18:50:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 2.0
              }
            },
            {
              "Timestamp": "2020-02-20T18:20:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 2.0
              }
            }
          ]
        },
        "output": 3.216756656748
      }
    ],
    "identifier": 60460376
  },
  {
    "context": [
      "My input file has this format:\r\n\r\n```\r\nkey1: string1\r\nkey2: string1\r\n\r\nkey1: string3\r\nkey2: string3\r\n```\r\n\r\nHow can I translate that to:\r\n\r\n```json\r\n[\r\n  {\"key1\":\"string1\", \"key2\": \"string2\"},\r\n  {\"key1\":\"string3\", \"key2\": \"string4\"}\r\n]\r\n```",
      "Run with your document on its stdin, the script:\r\n\r\n```jq\r\ndef input_line_to_object:\r\n  \"^(?<key>[^:]+): ?(?<value>.*)$\" as $re |\r\n  (capture($re) // (\"line \\(.) does not parse\" | halt_error(1))) | {(.key):.value};\r\n\r\nreduce (inputs, \"\") as $item (\r\n  [{}, []];\r\n  if $item == \"\" then\r\n    if .[0] == {} then\r\n      .\r\n    else\r\n      [{}, .[1]+[.[0]]]\r\n    end\r\n  else\r\n    [.[0] + ($item | input_line_to_object), .[1]]\r\n  end\r\n) | .[1]\r\n```",
      "Here\u0019s a succinct but fairly robust solution that assumes jq is called with the -n and -R options (e.g., `jq -nR ...`)\r\n\r\n```\r\n[foreach (inputs, null) as $in (null;\r\n  if ($in|length) == 0\r\n  then .out = .object | .object = null\r\n  else .object += ($in | capture(\"(?<k>^[^:]*): *(?<v>.*)\") | {(.k):.v})\r\n  | .out = null\r\n  end;\r\n  .out // empty) ]\r\n```"
    ],
    "utterance": "Convert a text file where each group of key:value lines is separated by a blank line into an array of objects, each object representing a group with key-value pairs.",
    "expressions": [
      "def input_line_to_object:\n  \"^(?<key>[^:]+): ?(?<value>.*)$\" as $re |\n  (capture($re) // (\"line \\(.) does not parse\" | halt_error(1))) | {(.key):.value};\n\nreduce (inputs, \"\") as $item (\n  [{}, []];\n  if $item == \"\" then\n    if .[0] == {} then\n      .\n    else\n      [{}, .[1]+[.[0]]]\n    end\n  else\n    [.[0] + ($item | input_line_to_object), .[1]]\n  end\n) | .[1]",
      "[foreach (inputs, null) as $in (null;\n  if ($in|length) == 0\n  then .out = .object | .object = null\n  else .object += ($in | capture(\"(?<k>^[^:]*): *(?<v>.*)\") | {(.k):.v})\n  | .out = null\n  end;\n  .out // empty) ]"
    ],
    "data": [
      {
        "input": "key1: string1\nkey2: string1\n\nkey1: string3\nkey2: string3\n",
        "output": [
          {
            "key1": "string1",
            "key2": "string1"
          },
          {
            "key1": "string3",
            "key2": "string3"
          }
        ]
      }
    ],
    "identifier": 60425030
  },
  {
    "context": [
      "I'd like to process many json objects with one json object per line. Is it possible to let jq process each line as a separate json object instead of the whole file as a single json object?",
      "jq does that out-of-the-box.  (The JSON entities provided as input do not **have** to be on separate lines, but it's fine if they are.)"
    ],
    "utterance": "Process a file where each line is a separate JSON object, treating each line as an independent object.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": [
          "{\"name\": \"alice\", \"age\": 30}",
          "{\"name\": \"bob\", \"age\": 25}"
        ],
        "output": [
          {
            "name": "alice",
            "age": 30
          },
          {
            "name": "bob",
            "age": 25
          }
        ]
      }
    ],
    "identifier": 60481640
  },
  {
    "context": [
      "$ printf '{\"ika\":5,\"uni\":3}' | jq '.ika, .uni | .'",
      "5",
      "3",
      "$ printf '{\"ika\":5,\"uni\":3}' | jq '.ika, .uni | . | add'",
      "jq: error (at <stdin>:0): Cannot iterate over number (5)",
      "$ printf '{\"ika\":5,\"uni\":3}' | jq '[ .ika, .uni ] | . | add'",
      "8",
      "$ printf '{\"ika\":[4,9],\"uni\":[1,3,5]}' | jq '.ika, .uni | add'",
      "13",
      "9",
      "$ printf '{\"ika\":[4,9],\"uni\":[1,3,5]}' | jq '[ .ika, .uni | add ]'",
      "[",
      "  13,",
      "  9",
      "]"
    ],
    "utterance": "Sum the values of the keys 'ika' and 'uni' from an object.",
    "expressions": [
      ".ika, .uni | add",
      "[ .ika, .uni ] | add"
    ],
    "data": [
      {
        "input": {
          "ika": 5,
          "uni": 3
        },
        "output": 8
      },
      {
        "input": {
          "ika": [
            4,
            9
          ],
          "uni": [
            1,
            3,
            5
          ]
        },
        "output": [
          13,
          9
        ]
      }
    ],
    "identifier": 60472049
  },
  {
    "context": [
      "And my desired output would pull various values from each object\u2019s `children` array into something like this:",
      "in other words, find \"tag\" == \"h2\" and output \"text\" value",
      "\"tag\" == \"p\", \"text\" value",
      "\"tag\" == \"span\", \"text\" value (lowercased if possible? Not needed though)",
      "\"tag\" == \"a\", \"href\" value",
      "how to select the nested values based on searching through the `children` array;",
      "how to lowercase the `type` value;",
      "how to deal with sometimes missing `link` values;",
      "[.[] | { title: .children[] | select(.tag == \"h2\").text, type: .children[] | select(.tag == \"span\").text | ascii_downcase, perex: .children[] | select(.tag == \"p\").text, link: format(((.children[] | select(.tag == \"a\").href) // null)) }]",
      "{ title: [.[] | select(.tag == \"h2\") | .text][0], perex: [.[] | select(.tag == \"p\") | .text][0], type:  [.[] | select(.tag == \"span\") | .text | ascii_downcase][0], link:  [.[] | select(.tag == \"a\") | .href][0] }"
    ],
    "utterance": "For each top-level object, extract the 'text' values of children with 'tag' equal to 'h2', 'p', 'span' (lowercased), and the 'href' value of the child with 'tag' equal to 'a' (or null if missing), compiling them into an object with keys 'title', 'perex', 'type', and 'link'.",
    "expressions": [
      "def format(link): if link | tostring | startswith(\"/\") then \"https://www.nihongomaster.com\" + link else link end; [.[] | { title: .children[] | select(.tag == \"h2\").text, type: .children[] | select(.tag == \"span\").text | ascii_downcase, perex: .children[] | select(.tag == \"p\").text, link: format(((.children[] | select(.tag == \"a\").href) // null)) }]",
      "[ .[] | .children | { title: [.[] | select(.tag == \"h2\") | .text][0], perex: [.[] | select(.tag == \"p\") | .text][0], type:  [.[] | select(.tag == \"span\") | .text | ascii_downcase][0], link:  [.[] | select(.tag == \"a\") | .href][0] } ]"
    ],
    "data": [
      {
        "input": [
          {
            "children": [
              {
                "class": "label label-info",
                "tag": "span",
                "text": "Lesson"
              },
              {
                "tag": "h2",
                "text": "Is That So?"
              },
              {
                "tag": "p",
                "text": "Learn how to provide shortened answers with \u305d\u3046\u3067\u3059 and stay in the conversation with \u305d\u3046\u3067\u3059\u304b."
              },
              {
                "class": "btn btn-primary",
                "href": "https://www.nihongomaster.com/japanese/lessons/view/62/is-that-so",
                "tag": "a",
                "text": "Read Lesson"
              }
            ],
            "class": "row col-sm-12",
            "tag": "div"
          },
          {
            "children": [
              {
                "class": "label label-warning",
                "tag": "span",
                "text": "Drills"
              },
              {
                "tag": "h2",
                "text": "Yes, That Is So."
              },
              {
                "tag": "p",
                "text": "Practice the phrases and vocab from the lesson, Is That So?"
              }
            ],
            "class": "row col-sm-12",
            "tag": "div"
          }
        ],
        "output": [
          {
            "title": "Is That So?",
            "perex": "Learn how to provide shortened answers with \u305d\u3046\u3067\u3059 and stay in the conversation with \u305d\u3046\u3067\u3059\u304b.",
            "type": "lesson",
            "link": "https://www.nihongomaster.com/japanese/lessons/view/62/is-that-so"
          },
          {
            "title": "Yes, That Is So.",
            "perex": "Practice the phrases and vocab from the lesson, Is That So?",
            "type": "drills",
            "link": null
          }
        ]
      }
    ],
    "identifier": 60424904
  },
  {
    "context": [
      "My first step worked by filtering any duplicates by a certain key (.ArchiveId). Once that's done I want to loop through the result.",
      "If you want to just get the `JobId` and the `ArchiveId` from each job, you could do something like this:",
      "$ jq -r '.Jobs |= unique_by(.ArchiveId) | .Jobs[] | \"\\(.JobId) \\(.ArchiveId)\"' \\",
      "jq -r '.Jobs |= unique_by(.ArchiveId) | .Jobs[] | \"\\(.JobId) \\(.ArchiveId)\"' \\",
      "To get `JobId` and `ArchiveId` as variables, you could do something like this:"
    ],
    "utterance": "Output each unique pair of JobId and ArchiveId, removing items with duplicate ArchiveId values.",
    "expressions": [
      ".Jobs |= unique_by(.ArchiveId) | .Jobs[] | \"\u0005c(.JobId) \u0005c(.ArchiveId)\""
    ],
    "data": [
      {
        "input": {
          "Jobs": [
            {
              "JobId": 111,
              "ArchiveId": 333
            },
            {
              "JobId": 112,
              "ArchiveId": 333
            },
            {
              "JobId": 113,
              "ArchiveId": 2323
            },
            {
              "JobId": 114,
              "ArchiveId": 444
            }
          ]
        },
        "output": [
          "111 333",
          "114 444",
          "113 2323"
        ]
      }
    ],
    "identifier": 60499649
  },
  {
    "context": [
      "echo 2 | jq 'if . == 0 then \"zero\" end'",
      "jq: error: syntax error, unexpected end (Unix shell quoting issues?) at <top-level>, line 1:",
      "if . == 0 then \"zero\" end",
      "echo 2 | jq 'if . == 0 then \"zero\" else . end'",
      "2",
      "echo 0 | jq 'if . == 0 then \"zero\" else . end'",
      "\"zero\""
    ],
    "utterance": "Output the string \"zero\" if the input is 0; otherwise, output the input unchanged.",
    "expressions": [
      "if . == 0 then \"zero\" else . end"
    ],
    "data": [
      {
        "input": 2,
        "output": 2
      },
      {
        "input": 0,
        "output": "zero"
      }
    ],
    "identifier": 60517702
  },
  {
    "context": [
      "JSON\n[\n      {\n        \"name\": \"username\",\n        \"value\": \"my-username\"\n      },\n      {\n        \"name\": \"password\",\n        \"value\": \"my-password\"\n      }\n]",
      "Desired Result\n{ \"username\": \"my-username\", \"password\": \"my-password\" }",
      "{ \n    username: (.[] | select(.name == \"username\").value), \n    password: (.[] | select(.name == \"password\").value) \n}",
      "You could also do map({ key: .name, value }) | from_entries",
      "you can achieve the result simply using the jq filter:\n\n    from_entries"
    ],
    "utterance": "Convert an array of objects with 'name' and 'value' fields into an object mapping each 'name' to its corresponding 'value'.",
    "expressions": [
      "{ username: (.[] | select(.name == \"username\").value), password: (.[] | select(.name == \"password\").value) }",
      "map({ key: .name, value }) | from_entries",
      "from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "name": "username",
            "value": "my-username"
          },
          {
            "name": "password",
            "value": "my-password"
          }
        ],
        "output": {
          "username": "my-username",
          "password": "my-password"
        }
      }
    ],
    "identifier": 60512115
  },
  {
    "context": [
      "I want to arrange the data in json array format in linux and append more such data with for/while loop in the same json array based on condition.",
      "< kv.txt jq -Rn --argfile object object.json -f program.jq | sponge object.json",
      "program.jq contains the jq program:",
      "$object | .Array += \r\n  reduce inputs as $in ([]; . + [$in | capture(\"(?<k>^[^:]*): *(?<v>.*)\") | {(.k):.v} ])"
    ],
    "utterance": "Append key-value pairs from a text file with lines like 'Name:Rock' and 'Name:Clock' as objects to an Array field, preserving previous array contents with each append.",
    "expressions": [
      "$object | .Array += reduce inputs as $in ([]; . + [$in | capture(\"(?<k>^[^:]*): *(?<v>.*)\") | {(.k):.v} ])"
    ],
    "data": [
      {
        "input": {
          "object.json": {
            "Array": []
          },
          "kv.txt": "Name:Rock\nName:Clock"
        },
        "output": {
          "Array": [
            {
              "Name": "Rock"
            },
            {
              "Name": "Clock"
            }
          ]
        }
      }
    ],
    "identifier": 60513099
  },
  {
    "context": [
      "I\u2019d like to generate a list of items where .DownloadURL doesn\u2019t contain the string in .Version.",
      "The following has worked for me:",
      "jq '.[]|.Version as $v|select(.DownloadURL | contains($v)| not)'",
      "If as you say you want the result as a list, you could use map:",
      "map(select( .Version as $v | .DownloadURL | contains($v) | not))",
      "However, the semantics of contains is very complex so you might wish to consider using index instead:",
      "map(select( .Version as $v | .DownloadURL | index($v) | not))"
    ],
    "utterance": "Return all items where the DownloadURL field does not contain the value of the Version field.",
    "expressions": [
      ".[] | .Version as $v | select(.DownloadURL | contains($v) | not)",
      "map(select(.Version as $v | .DownloadURL | contains($v) | not))",
      "map(select(.Version as $v | .DownloadURL | index($v) | not))"
    ],
    "data": [
      {
        "input": [
          {
            "Package": "pyasn1",
            "Version": "0.4.6",
            "DownloadURL": "https://files.pythonhosted.org/packages/3d/50/5ce5dbe42eaf016cb9b062caf6d0f38018454756d4feb467de3e29431dae/pyasn1-0.4.6-py2.4.egg"
          },
          {
            "Package": "cachetools",
            "Version": "3.1.1",
            "DownloadURL": "https://files.pythonhosted.org/packages/08/6a/abf83cb951617793fd49c98cb9456860f5df66ff89883c8660aa0672d425/cachetools-4.0.0-py3-none-any.whl"
          }
        ],
        "output": [
          {
            "Package": "cachetools",
            "Version": "3.1.1",
            "DownloadURL": "https://files.pythonhosted.org/packages/08/6a/abf83cb951617793fd49c98cb9456860f5df66ff89883c8660aa0672d425/cachetools-4.0.0-py3-none-any.whl"
          }
        ]
      }
    ],
    "identifier": 60497517
  },
  {
    "identifier": 60535547
  },
  {
    "context": [
      "i need a way with jq stream (i have installed version 1.6) to get all 001 values, that have in the content, a 4.. element.(400, or 401, or 402, or 403, ...)",
      "for example the above would return:\n\n    77\n    234\n    549\n\nand not 888, which does not contain any 4.. element.",
      "The following produces the desired output: \n\n```\n< input.json jq -r '.content\n| fromjson\n| select( any(keys_unsorted[]; test(\"^4\")) )\n| .[\"001\"]'\n```"
    ],
    "utterance": "Output all 001 values from entries whose content has a key starting with 4",
    "expressions": [
      ".content | fromjson | select( any(keys_unsorted[]; test(\"^4\")) ) | .[\"001\"]"
    ],
    "data": [
      {
        "input": [
          {
            "_id": {
              "$serialnumber": "572"
            },
            "content": "{\"001\":\"77\",\"401\":[[\" 0\",[\"a\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "_id": {
              "$serialnumber": "573"
            },
            "content": "{\"001\":\"234\",\"424\":[[\" 0\",[\"a\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "_id": {
              "$serialnumber": "574"
            },
            "content": "{\"001\":\"549\",\"432\":[[\" 0\",[\"a\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "_id": {
              "$serialnumber": "575"
            },
            "content": "{\"001\":\"888\",\"532\":[[\" 0\",[\"a\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          }
        ],
        "output": [
          "77",
          "234",
          "549"
        ]
      }
    ],
    "identifier": 60512221
  },
  {
    "context": [
      "How may I have the output sorted in numerically way by this  **\"name\"** value ? Thanx. -Jack",
      "An only-jq solution:\n\n    < results.json jq -s -c '\n        sort_by(.name|sub(\"I-\";\"\") | tonumber) | .[]'"
    ],
    "utterance": "Output the objects ordered in increasing order by the number part of the name field, where names are like 'I-1', 'I-2', ..., 'I-21'.",
    "expressions": [
      "sort_by(.name|sub(\"I-\";\"\") | tonumber) | .[]"
    ],
    "identifier": 60536358
  },
  {
    "context": [
      "Say I have a sample.json file that looks like this. Notice the objects are not separated by a comma. I am aware that this is not a JSON file without the commas.",
      "$ jq -Rsr 'gsub(\"^\\\\s*\\\\[|\\\\]\\\\s*$\"; \"\")' input.json | jq -n '[inputs]'"
    ],
    "utterance": "Convert an array containing objects missing separating commas into a valid array with commas between objects.",
    "expressions": [
      "jq -Rsr 'gsub(\"^\\\\s*\\\\[|\\\\]\\\\s*$\"; \"\")' input.json | jq -n '[inputs]'"
    ],
    "data": [
      {
        "input": [
          "  {",
          "    \"type\": \"message\",",
          "    \"user\": \"U024HFHU5\",",
          "    \"text\": \"hey there\",",
          "    \"ts\": \"1385407681.000003\"",
          "  }",
          "  {",
          "    \"type\": \"message\",",
          "    \"user\": \"U024HGJ4E\",",
          "    \"text\": \"right back at you\",",
          "    \"ts\": \"1385407706.000006\"",
          "  }"
        ],
        "output": [
          {
            "type": "message",
            "user": "U024HFHU5",
            "text": "hey there",
            "ts": "1385407681.000003"
          },
          {
            "type": "message",
            "user": "U024HGJ4E",
            "text": "right back at you",
            "ts": "1385407706.000006"
          }
        ]
      }
    ],
    "identifier": 60539044
  },
  {
    "context": [
      "The domain name brightside.mtn.co.za and other domains repeated more than 10 times now i want to drop brightside.mtn.co.za and other domains that are repeated more than 10 times and then the output the results the output  should look like.",
      "group_by( sub(\"/[^/]*$\";\"\") )",
      "map(select(length < 10) )",
      "< input.txt jq -Rr '[inputs] \n  | group_by( sub(\"/[^/]*$\";\"\") )\n  | map(select(length < 10) )\n  | .[][]'"
    ],
    "utterance": "Filter a list of URLs to exclude all URLs from domains that appear more than 10 times, keeping only those from domains that occur fewer than 10 times.",
    "expressions": [
      "[inputs] | group_by( sub(\"/[^/]*$\";\"\") ) | map(select(length < 10)) | .[][]"
    ],
    "data": [
      {
        "input": [
          "https://brianbrandt.dk/web/var/www/public_html/.htpasswd",
          "https://brianbrandt.dk/web/var/www/public_html/wp-config.php",
          "https://briannajackson1.wordpress.org/high-entropy-misc.txt",
          "https://briannajackson1.wordpress.org/Homestead.yaml",
          "https://brickellmiami.centric.hyatt.com/dev",
          "https://brickellmiami.centric.hyatt.com/django.log",
          "https://brickellmiami.centric.hyatt.com/.dockercfg",
          "https://brickellmiami.centric.hyatt.com/docker-compose.yml",
          "https://brickellmiami.centric.hyatt.com/.docker/config.json",
          "https://brickellmiami.centric.hyatt.com/Dockerfile",
          "https://brideonashoestring.wordpress.org/web/var/www/public_html/config.php",
          "https://brideonashoestring.wordpress.org/web/var/www/public_html/wp-config.php",
          "https://brideonashoestring.wordpress.org/wp-config.php",
          "https://brideonashoestring.wordpress.org/.wp-config.php.swp",
          "https://brideonashoestring.wordpress.org/_wpeprivate/config.json",
          "https://brideonashoestring.wordpress.org/yarn-debug.log",
          "https://brideonashoestring.wordpress.org/yarn-error.log",
          "https://brideonashoestring.wordpress.org/yarn.lock",
          "https://brideonashoestring.wordpress.org/.yarnrc",
          "https://bridgehome.adobe.com/etc/shadow",
          "https://bridgehome.adobe.com/phpinfo.php",
          "https://bridgetonema.wordpress.org/manifest.json",
          "https://bridgetonema.wordpress.org/manifest.yml",
          "https://bridge.twilio.com/.wp-config.php.swp",
          "https://bridge.twilio.com/wp-content/themes/.git/config",
          "https://bridge.twilio.com/_wpeprivate/config.json",
          "https://bridge.twilio.com/yarn-debug.log",
          "https://bridge.twilio.com/yarn-error.log",
          "https://bridge.twilio.com/yarn.lock",
          "https://bridge.twilio.com/.yarnrc",
          "https://brightside.mtn.co.za/config.lua",
          "https://brightside.mtn.co.za/config.php",
          "https://brightside.mtn.co.za/config.php.txt",
          "https://brightside.mtn.co.za/config.rb",
          "https://brightside.mtn.co.za/config.ru",
          "https://brightside.mtn.co.za/_config.yml",
          "https://brightside.mtn.co.za/console",
          "https://brightside.mtn.co.za/.credentials",
          "https://brightside.mtn.co.za/CVS/Entries",
          "https://brightside.mtn.co.za/CVS/Root",
          "https://brightside.mtn.co.za/dasbhoard/",
          "https://brightside.mtn.co.za/data",
          "https://brightside.mtn.co.za/data.txt",
          "https://brightside.mtn.co.za/db/dbeaver-data-sources.xml",
          "https://brightside.mtn.co.za/db/dump.sql",
          "https://brightside.mtn.co.za/db/.pgpass",
          "https://brightside.mtn.co.za/db/robomongo.json",
          "https://brightside.mtn.co.za/README.txt",
          "https://brightside.mtn.co.za/RELEASE_NOTES.txt",
          "https://brightside.mtn.co.za/.remote-sync.json",
          "https://brightside.mtn.co.za/Resources.zip.manifest",
          "https://brightside.mtn.co.za/.rspec",
          "https://br.infinite.sx/db/dump.sql",
          "https://br.infinite.sx/graphiql"
        ],
        "output": [
          "https://br.infinite.sx/db/dump.sql",
          "https://br.infinite.sx/graphiql",
          "https://bridgetonema.wordpress.org/manifest.json",
          "https://bridgetonema.wordpress.org/manifest.yml"
        ]
      }
    ],
    "identifier": 60499798
  },
  {
    "context": [
      "I am new to jq and tried to extract only the values from the keys \"taxonomy/definitions\" as a list from this json file",
      "I came to the following command:\n\n    jq -r '[].\"taxonomy/definitions$\"' skills.json\n\nHowever, it retrieves me null values.",
      "You can just simply do\n\n    jq -r '[].\"taxonomy/definition\"?'",
      "or if you want to use a regex based approach to match the \"taxonomy/definition\" exactly, you could do\n\n    jq -r 'map(to_entries[] | select(.key| test(\"^taxonomy/definition$\")?).value)[]'"
    ],
    "utterance": "Extract all values associated with the key taxonomy/definition from each object in the top-level array.",
    "expressions": [
      ".[].\"taxonomy/definition\"?",
      "map(to_entries[] | select(.key|test(\"^taxonomy/definition$\")?).value)[]"
    ],
    "data": [
      {
        "input": [
          {
            "taxonomy/relations": {
              "taxonomy/broader": 1,
              "taxonomy/narrower": 0,
              "taxonomy/related": 0,
              "taxonomy/substitutability-to": 0,
              "taxonomy/substitutability-from": 0
            },
            "taxonomy/id": "ZxHj_Wvj_39H",
            "taxonomy/type": "skill",
            "taxonomy/definition": "VM/CMS, operativsystem",
            "taxonomy/preferred-label": "VM/CMS, operativsystem"
          },
          {
            "taxonomy/relations": {
              "taxonomy/broader": 1,
              "taxonomy/narrower": 0,
              "taxonomy/related": 0,
              "taxonomy/substitutability-to": 0,
              "taxonomy/substitutability-from": 0
            },
            "taxonomy/id": "oRCp_wLd_dWd",
            "taxonomy/type": "skill",
            "taxonomy/definition": "OS/400, operativsystem",
            "taxonomy/preferred-label": "OS/400, operativsystem"
          }
        ],
        "output": [
          "VM/CMS, operativsystem",
          "OS/400, operativsystem"
        ]
      }
    ],
    "identifier": 60527224
  },
  {
    "context": [
      "So when I Pass some Key1 & value1 as a parameter **\"Name\": \"InstanceType\",** to the JQ probably using cat <filename> | jq <required params here> and output expected should be as below",
      "m5.2xlarge",
      "r5.2xlarge",
      "A generic approach to search for a key-value pair (`sk`-`sv`) in input recursively and extract another key's value (`pv`) from objects found:\n``` shell\njq -r --arg sk Name         \\\n      --arg sv InstanceType \\\n      --arg pv Value        \\\n'.. | objects | select(contains({($sk): $sv})) | .[$pv]' file\n```"
    ],
    "utterance": "Find all objects where Name equals InstanceType and output their Value fields.",
    "expressions": [
      "jq -r --arg sk Name --arg sv InstanceType --arg pv Value '.. | objects | select(contains({($sk): $sv})) | .[$pv]'"
    ],
    "data": [
      {
        "input": {
          "MetricAlarms": [
            {
              "EvaluationPeriods": 3,
              "ComparisonOperator": "GreaterThanOrEqualToThreshold",
              "AlarmActions": [
                "Unimportant:Random:alarm:ELK2[10.1.1.2]-Root-Disk-Alert"
              ],
              "AlarmName": "Unimportant:Random:alarm:ELK1[10.1.1.0]-Root-Alert",
              "Dimensions": [
                {
                  "Name": "path",
                  "Value": "/"
                },
                {
                  "Name": "InstanceType",
                  "Value": "m5.2xlarge"
                },
                {
                  "Name": "fstype",
                  "Value": "ext4"
                }
              ],
              "DatapointsToAlarm": 3,
              "MetricName": "disk_used_percent"
            },
            {
              "EvaluationPeriods": 3,
              "ComparisonOperator": "GreaterThanOrEqualToThreshold",
              "AlarmActions": [
                "Unimportant:Random:alarm:ELK2[10.1.1.2]"
              ],
              "AlarmName": "Unimportant:Random:alarm:ELK2[10.1.1.2]",
              "Dimensions": [
                {
                  "Name": "path",
                  "Value": "/"
                },
                {
                  "Name": "InstanceType",
                  "Value": "r5.2xlarge"
                },
                {
                  "Name": "fstype",
                  "Value": "ext4"
                }
              ],
              "DatapointsToAlarm": 3,
              "MetricName": "disk_used_percent"
            }
          ]
        },
        "output": [
          "m5.2xlarge",
          "r5.2xlarge"
        ]
      }
    ],
    "identifier": 60546107
  },
  {
    "context": [
      "return all ids, that have an element that starts with 4, but also have an array that has in it either the    \"v\" value, or the \"9\" value.",
      "Desired output:\r\n\r\n    2\r\n    3",
      "you are imposing an additional condition, you have only to use `and`.",
      "the following produces the expected results, and is a solution to one disambiguation of the stated problem:",
      "```\r\n.message\r\n    | fromjson\r\n    | select( any(keys_unsorted[]; test(\"^4\")) \r\n              and (.[] | arrays | flatten | (index([\"v\"]) or index([\"9\"])) )  )\r\n    | .[\"id\"]\r\n```"
    ],
    "utterance": "Return all ids for objects where a key starts with 4 and its associated array contains either the value \"v\" or \"9\".",
    "expressions": [
      ".message\n    | fromjson\n    | select( any(keys_unsorted[]; test(\"^4\")) \n              and (.[] | arrays | flatten | (index([\"v\"]) or index([\"9\"])) )  )\n    | .[\"id\"]"
    ],
    "data": [
      {
        "input": [
          {
            "memo": {
              "notice": "delivered on 17"
            },
            "message": "{\"id\":\"1\",\"401\":[[\" 0\",[\"a\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "memo": {
              "notice": "delivered on 190"
            },
            "message": "{\"id\":\"2\",\"424\":[[\" 0\",[\"v\",\"UK\"],[\"9\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "memo": {
              "notice": "delivered on 734"
            },
            "message": "{\"id\":\"3\",\"432\":[[\" 0\",[\"a\",\"UK\"],[\"9\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"v\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "memo": {
              "notice": "delivered on 1092"
            },
            "message": "{\"id\":\"888\",\"532\":[[\" 0\",[\"v\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          }
        ],
        "output": [
          2,
          3
        ]
      }
    ],
    "identifier": 60524084
  },
  {
    "context": [
      "I want to extract each \"member\" entry to a new json object by filtering via \"name\" value.",
      "Output should be like:",
      "[{\"severity\": \"Low\",\"product\": \"p1\"}]",
      "Another problem is if a member wasnt found by the name value. if a member wasnt found by the name it should print null for the missing member value->  \"missingmemberName\": null",
      "The solution to the first part of the question as I understand it can be solved by using `from_entries`:",
      ".[].methodResponse.params.param.value.struct.member\n| map( .value |= .string )\n| [from_entries]"
    ],
    "utterance": "Transform each object's 'member' array to an object with keys from the 'name' field and values from the nested 'string', filling in null for missing expected members such as 'missingmemberName'.",
    "expressions": [
      ".[].methodResponse.params.param.value.struct.member | map(.value |= .string) | [from_entries]"
    ],
    "data": [
      {
        "input": [
          {
            "methodResponse": {
              "params": {
                "param": {
                  "value": {
                    "struct": {
                      "member": [
                        {
                          "name": "severity",
                          "value": {
                            "string": "Low"
                          }
                        },
                        {
                          "name": "product",
                          "value": {
                            "string": "p1"
                          }
                        }
                      ]
                    }
                  }
                }
              }
            }
          }
        ],
        "output": [
          {
            "severity": "Low",
            "product": "p1"
          }
        ]
      }
    ],
    "identifier": 60562957
  },
  {
    "context": [
      "I want to iterate through the file, and compare the \"Option X\" key to the \"ans\" key, and if it matches, remove that line.",
      ".ans as $ans | with_entries(select((.key | test(\"^Option\")) and .value == $ans | not))"
    ],
    "utterance": "Remove entries where any key starting with 'Option' has a value matching the value of 'ans' in the same object.",
    "expressions": [
      ".ans as $ans | with_entries(select((.key | test(\"^Option\")) and .value == $ans | not))"
    ],
    "data": [
      {
        "input": {
          "ques": "What is the meaning of life?",
          "ans": "42",
          "Option1": "123",
          "Option2": "456",
          "Option3": "789",
          "Option4": "42"
        },
        "output": {
          "ques": "What is the meaning of life?",
          "ans": "42",
          "Option1": "123",
          "Option2": "456",
          "Option3": "789"
        }
      },
      {
        "input": {
          "ques": "What isn't the meaning of life?",
          "ans": "Something",
          "Option1": "something else",
          "Option2": "another thing",
          "Option3": "Something",
          "Option4": "Yet another thing",
          "Option5": "One last thing"
        },
        "output": {
          "ques": "What isn't the meaning of life?",
          "ans": "Something",
          "Option1": "something else",
          "Option2": "another thing",
          "Option4": "Yet another thing",
          "Option5": "One last thing"
        }
      }
    ],
    "identifier": 60568266
  },
  {
    "context": [
      "The filter `(..|select(type==\"boolean\")) |= if . then 1 else 0 end`, given your input, is equivalent to",
      "If you wanted to get just the mapped out values, you wouldn't want to do an assignment here and just do a regular pipe.",
      ".. | select(type==\"boolean\") | if . then 1 else 0 end"
    ],
    "utterance": "Convert every boolean value within arbitrarily nested lists to 1 if true, otherwise 0, maintaining the input's nested structure.",
    "expressions": [
      "(..|select(type==\"boolean\")) |= if . then 1 else 0 end"
    ],
    "data": [
      {
        "input": [
          true,
          false,
          [
            5,
            true,
            [
              true,
              [
                false
              ]
            ],
            false
          ]
        ],
        "output": [
          1,
          0,
          [
            5,
            1,
            [
              1,
              [
                0
              ]
            ],
            0
          ]
        ]
      }
    ],
    "identifier": 60609883
  },
  {
    "context": [
      "Just trying to figure out how can this simple JSON fragment\n\n    [{ \"rooms\": \"2 Rooms\" }, { \"rooms\": \"3 Rooms\" }]\n\nbe transformed to\n\n    [{ \"rooms\": 2 }, { \"rooms\": 3 }]",
      "Here&#39;s one way that can easily be adapted to different requirements: \n```\ndef extractNumber: gsub(\"[^0-9]\";\"\") | tonumber;\n\nmap( map_values(extractNumber) )\n```",
      "def extractNumber:\n  . as $in \n  | gsub(\"[^0-9]\";\"\")\n  | if length == 0 then $in else tonumber end;\n\nwalk(if type == \"object\" then map_values(extractNumber) else . end)\n"
    ],
    "utterance": "Convert the string values of the 'rooms' fields that contain numbers and text into numbers, such as converting '2 Rooms' to 2.",
    "expressions": [
      "def extractNumber: gsub(\"[^0-9]\";\"\") | tonumber; map( map_values(extractNumber) )",
      "def extractNumber: . as $in | gsub(\"[^0-9]\";\"\") | if length == 0 then $in else tonumber end; walk(if type == \"object\" then map_values(extractNumber) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "rooms": "2 Rooms"
          },
          {
            "rooms": "3 Rooms"
          }
        ],
        "output": [
          {
            "rooms": 2
          },
          {
            "rooms": 3
          }
        ]
      }
    ],
    "identifier": 60582492
  },
  {
    "context": [
      "But I need to have this result:\nWestpac,5d6043ce3b1a6903ba000021\nWestpac,5d6043ce3b1a6903ba000022",
      ".spaces[] | .ext_ids[] as $e | [.account_name, $e] | @csv"
    ],
    "utterance": "Create one row for each ext_ids value, pairing it with the account_name for each space.",
    "expressions": [
      ".spaces[] | .ext_ids[] as $e | [.account_name, $e] | @csv"
    ],
    "data": [
      {
        "input": {
          "id": 39,
          "max_x": null,
          "max_y": null,
          "min_x": null,
          "min_y": null,
          "name": "L1",
          "space_count": 159,
          "spaces": [
            {
              "account_name": "Westpac",
              "ext_ids": [
                "5d6043ce3b1a6903ba000021",
                "5d6043ce3b1a6903ba000022"
              ],
              "gla": 232,
              "gross_rent": 493565.04000000004,
              "id": 8955,
              "lease_end_time": "2021-09-15T00:00:00.000Z",
              "map_unit_no": "GD030A",
              "mat_excl_gst": 0,
              "mat_growth_rate": null,
              "mat_month": "January-2020",
              "net_rent": 337459.2,
              "unit_no": "030A",
              "vertices": []
            }
          ],
          "svg": null
        },
        "output": [
          "Westpac,5d6043ce3b1a6903ba000021",
          "Westpac,5d6043ce3b1a6903ba000022"
        ]
      }
    ],
    "identifier": 60580306
  },
  {
    "context": [
      "But how can I conditionally delete it? I\u2019m looking for something like:",
      "You could adopt the convention that, if a key\u2019s value is `null` (or `nan`), the key can be deleted.  To delete all the null-valued keys, you can use `map_values(select(. != null))` (or `map_values(select(isnan|not))`).",
      "$ echo '{\"id\": 1}' | jq '{newId: (if .id == 1 then null else .id end)} | map_values( select(. != null))'",
      "You can use `empty` as the special value along with `// {}`:",
      "$ echo '{\"id\": 1}' | jq '{newId: (if .id == 1 then empty else .id end) } // {} '"
    ],
    "utterance": "Conditionally exclude a field named newId from the output object if .id equals 1; otherwise include newId with the value of .id.",
    "expressions": [
      "{newId: (if .id == 1 then null else .id end)} | map_values(select(. != null))",
      "{newId: (if .id == 1 then empty else .id end)} // {}"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "more": "fields"
        },
        "output": {
          "newMore": "fields"
        }
      },
      {
        "input": {
          "id": 2,
          "more": "fields"
        },
        "output": {
          "newId": 2,
          "newMore": "fields"
        }
      }
    ],
    "identifier": 60586783
  },
  {
    "context": [
      "I'm trying to filter out items in the cars array where the item's comments array is null:",
      "\"or the item's comments array exists and any of the comments objects don't contain the value \\\"FooBar\\\"\"",
      "With jq I can figure out how to create the critera I want to filter down to but what I can't wrap my head around is how to make that apply to the top level items.",
      "JSON input:",
      "{ ... (input sample) ... }",
      "JSON Outut, same as the input but the oject with the comment array containg the value \\\"FooBar\\\" is filtered out:",
      "{ ... (output sample) ... }",
      "Just use the *update-assignment* operator (`|=`).",
      ".cars |= map(select(.comments and any(.comments[]; index(\"FooBar\")) | not))"
    ],
    "utterance": "Remove all elements from the cars array where the comments array exists and includes the value \"FooBar\", retaining the rest of the structure.",
    "expressions": [
      ".cars |= map(select(.comments == null or (any(.comments[]; index(\"FooBar\")) | not)))"
    ],
    "data": [
      {
        "input": {
          "person": {
            "first_name": "Bob",
            "last_name": "Smith"
          },
          "addresses": [
            {
              "home": {
                "line1": "123",
                "line2": "A st."
              }
            },
            {
              "work": {
                "line1": "456",
                "line2": "B st."
              }
            }
          ],
          "cars": [
            {
              "make": "Honda",
              "model": "Civic"
            },
            {
              "make": "Honda",
              "model": "Accord"
            },
            {
              "make": "Honda",
              "model": "Pilot",
              "comments": [
                "Comment 1",
                "Comment 2",
                "FooBar"
              ]
            },
            {
              "make": "Honda",
              "model": "Passport",
              "comments": [
                "Comment 3",
                "Comment 4"
              ]
            }
          ]
        },
        "output": {
          "person": {
            "first_name": "Bob",
            "last_name": "Smith"
          },
          "addresses": [
            {
              "home": {
                "line1": "123",
                "line2": "A st."
              }
            },
            {
              "work": {
                "line1": "456",
                "line2": "B st."
              }
            }
          ],
          "cars": [
            {
              "make": "Honda",
              "model": "Civic"
            },
            {
              "make": "Honda",
              "model": "Accord"
            },
            {
              "make": "Honda",
              "model": "Passport",
              "comments": [
                "Comment 3",
                "Comment 4"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 60578829
  },
  {
    "context": [
      "So example if a json the following is like:\n{\n\t\"href\": \"1234\",\n\t\"list\": [{\n\t\t\"a\": {\n\t\t\t\"dummy\": \"thing\"\n\t\t},\n\t\t\"b\": {\n\t\t\t\"0\": \"thing\",\n\t\t\t\"1\": \"thing\", <--- ex. I want to change this\n\t\t\t\"2\": \"thing\"\n\t\t}\n\t}]\n}",
      "# Result that I want\n{\n\t\"href\": \"1234\",\n\t\"list\": [{\n\t\t\"a\": {\n\t\t\t\"dummy\": \"thing\"\n\t\t},\n\t\t\"b\": {\n\t\t\t\"0\": \"thing\",\n\t\t\t\"1\": \"changed\", <--- this changed\n\t\t\t\"2\": \"thing\"\n\t\t}\n\t}]\n}",
      "Would you try the following:\n\njq '(.list[].b.\"1\")=\"changed\"' file.json"
    ],
    "utterance": "Update the value at list[0].b[\"1\"] to \"changed\" while preserving all other fields and items in the structure.",
    "expressions": [
      "(.list[].b.\"1\")=\"changed\""
    ],
    "data": [
      {
        "input": {
          "href": "1234",
          "list": [
            {
              "a": {
                "dummy": "thing"
              },
              "b": {
                "0": "thing",
                "1": "thing",
                "2": "thing"
              }
            }
          ]
        },
        "output": {
          "href": "1234",
          "list": [
            {
              "a": {
                "dummy": "thing"
              },
              "b": {
                "0": "thing",
                "1": "changed",
                "2": "thing"
              }
            }
          ]
        }
      }
    ],
    "identifier": 60612468
  },
  {
    "context": [
      "here are 3 JSON files",
      "Don&#39;t find the jq command line that would give this JSON file as jq output:\r\n{\r\n  &quot;components&quot;: {\r\n     &quot;component1&quot;: [\r\n      ],\r\n     &quot;component2&quot;: [\r\n      ],\r\n     &quot;component3&quot;: [\r\n      ]\r\n   }\r\n}\r\n",
      "jq -n 'reduce inputs as $d (.; .components += $d )' file{1..3}.json",
      "You can simply use `add`, e.g.\r\n\n    jq -s '{components: add}' file{1..3}.json",
      "jq -n '{components: [inputs]|add}' file{1..3}.json"
    ],
    "utterance": "Merge component objects from three files under a top-level 'components' key, combining their keys and values.",
    "expressions": [
      "jq -n 'reduce inputs as $d (.; .components += $d )' file1.json file2.json file3.json",
      "jq -s '{components: add}' file1.json file2.json file3.json",
      "jq -n '{components: [inputs]|add}' file1.json file2.json file3.json"
    ],
    "data": [
      {
        "input": [
          {
            "component1": []
          },
          {
            "component2": []
          },
          {
            "component3": []
          }
        ],
        "output": {
          "components": {
            "component1": [],
            "component2": [],
            "component3": []
          }
        }
      }
    ],
    "identifier": 60622466
  },
  {
    "context": [
      "I want to associate the `name` with the `msg`, but only for host `192.169.1.170`.",
      "And, how would I grab the sibling data for the name and bring in the same object, as above?",
      "I think you&#39;re looking for `select` and addition operator (`+`).",
      "```\n.plays[].tasks[]\n| select(.hosts | has(\"192.169.1.70\"))\n| .task + .hosts.\"192.169.1.70\"\n```"
    ],
    "utterance": "Extract objects containing both the task name and msg fields, but only for the host 192.169.1.70.",
    "expressions": [
      ".plays[].tasks[] | select(.hosts | has(\"192.169.1.70\")) | .task + .hosts.\"192.169.1.70\""
    ],
    "data": [
      {
        "input": {
          "plays": [
            {
              "tasks": [
                {
                  "hosts": {
                    "192.169.1.70": {
                      "msg": "inventory_hostname:192.169.1.70:"
                    },
                    "dontcare": {
                      "msg": "dont want to see this:"
                    }
                  },
                  "task": {
                    "name": "debug inventory_hostname"
                  }
                },
                {
                  "hosts": {
                    "192.169.1.70": {
                      "msg": "All items completed"
                    }
                  },
                  "task": {
                    "name": "install system-level components"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "debug inventory_hostname",
            "msg": "inventory_hostname:192.169.1.70:"
          },
          {
            "name": "install system-level components",
            "msg": "All items completed"
          }
        ]
      }
    ],
    "identifier": 60623116
  },
  {
    "context": [
      "I have a file where each line is a JSON object. I'd like to convert the file to a JSON array.",
      "I tried \r\n\r\n    jq --slurp --raw-input 'split(\"\\n\")[:-1]' my_file\r\n\r\nBut that just treats each line as a string creating a JSON array of strings.",
      "I'd like to have:\r\n\r\n    [\r\n      {\"address\":\"email1@foo.bar.com\", \"topic\":\"Some topic.\"},\r\n      {\"address\":\"email2@foo.bar.com\", \"topic\":\"Another topic.\"},\r\n      {\"address\":\"email3@foo.bar.com\", \"topic\":\"Yet another topic.\"}\r\n    ]",
      "jq -n '[inputs]' <in.jsonl >out.json",
      "jq --slurp . <in.jsonl >out.json"
    ],
    "utterance": "Convert a file containing one object per line into a single array of objects.",
    "expressions": [
      "jq -n '[inputs]'",
      "jq --slurp ."
    ],
    "data": [
      {
        "input": [
          {
            "address": "email1@foo.bar.com",
            "topic": "Some topic."
          },
          {
            "address": "email2@foo.bar.com",
            "topic": "Another topic."
          },
          {
            "address": "email3@foo.bar.com",
            "topic": "Yet another topic."
          }
        ],
        "output": [
          {
            "address": "email1@foo.bar.com",
            "topic": "Some topic."
          },
          {
            "address": "email2@foo.bar.com",
            "topic": "Another topic."
          },
          {
            "address": "email3@foo.bar.com",
            "topic": "Yet another topic."
          }
        ]
      }
    ],
    "identifier": 60637859
  },
  {
    "context": [
      "I want to get value from first object like size in below pic.",
      "Depending on the detailed requirements, you will probably want something like:",
      ".recordset[0] | .rowsAffected[0] | .size"
    ],
    "utterance": "Extract the value of the 'size' property from the first element of an array.",
    "expressions": [
      ".recordset[0] | .rowsAffected[0] | .size"
    ],
    "identifier": 60646268
  },
  {
    "context": [
      "is there a way to get the aggregated memory (sum of all memory values multiplied by the number of instances in each case) with a `jq` query?",
      "In this example it should perform the following operation:\r\n\r\n    512*3 + 256*1 + 128*6 + 1024*2\r\nso it should give me `4608` in total.",
      "A one-liner solution:\r\n\r\n    reduce .apps[] as $x (0; . + ($x | .memory * .instances))",
      "Or more elegantly:\r\n\r\n    def sigma(s): reduce s as $x (0; . + $x);\r\n\r\n    sigma(.apps[] | .memory * .instances)"
    ],
    "utterance": "Calculate the sum of each app's memory multiplied by its number of instances.",
    "expressions": [
      "reduce .apps[] as $x (0; . + ($x | .memory * .instances))",
      "def sigma(s): reduce s as $x (0; . + $x); sigma(.apps[] | .memory * .instances)"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "memory": 512,
              "instances": 3
            },
            {
              "memory": 256,
              "instances": 1
            },
            {
              "memory": 128,
              "instances": 6
            },
            {
              "memory": 1024,
              "instances": 2
            }
          ]
        },
        "output": 4608
      }
    ],
    "identifier": 60642449
  },
  {
    "context": [
      "I'm using this code \n\n    replace :=  `cat terraform/terraform.tfvars.json | jq -c --arg ami \"33\" '.ami_id_packer=$ami' ` set_ami:\n\t\t\t@echo $(replace)\n",
      "i think it means `.ami_id_packer` rather than `ami_id_packer` assume your json looks something like \n\n```\n{\n\"ami_id_packer\": ...\n}\n```\n\nplus since you are in Makefile, $ needs to be escaped, it should be `$$ami`"
    ],
    "utterance": "Set the ami_id_packer property to the value of the ami variable, interpolating a value of 33.",
    "expressions": [
      ".ami_id_packer = $ami"
    ],
    "data": [
      {
        "input": {
          "ami_id_packer": "old_value"
        },
        "output": {
          "ami_id_packer": "33"
        }
      }
    ],
    "identifier": 60643862
  },
  {
    "context": [
      "I want the **same** object (with all members, whatever they are, there could be more, there could be less), but only **the first n clients**, for example the first 2.",
      ".clients |= .[0:2]",
      "which can be abbreviated to: ",
      ".clients |= .[:2]"
    ],
    "utterance": "Return the entire top-level object but with only the first 2 elements from the clients array.",
    "expressions": [
      ".clients |= .[0:2]",
      ".clients |= .[:2]"
    ],
    "data": [
      {
        "input": {
          "title": "List of clients",
          "year": 2020,
          "clients": [
            {
              "name": "C0",
              "address": "A0"
            },
            {
              "name": "C1",
              "address": "A1"
            },
            {
              "name": "C2",
              "address": "A2"
            },
            {
              "name": "C3",
              "address": "A4"
            },
            {
              "name": "C4",
              "address": "A5"
            }
          ]
        },
        "output": {
          "title": "List of clients",
          "year": 2020,
          "clients": [
            {
              "name": "C0",
              "address": "A0"
            },
            {
              "name": "C1",
              "address": "A1"
            }
          ]
        }
      }
    ],
    "identifier": 60658461
  },
  {
    "context": [
      "I intend to extract a csv with a row for each sub array item.",
      "Given a json array with a sub array. e.g. like this one:\r\n\r\n    [\r\n      {\r\n         \"foo\": 108, \r\n         \"bar\": [\"a\",\"b\"]\r\n      },\r\n      {   \r\n         \"foo\": 201, \r\n         \"bar\": [\"c\",\"d\"]\r\n      }\r\n    ]",
      ".[] | { \"y\": .foo,  \"x\": .bar[] }| [.y,.x]  | @csv",
      "But I'd like to express it in a less elaborate form.",
      "or maybe less obscurely:\r\n```\r\n.[]\r\n| .bar[] as $bar\r\n| [.foo, $bar] \r\n| @csv\r\n```"
    ],
    "utterance": "Produce a CSV row for each element of the 'bar' array, pairing it with its corresponding 'foo' value.",
    "expressions": [
      ".[] | [.foo] + (.bar[] | [.]) | @csv",
      ".[] | .bar[] as $bar | [.foo, $bar] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 108,
            "bar": [
              "a",
              "b"
            ]
          },
          {
            "foo": 201,
            "bar": [
              "c",
              "d"
            ]
          }
        ],
        "output": [
          "\"108\",\"a\"",
          "\"108\",\"b\"",
          "\"201\",\"c\"",
          "\"201\",\"d\""
        ]
      }
    ],
    "identifier": 60659110
  },
  {
    "context": [
      "Given the json\n```\n{ \"games\": [\n{\n    \"id\":1,\n    \"files\": [ \"foo.mp4\" ]\n},\n{\n    \"id\":2,\n    \"files\": [ \"foo.ogv\",  \"bar.ogv\" ]\n},\n{\n    \"id\":3,\n    \"files\": [ \"bar.ogv\" ]\n}\n]}\n```",
      "`jq -r '.games[] | select(.files[] | contains(\"ogv\"))' foo.json`, `json` outputs an element once for every time it matches `ogv` in the subelement array. How do I get `jq` to output each matching element only once?",
      "jq -r '[.games[] | select(.files[] | contains(\"ogv\"))] | unique | .[]' foo.json",
      "Using `any` would be more efficient than relying on `unique`. E.g.\n\n    jq -r '.games[] | select(any(.files[]; test(\"ogv\")))'"
    ],
    "utterance": "Select all elements from an array where at least one value in the subarray matches the substring 'ogv', ensuring each element appears only once regardless of multiple matches.",
    "expressions": [
      ".games[] | select(any(.files[]; contains(\"ogv\")))",
      "[.games[] | select(.files[] | contains(\"ogv\"))] | unique | .[]"
    ],
    "data": [
      {
        "input": {
          "games": [
            {
              "id": 1,
              "files": [
                "foo.mp4"
              ]
            },
            {
              "id": 2,
              "files": [
                "foo.ogv",
                "bar.ogv"
              ]
            },
            {
              "id": 3,
              "files": [
                "bar.ogv"
              ]
            }
          ]
        },
        "output": [
          {
            "id": 2,
            "files": [
              "foo.ogv",
              "bar.ogv"
            ]
          },
          {
            "id": 3,
            "files": [
              "bar.ogv"
            ]
          }
        ]
      }
    ],
    "identifier": 60660059
  },
  {
    "context": [
      "Ideally, this would instead output the unique values contained in the jobId and earlyAccessStatus keys like this:\n\n    [\n      {\n        \"targetLanguage\": \"pt_BR\",\n        \"jobId\": [\n          35826846, 35826837\n        ],\n        \"earlyAccessStatus\": [\n          \"IN_PROGRESS\"\n        ]\n      },\n      {\n        \"targetLanguage\": \"zh_CN\",\n        \"jobId\": [\n          35826845, 35826836\n        ],\n        \"earlyAccessStatus\": [\n          \"IN_PROGRESS\", \"NOT_STARTED\"\n        ]\n      }\n    ]\n\nThat would let me easily filter for targetLanguage according to earlyAccessStatus == [\"IN_PROGRESS\"]\"",
      "Figured something out that worked! Went more the route of group_by and unique.\n\n    . | [{projectId: .projectId, \n          jobs: [( .jobs[] | { \n                targetLanguage: .targetLanguage, \n                jobId: .jobId, \n                earlyAccessStatus: (.steps[] | select(.workflowStepName == \"Target file export1\") | .status), \n                finalStatus: (.steps[] | select(.workflowStepName == \"Target file export2\") | .status) } )] }] | \n          .[].jobs | group_by(.targetLanguage) | map({\n                targetLanguage: .[0].targetLanguage, \n                jobId: map(.jobId),\n                earlyAccessStatus: map(.earlyAccessStatus) | unique, \n                finalStatus: map(.finalStatus) | unique})",
      "Once the content has been simplified in this manner, it is grouped by `.targetLanguage` and then the `.jobId`, `.earlyAccessStatus`, and `.finalStatus` keys are mapped for their unique values under each `.targetLanguage` key-value pair. I\u2019m sure there is a simpler way to format this, but it accomplishes exactly what I set out to accomplish, leaving the data in this format:\n\n    [\n      {\n        \"targetLanguage\": \"pt_BR\",\n        \"jobId\": [\n          35902526,\n          36433561,\n          36433552\n        ],\n        \"earlyAccessStatus\": [\n          \"IN_PROGRESS\"\n        ],\n        \"finalStatus\": [\n          \"IN_PROGRESS\"\n        ]\n      },\n      {\n        \"targetLanguage\": \"zh_CN\",\n        \"jobId\": [\n          35902516,\n          36433560,\n          36433551\n        ],\n        \"earlyAccessStatus\": [\n          \"IN_PROGRESS\",\n          \"NOT_STARTED\"\n        ],\n        \"finalStatus\": [\n          \"IN_PROGRESS\"\n        ]\n      }\n    ]"
    ],
    "utterance": "For each targetLanguage, group all jobs, collect unique jobId values and unique earlyAccessStatus values where earlyAccessStatus is found in steps.workflowStepName == \"Target file export1\".",
    "expressions": [
      ". | [{projectId: .projectId, jobs: [( .jobs[] | { targetLanguage: .targetLanguage, jobId: .jobId, earlyAccessStatus: (.steps[] | select(.workflowStepName == \"Target file export1\") | .status), finalStatus: (.steps[] | select(.workflowStepName == \"Target file export2\") | .status) } )] }] | .[].jobs | group_by(.targetLanguage) | map({targetLanguage: .[0].targetLanguage, jobId: map(.jobId), earlyAccessStatus: map(.earlyAccessStatus) | unique, finalStatus: map(.finalStatus) | unique})"
    ],
    "data": [
      {
        "input": {
          "projectId": 35902499,
          "completionStatus": "IN_PROGRESS",
          "activity": "ACTIVE",
          "sourceLanguage": "en_US",
          "jobs": [
            {
              "jobId": 35902526,
              "completionStatus": "IN_PROGRESS",
              "targetLanguage": "pt_BR",
              "steps": [
                {
                  "workflowStepName": "Project Intake and Quote Generation1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Translate1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Correct1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Segment greenification1",
                  "status": "FINISHED",
                  "autoStatus": "SUCCESS"
                },
                {
                  "workflowStepName": "Target file export1",
                  "status": "IN_PROGRESS"
                }
              ]
            },
            {
              "jobId": 35902516,
              "completionStatus": "IN_PROGRESS",
              "targetLanguage": "zh_CN",
              "steps": [
                {
                  "workflowStepName": "Project Intake and Quote Generation1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Translate1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Correct1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Segment greenification1",
                  "status": "FINISHED",
                  "autoStatus": "SUCCESS"
                },
                {
                  "workflowStepName": "Target file export1",
                  "status": "IN_PROGRESS"
                }
              ]
            },
            {
              "jobId": 36433561,
              "completionStatus": "IN_PROGRESS",
              "targetLanguage": "pt_BR",
              "steps": [
                {
                  "workflowStepName": "Project Intake and Quote Generation1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Translate1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Correct1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Segment greenification1",
                  "status": "FINISHED",
                  "autoStatus": "SUCCESS"
                },
                {
                  "workflowStepName": "Target file export1",
                  "status": "IN_PROGRESS"
                }
              ]
            },
            {
              "jobId": 36433560,
              "completionStatus": "IN_PROGRESS",
              "targetLanguage": "zh_CN",
              "steps": [
                {
                  "workflowStepName": "Project Intake and Quote Generation1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Translate1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Correct1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Segment greenification1",
                  "status": "FINISHED",
                  "autoStatus": "SUCCESS"
                },
                {
                  "workflowStepName": "Target file export1",
                  "status": "IN_PROGRESS"
                }
              ]
            },
            {
              "jobId": 36433552,
              "completionStatus": "IN_PROGRESS",
              "targetLanguage": "pt_BR",
              "steps": [
                {
                  "workflowStepName": "Project Intake and Quote Generation1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Translate1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Correct1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Segment greenification1",
                  "status": "FINISHED",
                  "autoStatus": "SUCCESS"
                },
                {
                  "workflowStepName": "Target file export1",
                  "status": "IN_PROGRESS"
                }
              ]
            },
            {
              "jobId": 36433551,
              "completionStatus": "IN_PROGRESS",
              "targetLanguage": "zh_CN",
              "steps": [
                {
                  "workflowStepName": "Project Intake and Quote Generation1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Translate1",
                  "status": "FINISHED"
                },
                {
                  "workflowStepName": "Correct1",
                  "status": "IN_PROGRESS"
                },
                {
                  "workflowStepName": "Segment greenification1",
                  "status": "NOT_STARTED"
                },
                {
                  "workflowStepName": "Target file export1",
                  "status": "NOT_STARTED"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "targetLanguage": "pt_BR",
            "jobId": [
              35902526,
              36433561,
              36433552
            ],
            "earlyAccessStatus": [
              "IN_PROGRESS"
            ],
            "finalStatus": [
              "IN_PROGRESS"
            ]
          },
          {
            "targetLanguage": "zh_CN",
            "jobId": [
              35902516,
              36433560,
              36433551
            ],
            "earlyAccessStatus": [
              "IN_PROGRESS",
              "NOT_STARTED"
            ],
            "finalStatus": [
              "IN_PROGRESS"
            ]
          }
        ]
      }
    ],
    "identifier": 60389855
  },
  {
    "context": [
      "Here is a sample of the output:\r\n```\r\n{\r\n  \"name\": \"amazon-ebs\",\r\n  \"builder_type\": \"amazon-ebs\",\r\n  \"build_time\": 1584037532,\r\n  \"files\": null,\r\n  \"artifact_id\": \"ca-central-1:ami-02420*,us-east-1:ami-06a4*,us-west-1:ami-078cf*\",\r\n  \"packer_run_uuid\": \"\",\r\n  \"custom_data\": null\r\n}\r\n```",
      "I'd like to use jq to be able to build a new json in this format:\r\n```\r\n{\r\n  \"ca-central\": \"ami_id\",\r\n  \"us-east-1\": \"ami_id\",\r\n  \"us-west-1\": \"ami_id\"\r\n}\r\n```",
      "With your input, the following jq program:\r\n\r\n```\r\n.artifact_id\r\n| [ split(\",\")[] \r\n    | (split(\":\") | {(.[0]): .[1] } ) ]\r\n| add    \r\n```\r\n\r\nproduces:\r\n\r\n```\r\n{\r\n  \"ca-central-1\": \"ami-02420*\",\r\n  \"us-east-1\": \"ami-06a4*\",\r\n  \"us-west-1\": \"ami-078cf*\"\r\n}\r\n```"
    ],
    "utterance": "Create an object mapping each region name to its AMI ID from the artifact_id string, splitting by commas and colons.",
    "expressions": [
      ".artifact_id | [ split(\",\")[] | (split(\":\") | {(.[0]): .[1] }) ] | add"
    ],
    "data": [
      {
        "input": {
          "name": "amazon-ebs",
          "builder_type": "amazon-ebs",
          "build_time": 1584037532,
          "files": null,
          "artifact_id": "ca-central-1:ami-02420*,us-east-1:ami-06a4*,us-west-1:ami-078cf*",
          "packer_run_uuid": "",
          "custom_data": null
        },
        "output": {
          "ca-central-1": "ami-02420*",
          "us-east-1": "ami-06a4*",
          "us-west-1": "ami-078cf*"
        }
      }
    ],
    "identifier": 60660305
  },
  {
    "context": [
      "upload_id=$(cat output_file.json | jq -r '.upload_id')",
      "sh \"\"\"\n    upload_id=\\$(cat output_file.json | jq -r '.upload_id')\n    echo \"\\${upload_id}\"\n\"\"\""
    ],
    "utterance": "Extract the value associated with the key 'upload_id' from output_file.json and print it.",
    "expressions": [
      "jq -r '.upload_id' output_file.json"
    ],
    "identifier": 60671276
  },
  {
    "context": [
      "I want to NOT showing the json strings when the `requested_reviewers` is empty.",
      "Besides I don't want to just print out the field. I want to be able to see the entire json string.",
      "How can I achieve my goal with `jq`?",
      "select(.requested_reviewers != [])",
      "jq 'select(.requested_reviewers | length > 0)'"
    ],
    "utterance": "Return each complete object only if the requested_reviewers array is not empty.",
    "expressions": [
      "select(.requested_reviewers != [])",
      "select(.requested_reviewers | length > 0)"
    ],
    "data": [
      {
        "input": {
          "id": 18535,
          "node_id": "MDExhN0M8877883",
          "number": 747,
          "state": "closed",
          "locked": false,
          "title": "Generate cordova protos",
          "user": {
            "login": "Superhacker"
          },
          "body": "Simple PR",
          "created_at": "2018-05-02T07:43:39Z",
          "updated_at": "2018-07-21T02:09:14Z",
          "closed_at": "2018-05-02T07:54:56Z",
          "merge_commit_sha": "4bf92c0332c66999999b6c0a766e",
          "assignee": null,
          "assignees": [],
          "requested_reviewers": [],
          "requested_teams": [],
          "labels": [],
          "milestone": null,
          "draft": false,
          "author_association": "CONTRIBUTOR"
        },
        "output": null
      },
      {
        "input": {
          "id": 18535,
          "node_id": "MDExhN0M8877883",
          "number": 747,
          "state": "closed",
          "locked": false,
          "title": "Generate cordova protos",
          "user": {
            "login": "Superhacker"
          },
          "body": "Simple PR",
          "created_at": "2018-05-02T07:43:39Z",
          "updated_at": "2018-07-21T02:09:14Z",
          "closed_at": "2018-05-02T07:54:56Z",
          "merge_commit_sha": "4bf92c0332c66999999b6c0a766e",
          "assignee": null,
          "assignees": [],
          "requested_reviewers": [
            {
              "login": "otheruser"
            }
          ],
          "requested_teams": [],
          "labels": [],
          "milestone": null,
          "draft": false,
          "author_association": "CONTRIBUTOR"
        },
        "output": {
          "id": 18535,
          "node_id": "MDExhN0M8877883",
          "number": 747,
          "state": "closed",
          "locked": false,
          "title": "Generate cordova protos",
          "user": {
            "login": "Superhacker"
          },
          "body": "Simple PR",
          "created_at": "2018-05-02T07:43:39Z",
          "updated_at": "2018-07-21T02:09:14Z",
          "closed_at": "2018-05-02T07:54:56Z",
          "merge_commit_sha": "4bf92c0332c66999999b6c0a766e",
          "assignee": null,
          "assignees": [],
          "requested_reviewers": [
            {
              "login": "otheruser"
            }
          ],
          "requested_teams": [],
          "labels": [],
          "milestone": null,
          "draft": false,
          "author_association": "CONTRIBUTOR"
        }
      }
    ],
    "identifier": 60650347
  },
  {
    "context": [
      "I am trying to find a way to use regex in jq to search value in `issuer_dn` that is more than 8 characters.",
      "A regex like `[A-Z]{8}` should work but I am unable to get results.",
      "I would use the following : \r\n\r\n    .data.tls.result.handshake_log.server_certificates.certificate.parsed.issuer_dn \\\r\n     | select(length &gt; 8)",
      "You could use:\r\n\r\n    test(&quot;[A-Z]{8}&quot;)"
    ],
    "utterance": "Filter issuer_dn fields whose value matches the regular expression [A-Z]{8} or have length greater than 8.",
    "expressions": [
      ".data.tls.result.handshake_log.server_certificates.certificate.parsed.issuer_dn | select(length > 8)",
      ".data.tls.result.handshake_log.server_certificates.certificate.parsed.issuer_dn | select(test(\"[A-Z]{8}\"))"
    ],
    "data": [
      {
        "input": {
          "ip": "127.0.0.1",
          "data": {
            "tls": {
              "status": "success",
              "protocol": "tls",
              "result": {
                "handshake_log": {
                  "server_hello": {
                    "version": {
                      "name": "TLSv1.2",
                      "value": 771
                    },
                    "random": "hhdshfhhdhfhshdh",
                    "session_id": "hjdsfyyueujhfjaskdfjjl",
                    "cipher_suite": {
                      "hex": "0xC014",
                      "name": "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA",
                      "value": 49172
                    },
                    "compression_method": 0,
                    "ocsp_stapling": false,
                    "ticket": false,
                    "secure_renegotiation": true,
                    "heartbeat": false,
                    "extended_master_secret": false
                  },
                  "server_certificates": {
                    "certificate": {
                      "raw": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC==",
                      "parsed": {
                        "version": 3,
                        "serial_number": "1234567890",
                        "signature_algorithm": {
                          "name": "SHA256-RSA",
                          "oid": "1.2.840.113549.1.1.11"
                        },
                        "issuer": {
                          "common_name": [
                            "ABC"
                          ],
                          "country": [
                            "ABC"
                          ],
                          "locality": [
                            "ABC"
                          ],
                          "province": [
                            "ABC"
                          ],
                          "organization": [
                            "ABC"
                          ],
                          "organizational_unit": [
                            "ABC"
                          ]
                        },
                        "issuer_dn": "C=ABCD, ST=ABCD, L=ABCD, O=ABCD, OU=ABCD, CN=ABCD",
                        "validity": {
                          "start": "2020-02-01T01:09:22Z",
                          "end": "2021-02-01T03:09:22Z",
                          "length": 7883663
                        },
                        "subject": {
                          "common_name": [
                            "ABC"
                          ],
                          "country": [
                            "ABC"
                          ],
                          "locality": [
                            "ABC"
                          ],
                          "province": [
                            "ABC"
                          ],
                          "organization": [
                            "ABC"
                          ],
                          "organizational_unit": [
                            "ABC"
                          ]
                        },
                        "subject_dn": "C=ABCD, ST=ABCD, L=ABCD, O=ABCD, OU=ABCD, CN=ABCD",
                        "subject_key_info": {
                          "key_algorithm": {
                            "name": "RSA"
                          },
                          "rsa_public_key": {
                            "exponent": 65537,
                            "modulus": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC",
                            "length": 2048
                          },
                          "fingerprint_sha256": "73hh3g39920jfjj38723bb3993hh3774994002"
                        },
                        "extensions": {
                          "basic_constraints": {
                            "is_ca": true
                          },
                          "authority_key_id": "73hh3g39920jfjj38723bb3993hh3774994002",
                          "subject_key_id": "73hh3g39920jfjj38723bb3993hh3774994002"
                        },
                        "signature": {
                          "signature_algorithm": {
                            "name": "SHA256-RSA",
                            "oid": "1.2.840.113549.1.1.11"
                          },
                          "value": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC",
                          "valid": true,
                          "self_signed": true
                        },
                        "fingerprint_md5": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "fingerprint_sha1": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "fingerprint_sha256": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "tbs_noct_fingerprint": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "spki_subject_fingerprint": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "tbs_fingerprint": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "validation_level": "73hh3g39920jfjj38723bb3993hh3774994002",
                        "redacted": false
                      }
                    },
                    "validation": {
                      "browser_trusted": false,
                      "browser_error": "x509: failed to load system roots and no roots provided"
                    }
                  },
                  "server_key_exchange": {
                    "ecdh_params": {
                      "curve_id": {
                        "name": "secp256r1",
                        "id": 23
                      },
                      "server_public": {
                        "x": {
                          "value": "73hh3g39920jfjj38723bb3993hh3774994002",
                          "length": 256
                        },
                        "y": {
                          "value": "73hh3g39920jfjj38723bb3993hh3774994002",
                          "length": 256
                        }
                      }
                    },
                    "digest": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC",
                    "signature": {
                      "raw": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC",
                      "type": "rsa",
                      "valid": true,
                      "signature_and_hash_type": {
                        "signature_algorithm": "rsa",
                        "hash_algorithm": "sha256"
                      },
                      "tls_version": {
                        "name": "TLSv1.2",
                        "value": 771
                      }
                    }
                  },
                  "client_key_exchange": {
                    "ecdh_params": {
                      "curve_id": {
                        "name": "secp256r1",
                        "id": 23
                      },
                      "client_public": {
                        "x": {
                          "value": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC=",
                          "length": 256
                        },
                        "y": {
                          "value": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC=",
                          "length": 256
                        }
                      },
                      "client_private": {
                        "value": "dGVzdCBkYXRhIGFuZCBnYXJiYWdldGVzdC=",
                        "length": 32
                      }
                    }
                  },
                  "client_finished": {
                    "verify_data": "dGVzdCBkY"
                  },
                  "server_finished": {
                    "verify_data": "dGVzdCBkY"
                  },
                  "key_material": {
                    "master_secret": {
                      "value": "dGVzdCBkY",
                      "length": 48
                    },
                    "pre_master_secret": {
                      "value": "dGVzdCBkY",
                      "length": 32
                    }
                  }
                }
              },
              "timestamp": "2020-02-9T07:14:47Z"
            }
          }
        },
        "output": "C=ABCD, ST=ABCD, L=ABCD, O=ABCD, OU=ABCD, CN=ABCD"
      }
    ],
    "identifier": 60614991
  },
  {
    "context": [
      "I need a jq command to replace array values with non-json standard values i.e. in the following json input I need to replace the \"webOrigins\" array values with a non-json value, which is a Jinja2 template variable replacement as per the second json block below.",
      "jq '.clients[] |= (.webOrigins = \"{{clients.\\(.clientId).webOrigins}}\")' |",
      "sed '/\"webOrigins\":/ { s/\"[{][{]/{{/; s/[}][}]\"$/}}/; }'"
    ],
    "utterance": "Replace each object's webOrigins array value with a Jinja2 template variable {{clients.<clientId>.webOrigins}}, unquoted and not in JSON array form.",
    "expressions": [
      ".clients[] |= (.webOrigins = \"{{clients.\\(.clientId).webOrigins}}\")"
    ],
    "data": [
      {
        "input": {
          "clients": [
            {
              "clientId": "abc",
              "webOrigins": [
                "/",
                "/api"
              ]
            },
            {
              "clientId": "xyz",
              "webOrigins": []
            }
          ]
        },
        "output": {
          "clients": [
            {
              "clientId": "abc",
              "webOrigins": "{{clients.abc.webOrigins}}"
            },
            {
              "clientId": "xyz",
              "webOrigins": "{{clients.xyz.webOrigins}}"
            }
          ]
        }
      }
    ],
    "identifier": 60667763
  },
  {
    "context": [
      "\"jq \\\".events[] | [.mydata.id, .mydata.account] | @csv\\\"  events.json\"",
      "I would like CSV file with two records per row, like this:",
      "\"\\\"123456\\\",\\\"21234\\\"\\n\\\"123457\\\",\\\"21234\\\"\\n\"",
      "Use the -r flag.",
      "\"jq -r '.events[] | [.mydata.id, .mydata.account] | @csv'\"",
      "Yields",
      "  \"123456\",\"21234\"",
      "  \"123457\",\"21234\""
    ],
    "utterance": "Produce a CSV file with records showing mydata.id and mydata.account from each element in the events array, with each CSV record as a row without extra escaping.",
    "expressions": [
      "jq -r '.events[] | [.mydata.id, .mydata.account] | @csv'"
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "mydata": {
                "id": "123456",
                "account": "21234"
              }
            },
            {
              "mydata": {
                "id": "123457",
                "account": "21234"
              }
            }
          ]
        },
        "output": "\"123456\",\"21234\"\n\"123457\",\"21234\""
      }
    ],
    "identifier": 60673754
  },
  {
    "context": [
      "For each `user_id` in the \"Logins\" files, I want to find a matching `id` in the \"Users\" files.",
      "I want to merge those two object together.",
      "As a bonus, I only want the email first and last name from \"Users\".",
      "the output using the sample inputs would be:\n\n```\n[\n  {\n    \"user_id\": \"5ce722b803b54f03f745cdf45d579920\",\n    \"time\": \"2019-10-29T20:03:18.894006Z\",\n    \"email\": \"foo@gmail.com\",\n    \"first_name\": \"John\",\n    \"last_name\": \"Doe\"\n  }\n]\n```",
      "where users-logins.jq contains:\n\n```\nINDEX($users[]; .id) as $udict\n| map( if $udict[.user_id] then . + $udict[.user_id] else empty end)\n| map( {user_id, time, email, first_name, last_name} )\n```"
    ],
    "utterance": "For each user_id in the logins data, find a record in the users data with a matching id, merge their data, and output objects containing user_id, time, email, first_name, and last_name.",
    "expressions": [
      "INDEX($users[]; .id) as $udict | map( if $udict[.user_id] then . + $udict[.user_id] else empty end) | map( {user_id, time, email, first_name, last_name} )"
    ],
    "data": [
      {
        "input": {
          "logins": [
            {
              "user_id": "5ce722b803b54f03f745cdf45d579920",
              "time": "2019-10-29T20:03:18.894006Z"
            },
            {
              "user_id": "5ce722b858f3e80e6e85aad3113a1665",
              "time": "2019-10-29T20:11:32.4843Z"
            }
          ],
          "users": [
            {
              "id": "5ce722b803b54f03f745cdf45d579920",
              "email": "foo@gmail.com",
              "first_name": "John",
              "last_name": "Doe",
              "enabled": true,
              "created_at": "2019-06-13T17:07:17.2925Z",
              "updated_at": "2019-06-13T17:15:20.903085Z",
              "groups": {
                "count": 1,
                "shortlist": [
                  {
                    "id": "5d0282c5d5d6063286140e864a0c6506",
                    "name": "cool users",
                    "description": "cool users",
                    "locked": true
                  }
                ]
              },
              "avatar": "",
              "role_id": "5d0282c488bba9ebc62df8b3c38571a9",
              "company_uid": ""
            },
            {
              "id": "5d0284fdec62d47039e7119013b0aa2c",
              "email": "bar@gmail.com",
              "first_name": "Jane",
              "last_name": "Doe",
              "enabled": true,
              "created_at": "2019-06-13T17:16:45.210018Z",
              "updated_at": "2019-06-13T17:16:45.210018Z",
              "groups": {
                "count": 1,
                "shortlist": [
                  {
                    "id": "5d0282c5d5d6063286140e864a0c6506",
                    "name": "cool users",
                    "description": "cool users",
                    "locked": true
                  }
                ]
              },
              "avatar": "",
              "role_id": "5d0282c488bba9ebc62df8b3c38571a9",
              "company_uid": ""
            }
          ]
        },
        "output": [
          {
            "user_id": "5ce722b803b54f03f745cdf45d579920",
            "time": "2019-10-29T20:03:18.894006Z",
            "email": "foo@gmail.com",
            "first_name": "John",
            "last_name": "Doe"
          }
        ]
      }
    ],
    "identifier": 60663178
  },
  {
    "context": [
      "My intention is to list all the values of \"Name\" key.",
      "jq -r '.Descriptions[].Name' <<<$DescribeProfession"
    ],
    "utterance": "Extract all values of the key \"Name\" from each element in the \"Descriptions\" array.",
    "expressions": [
      ".Descriptions[].Name",
      "-r '.Descriptions[].Name'"
    ],
    "data": [
      {
        "input": {
          "Descriptions": [
            {
              "Name": "Doctor",
              "AttributeDescriptions": [],
              "TypeName": "Professional"
            },
            {
              "Name": "Pilot",
              "AttributeDescriptions": [
                {
                  "AttributeValue": "",
                  "AttributeName": ""
                }
              ]
            }
          ]
        },
        "output": [
          "Doctor",
          "Pilot"
        ]
      }
    ],
    "identifier": 60707733
  },
  {
    "context": [
      "upload_id=$(cat output_file.json | jq -r \\' .upload_id \\')",
      "sh \"echo \\\"$upload_id\\\"\"",
      "def upload_id = sh label: '', script: 'echo $(cat output_file.json | jq -r \\' .upload_id \\')', returnStdout: true",
      "upload_id = upload_id.trim()  // remove extraneous whitespace"
    ],
    "utterance": "Extract the value associated with the key upload_id from output_file.json.",
    "expressions": [
      "jq -r '.upload_id' output_file.json"
    ],
    "data": [
      {
        "input": {
          "upload_id": "8f304c6d-804b-440a-xxxx"
        },
        "output": "8f304c6d-804b-440a-xxxx"
      }
    ],
    "identifier": 60706792
  },
  {
    "context": [
      "Would like it to end up like this:\r\n```\r\nName,Car,Location\r\nJohn Doe,Car1,Texas\r\nJohn Doe,Car2,Texas\r\nJane Roe,Car1,Illinois\r\nJane Roe,Car1,Kansas\r\n```",
      "Here is what I am going for. I think its the most readable in this format but anything would at least show all the keys",
      "You&#39;re looking for something like this:\r\n```\r\ndef expand($keys):\r\n    . as $in\r\n    | reduce $keys[] as $k ( [{}];\r\n        map(. + { \r\n            ($k): ($in[$k] | if type == \"array\" then .[] else . end)\r\n        })\r\n    ) | .[];\r\n(.[0] | keys_unsorted) as $h\r\n| $h, (.[] | expand($h) | [.[$h[]]]) | @csv\r\n```"
    ],
    "utterance": "Flatten each object so that for every combination of Name, Car, Location, and Repairs:RepairLocations:RepairsCompleted, there is a separate row, including all combinations from arrays or scalars.",
    "expressions": [
      "def expand($keys):\n    . as $in\n    | reduce $keys[] as $k ( [{}];\n        map(. + { \n            ($k): ($in[$k] | if type == \"array\" then .[] else . end)\n        })\n    ) | .[];\n(.[0] | keys_unsorted) as $h\n| $h, (.[] | expand($h) | [.[$h[]]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "Customers": [
            {
              "Name": "John Doe",
              "Car": [
                "Car1",
                "Car2"
              ],
              "Location": "Texas",
              "Repairs": {
                "RepairLocations": {
                  "RepairsCompleted": [
                    "Fix1",
                    "Fix2"
                  ]
                }
              }
            },
            {
              "Name": "Jane Roe",
              "Car": "Car1",
              "Location": [
                "Illinois",
                "Kansas"
              ]
            }
          ]
        },
        "output": [
          [
            "Name",
            "Car",
            "Location",
            "Repairs:RepairLocations:RepairsCompleted"
          ],
          [
            "John Doe",
            "Car1",
            "Texas",
            "Fix1"
          ],
          [
            "John Doe",
            "Car1",
            "Texas",
            "Fix2"
          ],
          [
            "John Doe",
            "Car2",
            "Texas",
            "Fix1"
          ],
          [
            "John Doe",
            "Car2",
            "Texas",
            "Fix2"
          ],
          [
            "Jane Roe",
            "Car1",
            "Illinois",
            ""
          ],
          [
            "Jane Roe",
            "Car1",
            "Kansas",
            ""
          ]
        ]
      }
    ],
    "identifier": 60674867
  },
  {
    "context": [
      "Instead of only reply the tunnel section I want it to return the full array.",
      "Simply have your `select()` refer to the nested field, that will return the whole top-level element.",
      "$ cat testerr.json | jq 'select(.tunnel.source | contains (\"1.5.55.\"))'"
    ],
    "utterance": "Return all top-level objects where the tunnel.source field contains \"1.5.55.\"",
    "expressions": [
      "select(.tunnel.source | contains (\"1.5.55.\"))"
    ],
    "data": [
      {
        "input": [
          {
            "circuitIdNum": 1226,
            "description": "9287-customer:vpn-2001226-(R1-Loopback0)",
            "interfaceId": "1040",
            "ipv4": {
              "aclEgress": "rot-out",
              "addr": "55.44.53.191/31",
              "bgpNeighbor": "33.567.53.190"
            },
            "loadInterval": 30,
            "remoteRouter": "R1-Loopback0",
            "shortName": "rot",
            "tunnel": {
              "destination": "94.252.78.14",
              "source": "66.52.5.4"
            }
          },
          {
            "circuitIdNum": 1227,
            "description": "9287-customer:vpn-2001227-(R2-Loopback0)",
            "interfaceId": "1041",
            "ipv4": {
              "aclEgress": "rot-out",
              "addr": "23.77.175.253/31",
              "bgpNeighbor": "21.44.175.252"
            },
            "loadInterval": 30,
            "remoteRouter": "R2-Loopback0",
            "shortName": "rot",
            "tunnel": {
              "destination": "22.22.18.15",
              "source": "1.5.55.5"
            }
          }
        ],
        "output": {
          "circuitIdNum": 1227,
          "description": "9287-customer:vpn-2001227-(R2-Loopback0)",
          "interfaceId": "1041",
          "ipv4": {
            "aclEgress": "rot-out",
            "addr": "23.77.175.253/31",
            "bgpNeighbor": "21.44.175.252"
          },
          "loadInterval": 30,
          "remoteRouter": "R2-Loopback0",
          "shortName": "rot",
          "tunnel": {
            "destination": "22.22.18.15",
            "source": "1.5.55.5"
          }
        }
      }
    ],
    "identifier": 60696717
  },
  {
    "context": [
      "Three of the objects have an `.overview.title` which contains the string \"Env Vars\".",
      "Im trying to use `jq` to get the output to look like:",
      "\"rvbrc7y6a5d6xpz37av534zv3a\", \"Env Vars - CSP 1\"",
      "Select objects where `.overview.title` contains `Env Vars`, extract `.uuid` out of them, make arrays of UUID and title pairs, and feed them to `@csv` filter.",
      ".[]\n| .overview.title as $t \n| select($t | index(\"Env Vars\")) \n| [.uuid, $t]\n| @csv"
    ],
    "utterance": "Get the uuid and title of objects whose overview.title contains the string \"Env Vars\".",
    "expressions": [
      ".[] | .overview.title as $t | select($t | index(\"Env Vars\")) | [.uuid, $t] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "uuid": "rvbrc7y6a5d6xpz37av534zv3a",
            "templateUuid": "101",
            "trashed": "N",
            "createdAt": "2018-07-26T05:48:51Z",
            "updatedAt": "2018-07-27T00:26:35Z",
            "changerUuid": "Y7WX2RXJ35GCLLERQA2T74CKNM",
            "itemVersion": 3,
            "vaultUuid": "awn3jry3oo55xdcfgs7bnlyioa",
            "overview": {
              "ps": 0,
              "title": "Env Vars - CSP 1"
            }
          },
          {
            "uuid": "xtf3vdsnw5ardldytwh6edihzu",
            "templateUuid": "001",
            "trashed": "N",
            "createdAt": "2013-10-15T01:29:57Z",
            "updatedAt": "2016-11-22T20:57:47Z",
            "changerUuid": "Y7WX2RXJ35GCLLERQA2T74CKNM",
            "itemVersion": 1,
            "vaultUuid": "qmorozyspqhb26kr4z7nbt7hpy",
            "overview": {
              "URLs": [
                {
                  "u": "https://example.com"
                }
              ],
              "ainfo": "*******@gmail.com",
              "ps": 72,
              "title": "https://example.com",
              "url": "https://example.com"
            }
          }
        ],
        "output": [
          "\"rvbrc7y6a5d6xpz37av534zv3a\",\"Env Vars - CSP 1\""
        ]
      }
    ],
    "identifier": 60703876
  },
  {
    "context": [
      "I would need to have variables on both the field name side and the value side?",
      "JQ already has a builtin for that",
      "jq -n env > env.json"
    ],
    "utterance": "Output all environment variables as key-value pairs within an object.",
    "expressions": [
      "jq -n env"
    ],
    "identifier": 60727371
  },
  {
    "context": [
      "I want to create a consolidate file with all the contents from the above files. There can be more than 2 files. In the consolidate file the `key` value will become the outer level key of the JSON record. eg:\r\n\r\n    {\r\n    \t\"k1\": {\r\n          \"host\": \"..\",\r\n          \"name\": \"..\"   \r\n      \t},\r\n      \t\"k2\": {\r\n          \"host\": \"..\",\r\n          \"name\": \"..\"   \r\n        }\r\n    }",
      "Using [`INDEX`](https://stedolan.github.io/jq/manual/v1.6/#SQL-StyleOperators):\r\n```\r\njq -n 'INDEX(inputs; .key) | map_values(del(.key))' \"${file_names[@]}\"\r\n```"
    ],
    "utterance": "Combine multiple files containing objects where each has a 'key' field, and produce a single result mapping each 'key' to its corresponding object (excluding the 'key' field).",
    "expressions": [
      "jq -n 'INDEX(inputs; .key) | map_values(del(.key))' \"${file_names[@]}\""
    ],
    "data": [
      {
        "input": [
          {
            "key": "k1",
            "host": "..",
            "name": ".."
          },
          {
            "key": "k2",
            "host": "..",
            "name": ".."
          }
        ],
        "output": {
          "k1": {
            "host": "..",
            "name": ".."
          },
          "k2": {
            "host": "..",
            "name": ".."
          }
        }
      }
    ],
    "identifier": 60720039
  },
  {
    "context": [
      "I have a JSON array like this:",
      "[{\"name\": \"Bo\",\"type\": \"dog\"}, {\"name\": \"Roxer\",\"type\": \"dog\"},{\"name\": \"Paws\",\"type\": \"cat\"}]",
      "I'm trying to convert it to an object keyed by `type`, like this:",
      "{\"dog\": [{\"name\": \"Bo\",\"type\": \"dog\"},{\"name\": \"Roxer\",\"type\": \"dog\"}],\"cat\": [{\"name\": \"Paws\",\"type\": \"cat\"}]}",
      "jq 'reduce .[] as $i ({}; .[$i.type] += [$i])'",
      "Another possible way using `group_by()` on the `.type` field and then create the final result with `.type` as the key",
      "jq 'group_by(.type)[] | { (.[0].type) : . }'"
    ],
    "utterance": "Group objects by the 'type' key, creating an object where each key is a type and the value is an array of all objects with that type.",
    "expressions": [
      "reduce .[] as $i ({}; .[$i.type] += [$i])",
      "group_by(.type) | map({ (.[0].type): . }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Bo",
            "type": "dog"
          },
          {
            "name": "Roxer",
            "type": "dog"
          },
          {
            "name": "Paws",
            "type": "cat"
          }
        ],
        "output": {
          "dog": [
            {
              "name": "Bo",
              "type": "dog"
            },
            {
              "name": "Roxer",
              "type": "dog"
            }
          ],
          "cat": [
            {
              "name": "Paws",
              "type": "cat"
            }
          ]
        }
      }
    ],
    "identifier": 60727891
  },
  {
    "context": [
      "[ \"10.149.46\", \"10.149.35\", \"10.149.45\" ]",
      "to something like a list of strings, see below:",
      "\"10.149.46\",\"10.149.35\",\"10.149.45\"",
      "Values are stored in a file sourcefile.json and under the field myfield in a format like:",
      "{ \"myfield\": [ \"10.149.46\", \"10.149.35\", \"10.149.45\" ], \"otherfield\": \"othervalue\" }",
      "with jq @csv:",
      "> echo $(jq -r '.myfield' sourcefile.json |jq @csv)",
      "result: \"\\\"10.149.46\\\" ,\\\"10.149.35\\\",\\\"10.149.45\\\"\""
    ],
    "utterance": "Extract the myfield array from the sourcefile and output its items as a single comma-separated list of strings with each value quoted.",
    "expressions": [
      ".myfield | @csv"
    ],
    "data": [
      {
        "input": {
          "myfield": [
            "10.149.46",
            "10.149.35",
            "10.149.45"
          ],
          "otherfield": "othervalue"
        },
        "output": "\"10.149.46\",\"10.149.35\",\"10.149.45\""
      }
    ],
    "identifier": 60748198
  },
  {
    "context": [
      "If IP is contained within Groups then add Host & Info.",
      "The following assumes that the Front and Back objects are presented in that order on STDIN or in a file; with this assumption, the following program should be invoked with the -n command-line option.",
      "input as $front\n| input as $back\n| ($back|INDEX(.Back[]; .IP) | map_values({Host,Info})) as $dict\n| $front\n| .Front[]\n  |= reduce ($dict | keys_unsorted[]) as $k (.;\n       if (.Groups | contains($k)) then . + $dict[$k] else . end)"
    ],
    "utterance": "For each item in Front, if any IP from Back appears within its Groups field, add the corresponding Host and Info values from Back, joining multiple matches by comma.",
    "expressions": [
      "input as $front\n| input as $back\n| ($back|INDEX(.Back[]; .IP) | map_values({Host,Info})) as $dict\n| $front\n| .Front[]\n  |= reduce ($dict | keys_unsorted[]) as $k (.;\n       if (.Groups | contains($k)) then . + $dict[$k] else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "Front": [
              {
                "Name": "new.domain.com-80",
                "Out": "8.8.8.8",
                "In": "192.168.2.2:80",
                "W Name": "new.domain.com-80",
                "Groups": "192.168.3.29:80 192.168.3.30:80"
              },
              {
                "Name": "new.domain.com -443",
                "Out": "8.8.8.8",
                "In": "192.168.2.2:443",
                "W Name": "new.domain.com-443",
                "Groups": "192.168.3.29:443 192.168.3.30:443"
              }
            ]
          },
          {
            "Back": [
              {
                "REC": "",
                "IP": "192.168.3.30",
                "Host": "new2.domain.com",
                "Info": "Worker5 MD: Data source - Owner: Q"
              },
              {
                "REC": "Q",
                "IP": "192.168.3.29",
                "Host": "new3.domain.com",
                "Info": "Worker5 MD: Data source - Owner: Q"
              },
              {
                "REC": "Q"
              }
            ]
          }
        ],
        "output": {
          "Front": [
            {
              "Name": "new.domain.com-80",
              "Out": "8.8.8.8",
              "In": "192.168.2.2:80",
              "W Name": "new.domain.com-80",
              "Groups": "192.168.3.29:80 192.168.3.30:80",
              "Host": "new2.domain.com,new3.domain.com",
              "Info": "Worker5 MD: Data source - Owner: Q,Worker5 MD: Data source - Owner: Q"
            },
            {
              "Name": "new.domain.com -443",
              "Out": "8.8.8.8",
              "In": "192.168.2.2:443",
              "W Name": "new.domain.com-443",
              "Groups": "192.168.3.29:443 192.168.3.30:443",
              "Host": "new2.domain.com,new3.domain.com",
              "Info": "Worker5 MD: Data source - Owner: Q,Worker5 MD: Data source - Owner: Q"
            }
          ]
        }
      }
    ],
    "identifier": 60725881
  },
  {
    "context": [
      "Here is the json data.  The repairs section is what breaks the jq command",
      "This is the end result i am trying to get. This data isnt actual data.",
      "A simple solution can be obtained using the same technique shown in one of the answers to the [similar question you already asked][1].  The only difference is fulfilling your requirements in the case where the \"Repairs\" key does not exist:",
      "[\"Name\", \"Car\", \"Location\", \"Repairs:RepairLocation\"],\n(.[]\n | [.Name]\n    + (.Car|..|scalars|[.])\n    + (.Location|..|scalars|[.])\n    + (.Repairs|..|scalars\n       | [if . == null then . else \"RepairsCompleted:\\(.)\" end]) )\n| @csv",
      "def s: .. | scalars | [.];",
      "[\"Name\", \"Car\", \"Location\", \"Repairs:RepairLocation\"],\n(.[]\n | [.Name] \n    + (.Car|s)\n    + (.Location|s) \n    + (.Repairs|s|map(if . == null then . else \"RepairsCompleted:\\(.)\" end)))\n| @csv"
    ],
    "utterance": "Produce a CSV where for each person, all combinations of car, location, and repair (with repairs optionally absent) are output as rows, with repairs formatted as 'RepairsCompleted:<fix>' or empty if not present.",
    "expressions": [
      "[\"Name\", \"Car\", \"Location\", \"Repairs:RepairLocation\"],\n(.[]\n | [.Name]\n    + (.Car|..|scalars|[.])\n    + (.Location|..|scalars|[.])\n    + (.Repairs|..|scalars\n       | [if . == null then . else \"RepairsCompleted:\\(.)\" end]) )\n| @csv",
      "def s: .. | scalars | [.];\n[\"Name\", \"Car\", \"Location\", \"Repairs:RepairLocation\"],\n(.[]\n | [.Name] \n    + (.Car|s)\n    + (.Location|s) \n    + (.Repairs|s|map(if . == null then . else \"RepairsCompleted:\\(.)\" end)))\n| @csv"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "John Doe",
            "Car": [
              "Car1",
              "Car2"
            ],
            "Location": "Texas",
            "Repairs": {
              "RepairLocations": {
                "RepairsCompleted": [
                  "Fix1",
                  "Fix2"
                ]
              }
            }
          },
          {
            "Name": "Jane Roe",
            "Car": "Car1",
            "Location": [
              "Illinois",
              "Kansas"
            ]
          }
        ],
        "output": "Name,Car,Location,Repairs:RepairLocation\nJohn Doe,Car1,Texas,RepairsCompleted:Fix1\nJohn Doe,Car1,Texas,RepairsCompleted:Fix2\nJohn Doe,Car2,Texas,RepairsCompleted:Fix1\nJohn Doe,Car2,Texas,RepairsCompleted:Fix2\nJane Roe,Car1,Illinois,\nJane Roe,Car1,Kansas,"
      }
    ],
    "identifier": 60715658
  },
  {
    "context": [
      "I want to create nested JSON using all keys.",
      "values=('one' 'two' 'three')",
      "I want to create a variable like below:",
      "{ \"all\":{ \"one\":  { \"name\":\"..\",\"value\":\"..\" }, \"two\":  { \"name\":\"..\",\"value\":\"..\" }, \"three\":  { \"name\":\"..\",\"value\":\"..\" } } }",
      "jq '{all: [{($ARGS.positional[]): .}] | add}' file --args \"${values[@]}\"",
      "printf '\"%s\"\\n' \"${values[@]}\" |\n    jq '{all: [{(inputs): .}] | add}' file -"
    ],
    "utterance": "Construct an object with a top-level key 'all' whose value is an object mapping each name in the array ('one', 'two', 'three') to the same given object with keys 'name' and 'value'.",
    "expressions": [
      "{all: [{($ARGS.positional[]): .}] | add}",
      "{all: [{(inputs): .}] | add}"
    ],
    "data": [
      {
        "input": {
          "name": "..",
          "value": ".."
        },
        "output": {
          "all": {
            "one": {
              "name": "..",
              "value": ".."
            },
            "two": {
              "name": "..",
              "value": ".."
            },
            "three": {
              "name": "..",
              "value": ".."
            }
          }
        }
      }
    ],
    "identifier": 60741567
  },
  {
    "context": [
      "I want to be able to combine just the fruit values into a string without the other keys and occupy one cell in a spreadsheet.",
      "I have a series of json files that I want to extract some information from and stick into CSVs using jq.",
      "this command will help.",
      "jq '[.[] | .content ]|join(\" \")'",
      "jq 'map(.content)|join(\" \")'",
      "Presumably therefore you will want to check `.type`, e.g.",
      "jq -r 'map(select(.type==\"fruit\").content) | join(\" \")'"
    ],
    "utterance": "Combine the content fields of all items where type equals fruit into a single space-separated string.",
    "expressions": [
      "[.[] | .content] | join(\" \")",
      "map(.content) | join(\" \")",
      "map(select(.type==\"fruit\").content) | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "content": "Apples",
            "_id": "7OLZ",
            "type": "fruit"
          },
          {
            "content": "Oranges",
            "_id": "5BHY",
            "type": "fruit"
          },
          {
            "content": "Pears",
            "_id": "DJQD",
            "type": "fruit"
          }
        ],
        "output": "Apples Oranges Pears"
      }
    ],
    "identifier": 60749204
  },
  {
    "context": [
      "I am able to split it into a single object based on the admin role using this:\r\n \r\n    .[] | if .roles[]==\"admin\" then {\"username\",\"password\",project_name: .tenant_name} else {\"username\",\"password\", \"user_domain_name\", project_name: .tenant_name, \"project_domain_name\" } end\r\n\r\nbut how can I achieve the desired output?",
      "A possible solution can be :\r\n\r\n    jq ' . as $alluser | \r\n       { \"admin\" : \r\n           $alluser |map(if .roles| any( . == \"admin\") then .roles|= empty else empty end),\r\n          \"users\"  : \r\n           $alluser |map(if .roles| any( . == \"admin\") then empty else .roles|= empty end) } ' \\"
    ],
    "utterance": "Construct an object with two keys: one containing entries where roles include admin, and one containing entries where roles do not include admin, transforming each entry accordingly.",
    "expressions": [
      ". as $alluser | { \"admin\": $alluser | map(if .roles | any(. == \"admin\") then .roles |= empty else empty end), \"users\": $alluser | map(if .roles | any(. == \"admin\") then empty else .roles |= empty end) }"
    ],
    "data": [
      {
        "input": [
          {
            "username": "saurabhu",
            "tenant_name": "abc_c1e3e096-6e95-4b84",
            "project_domain_name": "aa",
            "user_domain_name": "aa",
            "password": "saurabhp",
            "roles": [
              "admin"
            ]
          },
          {
            "username": "saurabhu",
            "tenant_name": "def_c1e3e096-6e95-4b84",
            "project_domain_name": "aa",
            "user_domain_name": "aa",
            "password": "saurabhp",
            "roles": [
              "ResellerAdmin",
              "heat_stack_owner",
              "Member"
            ]
          },
          {
            "username": "saurabhu",
            "tenant_name": "c_c1e3e096-6e95-4b84",
            "project_domain_name": "aa",
            "user_domain_name": "aa",
            "password": "saurabhp",
            "roles": [
              "ResellerAdmin",
              "heat_stack_owner",
              "Member"
            ]
          }
        ]
      }
    ],
    "identifier": 60770621
  },
  {
    "context": [
      "as an output, I need the id value of the lines that have these problems.",
      "expected output of the above: `id: 888` since in this line there is the erroneous `\\&quot;5 2\\&quot;:[`",
      "Decode all `message`s, select those which do not contain any key matching `\\d{3}`, and extract their `id`s.",
      "jq '.message | fromjson | select(any(keys_unsorted[]; test(\"[0-9]{3}\")) | not) .id' file"
    ],
    "utterance": "Extract the ids where the message object does not contain any top-level key that matches exactly three digits.",
    "expressions": [
      ".message | fromjson | select(any(keys_unsorted[]; test(\"[0-9]{3}\")) | not) .id"
    ],
    "data": [
      {
        "input": [
          {
            "memo": {
              "notice": "delivered on 17"
            },
            "message": "{\"id\":\"1\",\"401\":[[\" 0\",[\"a\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "memo": {
              "notice": "delivered on 190"
            },
            "message": "{\"id\":\"2\",\"424\":[[\" 0\",[\"v\",\"UK\"],[\"9\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "memo": {
              "notice": "delivered on 734"
            },
            "message": "{\"id\":\"3\",\"432\":[[\" 0\",[\"a\",\"UK\"],[\"9\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"v\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          },
          {
            "memo": {
              "notice": "delivered on 1092"
            },
            "message": "{\"id\":\"888\",\"5 2\":[[\" 0\",[\"v\",\"UK\"],[\"b\",\"Euy/ O\"],[\"c\",\"20160811\"],[\"g\",\"R2\"]],[\" 1\",[\"a\",\"UK\"],[\"b\",\"LO\"],[\"c\",\"20160811\"]]]}"
          }
        ],
        "output": [
          "888"
        ]
      }
    ],
    "identifier": 60736491
  },
  {
    "context": [
      "JSON_STRING=$(jq -n \\\r\n                  --arg bn \"$curl_url\" \\\r\n                  --arg on \"$tileset_id\" \\\r\n                  '{url: $bn, tileset: $on}')",
      "Once I can figure out how to properly format the json in the POST command I know it will work, but I can't seem to get the syntax right.",
      "JSON_STRING=$(jq -n \\\r\n          --arg bn \"$curl_url\" \\\r\n          --arg on \"$tileset_id\" \\\r\n          '{url: $bn, tileset: $on}')"
    ],
    "utterance": "Construct an object with keys 'url' and 'tileset' whose values are provided by the shell variables curl_url and tileset_id.",
    "expressions": [
      "jq -n --arg bn \"$curl_url\" --arg on \"$tileset_id\" '{url: $bn, tileset: $on}'"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "url": "api_url",
          "tileset": "username.filename"
        }
      }
    ],
    "identifier": 60778756
  },
  {
    "context": [
      "I would like to have for my shell script:\r\n\r\n    {\r\n      \"CIS\": 698435,\r\n      \"split\": 4.5\r\n    } \r\n    {\r\n      \"CIS\": 918839,\r\n      \"split\": 6.5\r\n    }",
      "How can I do to make the sum of all split value for a specific key CIS ?",
      "Group by CIS, for each group sum splits and put the result into a new object along with CIS value.",
      "$ jq '[.[].order[].orderInfo[]] | group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}' file",
      "user@machine:~$ cat /tmp/export/export_200519110544.json | jq '[.order[].orderInfo[] ]   |  group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}'"
    ],
    "utterance": "Group objects by CIS and for each group, output an object with CIS and the sum of split values.",
    "expressions": [
      "[.[].order[].orderInfo[]] | group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}",
      "[.order[].orderInfo[]] | group_by(.CIS)[] | {CIS: .[0].CIS, split: [.[].split] | add}"
    ],
    "data": [
      {
        "input": [
          {
            "CIS": 698435,
            "split": 3
          },
          {
            "CIS": 698435,
            "split": 1.5
          },
          {
            "CIS": 918839,
            "split": 4.5
          },
          {
            "CIS": 918839,
            "split": 2
          }
        ],
        "output": [
          {
            "CIS": 698435,
            "split": 4.5
          },
          {
            "CIS": 918839,
            "split": 6.5
          }
        ]
      }
    ],
    "identifier": 60740988
  },
  {
    "context": [
      "Now i'm trying to change the nr value in the object where\"name\": \"CN\"",
      "my first solution had a small mistake after changing the `.nr=` to  `\"nr\":` it worked:",
      "geoInfo=\"$( jq --arg country ${tmpGeo[0]} --arg count $count -r '.country | map( if .name == $country then . + { \"nr\": $count } else . end )'<<<\"${geoInfo}\" )\"",
      "Would you please try the following:\n```\ngeoInfo=$(jq \"(.[].country[] | select(.name == \\\"CN\\\") | .nr) = 1\" <<<$geoInfo)\n```"
    ],
    "utterance": "Set the nr value to a given value for the country object whose name is CN.",
    "expressions": [
      ".[] |= (.country |= map(if .name == \"CN\" then . + { \"nr\": 1 } else . end))",
      "(.[].country[] | select(.name == \"CN\") | .nr) = 1"
    ],
    "data": [
      {
        "input": [
          {
            "total": 0,
            "country": [
              {
                "name": "CN",
                "nr": 0,
                "region": [
                  {
                    "name": "Beijing",
                    "nr": 0,
                    "City": [
                      {
                        "name": "Haidian",
                        "nr": 0,
                        "Organisation": [
                          {
                            "name": "AS45090 Shenzhen Tencent Computer Systems Company Limited",
                            "nr": 0,
                            "IPS": [
                              {
                                "192.144.207.22": 0
                              }
                            ]
                          }
                        ]
                      }
                    ]
                  }
                ]
              },
              {
                "name": "NL",
                "nr": 0,
                "region": [
                  {
                    "name": "Noord Holland",
                    "nr": 0,
                    "City": [
                      {
                        "name": "Amsterdam",
                        "nr": 0,
                        "Organisation": [
                          {
                            "name": "FEAS",
                            "nr": 0,
                            "IPS": [
                              {
                                "192.162.1.1": 0
                              }
                            ]
                          }
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "total": 0,
            "country": [
              {
                "name": "CN",
                "nr": 1,
                "region": [
                  {
                    "name": "Beijing",
                    "nr": 0,
                    "City": [
                      {
                        "name": "Haidian",
                        "nr": 0,
                        "Organisation": [
                          {
                            "name": "AS45090 Shenzhen Tencent Computer Systems Company Limited",
                            "nr": 0,
                            "IPS": [
                              {
                                "192.144.207.22": 0
                              }
                            ]
                          }
                        ]
                      }
                    ]
                  }
                ]
              },
              {
                "name": "NL",
                "nr": 0,
                "region": [
                  {
                    "name": "Noord Holland",
                    "nr": 0,
                    "City": [
                      {
                        "name": "Amsterdam",
                        "nr": 0,
                        "Organisation": [
                          {
                            "name": "FEAS",
                            "nr": 0,
                            "IPS": [
                              {
                                "192.162.1.1": 0
                              }
                            ]
                          }
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60751522
  },
  {
    "context": [
      "The desired output looks like this:",
      "\"documents\",\"foo.bar\",\"123\",\"...\"",
      "\"documents/tmp\",\"deleteme\",\"567\",\"...\"",
      "...but i cannot wrap my head around how i can preserve build the directory path.",
      "def f(pfix):\n    ( [ pfix, .name ] | join(\"/\") ) as $path |\n    ( .files[] | .history[] as $hist | [ $path, .name, $hist[] ] ),\n    ( .subDirs[] | f($path) );\n.dirs[] | f(empty) | @csv",
      "This produces \"absolute\" paths (e.g. \"/documents\"); omitting the leading \"/\" can be accomplished easily enough."
    ],
    "utterance": "Flatten a nested directory structure and output for each file-history entry a row containing the full directory path, file name, hash, and timestamp.",
    "expressions": [
      "def f(pfix):\n    ( [ pfix, .name ] | join(\"/\") ) as $path |\n    ( .files[] | .history[] as $hist | [ $path, .name, $hist[] ] ),\n    ( .subDirs[] | f($path) );\n.dirs[] | f(empty) | @csv",
      "def names($path):\n  reduce getpath($path[0:range(0; $path|length)]) as $v (\"\";\n    if $v | type == \"object\" and has(\"name\") then . + \"/\" + $v[\"name\"] else . end) ;\n\npaths as $p\n| getpath($p) as $v\n| select($v | objects | has(\"history\"))\n| [names($p), getpath($p + [\"name\"])]\n  + ($v[\"history\"][] | [.hash, .timestamp] )\n| @csv"
    ],
    "data": [
      {
        "input": {
          "dirs": [
            {
              "name": "documents",
              "files": [
                {
                  "name": "foo.bar",
                  "history": [
                    {
                      "hash": "123",
                      "timestamp": "..."
                    },
                    {
                      "hash": "234",
                      "timestamp": "..."
                    }
                  ]
                },
                {
                  "name": "bar.baz",
                  "history": [
                    {
                      "hash": "345",
                      "timestamp": "..."
                    },
                    {
                      "hash": "456",
                      "timestamp": "..."
                    }
                  ]
                }
              ],
              "subDirs": [
                {
                  "name": "tmp",
                  "files": [
                    {
                      "name": "deleteme",
                      "history": [
                        {
                          "hash": "567",
                          "timestamp": "..."
                        },
                        {
                          "hash": "678",
                          "timestamp": "..."
                        }
                      ]
                    }
                  ],
                  "subDirs": []
                }
              ]
            }
          ]
        },
        "output": [
          "\"documents\",\"foo.bar\",\"123\",\"...\"",
          "\"documents\",\"foo.bar\",\"234\",\"...\"",
          "\"documents\",\"bar.baz\",\"345\",\"...\"",
          "\"documents\",\"bar.baz\",\"456\",\"...\"",
          "\"documents/tmp\",\"deleteme\",\"567\",\"...\"",
          "\"documents/tmp\",\"deleteme\",\"678\",\"...\""
        ]
      }
    ],
    "identifier": 60776523
  },
  {
    "context": [
      "Keys \"mail\", \"diskspace\", \"db\" etc. are unknown and could have any name.",
      "I'd like to print all object whose status in not \"UP\" if the overall status is not \"UP\".",
      "Just select those whose status is DOWN. `with_entries` is there to retain original structure.",
      "with_entries(select(.value.status? == \"DOWN\"))"
    ],
    "utterance": "Return all top-level objects with a status field equal to DOWN, regardless of their keys.",
    "expressions": [
      "with_entries(select(.value.status? == \"DOWN\"))"
    ],
    "data": [
      {
        "input": {
          "status": "DOWN",
          "FTPService": {
            "status": "UP"
          },
          "mail": {
            "status": "UP",
            "location": "somehost.example.com:-1"
          },
          "diskSpace": {
            "status": "UP",
            "total": 2000396742656,
            "free": 1213046730752,
            "threshold": 10485760
          },
          "db": {
            "status": "DOWN",
            "database": "Oracle",
            "schema": "foo"
          },
          "refreshScope": {
            "status": "UP"
          }
        },
        "output": {
          "db": {
            "status": "DOWN",
            "database": "Oracle",
            "schema": "foo"
          }
        }
      }
    ],
    "identifier": 60778881
  },
  {
    "context": [
      "I would like to merge some nested objects in array but without pointing elements numbers because CPU numbers may vary.",
      "I would like to end up with metric and value as one object which allow me to present it in one log line.",
      "For each result separate value field and add it to metric in a new object; and update the array with them.",
      "jq '.result[] |= {metric: (.metric + {value})}' file"
    ],
    "utterance": "Combine metric and value fields into a single metric object for each element of the result array, preserving all keys and values.",
    "expressions": [
      ".result[] |= {metric: (.metric + {value})}"
    ],
    "data": [
      {
        "input": {
          "resultType": "vector",
          "result": [
            {
              "metric": {
                "cpu": "cpu10",
                "instance": "hostname-1",
                "job": "node",
                "mode": "iowait"
              },
              "value": [
                1584371948,
                66,
                "8,466666666790843"
              ]
            },
            {
              "metric": {
                "cpu": "cpu11",
                "instance": "hostname-1",
                "job": "node",
                "mode": "nice"
              },
              "value": [
                1584371948,
                66,
                "0"
              ]
            }
          ]
        },
        "output": {
          "resultType": "vector",
          "result": [
            {
              "metric": {
                "cpu": "cpu10",
                "instance": "hostname-1",
                "job": "node",
                "mode": "iowait",
                "value": [
                  1584371948,
                  66,
                  "8,466666666790843"
                ]
              }
            },
            {
              "metric": {
                "cpu": "cpu11",
                "instance": "hostname-1",
                "job": "node",
                "mode": "nice",
                "value": [
                  1584371948,
                  66,
                  "0"
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 60753892
  },
  {
    "context": [
      "\"I have a json string like: { ... 'properties': { 'p2': {'test': 'test', 'value': 'b'}, 'p1': {'value': 'a'}, 'p3': {'value': 'c'} } } ... and I want: { 'p2' : 'b', 'p1' : 'a', 'p3' : 'c' } ... the order doesn't matter, but the relation of keys and values must be the same as origin.\"",
      "\"I tried jq '.properties | (keys_unsorted, .[].value)' and it gives: [ 'p2', 'p1', 'p3' ] 'b' 'a' 'c' \"",
      "\"You're looking for map_values ... jq '.properties | map_values(.value)' file { 'p2': 'b', 'p1': 'a', 'p3': 'c' }\""
    ],
    "utterance": "Extract the key-value pairs from the 'properties' field, mapping each key to the inner 'value' field.",
    "expressions": [
      ".properties | map_values(.value)"
    ],
    "data": [
      {
        "input": {
          "name": "test",
          "properties": {
            "p2": {
              "test": "test",
              "value": "b"
            },
            "p1": {
              "value": "a"
            },
            "p3": {
              "value": "c"
            }
          }
        },
        "output": {
          "p2": "b",
          "p1": "a",
          "p3": "c"
        }
      }
    ],
    "identifier": 60826054
  },
  {
    "context": [
      "To split each book into a separate file, I am using the following command:",
      "cat books.json | jq -c -M '.books[]' | while read line; do echo $line > temp/$(date +%s%N).json; done",
      "For the last two items, everything's ok, because the book title does not contain any quotes. However, in the first one, the \\\" get replaced by \" which leads to a broken JSON file",
      "You have to use the `-r` option to [`read`][1]:",
      "while read -r line; do echo \"$line\" > temp/\"$(date +%s%N)\".json; done",
      "It prevents interpreting backslash escapes."
    ],
    "utterance": "Extract each book element from the books array, preserving escaped characters such as backslashes, and write each to a separate file.",
    "expressions": [
      ".books[]"
    ],
    "data": [
      {
        "input": {
          "books": [
            {
              "title": "Professional JavaScript - \\\"The best guide\\\"",
              "authors": [
                "Nicholas C. Zakas"
              ],
              "edition": 3,
              "year": 2011
            },
            {
              "title": "Professional JavaScript",
              "authors": [
                "Nicholas C.Zakas"
              ],
              "edition": 2,
              "year": 2009
            },
            {
              "title": "Professional Ajax",
              "authors": [
                "Nicholas C. Zakas",
                "Jeremy McPeak",
                "Joe Fawcett"
              ],
              "edition": 2,
              "year": 2008
            }
          ]
        }
      }
    ],
    "identifier": 60794179
  },
  {
    "context": [
      "$ echo '[0, 1, 2]' | jq 'if .[] == 0 then \"zero\" elif .[] == 1 then \"one\" else \"many\" end'",
      "Perhaps it will be easier to understand if you start with a single iterator, e.g.",
      "echo '[0, 1, 2]' |   jq '.[] | if . == 0 then \"zero\" elif . == 1 then \"one\" else \"many\" end'"
    ],
    "utterance": "For the array [0, 1, 2], output 'zero' for 0, 'one' for 1, and 'many' for all other values.",
    "expressions": [
      ".[] | if . == 0 then \"zero\" elif . == 1 then \"one\" else \"many\" end"
    ],
    "data": [
      {
        "input": [
          0,
          1,
          2
        ],
        "output": [
          "zero",
          "one",
          "many"
        ]
      }
    ],
    "identifier": 60842509
  },
  {
    "context": [
      "I have a `jq` filter that converts (`influxdb`) json input to csv for further parsing. However, this filter fails when `influxdb` returns an error. I'm trying to improve my jq filter to detect this, however I can't get this to work.",
      "Example data",
      "{ \"results\":[{\"statement_id\":0,\"series\":[{\"name\":\"energyv3\",\"columns\":[\"time\",\"value\"],\"values\":[[\"2015-07-30T23:59:00Z\",56980800],[\"2015-07-31T23:59:00Z\",95108400]]}]}] }",
      "{ \"error\": \"error parsing query: found EOF, expected integer at line 1, char 34\" }",
      "Desired outcome",
      "\"\\\"time\\\" , \\\"value\\\"\"",
      "\"\\\"2015-07-30T23:59:00Z\\\" , 56980800\"",
      "\"\\\"2015-07-31T23:59:00Z\\\" , 95108400\"",
      "\"error parsing query: found EOF, expected integer at line 1, char 34\"",
      "For input with `.results` key: data formatted as csv (works OK)",
      "For input with `.error` key: only error string (doesn't work)",
      "Based on your attempts, and the assumption that each object contain either `results` or `error`, this should do it:",
      "( .results[0].series | .[0].columns, .[]?.values[] ) // [ .error ] | @csv"
    ],
    "utterance": "Output data as CSV when it has results, or output only the error string if present.",
    "expressions": [
      "( .results[0].series | .[0].columns, .[]?.values[] ) // [ .error ] | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "statement_id": 0,
              "series": [
                {
                  "name": "energyv3",
                  "columns": [
                    "time",
                    "value"
                  ],
                  "values": [
                    [
                      "2015-07-30T23:59:00Z",
                      56980800
                    ],
                    [
                      "2015-07-31T23:59:00Z",
                      95108400
                    ]
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "\"time\",\"value\"",
          "\"2015-07-30T23:59:00Z\",56980800",
          "\"2015-07-31T23:59:00Z\",95108400"
        ]
      },
      {
        "input": {
          "error": "error parsing query: found EOF, expected integer at line 1, char 34"
        },
        "output": [
          "\"error parsing query: found EOF, expected integer at line 1, char 34\""
        ]
      }
    ],
    "identifier": 60792617
  },
  {
    "context": [
      "How do I just get the port, banner, etc. for the specific service underneath the record which hit my condition?",
      ".services[]\n| if .banner == \"FQMDAAICCg==\" then .port else empty end",
      ".services[]\n| select(.banner == \"FQMDAAICCg==\")\n| .port",
      "I want to end up in this example with '8085' + '103.238.62.68'",
      ".ip as $ip\n| (.services[] | select(.banner == \"FQMDAAICCg==\") | .port) as $port\n| \"'\\($port)' + '\\($ip)'\"",
      "\"'\\(.services[] | select(.banner == \\\"FQMDAAICCg==\\\") | .port)' + '\\(.ip)'\""
    ],
    "utterance": "Select the port and ip for each service where the banner equals 'FQMDAAICCg==', and output them as a concatenated string in the form '8085' + '103.238.62.68'.",
    "expressions": [
      ".ip as $ip | (.services[] | select(.banner == \"FQMDAAICCg==\") | .port) as $port | \"'\\($port)' + '\\($ip)'\"",
      "\"'\\(.services[] | select(.banner == \\\"FQMDAAICCg==\\\") | .port)' + '\\(.ip)'\""
    ],
    "data": [
      {
        "input": {
          "services": [
            {
              "tls_detected": false,
              "banner_is_raw": true,
              "transport_protocol": "tcp",
              "banner": "PCFET0NUWVBFIEhU",
              "certificate": null,
              "timestamp": "2020-03-22T00:38:01.074Z",
              "protocol": null,
              "port": 4444
            },
            {
              "tls_detected": false,
              "banner_is_raw": true,
              "transport_protocol": "tcp",
              "banner": "SFRUUC8xLjEgMzA",
              "certificate": null,
              "timestamp": "2020-03-19T01:39:45.288Z",
              "protocol": null,
              "port": 8080
            },
            {
              "tls_detected": false,
              "banner_is_raw": true,
              "transport_protocol": "tcp",
              "banner": "FQMDAAICCg==",
              "certificate": null,
              "timestamp": "2020-03-19T01:39:45.288Z",
              "protocol": null,
              "port": 8085
            },
            {
              "tls_detected": false,
              "banner_is_raw": false,
              "transport_protocol": "tcp",
              "banner": "Q2FjaGUtQ29ud",
              "certificate": null,
              "timestamp": "2020-03-20T04:25:24Z",
              "protocol": "http",
              "port": 8080
            }
          ],
          "ip": "103.238.62.68",
          "autonomous_system": {
            "description": "CHAPTECH-AS-AP Chaptech Pty Ltd",
            "asn": 133493,
            "routed_prefix": "103.238.62.0/24",
            "country_code": "AU",
            "name": "CHAPTECH-AS-AP Chaptech Pty Ltd",
            "path": [
              11164,
              3491,
              63956,
              7594,
              7594,
              7594,
              7594,
              133493
            ]
          },
          "location": {
            "country_code": "AU",
            "registered_country": "Australia",
            "registered_country_code": "AU",
            "continent": "Oceania",
            "timezone": "Australia/Sydney",
            "latitude": -33.494,
            "longitude": 143.2104,
            "country": "Australia"
          }
        },
        "output": "'8085' + '103.238.62.68'"
      }
    ],
    "identifier": 60812016
  },
  {
    "context": [
      "I want to create another JSON file from the source file which will basically contain the actual values from param store based on the path.",
      "So, here in this case I want to call `aws ssm get-parameters --names <name>` for each param_name present inside the value field (for host, username and password) and replace them in the target.json file.",
      "is there any elegant way where we can basically iterate each field using `jq` and then call `aws ssm` command and replaces the value."
    ],
    "utterance": "Replace parameter name placeholders in a file's values with the corresponding SSM parameter values by looking up each referenced parameter and producing a new file with substituted values.",
    "expressions": [
      "jq 'walk(if type == \"string\" and test(\"^\\\\{.+_param_name\\\\}$\") then (sub(\"[{}]\"; \"\") | (\"aws ssm get-parameter --name \" + . + \" --query Parameter.Value --output text\" | system)) else . end)' source.json"
    ],
    "data": [
      {
        "input": {
          "redis": {
            "cluster": {
              "host": "{host_param_name}",
              "port": "21",
              "username": "{user_param_name}",
              "password": "{password_param_name}"
            },
            "cluster2": {
              "host": "{host_param_name}",
              "port": "21",
              "username": "{user_param_name}",
              "password": "{password_param_name}"
            }
          }
        },
        "output": {
          "redis": {
            "cluster": {
              "host": "localhost",
              "port": "21",
              "username": "temp",
              "password": "temp"
            },
            "cluster2": {
              "host": "localhost",
              "port": "21",
              "username": "test",
              "password": "temp"
            }
          }
        }
      }
    ],
    "identifier": 60835672
  },
  {
    "context": [
      "I need to transform an array of this kind of elements:\r\n\r\n    [\r\n      {\r\n        \"Field1\": \"value1\",\r\n        \"Field2\": \"value2\"\r\n      },\r\n      {\r\n        \"Field1\": \"value3\",\r\n        \"Field2\": \"value4\"\r\n      },\r\n      ...\r\n    ]",
      "To:\r\n\r\n    [\r\n        \"PutRequest\": {\r\n            \"Item\": {\r\n                \"Field1\": {\r\n                    \"S\": \"value1\"\r\n                },\r\n                \"Field2\": {\r\n                    \"S\": \"value2\"\r\n                }\r\n            }\r\n        },\r\n        ...\r\n    ]",
      "Is there any what to say: for each field add an like key: {\"S\": .value}?",
      "Does not exactly match your expected output but you&#39;re probably looking for something like this:\r\n```\r\nmap({PutRequest: {Item: map_values({S: .})}})\r\n```"
    ],
    "utterance": "Transform each object in the array so that each field becomes { fieldname: { S: value } } nested under Item, all wrapped with a PutRequest key.",
    "expressions": [
      "map({PutRequest: {Item: map_values({S: .})}})"
    ],
    "data": [
      {
        "input": [
          {
            "Field1": "value1",
            "Field2": "value2"
          },
          {
            "Field1": "value3",
            "Field2": "value4"
          }
        ],
        "output": [
          {
            "PutRequest": {
              "Item": {
                "Field1": {
                  "S": "value1"
                },
                "Field2": {
                  "S": "value2"
                }
              }
            }
          },
          {
            "PutRequest": {
              "Item": {
                "Field1": {
                  "S": "value3"
                },
                "Field2": {
                  "S": "value4"
                }
              }
            }
          }
        ]
      }
    ],
    "identifier": 60845947
  },
  {
    "context": [
      "I have a list of json files like:",
      "file1.json",
      "[",
      "  {obj1}",
      "]",
      "file2.json",
      "[",
      "  {obj2}",
      "]",
      "and I want to merge them all into one file:",
      "[",
      "  {obj1},",
      "  {obj2}",
      "]",
      "How can I achieve this using jq?",
      "jq -c '.[]' *.json | jq -s",
      "jq -s 'add' file1.json file2.json"
    ],
    "utterance": "Combine the contents of multiple files, each containing an array, into a single array containing all objects from those files.",
    "expressions": [
      "jq -c '.[]' *.json | jq -s",
      "jq -s 'add' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          {
            "file1.json": [
              {
                "obj1": "value1"
              }
            ]
          },
          {
            "file2.json": [
              {
                "obj2": "value2"
              }
            ]
          }
        ],
        "output": [
          {
            "obj1": "value1"
          },
          {
            "obj2": "value2"
          }
        ]
      }
    ],
    "identifier": 60858118
  },
  {
    "context": [
      "curl -s \"https://ip-api.com/#105.154.81.106\" |  jq '.'.",
      "parse error: Invalid numeric literal at line 1, column 2",
      "$ ansifilter output | jq -r .message",
      "curl -s http://ip-api.com/json/105.154.81.106 |  jq '.'."
    ],
    "utterance": "Display all response data for the IP address 105.154.81.106 from the API endpoint.",
    "expressions": [
      "curl -s http://ip-api.com/json/105.154.81.106 | jq '.'"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "country": "South Africa",
          "countryCode": "ZA",
          "region": "WC",
          "regionName": "Western Cape",
          "city": "Cape Town",
          "zip": "8001",
          "lat": -33.9258,
          "lon": 18.4232,
          "timezone": "Africa/Johannesburg",
          "isp": "Some ISP",
          "org": "Some org",
          "as": "ASnumber Some ASN",
          "query": "105.154.81.106"
        }
      }
    ],
    "identifier": 60850556
  },
  {
    "context": [
      "## \u00a0What I want to get: \n``` json\n    [\n        { \"name\":  \"url 'http://be-service.test.svc.cluster.local/SVC_INTERFACE_V1'\" , \"status\": \"passed\" },\n        { \"name\":  \"request\" , \"status\": \"passed\" },\n        { \"name\":  \"header Content-Type = 'application/soap+xml; charset=utf-8'\" , \"status\": \"passed\" },\n        { \"name\":  \"method post\" , \"status\": \"passed\" },\n        { \"name\":  \"status 200\" , \"status\": \"passed\" },\n        { \"name\":  \"def envelope = response['soapenv:Envelope']\" , \"status\": \"passed\" },\n        { \"name\":  \"def body = response['soapenv:Envelope']['_']['soapenv:Body']\" , \"status\": \"passed\" },\n        { \"name\":  \"def result = body['NS1:monitoraggioJBossResponse']._\" , \"status\": \"passed\" },\n        { \"name\":  \"def esito = result.esito\" , \"status\": \"passed\" },\n        { \"name\":  \"match esito == 'ERR'\" , \"status\": \"passed\" }\n    ]\n```",
      "jq '[.[].elements[].steps[]|{name} + (.result|{status})]'",
      "jq 'map(.elements[].steps[]|{name} + (.result|{status}))'"
    ],
    "utterance": "Extract an array where each item contains the name and status of every step across all elements in all items.",
    "expressions": [
      "[.[].elements[].steps[] | {name} + (.result|{status})]",
      "map(.elements[].steps[] | {name} + (.result|{status}))"
    ],
    "data": [
      {
        "input": [
          {
            "line": 1,
            "elements": [
              {
                "line": 3,
                "name": "",
                "description": "",
                "type": "background",
                "keyword": "Background",
                "steps": [
                  {
                    "name": "url 'http://be-service.test.svc.cluster.local/SVC_INTERFACE_V1'",
                    "result": {
                      "duration": 256885,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "*",
                    "line": 4,
                    "doc_string": {
                      "content_type": "",
                      "value": "10:54:12.945 karate.env",
                      "line": 4
                    }
                  }
                ]
              },
              {
                "line": 9,
                "name": "",
                "description": "",
                "id": "SoapEsbBackEnd1",
                "type": "scenario",
                "keyword": "Scenario",
                "steps": [
                  {
                    "name": "request",
                    "result": {
                      "duration": 92526141,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "Given",
                    "line": 11,
                    "doc_string": {
                      "content_type": "",
                      "value": "<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\">\n   </soap:Envelope>",
                      "line": 11
                    }
                  },
                  {
                    "name": "header Content-Type = 'application/soap+xml; charset=utf-8'",
                    "result": {
                      "duration": 1834255,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "And",
                    "line": 74
                  },
                  {
                    "name": "method post",
                    "result": {
                      "duration": 102112259,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "When",
                    "line": 76,
                    "doc_string": {
                      "content_type": "",
                      "value": "10:54:13.140 request:\n1 > POST http://be-service.test.svc.cluster.local/SVC_INTERFACE_V1",
                      "line": 76
                    }
                  },
                  {
                    "name": "status 200",
                    "result": {
                      "duration": 49328,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "Then",
                    "line": 77
                  },
                  {
                    "name": "def envelope = response['soapenv:Envelope']",
                    "result": {
                      "duration": 591138,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "*",
                    "line": 79
                  },
                  {
                    "name": "def body = response['soapenv:Envelope']['_']['soapenv:Body']",
                    "result": {
                      "duration": 470207,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "*",
                    "line": 81
                  },
                  {
                    "name": "def result = body['NS1:monitoraggioJBossResponse']._",
                    "result": {
                      "duration": 354671,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "*",
                    "line": 83
                  },
                  {
                    "name": "def esito = result.esito",
                    "result": {
                      "duration": 296656,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "*",
                    "line": 87
                  },
                  {
                    "name": "match esito == 'ERR'",
                    "result": {
                      "duration": 249327,
                      "status": "passed"
                    },
                    "match": {
                      "location": "karate",
                      "arguments": []
                    },
                    "keyword": "*",
                    "line": 89
                  }
                ],
                "tags": [
                  {
                    "name": "@esb",
                    "line": 6
                  },
                  {
                    "name": "@esb_svc_monitoraggio_ko",
                    "line": 6
                  },
                  {
                    "name": "@ko",
                    "line": 6
                  }
                ]
              }
            ],
            "name": "features/esb-be1.feature",
            "description": "esb be first request",
            "id": "esb-be-first-request",
            "keyword": "Feature",
            "uri": "features/esb-be1.feature"
          }
        ],
        "output": [
          {
            "name": "url 'http://be-service.test.svc.cluster.local/SVC_INTERFACE_V1'",
            "status": "passed"
          },
          {
            "name": "request",
            "status": "passed"
          },
          {
            "name": "header Content-Type = 'application/soap+xml; charset=utf-8'",
            "status": "passed"
          },
          {
            "name": "method post",
            "status": "passed"
          },
          {
            "name": "status 200",
            "status": "passed"
          },
          {
            "name": "def envelope = response['soapenv:Envelope']",
            "status": "passed"
          },
          {
            "name": "def body = response['soapenv:Envelope']['_']['soapenv:Body']",
            "status": "passed"
          },
          {
            "name": "def result = body['NS1:monitoraggioJBossResponse']._",
            "status": "passed"
          },
          {
            "name": "def esito = result.esito",
            "status": "passed"
          },
          {
            "name": "match esito == 'ERR'",
            "status": "passed"
          }
        ]
      }
    ],
    "identifier": 60673463
  },
  {
    "context": [
      "What should I do to the command \r\n\r\n> docker events --format \"{{json .}}\" \r\n\r\nSo that it will be formatted in a more readable way. Is there something to pipe that output so that it may look something like the following.",
      "If the output has to be [formatted][6], use the command. Also append jq as follows. Note the double quotes(\"). Single quotes(') did not work.\r\n\r\n> docker events --format \"{{json .}}\" | jq",
      "You can just pipe in `jq` to your `docker events` command.\r\n\r\n```\r\ndocker events --format '{{json .}}' | jq\r\n```"
    ],
    "utterance": "Format the output of 'docker events --format \"{{json .}}\"' in a more readable, pretty-printed form.",
    "expressions": [
      "docker events --format \"{{json .}}\" | jq"
    ],
    "data": [
      {
        "input": {
          "status": "create",
          "id": "7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37",
          "from": "mcr.microsoft.com/dotnet/core/sdk:3.1",
          "Type": "container",
          "Action": "create",
          "Actor": {
            "ID": "7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37",
            "Attributes": {
              "image": "mcr.microsoft.com/dotnet/core/sdk:3.1",
              "name": "objective_bhaskara"
            }
          },
          "scope": "local",
          "time": 1585135301,
          "timeNano": 1585135301351718800
        },
        "output": {
          "status": "create",
          "id": "7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37",
          "from": "mcr.microsoft.com/dotnet/core/sdk:3.1",
          "Type": "container",
          "Action": "create",
          "Actor": {
            "ID": "7897095c22919bcdcf39612386bebed63296bc33be250445e6069bf4fe90ce37",
            "Attributes": {
              "image": "mcr.microsoft.com/dotnet/core/sdk:3.1",
              "name": "objective_bhaskara"
            }
          },
          "scope": "local",
          "time": 1585135301,
          "timeNano": 1585135301351718800
        }
      }
    ],
    "identifier": 60848049
  },
  {
    "context": [
      "Is there any way to pipeline above two commands?",
      "We can make use of the `split --filter` option:",
      "jq -c '.[]' csvjson.json |",
      "split -l25 --filter='jq --slurp \"map({PutRequest: {Item: map_values({S: .})}})\" >$FILE.json' - output"
    ],
    "utterance": "Transform batches of 25 objects from an input into arrays where each object is wrapped in {PutRequest: {Item: ...}}, mapping all values to string fields.",
    "expressions": [
      "jq -c '.[]' csvjson.json | split -l25 --filter='jq --slurp \"map({PutRequest: {Item: map_values({S: .})}})\" >$FILE.json' - output",
      "jq --slurp 'map({PutRequest: {Item: map_values({S: .})}})' splitted-n > output-n.json"
    ],
    "identifier": 60863656
  },
  {
    "context": [
      "I have this json:\r\n\r\n    {\r\n\t  \"headers\": [\"x\", \"y\", \"z\"],\r\n\t  \"data\": [1, 2, 3, 4, 5, 6, 7, 8, 9],\r\n\t  \"rows\": [\"a\", \"b\", \"c\"]\r\n    }\r\nand I'd like to end up with this:\r\n```\r\n[{\r\n\t\"row\": \"a\",\r\n\t\"header\": \"x\",\r\n\t\"value\": 1\r\n}, {\r\n\t\"row\": \"a\",\r\n\t\"header\": \"y\",\r\n\t\"value\": 2\r\n}, {\r\n\t\"row\": \"a\",\r\n\t\"header\": \"z\",\r\n\t\"value\": 3\r\n}, {\r\n\t\"row\": \"b\",\r\n\t\"header\": \"x\",\r\n\t\"value\": 4\r\n}, {\r\n\t\"row\": \"b\",\r\n\t\"header\": \"y\",\r\n\t\"value\": 5\r\n}, {\r\n\t\"row\": \"b\",\r\n\t\"header\": \"z\",\r\n\t\"value\": 6\r\n}, {\r\n\t\"row\": \"c\",\r\n\t\"header\": \"x\",\r\n\t\"value\": 7\r\n}, {\r\n\t\"row\": \"c\",\r\n\t\"header\": \"y\",\r\n\t\"value\": 8\r\n}, {\r\n\t\"row\": \"c\",\r\n\t\"header\": \"z\",\r\n\t\"value\": 9\r\n}]\r\n```",
      "Here's one solution:\r\n```\r\n[(.rows|length) as $n\r\n | (.headers|length) as $hl\r\n | range(0; $n) as $r\r\n | range(0; $hl) as $h\r\n | {row: .rows[$r],\r\n    header: .headers[$h],\r\n    value:  .data[$r * $hl + $h] }\r\n]\r\n```"
    ],
    "utterance": "Create an array of objects with each combination of row and header, assigning each the corresponding value from data in row-major order.",
    "expressions": [
      "[(.rows|length) as $n | (.headers|length) as $hl | range(0; $n) as $r | range(0; $hl) as $h | {row: .rows[$r], header: .headers[$h], value: .data[$r * $hl + $h]}]"
    ],
    "data": [
      {
        "input": {
          "headers": [
            "x",
            "y",
            "z"
          ],
          "data": [
            1,
            2,
            3,
            4,
            5,
            6,
            7,
            8,
            9
          ],
          "rows": [
            "a",
            "b",
            "c"
          ]
        },
        "output": [
          {
            "row": "a",
            "header": "x",
            "value": 1
          },
          {
            "row": "a",
            "header": "y",
            "value": 2
          },
          {
            "row": "a",
            "header": "z",
            "value": 3
          },
          {
            "row": "b",
            "header": "x",
            "value": 4
          },
          {
            "row": "b",
            "header": "y",
            "value": 5
          },
          {
            "row": "b",
            "header": "z",
            "value": 6
          },
          {
            "row": "c",
            "header": "x",
            "value": 7
          },
          {
            "row": "c",
            "header": "y",
            "value": 8
          },
          {
            "row": "c",
            "header": "z",
            "value": 9
          }
        ]
      }
    ],
    "identifier": 60849816
  },
  {
    "context": [
      "\"for example: \\\"bar\\\" | sub(\\\"b\\\",\\\"f\\\")\"",
      "\"the sub() function along with the other functions in jq takes arguments separated by ; and not , ... It should have been written as\\n\\n    sub(\\\"b\\\"; \\\"f\\\")\""
    ],
    "utterance": "Replace the first occurrence of 'b' with 'f' in the string 'bar'.",
    "expressions": [
      "\"bar\" | sub(\"b\"; \"f\")"
    ],
    "data": [
      {
        "input": "bar",
        "output": "far"
      }
    ],
    "identifier": 60865446
  },
  {
    "context": [
      "I need to somehow compare the key `URL` in `data-A.json` with the same key in `data-B.json`. Where there is a match take data from the key `Position` in `data-A.json` and write to new key `PreviousPosition` in `data-B.json`. If there is no matching `URL`, write a null value for this new key in `data-B.json`",
      "This is perhaps more straightforward than it looks, as the expression in the first line is a commonly found idiom (namely `INDEX(...) | map_values(...)`) for creating a dictionary.  In the first line, it is assumed that $A holds the JSON in data-A.json.",
      "The second line just applies the lookup rule specified in the question.",
      "The following will suffice:\n\n    jq --argfile A data-A.json -f program.jq data-B.json\n\nwhere program.jq contains the above two-line program."
    ],
    "utterance": "For each object, set PreviousPosition to the Position value from data-A.json with matching URL, or null if no match.",
    "expressions": [
      "(INDEX($A[]; .URL) | map_values(.Position)) as $dict | map( .PreviousPosition = $dict[ .URL ] )"
    ],
    "data": [
      {
        "input": {
          "A": [
            {
              "Position": "1",
              "TrackName": "One hit wonder",
              "URL": "https://domain.local/xyz123"
            },
            {
              "Position": "2",
              "TrackName": "Random song",
              "URL": "https://domain.local/123qwe"
            },
            {
              "Position": "3",
              "TrackName": "Dueling banjos",
              "URL": "https://domain.local/asd456"
            }
          ],
          "B": [
            {
              "Position": "1",
              "TrackName": "Rocket",
              "URL": "https://domain.local/nbs678"
            },
            {
              "Position": "2",
              "TrackName": "Dueling banjos",
              "URL": "https://domain.local/asd456"
            },
            {
              "Position": "3",
              "TrackName": "One hit wonder",
              "URL": "https://domain.local/xyz123"
            }
          ]
        },
        "output": [
          {
            "Position": "1",
            "TrackName": "Rocket",
            "URL": "https://domain.local/nbs678",
            "PreviousPosition": null
          },
          {
            "Position": "2",
            "TrackName": "Dueling banjos",
            "URL": "https://domain.local/asd456",
            "PreviousPosition": "3"
          },
          {
            "Position": "3",
            "TrackName": "One hit wonder",
            "URL": "https://domain.local/xyz123",
            "PreviousPosition": "1"
          }
        ]
      }
    ],
    "identifier": 60858369
  },
  {
    "context": [
      "env-1 key will vary, and I need to access using recursion (..) or similar technique",
      "jq: error (at <stdin>:20): Cannot index string with string \"LoadBalancerGroup\";",
      "you need to select objects.",
      "Assuming `LoadBalancerGroup` is always an object, and a null `name` being ignored is not a concern:",
      ".. | objects | .LoadBalancerGroup.name // empty"
    ],
    "utterance": "Extract the value of the \"name\" field from any \"LoadBalancerGroup\" object, regardless of the variable parent key.",
    "expressions": [
      ".. | objects | .LoadBalancerGroup.name // empty"
    ],
    "data": [
      {
        "input": {
          "config": {
            "env-1": {
              "LoadBalancerGroup": {
                "Algorithm": "weighted-round-robin",
                "LBGroupMembers": [
                  {
                    "Server": "10.183.191.131"
                  },
                  {
                    "Server": "10.183.191.153"
                  }
                ],
                "name": "LBG-https",
                "state": {
                  "opstate": "up"
                }
              }
            }
          }
        },
        "output": "LBG-https"
      }
    ],
    "identifier": 60874368
  },
  {
    "context": [
      "For a side-project I want to sort the keys of a JSON with jq, and come up with the following solution:",
      "While this works, I have more than 10 keys and the `add_property_prefix` function is really bloaty because of this.",
      "The question: is there a way to make sorting list less redundant?",
      "To specify the keys and their order:",
      "{ beka, alma, paprika, korte }"
    ],
    "utterance": "Reorder object properties so that 'beka', 'alma', 'paprika', and 'korte' appear in that exact order.",
    "expressions": [
      "{ beka, alma, paprika, korte }"
    ],
    "data": [
      {
        "input": {
          "alma": 1,
          "beka": 2,
          "paprika": 3,
          "korte": 4
        },
        "output": {
          "beka": 2,
          "alma": 1,
          "paprika": 3,
          "korte": 4
        }
      }
    ],
    "identifier": 60886010
  },
  {
    "context": [
      "Even though the code is quite elegant, it removes all non-listed keys.",
      "**Question: How can I keep unknown keys in the output at the end of the JSON to have the following output?**",
      "{\n  \"beka\": 2,\n  \"alma\": 1,\n  \"paprika\": 3,\n  \"korte\": 4,\n  \"cekla\": 5\n}",
      "Based on [peak's answer to your other question](https://stackoverflow.com/a/60889140/10248678):",
      "{ beka, alma, paprika, korte } + ."
    ],
    "utterance": "Sort the object's keys so that beka, alma, paprika, and korte come first in that order, followed by all other keys in their original order.",
    "expressions": [
      "{ beka, alma, paprika, korte } + ."
    ],
    "data": [
      {
        "input": {
          "alma": 1,
          "beka": 2,
          "paprika": 3,
          "korte": 4,
          "cekla": 5
        },
        "output": {
          "beka": 2,
          "alma": 1,
          "paprika": 3,
          "korte": 4,
          "cekla": 5
        }
      }
    ],
    "identifier": 60889135
  },
  {
    "context": [
      "webhook_url=$(cat secrets.json | jq \".slack_config.slack_target_url\" | tr -d \\\" )",
      "message_1=$(cat secrets.json | jq \".slack_messages.message_1\" | tr -d \\\" )",
      "The `secrets.json` looks like this:\n{\n    \"slack_config\": {\n        \"slack_target_url\": \"https://hooks.slack.com/services/XXXXXXX/XXXXXXXXXXX/XXXXXXXXXXXXXXX\"\n    },\n    \"slack_messages\": {\n        \"message_1\": \"SLACK_MESSAGE_1 Testing Secrets Calls from secrets.json File\",\n        \"message_3\": \"SLACK_MESSAGE_3 Testing Secrets Calls from secrets.json File\",\n        \"message_2\": \"SLACK_MESSAGE_2 Testing Secrets Calls from secrets.json File\"\n    }\n}",
      "webhook_url=$(cat secrets.json | jq \".slack_config.slack_target_url\" | tr -d \\\" )",
      "message_1=$(cat secrets.json | jq \".slack_messages.message_1\" | tr -d \\\" )"
    ],
    "utterance": "Extract the value of the key 'message_1' from the property 'slack_messages' in the top-level object.",
    "expressions": [
      ".slack_messages.message_1"
    ],
    "data": [
      {
        "input": {
          "slack_config": {
            "slack_target_url": "https://hooks.slack.com/services/XXXXXXX/XXXXXXXXXXX/XXXXXXXXXXXXXXX"
          },
          "slack_messages": {
            "message_1": "SLACK_MESSAGE_1 Testing Secrets Calls from secrets.json File",
            "message_3": "SLACK_MESSAGE_3 Testing Secrets Calls from secrets.json File",
            "message_2": "SLACK_MESSAGE_2 Testing Secrets Calls from secrets.json File"
          }
        },
        "output": "SLACK_MESSAGE_1 Testing Secrets Calls from secrets.json File"
      }
    ],
    "identifier": 60871796
  },
  {
    "context": [
      "filter it on `status` (ok) and `tag` (highest group with an 'ok'), and flatten the matching objects to get a multi-line sorted string value of their `name` along with a static prefix (e.g. City).",
      "[.[]]\n| map(select(.status == \"ok\"))\n| (max_by( .tag | sub(\"group-\";\"\") | tonumber) | .tag) as $mx\n| .[]\n| select(.tag==$mx)\n| \"City: \\(.name)\""
    ],
    "utterance": "Get the names of all objects with status equal to 'ok' and with the highest group tag among those, each output as 'City: <name>' on a new line.",
    "expressions": [
      "[.[]] | map(select(.status == \"ok\")) | (max_by(.tag | sub(\"group-\";\"\") | tonumber) | .tag) as $mx | .[] | select(.tag==$mx) | \"City: \\(.name)\""
    ],
    "data": [
      {
        "input": {
          "9273": {
            "status": "ok",
            "tag": "group-8",
            "name": "London"
          },
          "4029": {
            "status": "unknown",
            "tag": "group-12",
            "name": "Tokyo"
          },
          "6322": {
            "status": "ok",
            "tag": "group-12",
            "name": "Singapore"
          },
          "1038": {
            "status": "unknown",
            "tag": "group-19",
            "name": "Melbourne"
          },
          "2938": {
            "status": "ok",
            "tag": "group-12",
            "name": "New York"
          }
        },
        "output": "City: Singapore\nCity: New York"
      }
    ],
    "identifier": 60878877
  },
  {
    "context": [
      "Expected Output should be in csv format as below:",
      "**key,name,id,\"categoryOptions.name\",\"categoryOptions.id\"**",
      "0,Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual),XOPEXepA7zg,0 -2 month,wfvXckoyaE9",
      "The final invocation ( with CSV header) may look like this:\r\n\r\n    jq -r -f program.jq input.json > output.csv && sed  -i '1i \"key\",\"name\",\"id\",\"categoryOptions.name\",\"categoryOptions.id\"' output.csv",
      "range(0;length) as $i\n| .[$i]\n| [$i, .name, .id] +\n  ( range(0, .[\"categoryOptions.name\"]|length) as $j\n    | [ .[\"categoryOptions.name\"][$j], .[\"categoryOptions.id\"][$j] ] )\n| @csv"
    ],
    "utterance": "Produce a CSV where each row contains the array index, name, id, each category option name, and corresponding id, with a header row: key, name, id, categoryOptions.name, categoryOptions.id.",
    "expressions": [
      "range(0;length) as $i | .[$i] | [$i, .name, .id] + ( range(0, .[\"categoryOptions.name\"]|length) as $j | [ .[\"categoryOptions.name\"][$j], .[\"categoryOptions.id\"][$j] ] ) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)",
            "id": "XOPEXepA7zg",
            "categoryOptions.name": [
              "0 -2 month",
              ">2months-<1 year",
              "< 1 year",
              "(1 - 4) Years",
              "(1-9) Years"
            ],
            "categoryOptions.id": [
              "wfvXckoyaE9",
              "Yi2K2FUDa3B",
              "kKt6hryCX75",
              "A0B8w6HoZvV",
              "upbvx1IvICR"
            ]
          },
          {
            "name": "Metadata:MER-2.0-ver KP-Results (Semi Annual)",
            "id": "k9p3Ghbi6eW",
            "categoryOptions.name": [
              "Sex Workers",
              "People in prisons and other enclosed settings (Incarcerated Population) ",
              "PWID..",
              "MSM",
              "Transgender"
            ],
            "categoryOptions.id": [
              "mwTwhESK21T",
              "eQjIwsDqbPy",
              "zYaPQA3uTiH",
              "vu0dG7psM5W",
              "Jyo9XWumVtZ"
            ]
          }
        ],
        "output": [
          "\"key\",\"name\",\"id\",\"categoryOptions.name\",\"categoryOptions.id\"",
          "0,\"Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)\",\"XOPEXepA7zg\",\"0 -2 month\",\"wfvXckoyaE9\"",
          "0,\"Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)\",\"XOPEXepA7zg\",\">2months-<1 year\",\"Yi2K2FUDa3B\"",
          "0,\"Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)\",\"XOPEXepA7zg\",\"< 1 year\",\"kKt6hryCX75\"",
          "0,\"Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)\",\"XOPEXepA7zg\",\"(1 - 4) Years\",\"A0B8w6HoZvV\"",
          "0,\"Metadata:MER-2.0-ver AGYW_PREV-Results (Semi Annual)\",\"XOPEXepA7zg\",\"(1-9) Years\",\"upbvx1IvICR\"",
          "1,\"Metadata:MER-2.0-ver KP-Results (Semi Annual)\",\"k9p3Ghbi6eW\",\"Sex Workers\",\"mwTwhESK21T\"",
          "1,\"Metadata:MER-2.0-ver KP-Results (Semi Annual)\",\"k9p3Ghbi6eW\",\"People in prisons and other enclosed settings (Incarcerated Population) \",\"eQjIwsDqbPy\"",
          "1,\"Metadata:MER-2.0-ver KP-Results (Semi Annual)\",\"k9p3Ghbi6eW\",\"PWID..\",\"zYaPQA3uTiH\"",
          "1,\"Metadata:MER-2.0-ver KP-Results (Semi Annual)\",\"k9p3Ghbi6eW\",\"MSM\",\"vu0dG7psM5W\"",
          "1,\"Metadata:MER-2.0-ver KP-Results (Semi Annual)\",\"k9p3Ghbi6eW\",\"Transgender\",\"Jyo9XWumVtZ\""
        ]
      }
    ],
    "identifier": 60819321
  },
  {
    "context": [
      "I am trying to apply a jq filter so as to be left with only the names and values of all the subcategories while maintaining the nested structure and having BOTH TopCatA and TopCatB in the final output.  The issue is that one of the subcategories (sale) doesnt have subcategories like the other ones (Mens, Womens) so I get the `Cannot iterate over null (null)` message.",
      "The end result I'm looking for is to get something like this:\n\n[\n    {\n      \"identifier\": \"IdNum\",\n      \"name\": \"TopCatA\",\n      \"subCategories\": [\n        {\n          \"name\": \"Mens\",\n          \"subCategories\": [\n            {\n              \"name\": \"Shirts\"\n            },\n            {\n              \"name\": \"Jeans\"\n            }\n          ]\n        },\n        {\n          \"name\": \"Womens\",\n          \"subCategories\": [\n            {\n              \"name\": \"Shirts\"\n            },\n            {\n              \"name\": \"Jeans\"\n            }\n          ]\n        },\n        {\n          \"name\": \"Sale\"\n          \"subCategories\": NULL\n        }\n      ]\n    }\n  ]",
      "If `[]` instead of `null` doesn't bother you:\n```\nmap(.subCategories |=\n  map({name, subCategories: (.subCategories // [] |\n    map({name}))}))\n```"
    ],
    "utterance": "Return an array of objects with identifier and name, where subCategories contains objects with only name and, if present, a subCategories array of objects with only name, preserving nesting even when some subCategories are missing.",
    "expressions": [
      "map(.subCategories |= map({name, subCategories: (.subCategories // [] | map({name}))}))"
    ],
    "data": [
      {
        "input": [
          {
            "identifier": "IdNum",
            "name": "TopCatA",
            "subCategories": [
              {
                "categoryId": "19232",
                "identifier": "83434",
                "name": "Mens",
                "sequence": 10,
                "attributes": {
                  "PrimaryFaceOutImage": "prod1",
                  "PrimaryHoverImage": "model1",
                  "categoryLabel": "Mens Clothing & Accessories",
                  "viewall": "false"
                },
                "subCategories": [
                  {
                    "categoryId": "23423423",
                    "identifier": "456456456",
                    "name": "Shirts",
                    "categoryImage": "gfhhfghfg",
                    "sequence": 1,
                    "attributes": {
                      "CategoryGroupType": "features",
                      "PrimaryFaceOutImage": "false",
                      "viewall": "false"
                    }
                  },
                  {
                    "categoryId": "3423423",
                    "identifier": "234234234234",
                    "name": "Jeans",
                    "categoryImage": "sdfadsf-sdfas-asdf-sdfasdf"
                  }
                ]
              },
              {
                "categoryId": "234234234",
                "identifier": "45345",
                "name": "Womens",
                "sequence": 12,
                "attributes": {
                  "PrimaryFaceOutImage": "prod1",
                  "PrimaryHoverImage": "model1",
                  "categoryLabel": "Womens Clothing & Accessories",
                  "viewall": "false"
                },
                "subCategories": [
                  {
                    "categoryId": "23423423",
                    "identifier": "456456456",
                    "name": "Shirts",
                    "categoryImage": "gfhhfghfg",
                    "sequence": 1,
                    "attributes": {
                      "CategoryGroupType": "features",
                      "PrimaryFaceOutImage": "false",
                      "viewall": "false"
                    }
                  },
                  {
                    "categoryId": "3423423",
                    "identifier": "234234234234",
                    "name": "Jeans",
                    "categoryImage": "sdfadsf-sdfas-asdf-sdfasdf"
                  }
                ]
              },
              {
                "categoryId": "23423423",
                "identifier": "SOME_SALE",
                "name": "Sale",
                "sequence": 23,
                "attributes": {
                  "PrimaryFaceOutImage": "prod1",
                  "PrimaryHoverImage": "model1",
                  "viewall": "false"
                }
              }
            ]
          }
        ],
        "output": [
          {
            "identifier": "IdNum",
            "name": "TopCatA",
            "subCategories": [
              {
                "name": "Mens",
                "subCategories": [
                  {
                    "name": "Shirts"
                  },
                  {
                    "name": "Jeans"
                  }
                ]
              },
              {
                "name": "Womens",
                "subCategories": [
                  {
                    "name": "Shirts"
                  },
                  {
                    "name": "Jeans"
                  }
                ]
              },
              {
                "name": "Sale",
                "subCategories": []
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60887677
  }
]