[
  {
    "context": [
      "But I want to concatenate the variable with an existing string, it ignores the value:",
      "Result:",
      "{\n  Name: \"prefix-value-\"\n}",
      "Expected:",
      "{\n  Name: \"prefix-value-my-hostname\"\n}",
      "Replace",
      "\"prefix-value-$hostname\"",
      "with",
      "\"prefix-value-\\( $hostname )\"",
      "or",
      "\"prefix-value-\" + $hostname"
    ],
    "utterance": "Concatenate the variable hostname with the prefix 'prefix-value-' to assign to the Name field.",
    "expressions": [
      "{ Name: \"prefix-value-\\($hostname)\" }",
      "{ Name: \"prefix-value-\" + $hostname }"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "Name": "prefix-value-my-hostname"
        }
      }
    ],
    "identifier": 69002792
  },
  {
    "context": [
      "Suppose a json exists:\r\n\r\n```\r\n{\r\n  \"foo\": {\r\n     \"descr\": \"this is hard to ask\",\r\n     \"value\": \"but it must be easy to answer\"\r\n  }\r\n}\r\n```",
      "And the goal is:\r\n\r\n```\r\n{\r\n  \"foo\": \"but it must be easy to answer\"\r\n}\r\n```",
      "jq 'map_values(.value)'",
      ".foo |= .value"
    ],
    "utterance": "Replace each top-level object whose value is an object containing a field named \"value\" with the value of its \"value\" field, preserving the original key.",
    "expressions": [
      "map_values(.value)",
      ".foo |= .value"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "descr": "this is hard to ask",
            "value": "but it must be easy to answer"
          }
        },
        "output": {
          "foo": "but it must be easy to answer"
        }
      }
    ],
    "identifier": 68989626
  },
  {
    "context": [
      "Need some help for change the value in JSON file using jq command.",
      "What you want here is:",
      ".Tags |= map(if .Key == \"Period\" then .Value = \"Weekly\" else . end)"
    ],
    "utterance": "Change the Value field to 'Weekly' for every tag object where Key equals 'Period'.",
    "expressions": [
      ".Tags |= map(if .Key == \"Period\" then .Value = \"Weekly\" else . end)"
    ],
    "data": [
      {
        "input": {
          "DBSnapshotIdentifier": "snapshot-myrds-backup-1",
          "DBInstanceIdentifier": "myrds",
          "Tags": [
            {
              "Key": "Name",
              "Value": "snapshot-myrds-backup-1"
            },
            {
              "Key": "Application",
              "Value": "myapp"
            },
            {
              "Key": "Environment",
              "Value": "Dev and QA"
            },
            {
              "Key": "Period",
              "Value": "Daily"
            }
          ]
        },
        "output": {
          "DBSnapshotIdentifier": "snapshot-myrds-backup-1",
          "DBInstanceIdentifier": "myrds",
          "Tags": [
            {
              "Key": "Name",
              "Value": "snapshot-myrds-backup-1"
            },
            {
              "Key": "Application",
              "Value": "myapp"
            },
            {
              "Key": "Environment",
              "Value": "Dev and QA"
            },
            {
              "Key": "Period",
              "Value": "Weekly"
            }
          ]
        }
      }
    ],
    "identifier": 68969718
  },
  {
    "context": [
      "I want modify using jq and give output like this. I only pick 8 characthers from ID:",
      "Use the [Array/String Slice operator][1]",
      "jq 'map(.id |= .[:8])'",
      "The above command will produce:",
      "[\n  {\n    \"id\": \"35a97c36\",\n    \"name\": \"this is title one\"\n  },\n  {\n    \"id\": \"a547d011\",\n    \"name\": \"this is title two\"\n  }\n]"
    ],
    "utterance": "For each object, keep only the first 8 characters of the id field.",
    "expressions": [
      "map(.id |= .[:8])"
    ],
    "data": [
      {
        "input": [
          {
            "id": "35a97c36397886b93bd5619f38c676e739f7f834f82838dcfed602da1d3abf74",
            "name": "this is title one"
          },
          {
            "id": "a547d0112840946aa9e5c266261888d6ab7706e69fc7bb7fdbf907ea2d3da735",
            "name": "this is title two"
          }
        ],
        "output": [
          {
            "id": "35a97c36",
            "name": "this is title one"
          },
          {
            "id": "a547d011",
            "name": "this is title two"
          }
        ]
      }
    ],
    "identifier": 69001362
  },
  {
    "context": [
      "1. Units that have less than 2 \"screenProcesses\".",
      "for #1 you can use `with_entries` to convert `units` to series of maps with `key` and `value` fields, operate on those with `select` and convert back again.",
      "$ jq '{\"units\": .units | with_entries(select(.value.\"screensProcesses\" | length < 2))}' file.json"
    ],
    "utterance": "Return all units whose screensProcesses array has fewer than 2 items.",
    "expressions": [
      "{ \"units\": .units | with_entries(select(.value.\"screensProcesses\" | length < 2)) }"
    ],
    "data": [
      {
        "input": {
          "units": {
            "1000000043579e28": {
              "1_hostname": "unit-a",
              "3_lastCheckIn": "08/31/21 16:00",
              "screensProcesses": [
                "file1",
                "file2"
              ]
            },
            "10000000553ff4cd": {
              "1_hostname": "unit-b",
              "3_lastCheckIn": "08/31/21 16:00",
              "screensProcesses": [
                "file1"
              ]
            }
          }
        },
        "output": {
          "units": {
            "10000000553ff4cd": {
              "1_hostname": "unit-b",
              "3_lastCheckIn": "08/31/21 16:00",
              "screensProcesses": [
                "file1"
              ]
            }
          }
        }
      }
    ],
    "identifier": 69005505
  },
  {
    "context": [
      "With jq, how can I transform the following:\n\n```\n{\n  \"root\": {\n    \"branch1\": {\n      \"leaf\": 1\n    },\n    \"branch2\": {\n      \"leaf\": 2\n    },\n    \"branch3\": {\n      \"leaf\": 3\n    }\n  },\n  \"another-root\": {\n      \"branch\": 123\n  },\n  \"foo\": \"bar\"\n}\n```",
      "to this:\n\n```\n{\n  \"root\": {\n    \"branch1\": {\n      \"leaf\": \"updated\"\n    },\n    \"branch2\": {\n      \"leaf\": \"updated\"\n    },\n    \"branch3\": {\n      \"leaf\": \"updated\"\n    }\n  },\n  \"another-root\": {\n      \"branch\": 123\n  },\n  \"foo\": \"bar\"\n}\n\n```",
      "The following was all I needed.\n\n`.root[].leaf=\"updated\"`"
    ],
    "utterance": "Update all leaf values in every branch under the root key to \"updated\".",
    "expressions": [
      ".root[].leaf=\"updated\""
    ],
    "data": [
      {
        "input": {
          "root": {
            "branch1": {
              "leaf": 1
            },
            "branch2": {
              "leaf": 2
            },
            "branch3": {
              "leaf": 3
            }
          },
          "another-root": {
            "branch": 123
          },
          "foo": "bar"
        },
        "output": {
          "root": {
            "branch1": {
              "leaf": "updated"
            },
            "branch2": {
              "leaf": "updated"
            },
            "branch3": {
              "leaf": "updated"
            }
          },
          "another-root": {
            "branch": 123
          },
          "foo": "bar"
        }
      }
    ],
    "identifier": 68968413
  },
  {
    "context": [
      "How can I get the \"openssl\" values if \"configurations\" is \"modern\" or \"intermediate\"?",
      "To get all both the `modern` and `intermediate` `openssl` arrays, we can use:",
      "jq '.configurations | with_entries(select([.key] | inside([ \"modern\", \"intermediate\" ])))[] | .ciphers.openssl' input",
      "To get a result with an object so we can see on what `key` those `openssl` certs are found, use something like:",
      "jq '.configurations | to_entries | map(select([.key] | inside([ \"modern\", \"intermediate\" ])) | { \"\\(.key)\": .value.ciphers.openssl }) | add' input"
    ],
    "utterance": "Get the values of the 'openssl' arrays under both 'modern' and 'intermediate' configurations.",
    "expressions": [
      ".configurations | with_entries(select([.key] | inside([ \"modern\", \"intermediate\" ])))[] | .ciphers.openssl",
      ".configurations | to_entries | map(select([.key] | inside([ \"modern\", \"intermediate\" ])) | { \"\\(.key)\": .value.ciphers.openssl }) | add"
    ],
    "data": [
      {
        "input": {
          "configurations": {
            "intermediate": {
              "ciphers": {
                "openssl": [
                  "ECDHE-ECDSA-AES128-GCM-SHA256",
                  "ECDHE-RSA-AES128-GCM-SHA256",
                  "ECDHE-ECDSA-AES256-GCM-SHA384",
                  "ECDHE-RSA-AES256-GCM-SHA384",
                  "ECDHE-ECDSA-CHACHA20-POLY1305",
                  "ECDHE-RSA-CHACHA20-POLY1305",
                  "DHE-RSA-AES128-GCM-SHA256",
                  "DHE-RSA-AES256-GCM-SHA384"
                ]
              }
            }
          }
        },
        "output": [
          [],
          [
            "ECDHE-ECDSA-AES128-GCM-SHA256",
            "ECDHE-RSA-AES128-GCM-SHA256",
            "ECDHE-ECDSA-AES256-GCM-SHA384",
            "ECDHE-RSA-AES256-GCM-SHA384",
            "ECDHE-ECDSA-CHACHA20-POLY1305",
            "ECDHE-RSA-CHACHA20-POLY1305",
            "DHE-RSA-AES128-GCM-SHA256",
            "DHE-RSA-AES256-GCM-SHA384"
          ]
        ]
      }
    ],
    "identifier": 68954848
  },
  {
    "context": [
      "My requirement is to print the \"read-transactions\" value.",
      "Expected output is 0.1233",
      "validator-info --json | jq .Node_info.Metrics[].read-transactions",
      "Since there are some `-`'s in your path, you'll need to pass the key as string like so:",
      "jq '.Node_info.Metrics.\"average-per-second\".\"read-transactions\"'",
      "This will output (after making the JSON valid):",
      "0.1233"
    ],
    "utterance": "Extract the value of the read-transactions field located under Node_info.Metrics.average-per-second.",
    "expressions": [
      ".Node_info.Metrics.\"average-per-second\".\"read-transactions\""
    ],
    "data": [
      {
        "input": {
          "Node_info": {
            "Metrics": {
              "Delta": 0.12,
              "Lambda": 2410,
              "Omega": 220,
              "average-per-second": {
                "read-transactions": 0.1233,
                "write-transactions": 0.122334
              }
            }
          }
        },
        "output": 0.1233
      }
    ],
    "identifier": 69013938
  },
  {
    "context": [
      "Given an array of JSON objects, I&#39;d like to output a CSV where one of the rows contains each object key and the others are based on each object value.",
      "The input json is:\n \n```json\n{\n  \"PCID000\": {\n    \"OSmodle\": \"LINUX\",\n    \"IEversion\": \"2.15.0\",\n    \"hardwareUSB\": [\n      \"Card reader\",\n      \"keyboard\"\n    ],\n    \"OrderStatus\": \"01\"\n  },\n  \"PCID999\": {\n    \"OSmodle\": \"LINUX\",\n    \"OSversion\": \"4.0\",\n    \"hardwareUSB\": [],\n    \"OrderStatus\": \"01\"\n  }\n}\n```",
      "The output would look something like this. The header can be hardcoded.\n\n```csv\nPCID,OSmodle,OSversion,IEversion,hardwareUSB, OrderStatus\n\"PCID000\",\"LINUX\",,\"2.15.0\",\"Card reader&keyboard\",\"01\"\n\"PCID999\",\"LINUX\",\"4.0\",,\"01\n```",
      "The jq script would look like this:\n\n```jq\nto_entries | map([\n    .key,\n    .value.OSmodle,\n    .value.OSversion,\n    .value.IEversion,\n    (.value.hardwareUSB | join(\"&\")),\n    .value.OrderStatus])\n| [\"PCID\", \"OSmodle\", \"OSversion\", \"IEversion\", \"hardwareUSB\", \"OrderStatus\"], .[]\n| @csv\n```",
      "Output (with `-r`):\n\n```csv\n\"PCID\",\"OSmodle\",\"OSversion\",\"IEversion\",\"hardwareUSB\",\"OrderStatus\"\n\"PCID000\",\"LINUX\",,\"2.15.0\",\"Card reader&keyboard\",\"01\"\n\"PCID999\",\"LINUX\",\"4.0\",,\"\",\"01\"\n```"
    ],
    "utterance": "Convert an object whose keys are IDs and values are properties into a CSV with a header row and the ID as the first field, joining hardwareUSB array fields with & and leaving missing properties blank.",
    "expressions": [
      "to_entries | map([\n    .key,\n    .value.OSmodle,\n    .value.OSversion,\n    .value.IEversion,\n    (.value.hardwareUSB | join(\"&\")),\n    .value.OrderStatus])\n| [\"PCID\", \"OSmodle\", \"OSversion\", \"IEversion\", \"hardwareUSB\", \"OrderStatus\"], .[]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "PCID000": {
            "OSmodle": "LINUX",
            "IEversion": "2.15.0",
            "hardwareUSB": [
              "Card reader",
              "keyboard"
            ],
            "OrderStatus": "01"
          },
          "PCID999": {
            "OSmodle": "LINUX",
            "OSversion": "4.0",
            "hardwareUSB": [],
            "OrderStatus": "01"
          }
        },
        "output": "\"PCID\",\"OSmodle\",\"OSversion\",\"IEversion\",\"hardwareUSB\",\"OrderStatus\"\n\"PCID000\",\"LINUX\",,\"2.15.0\",\"Card reader&keyboard\",\"01\"\n\"PCID999\",\"LINUX\",\"4.0\",,\"\",\"01\""
      }
    ],
    "identifier": 68996590
  },
  {
    "context": [
      "I would like to use JQ to extract every value for every block and assign them to some variables.",
      "Result should be like this :\n    VAR1 = \"customer1_name\"\n    VAR2 = \"customer1@email.com\"\n    VAR3 = \"customer1_phone\"\n    VAR4 = \"customer1_city\"",
      "$ jq -rc '.values[]' input | tr -d '[\"]' | while IFS=, read var1 var2 var3 var4; do echo \"$var1 $var2 $var3 $var4\"; done",
      "$ jq -rc '.values[][]' input | while read name; read email; read phone; read city; do echo \"$name $email $phone $city\"; done;"
    ],
    "utterance": "Extract each inner array of four elements as variables VAR1, VAR2, VAR3, VAR4 for every block in the values array.",
    "expressions": [
      ".values[]",
      ".values[][]"
    ],
    "data": [
      {
        "input": {
          "range": "Sheet!A2:B100",
          "majorDimension": "ROWS",
          "values": [
            [
              "customer1_name",
              "customer1@email.com",
              "customer1_phone",
              "customer1_city"
            ],
            [
              "customer2_name",
              "customer2@email.com",
              "customer2_phone",
              "customer2_city"
            ]
          ]
        },
        "output": [
          [
            "customer1_name",
            "customer1@email.com",
            "customer1_phone",
            "customer1_city"
          ],
          [
            "customer2_name",
            "customer2@email.com",
            "customer2_phone",
            "customer2_city"
          ]
        ]
      }
    ],
    "identifier": 69016101
  },
  {
    "context": [
      "cat explorer/connection-profile/test-network.json | jq \".organizations.Org1MSP.adminPrivateKey.path |= 44ab\"",
      "jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      ".organizations.Org1MSP.adminPrivateKey.path|=44ab",
      "Actually I am trying to use",
      "cat explorer/connection-profile/test-network.json | jq \".organizations.Org1MSP.adminPrivateKey.path |= ${PRIV_KEY}\"",
      "where the ${PRIV_KEY} is 44ab..._sk",
      "You can assign a string to a variable that can be used inside a `jq` filter:",
      "PRIV_KEY=\"44ab..._sk\"",
      "jq --arg path \"$PRIV_KEY\" '.organizations.Org1MSP.adminPrivateKey.path |= $path' explorer/connection-profile/test-network.json",
      "did you try this , i fixed the same error by setting the expression between '' and the values between \"\"",
      "cat explorer/connection-profile/test-network.json | jq '.organizations.Org1MSP.adminPrivateKey.path |= \"44ab\"'"
    ],
    "utterance": "Replace organizations.Org1MSP.adminPrivateKey.path with the value of an environment variable PRIV_KEY, including values like 44ab..._sk.",
    "expressions": [
      "jq --arg path \"$PRIV_KEY\" '.organizations.Org1MSP.adminPrivateKey.path |= $path' explorer/connection-profile/test-network.json",
      "jq '.organizations.Org1MSP.adminPrivateKey.path |= \"44ab\"' explorer/connection-profile/test-network.json"
    ],
    "identifier": 69026642
  },
  {
    "context": [
      "I have some json data which looks like below:",
      "{ \"spark.master\": \"local\" }",
      "$ key=\"spark.master\"",
      "$ val=$(echo $json_data | jq .'$key')",
      "jq: error: syntax error, unexpected '$' (Unix shell quoting issues?) at <top-level>, line 1:",
      "jq: error: try .[\"field\"] instead of .field for unusually named fields at <top-level>, line 1:"
    ],
    "utterance": "Select the value associated with a key containing a period, where the key name is stored in a shell variable called key.",
    "expressions": [
      ".[$key]"
    ],
    "data": [
      {
        "input": {
          "spark.master": "local"
        },
        "output": "local"
      }
    ],
    "identifier": 69025923
  },
  {
    "context": [
      "How could I use JQ to parse the following JSON object and produce the output below?",
      "JSON Input:\n{\n\t\"key1\": {\n\t\t\"a\": \"A\"\n\t},\n\t\"key2\": {\n\t\t\"b\": \"123\"\n\t},\n\t\"key3\": {\n\t\t\"c\": [\"C1\", \"C2\"]\n\t}\n}",
      "Desired Output:\n[\n  \"a\": \"A\",\n  \"b\": 123,\n  \"c\": \"C1\",\n  \"c\": \"C2\"\n]",
      "The following program produces the output shown below it:\n\ndef q: \"\\\"\\(.)\\\"\";\n\n.[]\n| to_entries[]\n| (.key|q) as $k\n| if .value|type == \"array\"\n  then .value[] | \"\\($k): \\(q)\"\n  else \"\\($k): \\(.value|q)\"\n  end"
    ],
    "utterance": "Produce an array where for each object property, array values are expanded into multiple key-value pairs, with each scalar or array element represented as a key-value mapping using the property name and value.",
    "expressions": [
      "def q: \"\\\"\\(.)\\\"\";\n.[]\n| to_entries[]\n| (.key|q) as $k\n| if .value|type == \"array\"\n  then .value[] | \"\\($k): \\(q)\"\n  else \"\\($k): \\(.value|q)\"\n  end"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "a": "A"
          },
          "key2": {
            "b": "123"
          },
          "key3": {
            "c": [
              "C1",
              "C2"
            ]
          }
        },
        "output": [
          "\"a\": \"A\"",
          "\"b\": \"123\"",
          "\"c\": \"C1\"",
          "\"c\": \"C2\""
        ]
      }
    ],
    "identifier": 69018477
  },
  {
    "context": [
      "given a input `{ \"type\": \"dropdown\"}`, I want to turn the type to `select`, based on the following type mapping, possible to do this in jq?",
      "Assign the lookup object to a variable first:\n```\n{ \"radiogroup\": \"radio\", \"checkbox\": \"checkbox\", \"dropdown\": \"select\", \"text\": \"text\", \"rating\": \"rate\", \"boolean\": \"switch\", \"comment\": \"textarea\" }\n  as $lookup | $lookup[.type]\n```",
      "If both the `input` and `map` objects are in separate files we can use an alternative ...\nThen we can\n```\njq -s '[1].type = .[0][.[1].type] | last' map input\n```"
    ],
    "utterance": "Map the value of the type attribute from 'dropdown' to 'select' using a provided key-value mapping.",
    "expressions": [
      "{ \"radiogroup\": \"radio\", \"checkbox\": \"checkbox\", \"dropdown\": \"select\", \"text\": \"text\", \"rating\": \"rate\", \"boolean\": \"switch\", \"comment\": \"textarea\" } as $lookup | $lookup[.type]",
      ".[1].type = .[0][.[1].type] | last"
    ],
    "data": [
      {
        "input": {
          "type": "dropdown"
        },
        "output": "select"
      },
      {
        "input": [
          {
            "radiogroup": "radio",
            "checkbox": "checkbox",
            "dropdown": "select",
            "text": "text",
            "rating": "rate",
            "boolean": "switch",
            "comment": "textarea"
          },
          {
            "type": "dropdown"
          }
        ],
        "output": {
          "type": "select"
        }
      }
    ],
    "identifier": 69032773
  },
  {
    "context": [
      "I need to remove an entry of `targets` with its `labels` given a data of the `target's` IP.",
      "Input:\n```\n172.17.1.51\n```",
      "expected output:\n```\n[\n    {\n        \"targets\": [\n            \"172.17.1.199\"\n        ],\n        \"labels\": {\n            \"__meta_netbox_pop\": \"st-1742\",\n            \"__snmp_module__\": \"arista_sw\"\n        }\n    }\n]\n```",
      "Using `jq`:\n\n```sh\n$ jq --arg ip 172.17.1.51 'map(select(.targets | contains([$ip]) | not ))' input.json \n[\n  {\n    \"targets\": [\n      \"172.17.1.199\"\n    ],\n    \"labels\": {\n      \"__meta_netbox_pop\": \"st-1742\",\n      \"__snmp_module__\": \"arista_sw\"\n    }\n  }\n]\n```"
    ],
    "utterance": "Remove the object from an array where the 'targets' field contains the IP address 172.17.1.51.",
    "expressions": [
      "map(select(.targets | contains([$ip]) | not ))"
    ],
    "data": [
      {
        "input": [
          {
            "targets": [
              "172.17.1.199"
            ],
            "labels": {
              "__meta_netbox_pop": "st-1742",
              "__snmp_module__": "arista_sw"
            }
          },
          {
            "targets": [
              "172.17.1.51"
            ],
            "labels": {
              "__meta_netbox_pop": "st-1754",
              "__snmp_module__": "arista_sw"
            }
          }
        ],
        "output": [
          {
            "targets": [
              "172.17.1.199"
            ],
            "labels": {
              "__meta_netbox_pop": "st-1742",
              "__snmp_module__": "arista_sw"
            }
          }
        ]
      }
    ],
    "identifier": 69038990
  },
  {
    "context": [
      "Is there a straightforward way to achieve this?",
      "Sample data:",
      "[",
      "  {\"a\": 11, \"b\": 12, \"c\": 13},",
      "  {\"a\": 21, \"b\": 22, \"c\": 23},",
      "  {\"a\": 31, \"b\": 32, \"c\": 33},",
      "  {\"a\": 41, \"b\": 42, \"c\": 43}",
      "]",
      "Desired output:",
      "a,c",
      "11,13",
      "21,23",
      "31,33",
      "41,43",
      "jq --raw-output 'map({ a, c }) | ( .[0] | keys_unsorted), (.[] | [.[]]) | @csv'",
      "\"a\",\"c\"",
      "11,13",
      "21,23",
      "31,33",
      "41,43"
    ],
    "utterance": "Emit only the fields 'a' and 'c' from each object in the array as comma-delimited rows, including a header with the field names.",
    "expressions": [
      "jq --raw-output 'map({ a, c }) | ( .[0] | keys_unsorted), (.[] | [.[]]) | @csv'"
    ],
    "data": [
      {
        "input": [
          {
            "a": 11,
            "b": 12,
            "c": 13
          },
          {
            "a": 21,
            "b": 22,
            "c": 23
          },
          {
            "a": 31,
            "b": 32,
            "c": 33
          },
          {
            "a": 41,
            "b": 42,
            "c": 43
          }
        ],
        "output": [
          "\"a\",\"c\"",
          "11,13",
          "21,23",
          "31,33",
          "41,43"
        ]
      }
    ],
    "identifier": 69039593
  },
  {
    "context": [
      "my desired output is:\n```csv\nnames,ip_address,discovered_data.mac_address,discovered_data.discovered_name\nTest_Device,10.202.202.1,aa:bb:cc:dd:ee:ff,Test_Device.network.local\n```",
      "Assuming jq is invoked with the -r command-line option, this has the advantage of producing valid CSV."
    ],
    "utterance": "Extract the fields 'names', 'ip_address', 'discovered_data.mac_address', and 'discovered_data.discovered_name' from the object and output them as CSV with header and row.",
    "expressions": [
      "(null \n| {names,\n  ip_address,\n  \"discovered_data.mac_address\",\n  \"discovered_data.discovered_name\"} | keys_unsorted) as $keys\n| $keys, \n  ({names: .names[],\n   ip_address,\n   \"discovered_data.mac_address\": .discovered_data.mac_address,\n   \"discovered_data.discovered_name\": .discovered_data.discovered_name }\n   | [.[]])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "_ref": "ipv4address/Li5pcHY0X2FkZHJlc3yMDIuMS8w:10.202.202.1",
          "discovered_data": {
            "bgp_as": 64638,
            "device_model": "catalyst37xxStack",
            "device_port_name": "Vl2002",
            "device_port_type": "propVirtual",
            "device_type": "Switch-Router",
            "device_vendor": "Cisco",
            "discovered_name": "Test_Device.network.local",
            "discoverer": "Network Insight",
            "first_discovered": 1580161888,
            "last_discovered": 1630773758,
            "mac_address": "aa:bb:cc:dd:ee:ff",
            "mgmt_ip_address": "10.202.202.1",
            "os": "15.2(4)E10",
            "port_speed": "Unknown",
            "port_vlan_name": "TEST-DATA",
            "port_vlan_number": 2002
          },
          "ip_address": "10.202.202.1",
          "is_conflict": false,
          "mac_address": "",
          "names": [
            "Test_Device"
          ],
          "network": "10.202.202.0/23",
          "network_view": "TEST VIEW",
          "objects": [],
          "status": "USED",
          "types": [
            "UNMANAGED"
          ],
          "usage": []
        },
        "output": "names,ip_address,discovered_data.mac_address,discovered_data.discovered_name\nTest_Device,10.202.202.1,aa:bb:cc:dd:ee:ff,Test_Device.network.local"
      }
    ],
    "identifier": 69058307
  },
  {
    "context": [
      "I would like to display password's with the help of `jq` command.",
      "The tricky part is you can't use `.0` as it's interpreted as a number, you need to use quotes:",
      "jq '.\"0\".data_bags.passwords | keys' file.json",
      "Or perhaps use `..`, e.g. along the lines of:",
      ".. | objects | .passwords // empty"
    ],
    "utterance": "List all password keys under the 'passwords' field of the object with key \"0\".",
    "expressions": [
      ".\"0\".data_bags.passwords | keys"
    ],
    "data": [
      {
        "input": {
          "0": {
            "data_bags": {
              "license_keys": {
                "nagios": "xxx"
              },
              "passwords": {
                "ONE": "abcd",
                "TWO": "efgh",
                "THREE": "hhhhh",
                "FOUR": "abcdefgh"
              }
            }
          }
        },
        "output": [
          "ONE",
          "TWO",
          "THREE",
          "FOUR"
        ]
      }
    ],
    "identifier": 69071926
  },
  {
    "context": [
      "I am struggling to figure out the correct `jq` expression to convert the following JSON back to some JSON which can generate the appropriate CSV with `@csv`.",
      "There's a fixed number of 'columns', i.e. the \"AAA\" values, but the number of values in each 'column' is dynamic yet fixed across columns.",
      "Desired output ...",
      "You can use the `transpose` function in `jq` to do the transposing of arrays, formed from keys/values.",
      "jq '[ to_entries[] | [.key, .value[]] ] | transpose'",
      "You could also use `map()` and ...",
      "jq 'to_entries | map([.key, .value[]]) | transpose'"
    ],
    "utterance": "Transpose column-based data so that each row is an array of column values with the first row as the array of keys, preserving input order.",
    "expressions": [
      "[to_entries[] | [.key, .value[]]] | transpose",
      "to_entries | map([.key, .value[]]) | transpose"
    ],
    "data": [
      {
        "input": {
          "AAA": [
            111.1,
            111.2,
            111.3,
            "111..",
            "111.n"
          ],
          "BBB": [
            222.1,
            222.2,
            222.3,
            "222..",
            "222.n"
          ],
          "CCC": [
            333.1,
            333.2,
            333.3,
            "333..",
            "333.n"
          ],
          "DDD": [
            444.1,
            444.2,
            444.3,
            "444..",
            "444.n"
          ],
          "EEE": [
            555.1,
            555.2,
            555.3,
            "555..",
            "555.n"
          ]
        },
        "output": [
          [
            "AAA",
            "BBB",
            "CCC",
            "DDD",
            "EEE"
          ],
          [
            111.1,
            222.1,
            333.1,
            444.1,
            555.1
          ],
          [
            111.2,
            222.2,
            333.2,
            444.2,
            555.2
          ],
          [
            111.3,
            222.3,
            333.3,
            444.3,
            555.3
          ],
          [
            "111..",
            "222..",
            "333..",
            "444..",
            "555.."
          ],
          [
            "111.n",
            "222.n",
            "333.n",
            "444.n",
            "555.n"
          ]
        ]
      }
    ],
    "identifier": 69076304
  },
  {
    "context": [
      "I have a json below, I need to use stream mode(file is huge) to parse the data then convert it to another data structure",
      "My expected result is \r\n[\r\n  {\r\n    \"bioguide\": \"E000295\",\r\n    \"thomas\": \"02283\",\r\n    \"name\": \"A\",\r\n    \"toolid\": 12345,\r\n    \"data\": [ ... ]\r\n  },\r\n  {\r\n    \"bioguide\": \"E000295\",\r\n    \"thomas\": \"02283\",\r\n    \"name\": \"A\",\r\n    \"toolid\": 12346,\r\n    \"data\": [ ... ]\r\n  }\r\n]",
      "jq -nM --stream '[fromstream( inputs | (.[0] | index(\"id\")) as $ix | if $ix then .[0] |= .[1+$ix:] else (.[0] | index(\"data\")) as $ix | if $ix then .[0] |= .[$ix:] else (.[0] | index(\"tooldatareports\")) as $ix | (.[0][$ix:] | index(\"name\")) as $jx | if $jx then (.[0] |= .[$ix+$jx:] ) else (.[0] | index(\"toolid\")) as $ix | if $ix then .[0] |= .[$ix:] else empty end end end end ))]| .[0] as $general| [.[1:][]  | ($general + .) | {bioguide,thomas,name,toolid,data} ]' input.json"
    ],
    "utterance": "Extract an array of objects, each containing the values of bioguide, thomas, name, toolid, and data from deeply nested structures, using streaming mode for large input size.",
    "expressions": [
      "jq -nM --stream '[fromstream( inputs | (.[0] | index(\"id\")) as $ix | if $ix then .[0] |= .[1+$ix:] else (.[0] | index(\"data\")) as $ix | if $ix then .[0] |= .[$ix:] else (.[0] | index(\"tooldatareports\")) as $ix | (.[0][$ix:] | index(\"name\")) as $jx | if $jx then (.[0] |= .[$ix+$jx:] ) else (.[0] | index(\"toolid\")) as $ix | if $ix then .[0] |= .[$ix:] else empty end end end end ))]| .[0] as $general| [.[1:][]  | ($general + .) | {bioguide,thomas,name,toolid,data} ]' input.json"
    ],
    "data": [
      {
        "input": {
          "id": {
            "bioguide": "E000295",
            "thomas": "02283",
            "govtrack": 412667
          },
          "bio": {
            "gender": "F",
            "birthday": "1970-07-01"
          },
          "tooldatareports": [
            {
              "name": "A",
              "tooldata": [
                {
                  "toolid": {
                    "value": 12345
                  },
                  "data": [
                    {
                      "time": "2021-01-01",
                      "value": 1
                    },
                    {
                      "time": "2021-01-02",
                      "value": 10
                    },
                    {
                      "time": "2021-01-03",
                      "value": 5
                    }
                  ]
                },
                {
                  "toolid": {
                    "value": 12346
                  },
                  "data": [
                    {
                      "time": "2021-01-01",
                      "value": 10
                    },
                    {
                      "time": "2021-01-02",
                      "value": 100
                    },
                    {
                      "time": "2021-01-03",
                      "value": 50
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "bioguide": "E000295",
            "thomas": "02283",
            "name": "A",
            "toolid": 12345,
            "data": [
              {
                "time": "2021-01-01",
                "value": 1
              },
              {
                "time": "2021-01-02",
                "value": 10
              },
              {
                "time": "2021-01-03",
                "value": 5
              }
            ]
          },
          {
            "bioguide": "E000295",
            "thomas": "02283",
            "name": "A",
            "toolid": 12346,
            "data": [
              {
                "time": "2021-01-01",
                "value": 10
              },
              {
                "time": "2021-01-02",
                "value": 100
              },
              {
                "time": "2021-01-03",
                "value": 50
              }
            ]
          }
        ]
      }
    ],
    "identifier": 69055207
  },
  {
    "context": [
      "I have a JSON file like this:\n\n{\n  \"cmp\": {\n    \"vr1\": {\n      \"vr2\": {\n        \"mpa\": [\n          \"foo1\",\n          \"foo2\"          \n        ]\n      }\n    }\n  },  \n  \"at\": \"\",\n  \"pl\": {\n    \"accountId\": \"\"\n  },\n  \"sv\": {\n    \"accountId\": \"\"\n  }\n}",
      "I am trying to use `jq` to replace the values in the JSON array `mpa` from [\"foo1\", \"foo2\"] to [\"bar1\", \"bar2\"]. How can I do this?",
      "Since you're dealing with an object, no need to use an iterator, you can target your array like so:\n\njq '.cmp.vr1.vr2.mpa = [ \"bar1\", \"bar2\" ]' input.json"
    ],
    "utterance": "Replace the array at cmp.vr1.vr2.mpa with [\"bar1\", \"bar2\"] wherever it occurs.",
    "expressions": [
      ".cmp.vr1.vr2.mpa = [\"bar1\", \"bar2\"]"
    ],
    "data": [
      {
        "input": {
          "cmp": {
            "vr1": {
              "vr2": {
                "mpa": [
                  "foo1",
                  "foo2"
                ]
              }
            }
          },
          "at": "",
          "pl": {
            "accountId": ""
          },
          "sv": {
            "accountId": ""
          }
        },
        "output": {
          "cmp": {
            "vr1": {
              "vr2": {
                "mpa": [
                  "bar1",
                  "bar2"
                ]
              }
            }
          },
          "at": "",
          "pl": {
            "accountId": ""
          },
          "sv": {
            "accountId": ""
          }
        }
      }
    ],
    "identifier": 69079904
  },
  {
    "context": [
      "I am using the following bash script which doesn't give the expected result",
      "secretList=$(aws secretsmanager get-secret-value --secret-id test | jq --raw-output '.SecretString' | jq -r \"to_entries|map(\\\"\\(.key)=\\(.value|tostring)\\\")|.[]\")",
      "Current result is",
      "test=test123 test2=sdf543",
      "Expected result is",
      "Key = test",
      "Value  = test123",
      "Key = test2",
      "Value  = sdf543"
    ],
    "utterance": "Extract each key and value from the secret string so they can be processed in a shell loop with variables named after the actual keys.",
    "expressions": [
      ".SecretString | fromjson | to_entries[] | [.key, .value] | @tsv",
      ".SecretString | fromjson | to_entries[] | \"Key = \"+.key+\"\nValue  = \"+(.value|tostring)"
    ],
    "data": [
      {
        "input": {
          "SecretString": "{\"test\":\"test123\",\"test2\":\"sdf543\"}"
        },
        "output": [
          "Key = test",
          "Value  = test123",
          "Key = test2",
          "Value  = sdf543"
        ]
      }
    ],
    "identifier": 69081781
  },
  {
    "context": [
      "I have 2 arrays in 2 files and I\u2019m trying to multiply them using JQ.",
      "the expected output:\n\n    [\n     {\"a\": \"1\", \"b\": \"2\", \"x\": \"10\", \"y\": \"12\", \"z\": \"15\"},\n     {\"a\": \"1\", \"b\": \"2\", \"x\": \"20\", \"y\": \"22\", \"z\": \"25\"},\n     {\"a\": \"3\", \"b\": \"4\", \"x\": \"10\", \"y\": \"12\", \"z\": \"15\"},\n     {\"a\": \"3\", \"b\": \"4\", \"x\": \"20\", \"y\": \"22\", \"z\": \"25\"}\n    ]",
      "I infer that you\u2019re looking for a cartesian product of the input arrays, such that your output array has an object for each possible pairing of one object from file1\u2019s array and one object from file2\u2019s array, and that the output objects are the merging of the two paired input objects.",
      "This should do what you want:\n\n```\njq -n --slurpfile file1 file1.json --slurpfile file2 file2.json '[$file2[0][] + $file1[0][]|{a,b,x,y,z}]'\n```",
      "jq '. '  -s file1.json file2.json | jq '( .[0] as $a | .[1] as $b | [$a[]+$b[]] )'"
    ],
    "utterance": "Produce an array containing every merged pair of objects between the arrays in file1.json and file2.json such that each output object contains the combined fields of one object from each input array.",
    "expressions": [
      "jq -n --slurpfile file1 file1.json --slurpfile file2 file2.json '[$file1[0][] + $file2[0][]]'",
      "jq '.' -s file1.json file2.json | jq '([.[0][] as $a | .[1][] as $b | $a + $b])'",
      "jq '.' -s file1.json file2.json | jq '(.[0] as $a | .[1] as $b | [$a[]+$b[]])'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": "1",
              "b": "2"
            },
            {
              "a": "3",
              "b": "4"
            }
          ],
          [
            {
              "x": "10",
              "y": "12",
              "z": "15"
            },
            {
              "x": "20",
              "y": "22",
              "z": "25"
            }
          ]
        ],
        "output": [
          {
            "a": "1",
            "b": "2",
            "x": "10",
            "y": "12",
            "z": "15"
          },
          {
            "a": "1",
            "b": "2",
            "x": "20",
            "y": "22",
            "z": "25"
          },
          {
            "a": "3",
            "b": "4",
            "x": "10",
            "y": "12",
            "z": "15"
          },
          {
            "a": "3",
            "b": "4",
            "x": "20",
            "y": "22",
            "z": "25"
          }
        ]
      }
    ],
    "identifier": 69080571
  },
  {
    "context": [
      "jq: error (at <stdin>:1): date \"2021-09-07T08:29:29Z\" does not match format \"%Y-%m-%dT%H:%M:%S\"",
      "My script has this line which I guess is what causes the error",
      "yq '.metadata.creationTimestamp |= (. | strptime(\"%Y-%m-%dT%H:%M:%S\") | strftime(\"%Y-%m-%dT%H:%M:%SZ\"))'",
      "the given date-time string does not match the given format.",
      "the former has a trailing \"Z\", which is not accounted for in the latter.",
      "\"2021-09-07T08:29:29Z\"|strptime(\"%Y-%m-%dT%H:%M:%SZ\")"
    ],
    "utterance": "Parse date-time strings with a trailing 'Z' in the form '2021-09-07T08:29:29Z' to arrays using the matching format string including the 'Z'.",
    "expressions": [
      "\"2021-09-07T08:29:29Z\" | strptime(\"%Y-%m-%dT%H:%M:%SZ\")"
    ],
    "data": [
      {
        "input": "2021-09-07T08:29:29Z",
        "output": [
          2021,
          8,
          7,
          8,
          29,
          29,
          2,
          249
        ]
      }
    ],
    "identifier": 69091003
  },
  {
    "context": [
      "To do so I found a prewritten command which I'm using :",
      "jq <interview.json '.response.results[].alternatives[].transcript' -r > interview.txt",
      "Except I get :",
      "jq: error (at <stdin>:111181): Cannot iterate over null (null)",
      "How can I work around this ? All I want is the raw transcript text.",
      "The JSON you posted does not have a top-level \"response\" key.",
      "This seems to do the trick:",
      ".results[].alternatives[].transcript"
    ],
    "utterance": "Extract all transcript fields from every alternative in all results.",
    "expressions": [
      ".results[].alternatives[].transcript"
    ],
    "identifier": 69093383
  },
  {
    "context": [
      "How to make the following JSON?\r\n\r\n    {\r\n        \"test1\":\"172.1.1\",\r\n        \"test2\":\"172.1.1.2\",\r\n        \"test3\":\"172.1.1.3\"\r\n    }"
    ],
    "utterance": "Create an object mapping keys test1, test2, and test3 to their corresponding IP address values.",
    "expressions": [],
    "data": [
      {
        "input": {
          "rep_hostname": {
            "test1": "172.1.1.1",
            "test2": "172.1.1.2",
            "test3": "172.1.1.3"
          }
        },
        "output": {
          "test1": "172.1.1.1",
          "test2": "172.1.1.2",
          "test3": "172.1.1.3"
        }
      }
    ],
    "identifier": 69102441
  },
  {
    "context": [
      "I want to print each dict with a loop in shell script",
      "I have a json data as below",
      "My except in each loop have printed a dict, total have 2 dict",
      "Use `jq` again to get separate objects from your json list. That is done with `jq -c '.[]'`",
      "You can get identical output (this seems likely to be unnecessary) with:\n\n    $ jq -c '.tooldatareports[].tooldata[].data | {\"data\": .}' data.json  | while read d; do echo \"item: $d\"; done"
    ],
    "utterance": "Extract each object whose key is 'data' under all elements of tooldatareports[].tooldata[] as individual compact objects.",
    "expressions": [
      ".tooldatareports[].tooldata[].data | {\"data\": .}",
      ".tooldatareports[].tooldata[] | {\"data\": .data}",
      ".tooldatareports[].tooldata[].data[] | {\"data\": .}",
      "[.tooldatareports[].tooldata[].data | {\"data\": .}][]"
    ],
    "data": [
      {
        "input": {
          "id": {
            "bioguide": "E000295",
            "thomas": "02283",
            "govtrack": 412667,
            "opensecrets": "N00035483",
            "lis": "S376"
          },
          "bio": {
            "gender": "F",
            "birthday": "1970-07-01"
          },
          "tooldatareports": [
            {
              "name": "A",
              "tooldata": [
                {
                  "toolid": 12345,
                  "data": [
                    {
                      "time": "2021-01-01",
                      "value": 1
                    },
                    {
                      "time": "2021-01-02",
                      "value": 10
                    },
                    {
                      "time": "2021-01-03",
                      "value": 5
                    }
                  ]
                },
                {
                  "toolid": 12346,
                  "data": [
                    {
                      "time": "2021-01-01",
                      "value": 10
                    },
                    {
                      "time": "2021-01-02",
                      "value": 100
                    },
                    {
                      "time": "2021-01-03",
                      "value": 50
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "data": [
              {
                "time": "2021-01-01",
                "value": 1
              },
              {
                "time": "2021-01-02",
                "value": 10
              },
              {
                "time": "2021-01-03",
                "value": 5
              }
            ]
          },
          {
            "data": [
              {
                "time": "2021-01-01",
                "value": 10
              },
              {
                "time": "2021-01-02",
                "value": 100
              },
              {
                "time": "2021-01-03",
                "value": 50
              }
            ]
          }
        ]
      }
    ],
    "identifier": 69053857
  },
  {
    "context": [
      "I need to merge them into a single json array file.",
      "Then, we can create a single array containing those 3 files by using the following JQ command:",
      "jq -s add first.json second.json third.json"
    ],
    "utterance": "Merge multiple array files into one flat array containing all their elements.",
    "expressions": [
      "jq -s add first.json second.json third.json"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2,
            3,
            4,
            5
          ],
          [
            6,
            7,
            8,
            9,
            10
          ],
          [
            11,
            12,
            13,
            14,
            15
          ]
        ],
        "output": [
          1,
          2,
          3,
          4,
          5,
          6,
          7,
          8,
          9,
          10,
          11,
          12,
          13,
          14,
          15
        ]
      }
    ],
    "identifier": 69102865
  },
  {
    "context": [
      "for example I can check whats on 5th row for 1400 and whats for 1401",
      "If we loop over the arrays, we can use string interpolation to create the desired output using hard coded array indexes.",
      "For example, index `0` and `5`:",
      "jq --slurp --raw-output '.[] | \"\\(.[0]) - \\(.[5])\"'",
      "Will show:\n1400 - 562949953421312\n1401 - 0"
    ],
    "utterance": "Show each array's first element paired with the value at index 5 for every array in the input.",
    "expressions": [
      ".[] | \"\u001b[0m\\(.[0]) - \\(.[5])\u001b[0m\"",
      "--slurp --raw-output '.[] | \"\\(.[0]) - \\(.[5])\"'"
    ],
    "data": [
      {
        "input": [
          [
            "1400",
            0,
            0,
            0,
            285697101361315840,
            562949953421312,
            "2021-09-08T01:28:00.000Z",
            false,
            0,
            0,
            0
          ],
          [
            "1401",
            0,
            0,
            0,
            263179103224463360,
            0,
            "2021-09-08T01:28:00.000Z",
            false,
            0,
            0,
            0
          ]
        ],
        "output": [
          "1400 - 562949953421312",
          "1401 - 0"
        ]
      }
    ],
    "identifier": 69100098
  },
  {
    "context": [
      "I read all networkpolicies from a kubernetes namespace and try to output the names of all networkpilicies, which allow access to a certain IP address",
      "The closest I cloud get is:\n\nkubectl get netpol -ojson|jq -r '.items[]|select(.spec.egress[0].to[0].ipBlock.cidr==\"1.2.3.4/32\")|.metadata.name'\n\nbut this only works, if the ip block is the first one in the array. I have no idea, how to iterate over all elements in the array.",
      ".items[]|select(any(.spec.egress[]?.to[]?;.ipBlock.cidr==\"1.2.3.4/32\"))|.metadata.name"
    ],
    "utterance": "List all network policy names that allow egress access to the IP block 1.2.3.4/32, checking every 'to' array in every egress rule.",
    "expressions": [
      ".items[] | select(any(.spec.egress[]?.to[]?; .ipBlock.cidr==\"1.2.3.4/32\")) | .metadata.name"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "policy-1"
              },
              "spec": {
                "egress": [
                  {
                    "to": [
                      {
                        "ipBlock": {
                          "cidr": "1.2.3.4/32"
                        }
                      }
                    ]
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "policy-2"
              },
              "spec": {
                "egress": [
                  {
                    "to": [
                      {
                        "ipBlock": {
                          "cidr": "5.6.7.8/32"
                        }
                      }
                    ]
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "policy-3"
              },
              "spec": {}
            }
          ]
        },
        "output": [
          "policy-1"
        ]
      }
    ],
    "identifier": 69105302
  },
  {
    "context": [
      "If `jq` does receive positional arguments after the filter, it interprets them as filenames. It adheres to the convention of treating `-` as stdin.",
      "bash-4.2# jq --slurp add first - third <<< '{\"two\":2}'\n{\n  \"one\": 1,\n  \"two\": 2,\n  \"three\": 3\n}"
    ],
    "utterance": "Merge JSON objects from two files and one runtime-generated value provided via stdin.",
    "expressions": [
      "jq --slurp add first - third <<< '{\"two\":2}'"
    ],
    "data": [
      {
        "input": [
          {
            "one": 1,
            "two": 1
          },
          {
            "two": 2
          },
          {
            "three": 3
          }
        ],
        "output": {
          "one": 1,
          "two": 2,
          "three": 3
        }
      }
    ],
    "identifier": 69106186
  },
  {
    "context": [
      "the array 'allowed-test-mapper-data' should be sorted in descending order",
      "Use the update assignment `|=` operator to change a part of the structure:",
      "jq  '.components.\"test.data.app\"[].config.\"allowed-test-mapper-data\"\n         |= if . then sort else empty end' file.json"
    ],
    "utterance": "Sort the array at components.\"test.data.app\"[].config.\"allowed-test-mapper-data\" in descending order.",
    "expressions": [
      ".components.\"test.data.app\"[].config.\"allowed-test-mapper-data\" |= sort | reverse"
    ],
    "data": [
      {
        "input": {
          "accessCodeLife": 60,
          "accessCodeLifespan": 1800,
          "accessCodeType": 300,
          "components": {
            "test.data.app": [
              {
                "config": {
                  "allow-default-test-scopes": [
                    "true"
                  ]
                },
                "name": "Allowed Test Client",
                "id": "allowed-testdata",
                "subComponents": {},
                "subType": "testdata"
              },
              {
                "config": {
                  "allowed-test-mapper-data": [
                    "alfred",
                    "usa",
                    "canada",
                    "somedata",
                    "alcohol",
                    "brother"
                  ]
                }
              }
            ]
          }
        },
        "output": {
          "accessCodeLife": 60,
          "accessCodeLifespan": 1800,
          "accessCodeType": 300,
          "components": {
            "test.data.app": [
              {
                "config": {
                  "allow-default-test-scopes": [
                    "true"
                  ]
                },
                "name": "Allowed Test Client",
                "id": "allowed-testdata",
                "subComponents": {},
                "subType": "testdata"
              },
              {
                "config": {
                  "allowed-test-mapper-data": [
                    "usa",
                    "somedata",
                    "canada",
                    "brother",
                    "alfred",
                    "alcohol"
                  ]
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 69110148
  },
  {
    "context": [
      "I am trying to make my json file that looks like this",
      "to look like",
      "Assuming valid JSON like",
      "you can use the filter",
      ".database_details |= (map({key: .servername, value: .}) | from_entries)",
      "The  array associated with `database_details` is turned into an array of key/value pairs, which `from_entries` turns into a new object that `|=` assigns back to the key `database_details` in the original object."
    ],
    "utterance": "Transform the array under 'database_details' so its elements become object properties keyed by their 'servername' value.",
    "expressions": [
      ".database_details |= (map({key: .servername, value: .}) | from_entries)"
    ],
    "data": [
      {
        "input": {
          "database_details": [
            {
              "age": "false",
              "help": "xxxx",
              "host": "",
              "servername": "fra02",
              "db_name": "config_tools",
              "pass": "xxxx",
              "user": "default"
            },
            {
              "age": "false",
              "help": "xxxx",
              "host": "",
              "servername": "fra03",
              "db_name": "config_tools",
              "pass": "xxxx",
              "user": "default"
            }
          ]
        },
        "output": {
          "database_details": {
            "fra02": {
              "age": "false",
              "help": "xxxx",
              "host": "",
              "servername": "fra02",
              "db_name": "config_tools",
              "pass": "xxxx",
              "user": "default"
            },
            "fra03": {
              "age": "false",
              "help": "xxxx",
              "host": "",
              "servername": "fra03",
              "db_name": "config_tools",
              "pass": "xxxx",
              "user": "default"
            }
          }
        }
      }
    ],
    "identifier": 69124013
  },
  {
    "context": [
      "Input:\n```\n[ \n  { \"capital\": \"St. John's\",\n    \"lat\": 17.1172,\n    \"lon\": -61.8457\n  },\n  { \"capital\": \"Buenos Aires\",\n    \"lat\": -34.6051,\n    \"lon\": -58.4004\n  },\n]\n```",
      "Desired output:\n```\n[ \n  { \"capital\": \"St. John's\",\n    \"lonlat\": [ -61.8457, 17.1172]\n  },\n  { \"capital\": \"Buenos Aires\",\n    \"lonlat\": [-58.4004, -34.6051]\n  },\n]\n```",
      "map(. + { lonlat : [.lon, .lat] } | del(.lat, .lon))"
    ],
    "utterance": "Convert each object by combining the lon and lat fields into a lonlat array (order: [lon, lat]), keeping capital, and removing lat and lon.",
    "expressions": [
      "map(. + { lonlat : [.lon, .lat] } | del(.lat, .lon))"
    ],
    "data": [
      {
        "input": [
          {
            "capital": "St. John's",
            "lat": 17.1172,
            "lon": -61.8457
          },
          {
            "capital": "Buenos Aires",
            "lat": -34.6051,
            "lon": -58.4004
          }
        ],
        "output": [
          {
            "capital": "St. John's",
            "lonlat": [
              -61.8457,
              17.1172
            ]
          },
          {
            "capital": "Buenos Aires",
            "lonlat": [
              -58.4004,
              -34.6051
            ]
          }
        ]
      }
    ],
    "identifier": 69124229
  },
  {
    "context": [
      "I am trying to filter this data by date, e.g. I want to find all of these events after a certain date. The timestamp `1631122500` should filter out the top entry here (with `ts` == `2021-09-08T17:34:39.163Z`).",
      "Right after calling `select`, we can pipe the `.ts` value to remove the nanoseconds which JQ can't parse like so:",
      "jq 'map(select(.ts | (split(\".\")[0] + \"Z\") | fromdateiso8601 > 1631184310))'"
    ],
    "utterance": "Select all events whose ts value is after epoch timestamp 1631184310 by transforming ts to remove milliseconds before comparison.",
    "expressions": [
      "map(select(.ts | (split(\".\")[0] + \"Z\") | fromdateiso8601 > 1631184310))"
    ],
    "data": [
      {
        "input": [
          {
            "level": "error",
            "ts": "2021-09-08T17:34:39.163Z",
            "caller": "controller/events.go:39",
            "msg": "Metric query failed for p50 Latency: request failed: Get \\\"https://blah\\\": context deadline exceeded",
            "canary": "blah",
            "stacktrace": "github.com/fluxcd/flagger/pkg/controller.(*Controller).recordEventErrorf\n\t/workspace/pkg/controller/events.go:39\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runMetricChecks\n\t/workspace/pkg/controller/scheduler_metrics.go:280\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runAnalysis\n\t/workspace/pkg/controller/scheduler.go:682\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).advanceCanary\n\t/workspace/pkg/controller/scheduler.go:380\ngithub.com/fluxcd/flagger/pkg/controller.CanaryJob.Start.func1\n\t/workspace/pkg/controller/job.go:39"
          },
          {
            "level": "error",
            "ts": "2021-09-09T11:22:33.162Z",
            "caller": "controller/events.go:39",
            "msg": "Metric query failed for p50 Latency: request failed: Get \\\"https://blah\\\": context deadline exceeded",
            "canary": "blah",
            "stacktrace": "github.com/fluxcd/flagger/pkg/controller.(*Controller).recordEventErrorf\n\t/workspace/pkg/controller/events.go:39\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runMetricChecks\n\t/workspace/pkg/controller/scheduler_metrics.go:280\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runAnalysis\n\t/workspace/pkg/controller/scheduler.go:682\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).advanceCanary\n\t/workspace/pkg/controller/scheduler.go:380\ngithub.com/fluxcd/flagger/pkg/controller.CanaryJob.Start.func1\n\t/workspace/pkg/controller/job.go:39"
          }
        ],
        "output": [
          {
            "level": "error",
            "ts": "2021-09-09T11:22:33.162Z",
            "caller": "controller/events.go:39",
            "msg": "Metric query failed for p50 Latency: request failed: Get \\\"https://blah\\\": context deadline exceeded",
            "canary": "blah",
            "stacktrace": "github.com/fluxcd/flagger/pkg/controller.(*Controller).recordEventErrorf\n\t/workspace/pkg/controller/events.go:39\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runMetricChecks\n\t/workspace/pkg/controller/scheduler_metrics.go:280\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runAnalysis\n\t/workspace/pkg/controller/scheduler.go:682\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).advanceCanary\n\t/workspace/pkg/controller/scheduler.go:380\ngithub.com/fluxcd/flagger/pkg/controller.CanaryJob.Start.func1\n\t/workspace/pkg/controller/job.go:39"
          }
        ]
      }
    ],
    "identifier": 69116628
  },
  {
    "context": [
      "I then pipe the output to another jq to remove duplicates in \"sub\"arrays with:\r\n\r\n  jq '. |= unique_by(.bound_to[].where_to)'",
      "I only want 1 entry in each bound_to array. As you can see record 2 and 3 have duplicates, yet unique_by doesn't remove them.",
      "The task as I understand it can easily (and perhaps most easily) be accomplished using `unique`:\r\n\r\n    map( .bound_to |= unique )"
    ],
    "utterance": "Remove duplicate objects from each bound_to array in each record, keeping only unique items.",
    "expressions": [
      "map( .bound_to |= unique )"
    ],
    "data": [
      {
        "input": [
          {
            "location": "S24C2B1F1",
            "bound_to": [
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 11
              }
            ],
            "description": null,
            "ipv4": "192.168.11.1",
            "id": "50011"
          },
          {
            "location": "S24C2B1F2",
            "bound_to": [
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 3
              },
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 3
              },
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 3
              }
            ],
            "description": null,
            "ipv4": "10.10.3.254",
            "id": "60003"
          },
          {
            "location": "S48C1B2F1",
            "bound_to": [
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 10
              },
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 10
              }
            ],
            "description": null,
            "ipv4": "192.168.10.1",
            "id": "50010"
          }
        ],
        "output": [
          {
            "location": "S24C2B1F1",
            "bound_to": [
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 11
              }
            ],
            "description": null,
            "ipv4": "192.168.11.1",
            "id": "50011"
          },
          {
            "location": "S24C2B1F2",
            "bound_to": [
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 3
              }
            ],
            "description": null,
            "ipv4": "10.10.3.254",
            "id": "60003"
          },
          {
            "location": "S48C1B2F1",
            "bound_to": [
              {
                "access_ids": [],
                "system_ssn": "",
                "where_to": 10
              }
            ],
            "description": null,
            "ipv4": "192.168.10.1",
            "id": "50010"
          }
        ]
      }
    ],
    "identifier": 69059937
  },
  {
    "context": [
      "I'd like to write to a `.env` file instead with the following format:\nCORS_ORIGIN=\"https://example.com\"\nDATABASE_URL=\"db://user:pass@host:3306/example\"",
      "Easy with `jq` and some string interpolation and `@sh` to properly quote the Value strings for shells:",
      "$  jq -r '.Parameters[] | \"\\(.Name | .[rindex(\"/\")+1:])=\\(.Value | @sh)\"' input.json\nCORS_ORIGIN='https://example.com'\nDATABASE_URL='db://user:pass@host:3306/example'"
    ],
    "utterance": "Produce lines in the format KEY=VALUE using the part of Name after the last slash as KEY and quoting the Value field appropriately for shell variables.",
    "expressions": [
      ".Parameters[] | \"\\(.Name | .[rindex(\"/\")+1:])=\\(.Value | @sh)\""
    ],
    "data": [
      {
        "input": {
          "Parameters": [
            {
              "Name": "/EXAMPLE/CORS_ORIGIN",
              "Value": "https://example.com"
            },
            {
              "Name": "/EXAMPLE/DATABASE_URL",
              "Value": "db://user:pass@host:3306/example"
            }
          ]
        },
        "output": [
          "CORS_ORIGIN='https://example.com'",
          "DATABASE_URL='db://user:pass@host:3306/example'"
        ]
      }
    ],
    "identifier": 69129762
  },
  {
    "context": [
      "And I want to extract the O/P in a CSV format with the below fields. Specifically, I want to get the value of the key \"Gamma\" in the o/p if the key \"Gamma\" exists in \"tags\" map. If the key doesn't exists, it should just print a NULL value. The expected o/p is below.",
      "jq --raw-output '\n      \n      # produce an array for each element in the input array\n      .[] | [\n        \n        # containing the first three columns unchanged\n        .generated_time, .platform, .id,\n        \n        # if the input element has a field named \"tags\"\n        if has(\"tags\")\n        \n        # then add two more columns and replace an inexistant Gamma with \"NULL\"\n        then (.tags.Gamma // \"NULL\", .created)\n        \n        # otherwise add two empty columns instead\n        else (null, null) end\n        \n      # and convert the array into CSV format\n      ] | @csv\n      \n    ' input.json"
    ],
    "utterance": "Output a CSV with generated_time, platform, id, Gamma (or NULL if missing from tags), and created fields for each record.",
    "expressions": [
      ".[] | [ .generated_time, .platform, .id, (if has(\"tags\") then (.tags.Gamma // \"NULL\", .created) else (null, null) end) ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "generated_time": "generated_time",
            "platform": "platform",
            "id": "id"
          },
          {
            "generated_time": "2021-09-09:12:03:12",
            "platform": "earth",
            "id": "2eeee67748",
            "tags": {
              "app": "map",
              "Gamma": "Ray",
              "null": [
                "allow-all-humans"
              ]
            },
            "created": "2021-08-25 09:41:06"
          },
          {
            "generated_time": "2021-09-09:12:03:12",
            "platform": "sun",
            "id": "xxxxx12334",
            "tags": {
              "component": "machine",
              "environment": "hot",
              "null": [
                "aallow-all-humans"
              ]
            },
            "created": "2021-08-25 10:11:31"
          }
        ],
        "output": [
          "\"generated_time\",\"platform\",\"id\",,",
          "\"2021-09-09:12:03:12\",\"earth\",\"2eeee67748\",\"Ray\",\"2021-08-25 09:41:06\"",
          "\"2021-09-09:12:03:12\",\"sun\",\"xxxxx12334\",\"NULL\",\"2021-08-25 10:11:31\""
        ]
      }
    ],
    "identifier": 69125439
  },
  {
    "context": [
      "I have a json file with keys containing dots.:",
      "{\n\"a\": \"b\",\n\"foo.bar\": true \n}",
      "I want to get the value of certain keys using jq from a script.",
      "Pass your key as an `--arg name value` to `jq`.",
      "jq --exit-status --raw-output --arg k \"$key\" '.[$k]' \"$file\""
    ],
    "utterance": "Retrieve the value of a key containing a dot, where the key name is stored in a variable, from a file.",
    "expressions": [
      "jq --raw-output --arg k \"$key\" '.[$k]' \"$file\"",
      "jq -r --arg k \"$key\" '.[$k]' \"$file\""
    ],
    "data": [
      {
        "input": {
          "a": "b",
          "foo.bar": true
        },
        "output": true
      }
    ],
    "identifier": 69142574
  },
  {
    "context": [
      "I\u2019d like to obtain a (one per line or a single array) list of all combinations of matching key/values pairs between c1 and c2 array where the value of the \"type\" key (string) matches between c1 and c2 exactly.",
      "You will notice that type \"yotta\" from the c2 is not included in the output. This is expected. Only \"types\" which exist in c1 and match c2 are expected to be in the results.",
      "Here\u2019s an example of using INDEX and JOIN:",
      "jq --compact-output --slurpfile c1 c1.json '\n    INDEX(\n        $c1[0].c1[];\n        .type\n    ) as $index |\n    JOIN(\n        $index;\n        .c2[];\n        .type;\n        reverse|add\n    )\n' c2.json"
    ],
    "utterance": "Get all combined objects where each entry from c1 matches each entry from c2 with the same value for the key 'type', merging relevant key/value pairs from both.",
    "expressions": [
      "INDEX($c1[0].c1[]; .type) as $index | JOIN($index; .c2[]; .type; reverse|add)"
    ],
    "data": [
      {
        "input": [
          {
            "c1": [
              {
                "c1id": 1,
                "type": "alpha"
              },
              {
                "c1id": 2,
                "type": "beta"
              }
            ]
          },
          {
            "c2": [
              {
                "c2id": 1,
                "type": "alpha",
                "serial": "DDBB001"
              },
              {
                "c2id": 2,
                "type": "beta",
                "serial": "DDBB007"
              },
              {
                "c2id": 3,
                "type": "alpha",
                "serial": "DDTT005"
              },
              {
                "c2id": 4,
                "type": "beta",
                "serial": "DDAA002"
              },
              {
                "c2id": 5,
                "type": "yotta",
                "serial": "DDCC017"
              }
            ]
          }
        ],
        "output": [
          {
            "c1id": 1,
            "type": "alpha",
            "c2id": 1,
            "serial": "DDBB001"
          },
          {
            "c1id": 1,
            "type": "alpha",
            "c2id": 3,
            "serial": "DDTT005"
          },
          {
            "c1id": 2,
            "type": "beta",
            "c2id": 2,
            "serial": "DDBB007"
          },
          {
            "c1id": 2,
            "type": "beta",
            "c2id": 4,
            "serial": "DDAA002"
          }
        ]
      }
    ],
    "identifier": 69134020
  },
  {
    "context": [
      "I have 2 files and I'd like to merge them into one file while also aggregating (sum) the values when names in the name/value pairs are the same.",
      "As an example:",
      "*Input1.json*",
      "[ { \"A\": \"Name 1\", \"B\": \"1.1\", \"C\": \"2\" }, { \"A\": \"Name 2\", \"B\": \"3.2\", \"C\": \"4\" } ]",
      "*Input2.json*",
      "[ { \"A\": \"Name 2\", \"B\": \"5\", \"C\": \"6\" }, { \"A\": \"Name 3\", \"B\": \"7\", \"C\": \"8\" } ]",
      "Expected result:",
      "Output.json",
      "[ { \"A\": \"Name 1\", \"B\": \"1.1\", \"C\": \"2\" }, { \"A\": \"Name 2\", \"B\": \"8.2\", \"C\": \"10\" }, { \"A\": \"Name 3\", \"B\": \"7\", \"C\": \"8\" } ]",
      "jq is beautiful for problems like this:",
      "jq -n '\nreduce inputs[] as {$A,$B,$C} ({};\n    .[$A] |= {\n        $A,\n        B: (.B + ($B|tonumber)),\n        C: (.C + ($C|tonumber))\n    }\n)\n| map({\n    A,\n    B: (.B|tostring),\n    C: (.C|tostring)\n  })\n' input1.json input2.json"
    ],
    "utterance": "Combine two files and, for each unique value of field 'A', sum the values of 'B' and 'C', returning the results in an array of objects.",
    "expressions": [
      "jq -n '\nreduce inputs[] as {$A,$B,$C} ({};\n    .[$A] |= {\n        $A,\n        B: (.B + ($B|tonumber)),\n        C: (.C + ($C|tonumber))\n    }\n)\n| map({\n    A,\n    B: (.B|tostring),\n    C: (.C|tostring)\n  })\n' input1.json input2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "A": "Name 1",
              "B": "1.1",
              "C": "2"
            },
            {
              "A": "Name 2",
              "B": "3.2",
              "C": "4"
            }
          ],
          [
            {
              "A": "Name 2",
              "B": "5",
              "C": "6"
            },
            {
              "A": "Name 3",
              "B": "7",
              "C": "8"
            }
          ]
        ],
        "output": [
          {
            "A": "Name 1",
            "B": "1.1",
            "C": "2"
          },
          {
            "A": "Name 2",
            "B": "8.2",
            "C": "10"
          },
          {
            "A": "Name 3",
            "B": "7",
            "C": "8"
          }
        ]
      }
    ],
    "identifier": 69137721
  },
  {
    "context": [
      "I want it to clone the repos into a directory using the REST API parameter `full_name` (since it consists of `repo.owner` and `repo.name`), how do I get around to do that?",
      "jq -r '.[] | [ .html_url, .full_name ] | @sh'"
    ],
    "utterance": "Retrieve each repository's html_url and full_name as a shell-quoted line for further processing.",
    "expressions": [
      ".[] | [ .html_url, .full_name ] | @sh"
    ],
    "identifier": 69151495
  },
  {
    "context": [
      "From the above json i need to sum the ```monthlyCost``` of each resources and update total value in ```totalMonthlyCost```",
      "So the input would be ```\"3.9660999999999986 + 2.482 + 87.24400000000001\"``` the sum of these values should be updated in ```totalMonthlyCost```",
      "(.breakdown.resources | map(.monthlyCost) | add) as $sum\n| .breakdown.totalMonthlyCost = $sum",
      ".breakdown.totalMonthlyCost \n = (.breakdown.resources | map(.monthlyCost) | add)",
      ".breakdown\n |= (.totalMonthlyCost = (.resources | map(.monthlyCost) | add))"
    ],
    "utterance": "Set breakdown.totalMonthlyCost to the sum of all resources[].monthlyCost values",
    "expressions": [
      "(.breakdown.resources | map(.monthlyCost) | add) as $sum | .breakdown.totalMonthlyCost = $sum",
      ".breakdown.totalMonthlyCost = (.breakdown.resources | map(.monthlyCost) | add)",
      ".breakdown |= (.totalMonthlyCost = (.resources | map(.monthlyCost) | add))"
    ],
    "data": [
      {
        "input": {
          "name": ".",
          "metadata": {
            "path": ".",
            "type": "terraform_dir",
            "terraformWorkspace": "default"
          },
          "pastBreakdown": {
            "resources": [],
            "totalHourlyCost": "0",
            "totalMonthlyCost": "0"
          },
          "breakdown": {
            "resources": [
              {
                "name": "vm01",
                "metadata": {},
                "hourlyCost": "0.007989726027400584",
                "monthlyCost": 3.9660999999999986,
                "costComponents": [
                  {
                    "name": "vm01-201",
                    "unit": "years",
                    "hourlyQuantity": "0.0001141552511416",
                    "monthlyQuantity": "0.0833333333333333",
                    "price": "69.99",
                    "hourlyCost": "0.007989726027400584",
                    "monthlyCost": "5.832499999999997667"
                  }
                ]
              },
              {
                "name": "public_ip.example",
                "metadata": {},
                "hourlyCost": "0.005",
                "monthlyCost": 2.482,
                "costComponents": [
                  {
                    "name": "IP address (static)",
                    "unit": "hours",
                    "hourlyQuantity": "1",
                    "monthlyQuantity": "730",
                    "price": "0.005",
                    "hourlyCost": "0.005",
                    "monthlyCost": "3.65"
                  }
                ]
              },
              {
                "name": "storage_account",
                "metadata": {},
                "hourlyCost": "0.17575342465753424425",
                "monthlyCost": 87.24400000000001,
                "costComponents": [
                  {
                    "name": "Write",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.136986301369863",
                    "monthlyQuantity": "100",
                    "price": "0.1",
                    "hourlyCost": "0.0136986301369863",
                    "monthlyCost": "10"
                  },
                  {
                    "name": "List",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.136986301369863",
                    "monthlyQuantity": "100",
                    "price": "0.05",
                    "hourlyCost": "0.00684931506849315",
                    "monthlyCost": "5"
                  },
                  {
                    "name": "Read",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.0136986301369863",
                    "monthlyQuantity": "10",
                    "price": "0.01",
                    "hourlyCost": "0.000136986301369863",
                    "monthlyCost": "0.1"
                  },
                  {
                    "name": "All other operations",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.136986301369863",
                    "monthlyQuantity": "100",
                    "price": "0.004",
                    "hourlyCost": "0.000547945205479452",
                    "monthlyCost": "0.4"
                  },
                  {
                    "name": "retrieval",
                    "unit": "GB",
                    "hourlyQuantity": "1.3698630136986301",
                    "monthlyQuantity": "1000",
                    "price": "0.01",
                    "hourlyCost": "0.013698630136986301",
                    "monthlyCost": "10"
                  },
                  {
                    "name": "write",
                    "unit": "GB",
                    "hourlyQuantity": "1.3698630136986301",
                    "monthlyQuantity": "1000",
                    "price": "0.0025",
                    "hourlyCost": "0.00342465753424657525",
                    "monthlyCost": "2.5"
                  },
                  {
                    "name": "index",
                    "unit": "10K tags",
                    "hourlyQuantity": "0.0136986301369863",
                    "monthlyQuantity": "10",
                    "price": "0.03",
                    "hourlyCost": "0.000410958904109589",
                    "monthlyCost": "0.3"
                  }
                ]
              }
            ],
            "totalMonthlyCost": "sum value"
          }
        },
        "output": {
          "name": ".",
          "metadata": {
            "path": ".",
            "type": "terraform_dir",
            "terraformWorkspace": "default"
          },
          "pastBreakdown": {
            "resources": [],
            "totalHourlyCost": "0",
            "totalMonthlyCost": "0"
          },
          "breakdown": {
            "resources": [
              {
                "name": "vm01",
                "metadata": {},
                "hourlyCost": "0.007989726027400584",
                "monthlyCost": 3.9660999999999986,
                "costComponents": [
                  {
                    "name": "vm01-201",
                    "unit": "years",
                    "hourlyQuantity": "0.0001141552511416",
                    "monthlyQuantity": "0.0833333333333333",
                    "price": "69.99",
                    "hourlyCost": "0.007989726027400584",
                    "monthlyCost": "5.832499999999997667"
                  }
                ]
              },
              {
                "name": "public_ip.example",
                "metadata": {},
                "hourlyCost": "0.005",
                "monthlyCost": 2.482,
                "costComponents": [
                  {
                    "name": "IP address (static)",
                    "unit": "hours",
                    "hourlyQuantity": "1",
                    "monthlyQuantity": "730",
                    "price": "0.005",
                    "hourlyCost": "0.005",
                    "monthlyCost": "3.65"
                  }
                ]
              },
              {
                "name": "storage_account",
                "metadata": {},
                "hourlyCost": "0.17575342465753424425",
                "monthlyCost": 87.24400000000001,
                "costComponents": [
                  {
                    "name": "Write",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.136986301369863",
                    "monthlyQuantity": "100",
                    "price": "0.1",
                    "hourlyCost": "0.0136986301369863",
                    "monthlyCost": "10"
                  },
                  {
                    "name": "List",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.136986301369863",
                    "monthlyQuantity": "100",
                    "price": "0.05",
                    "hourlyCost": "0.00684931506849315",
                    "monthlyCost": "5"
                  },
                  {
                    "name": "Read",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.0136986301369863",
                    "monthlyQuantity": "10",
                    "price": "0.01",
                    "hourlyCost": "0.000136986301369863",
                    "monthlyCost": "0.1"
                  },
                  {
                    "name": "All other operations",
                    "unit": "10K operations",
                    "hourlyQuantity": "0.136986301369863",
                    "monthlyQuantity": "100",
                    "price": "0.004",
                    "hourlyCost": "0.000547945205479452",
                    "monthlyCost": "0.4"
                  },
                  {
                    "name": "retrieval",
                    "unit": "GB",
                    "hourlyQuantity": "1.3698630136986301",
                    "monthlyQuantity": "1000",
                    "price": "0.01",
                    "hourlyCost": "0.013698630136986301",
                    "monthlyCost": "10"
                  },
                  {
                    "name": "write",
                    "unit": "GB",
                    "hourlyQuantity": "1.3698630136986301",
                    "monthlyQuantity": "1000",
                    "price": "0.0025",
                    "hourlyCost": "0.00342465753424657525",
                    "monthlyCost": "2.5"
                  },
                  {
                    "name": "index",
                    "unit": "10K tags",
                    "hourlyQuantity": "0.0136986301369863",
                    "monthlyQuantity": "10",
                    "price": "0.03",
                    "hourlyCost": "0.000410958904109589",
                    "monthlyCost": "0.3"
                  }
                ]
              }
            ],
            "totalMonthlyCost": 93.6921
          }
        }
      }
    ],
    "identifier": 69010181
  },
  {
    "context": [
      "I can't get any combination like this to work:\n\n\n     KEY='.Resources.lc.Properties.UserData.\"Fn::Base64\"'\n      jq --arg p \"$KEY\" '$p = \"HHH\"' my_data.json\n\nn\n\njq: error (at my_data.json:470): Invalid path expression with result \".Resources.lc.Properties....",
      "The recommended approach here is to pass in the path as an array if possible, so that `setpath` can be used:\n```\nKEY='[\"Resources\", \"lc\", \"Properties\", \"UserData\", \"Fn::Base64\"]'\njq --argjson p \"$KEY\" 'setpath( $p; \"HHH\")' my_data.json\n```",
      "If that is not possible, next best would probably be to parse your $KEY string\nwith the inner double-quotation-marks removed:\n```\nKEY='.Resources.lc.Properties.UserData.Fn::Base64'\njq -n --arg p \"$KEY\" 'setpath( $p|split(\".\")[1:]; \"HHH\")' my_data.json\n```",
      "Next to next-best would be to strip the inner double-quotation-marks,\ne.g. in the shell or using jq\n```\nKEY='.Resources.lc.Properties.UserData.Fn::Base64'\njq -n --arg p \"$KEY\" '\n  setpath( $p|gsub(\"\\\"\",\"\")|split(\".\")[1:]; \"HHH\")\n' my_data.json\n```"
    ],
    "utterance": "Update the value at the path Resources.lc.Properties.UserData.Fn::Base64 to HHH, where the path is provided dynamically as a variable.",
    "expressions": [
      "jq --argjson p '[\"Resources\", \"lc\", \"Properties\", \"UserData\", \"Fn::Base64\"]' 'setpath( $p; \"HHH\")' my_data.json",
      "jq -n --arg p \".Resources.lc.Properties.UserData.Fn::Base64\" 'setpath( $p|split(\".\")[1:]; \"HHH\")' my_data.json",
      "jq -n --arg p \".Resources.lc.Properties.UserData.Fn::Base64\" 'setpath( $p|gsub(\"\\\"\";\"\")|split(\".\")[1:]; \"HHH\")' my_data.json"
    ],
    "identifier": 69142882
  },
  {
    "context": [
      "I have a space separated list of names generated by a program, I need to convert this list to json.",
      "example: file output is called names.txt. context is below. ",
      "name1 name2 name3",
      "The json expectation is ",
      "{\n    \"names\": [\n        \"name1\",\n        \"name2\",\n        \"name3\"\n    ]\n}",
      "A [tag:jq] solution could be simplefied by passing the 'string' as argument, then using `split()` to create an array like so:",
      "jq -n --arg d \"$(cat input)\" '{ \"names\": $d | split(\" \") }'",
      "$ cat input",
      "name1 name2 name3",
      "$ jq -n --arg d \"$(cat input)\" '{ \"names\": $d | split(\" \") }'",
      "{\n  \"names\": [\n    \"name1\",\n    \"name2\",\n    \"name3\"\n  ]\n}"
    ],
    "utterance": "Convert a space-separated list of names in a file to an object with a 'names' key containing an array of the names.",
    "expressions": [
      "jq -n --arg d \"$(cat names.txt)\" '{ \"names\": $d | split(\" \") }'"
    ],
    "data": [
      {
        "input": "name1 name2 name3",
        "output": {
          "names": [
            "name1",
            "name2",
            "name3"
          ]
        }
      }
    ],
    "identifier": 69163768
  },
  {
    "context": [
      "but the lines  are seprated:\r\n\r\n``` \r\n127.0.0.1\r\n80\r\n```\r\nneed a string like :\r\n```127.0.0.1:80```",
      "jq -r '.[] | .ip + \":\" + ( .ports[].port | tostring )' output.json",
      "jq -r '.[] | .ip as $ip | .ports[].port as $port | [ $ip, $port ] | join(\":\" )' output.json",
      "jq -r '.[] | \"\\(.ip):\\(.ports[].port)\"' output.json"
    ],
    "utterance": "For each object, print the ip and each port value separated by a colon, e.g., 127.0.0.1:80.",
    "expressions": [
      ".[] | .ip + \":\" + (.ports[].port | tostring)",
      ".[] | .ip as $ip | .ports[].port as $port | [ $ip, $port ] | join(\":\")",
      ".[] | \"\\(.ip):\\(.ports[].port)\""
    ],
    "data": [
      {
        "input": [
          {
            "ip": "127.0.0.1",
            "timestamp": "1631581369",
            "ports": [
              {
                "port": 80,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 42
              }
            ]
          }
        ],
        "output": [
          "127.0.0.1:80"
        ]
      }
    ],
    "identifier": 69171091
  },
  {
    "context": [
      "I have a large JSON file contains a list of objects like this:",
      "I'm using jq to convert it to a csv like this:",
      "\"address\",\"lat\",\"lon\"\n\"375/20 B\u00f9i Qu\u1ed1c Kh\u00e1nh, Ch\u00e1nh Ngh\u0129a, B\u00ecnh D\u01b0\u01a1ng, Vi\u1ec7t Nam\",10.959882,106.66307",
      "The problem is that this file has sized up to more than 2GB. I'm studying to apply streaming but still can not understand how to use it.",
      "Since the input file is just a stream of JSON entities, and since it seems each output row depends only on one of these, you can avoid memory issues most simply by NOT using the -s command-line option, and adapting your jq program accordingly.",
      "If you can efficiently filter out the required fields alone for the CSV output, you should be fine, i.e.",
      "jq -r -cn '[\"address\",\"lat\",\"lon\"], (inputs | [._source.name.default,._source.center_point.lat,._source.center_point.lon]) | @csv'"
    ],
    "utterance": "Output a CSV with columns address, lat, and lon, extracting ._source.name.default, ._source.center_point.lat, and ._source.center_point.lon from each object in a large input file where each JSON object appears on its own line.",
    "expressions": [
      "[\"address\",\"lat\",\"lon\"], (inputs | [._source.name.default,._source.center_point.lat,._source.center_point.lon]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "_index": "pelias",
            "_type": "address",
            "_id": "jf808cdawi46z",
            "_score": 1,
            "_source": {
              "center_point": {
                "lon": 106.66307,
                "lat": 10.959882
              },
              "name": {
                "default": "375/20 B\u00f9i Qu\u1ed1c Kh\u00e1nh, Ch\u00e1nh Ngh\u0129a, B\u00ecnh D\u01b0\u01a1ng, Vi\u1ec7t Nam"
              }
            }
          },
          {
            "_index": "pelias",
            "_type": "address",
            "_id": "jf808cdawi46z",
            "_score": 1,
            "_source": {
              "center_point": {
                "lon": 106.66307,
                "lat": 10.959882
              },
              "name": {
                "default": "375/20 B\u00f9i Qu\u1ed1c Kh\u00e1nh, Ch\u00e1nh Ngh\u0129a, B\u00ecnh D\u01b0\u01a1ng, Vi\u1ec7t Nam"
              }
            }
          }
        ],
        "output": [
          "\"address\",\"lat\",\"lon\"",
          "\"375/20 B\u00f9i Qu\u1ed1c Kh\u00e1nh, Ch\u00e1nh Ngh\u0129a, B\u00ecnh D\u01b0\u01a1ng, Vi\u1ec7t Nam\",10.959882,106.66307",
          "\"375/20 B\u00f9i Qu\u1ed1c Kh\u00e1nh, Ch\u00e1nh Ngh\u0129a, B\u00ecnh D\u01b0\u01a1ng, Vi\u1ec7t Nam\",10.959882,106.66307"
        ]
      }
    ],
    "identifier": 69157508
  },
  {
    "context": [
      "How can I get all unique names (so there are no duplicates)?",
      "the following jq program will yield an array of the distinct names:\r\n\r\n    map(.name) | unique"
    ],
    "utterance": "Get all unique values of the 'name' key from a list of objects.",
    "expressions": [
      "map(.name) | unique"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Joe",
            "age": 21
          },
          {
            "name": "Steve",
            "age": 27
          },
          {
            "name": "Michelle",
            "age": 32
          },
          {
            "name": "Joe",
            "age": 23
          }
        ],
        "output": [
          "Joe",
          "Michelle",
          "Steve"
        ]
      }
    ],
    "identifier": 69172925
  },
  {
    "context": [
      "I having trouble of getting my json append with a new object into the `config -> list -> key(vehicles) -> Rows`. But then only for `vehicles`.",
      "Wanted result:",
      "{\r\n    \"id\": \"1234\",\r\n    \"name\": \"CatList\",\r\n    \"config\": {\r\n        \"list\": [\r\n            {\r\n                \"key\": \"vehicles\",\r\n                \"rows\": [\r\n                    {\r\n                        \"data\": [\r\n                            {\r\n                                \"key\": \"bike\",\r\n                                \"value\": \"yyy\"\r\n                            },\r\n                            {\r\n                                \"key\": \"car\",\r\n                                \"value\": \"xxx\"\r\n                            }\r\n                        ],\r\n                        \"default\": false\r\n                    },\r\n                    {                             \r\n                        \"data\": [                  \r\n                            {                      \r\n                                \"key\": \"bike\",     \r\n                                \"value\": \"yyy\"     \r\n                            },                     \r\n                            {                      \r\n                                \"key\": \"car\",      \r\n                                \"value\": \"xxx\"     \r\n                            }                      \r\n                        ],                         \r\n                        \"default\": false           \r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                \"key\": \"boots\",\r\n                \"rows\": []\r\n            }\r\n        ],\r\n        \"data\": [\r\n            {\r\n                \"key\": \"GROUPS\",\r\n                \"value\": \"false\"\r\n            }\r\n        ]\r\n    }\r\n}",
      "jq '.config.list[.config.list|map(.key==\"vehicles\")|index(true)].rows += [{\"data\":[{\"key\":\"fot\",\"value\":\"K\"},{\"key\":\"seat\",\"value\":\"leon\"}],\"default\":false}]'"
    ],
    "utterance": "Append a specified object to the rows array of the list element where key equals 'vehicles'.",
    "expressions": [
      ".config.list[.config.list|map(.key==\"vehicles\")|index(true)].rows += [{\"data\":[{\"key\":\"fot\",\"value\":\"K\"},{\"key\":\"seat\",\"value\":\"leon\"}],\"default\":false}]"
    ],
    "data": [
      {
        "input": {
          "id": "1234",
          "name": "CatList",
          "config": {
            "list": [
              {
                "key": "vehicles",
                "rows": [
                  {
                    "data": [
                      {
                        "key": "bike",
                        "value": "yyy"
                      },
                      {
                        "key": "car",
                        "value": "xxx"
                      }
                    ],
                    "default": false
                  }
                ]
              },
              {
                "key": "boots",
                "rows": []
              }
            ],
            "data": [
              {
                "key": "GROUPS",
                "value": "false"
              }
            ]
          }
        }
      }
    ],
    "identifier": 69172746
  },
  {
    "context": [
      "How can I titleize text (capitalize each word) with `jq`?",
      "Expected transformation: `\"lorum ipsum\"` \u2192 `\"Lorum Ipsum\"`",
      "this may be achieved with `gsub`, `ascii_upcase`, and named capture groups:\n```\n$ echo '\"lorum ipsum\"' | jq 'gsub(\"(?<x>[A-z])(?<y>[A-z]+)\"; \"\\(.x|ascii_upcase)\\(.y)\")'\n\"Lorum Ipsum\"\n```",
      "Given a string of words, split it into an array of words, apply the above to each element using `map` and join them back together... Given your input example (`\"lorum ipsum\"`), using a single space character as word separator will suffice...:\n\n    echo '\"lorum ipsum\"' | jq --arg ws ' ' '\n      \n      ./$ws | map(\n        \n        ./\"\" | first |= ascii_upcase | add\n        \n      ) | join($ws)\n      \n    '"
    ],
    "utterance": "Capitalize the first letter of each word in the input string 'lorum ipsum'.",
    "expressions": [
      "gsub(\"(?<x>[A-z])(?<y>[A-z]+)\"; \"\\(.x|ascii_upcase)\\(.y)\")",
      "split(\" \") | map( .[0:1] | ascii_upcase + .[1:] ) | join(\" \")",
      "split(\" \") | map( .[0:1] + .[1:] | .[0] |= ascii_upcase ) | join(\" \")",
      "split(\" \") | map( ./(\"\") | first |= ascii_upcase | add ) | join(\" \")"
    ],
    "data": [
      {
        "input": "lorum ipsum",
        "output": "Lorum Ipsum"
      }
    ],
    "identifier": 69170688
  },
  {
    "context": [
      "for every shop it loops through the json and should compare the currentShop with the store.shop from json and then echo the user and the shop.",
      "jq -r --arg storeName \"$shop\" '.[] | select(.store.storeName == \"\\($storeName)\") | \"\\(.userName) - \\(.store.storeName)\"' details.json"
    ],
    "utterance": "For each shop name in a list, find all entries where store.storeName matches the shop name and output the userName and storeName.",
    "expressions": [
      ".[] | select(.store.storeName == $shop) | {userName, storeName: .store.storeName}",
      ".[] | select(.store.storeName == $shop) | \"\f(.userName) - \f(.store.storeName)\""
    ],
    "data": [
      {
        "input": [
          {
            "userName": "Anne",
            "email": "anne@stack.com",
            "company": {
              "name": "Stack GmbH"
            },
            "details": {
              "key": "EFHJKI-KJEFT-DHMNEB",
              "prod": "Car"
            },
            "store": {
              "id": "05611a7f-a679-12ad-a3u2-0745e3650a03",
              "storeName": "shop-a57ca0a3-120c-1a73-153b-fa4231cab768"
            }
          },
          {
            "userName": "Tom",
            "email": "tom@stack.com",
            "company": {
              "name": "Stack GmbH"
            },
            "details": {
              "key": "DFSGSE-FGEAR-GWRTGW",
              "prod": "Bike"
            },
            "store": null
          }
        ],
        "output": [
          {
            "userName": "Anne",
            "storeName": "shop-a57ca0a3-120c-1a73-153b-fa4231cab768"
          }
        ]
      }
    ],
    "identifier": 69176379
  },
  {
    "context": [
      "My intension is to pull value of corresponding key passed as a variable?",
      "jq -r --arg var_name \"$var_name\" '.[$var_name]' <<< \"$temp1\"",
      "echo $temp1 | jq -r '.SSM_DEV_SECRET_KEY'  <----- return Smkfnkhnb48dh // output",
      "echo $temp1 | jq -r '.\"$var_name\"'  <---- return null",
      "echo $temp1 | jq -r --arg var_name \"$var_name\" '.\"$var_name\"'  <---- return null , alternative way",
      "You simply need to remove the single quotes and you'll be good:\n\n    echo $temp1 | jq -r .\"$var_name\"  <---- Does this work?",
      "That said, I would never write my script that way.  I would definitely want to include the '.' in the quoted string like this:\n\n    echo $temp1 | jq -r \".$var_name\"  <---- Does this work?",
      "jq -r --arg var_name \"$var_name\" '.[$var_name]' <<< \"$temp1\""
    ],
    "utterance": "Extract the value for the object key specified by a shell variable whose name is stored in var_name.",
    "expressions": [
      "jq -r --arg var_name \"$var_name\" '.[$var_name]' <<< \"$temp1\"",
      "echo $temp1 | jq -r \".$var_name\"",
      "echo $temp1 | jq -r .\"$var_name\""
    ],
    "data": [
      {
        "input": {
          "SSM_DEV_SECRET_KEY": "Smkfnkhnb48dh",
          "SSM_DEV_GRAPH_DB": "Prod=bolt://neo4j:Grt56@atc.preprod.test.com:7687",
          "SSM_DEV_RDS_DB": "sqlite:////var/local/ecosystem_dashboard/config.db",
          "SSM_DEV_SUPPERUSER_USERNAME": "admin",
          "SSM_DEV_SUPPERUSER_PASSWORD": "9dW6JE8@KH9qiO006"
        },
        "output": "Smkfnkhnb48dh"
      }
    ],
    "identifier": 69179552
  },
  {
    "context": [
      "how can I detect the presence of duplicates in the replicas list? (replicas\":[**5,5**,6]\")",
      "jq '[.partitions[] | select((.replicas | length) != (.replicas | unique | length))]' input.json"
    ],
    "utterance": "Find all partitions where the replicas array contains duplicate values.",
    "expressions": [
      "[.partitions[] | select((.replicas | length) != (.replicas | unique | length))]"
    ],
    "data": [
      {
        "input": {
          "version": 1,
          "partitions": [
            {
              "topic": "mytopic1",
              "partition": 3,
              "replicas": [
                4,
                5
              ],
              "log_dirs": [
                "any",
                "any"
              ]
            },
            {
              "topic": "mytopic1",
              "partition": 1,
              "replicas": [
                5,
                5,
                6
              ],
              "log_dirs": [
                "any",
                "any"
              ]
            },
            {
              "topic": "mytopic2",
              "partition": 2,
              "replicas": [
                6,
                5
              ],
              "log_dirs": [
                "any",
                "any"
              ]
            }
          ]
        },
        "output": [
          {
            "topic": "mytopic1",
            "partition": 1,
            "replicas": [
              5,
              5,
              6
            ],
            "log_dirs": [
              "any",
              "any"
            ]
          }
        ]
      }
    ],
    "identifier": 69187697
  },
  {
    "context": [
      "You have to specify a filter for jq \u2013 just `.` to get the entire input",
      "Once in a variable with whitespace, you must quote the string, else it shows up differently when you print it",
      "var=$(cat /etc/tfe-config/sources/fluent-bit.conf.tpl | jq -R -s '.')",
      "echo \"$var\""
    ],
    "utterance": "Read a file as a single raw string and assign it to a shell variable, preserving all whitespace and special characters.",
    "expressions": [
      "jq -R -s '.'"
    ],
    "data": [
      {
        "input": "[OUTPUT]\n    Name               cloudwatch_logs\n    Match              *\n    region             eu-central-1\n    log_group_name     TFE-LogForwarding\n    log_stream_name    TFE-AllLogs\n",
        "output": "\"[OUTPUT]\\n    Name               cloudwatch_logs\\n    Match              *\\n    region             eu-central-1\\n    log_group_name     TFE-LogForwarding\\n    log_stream_name    TFE-AllLogs\\n\""
      }
    ],
    "identifier": 69192639
  },
  {
    "context": [
      "Given the following JSON input :\n\n```\n{\n  \"hostname\": \"server1.domain.name\\nserver2.domain.name\\n*.gtld.net\",\n  \"protocol\": \"TCP\",\n  \"port\": \"8080\\n8443\\n9500-9510\",\n  \"component\": \"Component1\",\n  \"hostingLocation\": \"DC1\"\n}\n```",
      "I would like to obtain the following JSON output :\n\n```\n{\n  \"hostname\": [\n    \"server1.domain.name\",\n    \"server2.domain.name\",\n    \"*.gtld.net\"\n  ],\n  \"protocol\": \"TCP\",\n  \"port\": [\n    \"8080-8080\",\n    \"8443-8443\",\n    \"9500-9510\"\n  ],\n  \"component\": \"Component1\",\n  \"hostingLocation\": \"DC1\"\n}\n```",
      "That if an individual value in the `port` array does not contain the `-` separator, I then need to add it and then repeat the array value after the `-` separator. For example, `8080` becomes `8080-8080`, `8443` becomes `8443-8443` and so forth.",
      "And finally, that if a value in the `port` array is already of the format `value-value`, I should simply leave it unmodified.",
      "(.hostname, .port) /= \"\\n\" |\n  .port[] |= (split(\"[^\\\\d]\";\"g\") | \"\\(.[0])-\\(.[1]//.[0])\")"
    ],
    "utterance": "Split the hostname and port fields by newlines, and transform each port value: if it is a single number, convert it to 'number-number'; if it is already in the form 'value-value', leave it unchanged.",
    "expressions": [
      "(.hostname, .port) /= \"\\n\" | .port[] |= (split(\"[^\\d]\";\"g\") | \"\\(.[0])-\\(.[1]//.[0])\")"
    ],
    "data": [
      {
        "input": {
          "hostname": "server1.domain.name\nserver2.domain.name\n*.gtld.net",
          "protocol": "TCP",
          "port": "8080\n8443\n9500-9510",
          "component": "Component1",
          "hostingLocation": "DC1"
        },
        "output": {
          "hostname": [
            "server1.domain.name",
            "server2.domain.name",
            "*.gtld.net"
          ],
          "protocol": "TCP",
          "port": [
            "8080-8080",
            "8443-8443",
            "9500-9510"
          ],
          "component": "Component1",
          "hostingLocation": "DC1"
        }
      }
    ],
    "identifier": 69183436
  },
  {
    "context": [
      "I have a file with a json array like this one:",
      "I'd like to output a json object that shows the count of each trait so the end result would include something like",
      "{\n   \"Color 1\": {\n        \"Blue\":2\n   },\n   \"Color 2\":{\n        \"Yellow\":1,\n        \"Red\":1\n   },\n   \"Hair\":{\n        \"Wild\":2\n   }\n}",
      "So to get the result you want, simply add `| add` to the pipeline.",
      "map(.attributes[])\n| group_by(.trait)\n| map( { (.[0].trait):  bow(.[].value) } )",
      "def bow(stream): \n  reduce stream as $word ({}; .[($word|tostring)] += 1);"
    ],
    "utterance": "Show the count of each trait's values, formatted as an object nested by trait name and value counts.",
    "expressions": [
      "def bow(stream): reduce stream as $word ({}; .[($word|tostring)] += 1); map(.attributes[]) | group_by(.trait) | map({ (.[0].trait): bow(.[].value) }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "aaaaa",
            "description": "aaaaa",
            "attributes": [
              {
                "trait": "Color 1",
                "value": "Blue"
              },
              {
                "trait": "Color 2",
                "value": "Yellow"
              },
              {
                "trait": "Hair",
                "value": "Wild"
              }
            ]
          },
          {
            "name": "bbbbb",
            "description": "bbbbbb",
            "attributes": [
              {
                "trait": "Color 1",
                "value": "Blue"
              },
              {
                "trait": "Color 2",
                "value": "Red"
              },
              {
                "trait": "Hair",
                "value": "Wild"
              }
            ]
          }
        ],
        "output": {
          "Color 1": {
            "Blue": 2
          },
          "Color 2": {
            "Yellow": 1,
            "Red": 1
          },
          "Hair": {
            "Wild": 2
          }
        }
      }
    ],
    "identifier": 69185056
  },
  {
    "context": [
      "I want to return the Name, Type & DNSName only.",
      "You'll need `.AliasTarget.DNSName` to get the `.DNSName` **inside** the `.AliasTarget` object:",
      ".ResourceRecordSets[] | \"\\(.Name) \\t\\(.Type) \\t\\(.AliasTarget.DNSName)\"",
      "\"test.example.net. \\tA \\ttest.example.net.us-east-1.elb.amazonaws.com.\""
    ],
    "utterance": "Return the Name, Type, and AliasTarget.DNSName properties for each entry in ResourceRecordSets, formatted as tab-separated values.",
    "expressions": [
      ".ResourceRecordSets[] | \"\\(.Name) \\t\\(.Type) \\t\\(.AliasTarget.DNSName)\""
    ],
    "data": [
      {
        "input": {
          "ResourceRecordSets": [
            {
              "Name": "test.example.net.",
              "Type": "A",
              "AliasTarget": {
                "HostedZoneId": "XXX12345XX54321",
                "DNSName": "test.example.net.us-east-1.elb.amazonaws.com.",
                "EvaluateTargetHealth": false
              }
            }
          ]
        },
        "output": "test.example.net. \tA \ttest.example.net.us-east-1.elb.amazonaws.com."
      }
    ],
    "identifier": 69193083
  },
  {
    "context": [
      "A much simpler and more portable rearticulation of the `jq` part would be\n\n```sh\njq --null-input --rawfile yaml .gitlab-ci.yml '.content=$yaml'\n```",
      "Inside a `Makefile`, obviously double the dollar sign.",
      "The `--rawfile` option was introduced in `jq` 1.6."
    ],
    "utterance": "Create an object with a key 'content' whose value is the contents of .gitlab-ci.yml, preserving all newlines.",
    "expressions": [
      "jq --null-input --rawfile yaml .gitlab-ci.yml '.content=$yaml'"
    ],
    "data": [
      {
        "input": "include:\n  - project: adamcunnington.info/MLG/common\n    file: /cicd/.gitlab-ci-python.yml\n",
        "output": {
          "content": "include:\n  - project: adamcunnington.info/MLG/common\n    file: /cicd/.gitlab-ci-python.yml\n"
        }
      }
    ],
    "identifier": 69197789
  },
  {
    "context": [
      "How can I output the objects from a JSON file which doesn't match in another JSON file.",
      "I want the output from file2 which doesn't match in file1. Example:",
      "The jq minus operator does exactly what you need. Just use `--slurpfile` to get both files into variables:",
      "jq -n --slurpfile file1 file1.json --slurpfile file2 file2.json '$file2[0] - $file1[0]'"
    ],
    "utterance": "Output objects from file2 that do not have exact matches in file1.",
    "expressions": [
      "jq -n --slurpfile file1 file1.json --slurpfile file2 file2.json '$file2[0] - $file1[0]'"
    ],
    "data": [
      {
        "input": [
          {
            "file1": [
              {
                "name": "ABC",
                "age": "23",
                "address": "xyz"
              },
              {
                "name": "DEF",
                "age": "24",
                "address": "pqr"
              }
            ],
            "file2": [
              {
                "name": "ABC",
                "age": "23",
                "address": "xyz"
              },
              {
                "name": "GHI",
                "age": "24",
                "address": "pqr"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "GHI",
            "age": "24",
            "address": "pqr"
          }
        ]
      }
    ],
    "identifier": 69208284
  },
  {
    "context": [
      "I have a JSON object that looks like this:\r\n\r\n\t{\r\n\t\t\"Accounts\": [\r\n\t\t\t{\r\n\t\t\t\t\"Id\": \"1\",\r\n\t\t\t\t\"Name\": \"Joe\",\r\n\t\t\t\t\"Zip\": \"11111\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t\"Id\": \"2\",\r\n\t\t\t\t\"Name\": \"Jack\",\r\n\t\t\t\t\"Zip\": \"22222\"\r\n\t\t\t}\r\n\t\t]\t\r\n\t}\r\n\r\nI am trying to write a `jq` query that gives me this:\r\n\r\n\t[\r\n\t\t{\r\n\t\t\t\"Id\": \"1\",\r\n\t\t\t\"Name\": \"Joe\"\r\n\t\t},\r\n\t\t{\r\n\t\t\t\"Id\": \"2\",\r\n\t\t\t\"Name\": \"Jack\"\r\n\t\t}\t\r\n\t]",
      "jq '.Accounts | map({ Id, Name })'",
      "[.Accounts[] | {Id, Name}]"
    ],
    "utterance": "Extract all objects in the Accounts array with only their Id and Name fields.",
    "expressions": [
      ".Accounts | map({ Id, Name })",
      "[.Accounts[] | {Id, Name}]"
    ],
    "data": [
      {
        "input": {
          "Accounts": [
            {
              "Id": "1",
              "Name": "Joe",
              "Zip": "11111"
            },
            {
              "Id": "2",
              "Name": "Jack",
              "Zip": "22222"
            }
          ]
        },
        "output": [
          {
            "Id": "1",
            "Name": "Joe"
          },
          {
            "Id": "2",
            "Name": "Jack"
          }
        ]
      }
    ],
    "identifier": 69198107
  },
  {
    "context": [
      "I want to remove the empty results ... I don't want test2 to be presented since it's empty.",
      "You could simply append the following to your existing pipeline:\n| select(.services!=[])\n",
      "Or you could rewrite the query:\n.[]\n| [.clusters[].services[] \n   | select(.taskdef[] | .name==\"app\" and .version==\"1.3.2\") \n   | .taskdef[] ] as $services\n| select($services!=[])\n| {profile, $services}\n"
    ],
    "utterance": "Return only objects where the resulting services array contains at least one taskdef with name equal to \"app\" and version equal to \"1.3.2\".",
    "expressions": [
      ".[] | {profile: .profile, services: [.clusters[].services[] | select(.taskdef[] | .name==\"app\" and .version==\"1.3.2\") | .taskdef[] ]} | select(.services != [])",
      ".[] | [.clusters[].services[] | select(.taskdef[] | .name==\"app\" and .version==\"1.3.2\") | .taskdef[] ] as $services | select($services != []) | {profile, $services}"
    ],
    "data": [
      {
        "input": [
          {
            "profile": "test1",
            "clusters": [
              {
                "cluster": "test1-cluster1",
                "services": [
                  {
                    "servicename": "cluster1-service",
                    "taskdef": [
                      {
                        "name": "app",
                        "version": "1.3.3"
                      }
                    ]
                  }
                ]
              },
              {
                "cluster": "test1-cluster2",
                "services": [
                  {
                    "servicename": "cluster2-service",
                    "taskdef": [
                      {
                        "name": "app",
                        "version": "1.3.2"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "profile": "test2",
            "clusters": [
              {
                "cluster": "test2-cluster1",
                "services": [
                  {
                    "servicename": "cluster1-service",
                    "taskdef": [
                      {
                        "name": "app",
                        "version": "1.4.0"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "profile": "test1",
            "services": [
              {
                "name": "app",
                "version": "1.3.2"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 69194523
  },
  {
    "identifier": 69234860
  },
  {
    "context": [
      "I have a JSON file with 100 objects that I would like to convert into separate JSON files, one per each object."
    ],
    "utterance": "Write each element from an array in a file to its own file, naming files by their array index.",
    "expressions": [
      "jq -c '.[]' _metadata.json | split -l 1 --additional-suffix=.json"
    ],
    "identifier": 69230253
  },
  {
    "context": [
      "Can I do both of these operations with just one `jq` command?",
      "jq \\\n    --slurp \\\n    '[ .[0] * .[1] * .[2] ] as $all | .[3].owners as $owners | { \"animals\": $all, \"owners\": $owners }' cats.json dogs.json snakes.json owners.json",
      "Will produce:\n{\n  \"animals\": [\n    {\n      \"cats\": [ ... ],\n      \"dogs\": [ ... ],\n      \"snakes\": [ ... ]\n    }\n  ],\n  \"owners\": [\n    \"peter\",\n    \"william\",\n    \"sally\"\n  ]\n}"
    ],
    "utterance": "Merge cats.json, dogs.json, snakes.json, and owners.json into a single object with 'animals' containing an array of merged animal objects and 'owners' containing the owners array.",
    "expressions": [
      "[ .[0] * .[1] * .[2] ] as $all | .[3].owners as $owners | { \"animals\": $all, \"owners\": $owners }"
    ],
    "data": [
      {
        "input": [
          {
            "cats": [
              {
                "name": "fluffles",
                "age": 10,
                "color": "white"
              }
            ]
          },
          {
            "dogs": [
              {
                "name": "sam",
                "age": 5,
                "color": "black and white"
              },
              {
                "name": "rover",
                "age": 2,
                "color": "brown and white"
              }
            ]
          },
          {
            "snakes": [
              {
                "name": "noodles",
                "age": 10,
                "color": "green"
              }
            ]
          },
          {
            "owners": [
              "peter",
              "william",
              "sally"
            ]
          }
        ],
        "output": {
          "animals": [
            {
              "cats": [
                {
                  "name": "fluffles",
                  "age": 10,
                  "color": "white"
                }
              ],
              "dogs": [
                {
                  "name": "sam",
                  "age": 5,
                  "color": "black and white"
                },
                {
                  "name": "rover",
                  "age": 2,
                  "color": "brown and white"
                }
              ],
              "snakes": [
                {
                  "name": "noodles",
                  "age": 10,
                  "color": "green"
                }
              ]
            }
          ],
          "owners": [
            "peter",
            "william",
            "sally"
          ]
        }
      }
    ],
    "identifier": 69180158
  },
  {
    "context": [
      "I have two JSON arrays.",
      "I want to have a result like this below.",
      "reduce range(0, ($inode[0]|length)) as $d (.; .[$d] += {inode: $inode[0][$d]})",
      "transpose | map(.[0] + {inode: .[1]})"
    ],
    "utterance": "For two input arrays of equal length, append each element of the second array as an 'inode' field to the corresponding object in the first array.",
    "expressions": [
      "reduce range(0, ($inode[0]|length)) as $d (.; .[$d] += {inode: $inode[0][$d]})",
      "-n 'input as $inode | input | reduce range(0, length) as $d (.; .[$d] += {inode: $inode[$d]})'",
      "transpose | map(.[0] + {inode: .[1]})"
    ],
    "data": [
      {
        "input": [
          [
            {
              "date": "2021/9/12",
              "rate": 7,
              "path": "f"
            },
            {
              "date": "2021/9/13",
              "rate": 8,
              "path": "f"
            },
            {
              "date": "2021/9/14",
              "rate": 8,
              "path": "f"
            }
          ],
          [
            "562949953740755",
            "562949953740743",
            "562949953740744"
          ]
        ],
        "output": [
          {
            "date": "2021/9/12",
            "rate": 7,
            "path": "f",
            "inode": "562949953740755"
          },
          {
            "date": "2021/9/13",
            "rate": 8,
            "path": "f",
            "inode": "562949953740743"
          },
          {
            "date": "2021/9/14",
            "rate": 8,
            "path": "f",
            "inode": "562949953740744"
          }
        ]
      }
    ],
    "identifier": 69210892
  },
  {
    "context": [
      "I grouped a curl response by `stickyType` using following command :",
      "`curl <url> | jq 'group_by(.stickyType)' `",
      "Now I want to print it as:",
      "TypeA",
      "1. X",
      "2. Y",
      "",
      "TypeB",
      "1. Z",
      "How can I do that ?",
      "* With numbering:",
      ".[] | (.[0]|.stickyType), (range(0;length) as $i | \"\\($i). \\(.[$i].content)\")"
    ],
    "utterance": "For each group of items, print the group's stickyType once followed by a numbered list of the content values within that group.",
    "expressions": [
      ".[] | (.[0]|.stickyType), (range(0;length) as $i | \"\\($i+1). \\(.[$i].content)\")"
    ],
    "data": [
      {
        "input": [
          [
            {
              "stickyType": "TypeA",
              "content": "X"
            },
            {
              "stickyType": "TypeA",
              "content": "Y"
            }
          ],
          [
            {
              "stickyType": "TypeB",
              "content": "Z"
            }
          ]
        ],
        "output": [
          "TypeA",
          "1. X",
          "2. Y",
          "TypeB",
          "1. Z"
        ]
      }
    ],
    "identifier": 69237892
  },
  {
    "context": [
      "I want the value of the `b` key in the hash to get the value of `.v` below it",
      "with_entries(.value|=if .v? then .v else . end)",
      "outputs:\n{\n  \"a\": null,\n  \"b\": 1,\n  \"c\": null\n}",
      "If you want to keep the structure of you script, add object test :\n\njq -n '\n  {a:\"string\",b:{k:\"k\",v:1},c:12} |\n  with_entries(.value|=(if type == \"object\" and .v? then .v else . end))\n'",
      "'objects' can be used, but on the *left* of '|=', not the right. You want to disregard non-objects from even being updated, rather than trying to replace it with itself if it isn't an object with `v`.",
      "jq -n '\n  {a:\"string\",b:{k:\"k\",v:1},c:12} |\n  with_entries((.value|objects) |= if .v then .v else . end)\n'"
    ],
    "utterance": "Update each key's value to the .v property if it exists and the value is an object; otherwise, leave the value unchanged.",
    "expressions": [
      "with_entries(.value|=(if type == \"object\" and .v? then .v else . end))",
      "with_entries((.value|objects) |= if .v then .v else . end)"
    ],
    "data": [
      {
        "input": {
          "a": "string",
          "b": {
            "k": "k",
            "v": 1
          },
          "c": 12
        },
        "output": {
          "a": "string",
          "b": 1,
          "c": 12
        }
      }
    ],
    "identifier": 69214919
  },
  {
    "context": [
      "I want all the fields from the array `item`, like below:\n\n```\n{...}, # A\n{...}, # B\n{...}  # C\n```",
      "With this, I still avec the squares brackets, at the beginning and the end.",
      "With this, the comma between the fields is removed.",
      "For instance, convert them into strings using `tostring` and glue them together with the `join` builtin:",
      "jq -r '.item | map(tostring) | join(\",\\n\")' collection.json"
    ],
    "utterance": "Print each object in the item array without square brackets, separated by commas and newlines.",
    "expressions": [
      ".item | map(tostring) | join(\",\\n\")"
    ],
    "data": [
      {
        "input": {
          "info": {},
          "item": [
            {
              "foo": 1
            },
            {
              "bar": 2
            },
            {
              "baz": 3
            }
          ]
        },
        "output": "{\n  \"foo\": 1\n},\n{\n  \"bar\": 2\n},\n{\n  \"baz\": 3\n}"
      }
    ],
    "identifier": 69252176
  },
  {
    "context": [
      "this finds the correct item(s):",
      "jq '.items[].rules[]|select(.expression|test(\".*FOO.*\"))' testfile.json",
      "but i need to get the \"name\" : \"test1\" to the output."
    ],
    "utterance": "Return the name of each top-level item whose rules contain an expression with the substring 'FOO'.",
    "expressions": [
      ".items[] | select(.rules[].expression | test(\"FOO\")) | .name"
    ],
    "data": [
      {
        "input": {
          "name": "test1",
          "selfLink": "https://1.2.3.4",
          "items": [
            {
              "name": "test1",
              "rules": [
                {
                  "expression": "expresFOOsion1"
                }
              ]
            },
            {
              "name": "test2",
              "rules": [
                {
                  "expression": "somethingelse"
                }
              ]
            },
            {
              "name": "test3",
              "rules": [
                {
                  "expression": "FOOBAR"
                }
              ]
            }
          ]
        },
        "output": [
          "test1",
          "test3"
        ]
      }
    ],
    "identifier": 69269719
  },
  {
    "context": [
      "I am trying to output the value for .metadata.name followed by the student's name in .spec.template.spec.containers[].students[] array using the regex test() function in jq.",
      "if I check the students[] array if it contains the word \"Jeff\", I would like the output to display as below:\n\n    student-deployment:    Jefferson",
      "I am having trouble to retrieve the individual array value since there is no key specified for the students[] array.",
      "kubectl get deployments -o json | jq -r '.items[] | select(.spec.template.spec.containers[].students[]?|test(\"\\\"^Jeff.\\\"\") ) | .metadata.name, \"\\\":\\t\\\"\", .spec.template.spec.containers[].students'",
      "Now, we iterate over all .item[] elements (i.e. over \"all deployments\"). For each found, we output the content of .metadata.name followed by a literal colon and a space. Then we iterate again over all .spec.template.spec.containers[].students[], perform the pattern test and concatenate the outcome.",
      "kubectl get deployments -o json \\\n| jq --arg pattern \"Jeff\" -r '\n    .items[]\n    | .metadata.name + \": \" + (\n        .spec.template.spec.containers[].students[]\n        | select(test($pattern))\n      )\n  '\n"
    ],
    "utterance": "Print the deployment name followed by each student name matching the pattern 'Jeff' from containers[].students[].",
    "expressions": [
      ".items[] | .metadata.name + \": \" + (.spec.template.spec.containers[].students[] | select(test(\"Jeff\")))"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "apiVersion": "apps/v1",
              "kind": "Deployment",
              "metadata": {
                "name": "student-deployment",
                "namespace": "default"
              },
              "spec": {
                "template": {
                  "spec": {
                    "containers": [
                      {
                        "students": [
                          "Alice",
                          "Bob",
                          "Peter",
                          "Sally",
                          "Jefferson"
                        ]
                      }
                    ]
                  }
                }
              }
            }
          ]
        },
        "output": "student-deployment: Jefferson"
      }
    ],
    "identifier": 69260360
  },
  {
    "context": [
      "input |\njq -R 'split(\"?\")|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3], timeWindow:.[4], numberOfOccurrence:.[5] }'",
      "jq: error: syntax error, unexpected IDENT, expecting '}' (Unix shell quoting issues?) at <top-level>, line 1:\nsplit(\"?\")|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3] timeWindow:.[4], numberOfOccurrence:.[5] }",
      "There is a comma missing between the fields \"description\" and \"timeWindow\".  The `jq` error msg reflects the typo:",
      "Your code example has the comma & works for us!"
    ],
    "utterance": "Parse lines separated by '?' into objects with fields: deviceName, ProcessId, processName, description, timeWindow, numberOfOccurrence.",
    "expressions": [
      "split(\"?\") | { deviceName: .[0], ProcessId: .[1], processName: .[2], description: .[3], timeWindow: .[4], numberOfOccurrence: .[5] }"
    ],
    "data": [
      {
        "input": "BBAOMACBOOKAIR2?976?AMPDeviceDiscoveryAgent[976]:?      - Can't handle disconnect with invalid ecid?0700-0800?8",
        "output": {
          "deviceName": "BBAOMACBOOKAIR2",
          "ProcessId": "976",
          "processName": "AMPDeviceDiscoveryAgent[976]:",
          "description": "      - Can't handle disconnect with invalid ecid",
          "timeWindow": "0700-0800",
          "numberOfOccurrence": "8"
        }
      }
    ],
    "identifier": 69275915
  },
  {
    "context": [
      "I have the **data.txt** file containing below information:\r\n\r\n~~~\r\n611111|22|53|200003|ADD|234566|REMOVE|546768|647|Return|5647|746927|ADD|345677858|REMOVE|546768|64774|Return|5647|2134\r\n611112|24|53|200043|ADD|234576|REMOVE|5467658|647|Return|5687|746927|ADD|445677858|REMOVE|546768|64774|Return|5647|2334\r\n~~~",
      "How can I convert into **.json** file like below :",
      "And like wise for every line.\r\nPlease suggest how we can obtain this using **jq command** or **shell scripting**?",
      "However, if all of them were static as provided in your example, I&#39;d simply go with reading the raw input into an array of lines, split them further into arrays of values, then align them with a static ordered set of paths pointing into the output object, and build them setting the paths to those values accordingly.",
      "jq -Rn '[inputs / \"|\" | [[\r\n      \r\n      [\"ProductId\"],[\"PIDT\"],[\"RPID\"],[\"OfferId\"],\r\n      ((\"Product1\", \"Product2\") as $p |\r\n        [$p, 0] + ([\"Action\"], [\"ProductOfferId\"]),\r\n        [$p, 1] + ([\"Action\"], [\"ProductOfferId\"], [\"RemoveProduct1Instance\"]),\r\n        [$p, 2] + ([\"Action\"], [\"RemoveProduct1Instance\"], [\"ProductOfferId\"])\r\n      )\r\n    \r\n    ],.] | transpose | reduce .[] as $k ({}; setpath($k[0];$k[1]))]' data.txt"
    ],
    "utterance": "Transform delimited lines containing product and action details into objects with ProductId, PIDT, RPID, OfferId, and split structured Product1 and Product2 arrays as shown for each line.",
    "expressions": [
      "jq -Rn '[inputs / \"|\" | [[\n      \n      [\"ProductId\"],[\"PIDT\"],[\"RPID\"],[\"OfferId\"],\n      ((\"Product1\", \"Product2\") as $p |\n        [$p, 0] + ([\"Action\"], [\"ProductOfferId\"]),\n        [$p, 1] + ([\"Action\"], [\"ProductOfferId\"], [\"RemoveProduct1Instance\"]),\n        [$p, 2] + ([\"Action\"], [\"RemoveProduct1Instance\"], [\"ProductOfferId\"])\n      )\n    \n    ],.] | transpose | reduce .[] as $k ({}; setpath($k[0];$k[1]))]' data.txt"
    ],
    "data": [
      {
        "input": "611111|22|53|200003|ADD|234566|REMOVE|546768|647|Return|5647|746927|ADD|345677858|REMOVE|546768|64774|Return|5647|2134",
        "output": {
          "ProductId": "611111",
          "PIDT": "22",
          "RPID": "53",
          "OfferId": "20003",
          "Product1": [
            {
              "Action": "ADD",
              "ProductOfferId": "234566"
            },
            {
              "Action": "REMOVE",
              "ProductOfferId": "546768",
              "RemoveProduct1Instance": "647"
            },
            {
              "Action": "RETURN",
              "RemoveProduct1Instance": "5647",
              "ProductOfferId": "746927"
            }
          ],
          "Product2": [
            {
              "Action": "ADD",
              "NewComponentOfferId": "345677858"
            },
            {
              "Action": "REMOVE",
              "ComponentOfferId": "546768",
              "RemoveProduct2Instance": "64774"
            },
            {
              "Action": "RETURN",
              "RemoveProduct2Instance": "5647",
              "ProductOfferId": "2134"
            }
          ]
        }
      }
    ],
    "identifier": 69268321
  },
  {
    "context": [
      "then you can use the `to_entries` or `with_entries` filters of jq to get an object containing only those keys which start with `\"TEST_\"`:",
      "with_entries(select(.key|startswith(\"TEST_\")))",
      "This will give you a new object as output:",
      "{",
      "  \"TEST_DB_HOSTNAME\": \"10.123.56.222\",",
      "  \"TEST_DB_PORTNUMBER\": 1521,",
      "  \"TEST_USERNAME\": \"TEST\",",
      "  \"TEST_PASSWORD\": \"TEST\",",
      "  \"TEST_SCHEMANAME\": \"SCHEMA\",",
      "  \"TEST_ACTIVEMQNAME\": \"10.123.56.223\",",
      "  \"TEST_ACTIVEMQPORT\": 8161",
      "}"
    ],
    "utterance": "Extract all key-value pairs where the key starts with \"TEST_\".",
    "expressions": [
      "with_entries(select(.key|startswith(\"TEST_\")))"
    ],
    "data": [
      {
        "input": {
          "build.sourceBranchName": "master",
          "build.reason": "Manual",
          "system.pullRequest.isFork": "False",
          "system.jobParallelismTag": "Public",
          "system.enableAccessToken": "SecretVariable",
          "TEST_DB_HOSTNAME": "10.123.56.222",
          "TEST_DB_PORTNUMBER": 1521,
          "TEST_USERNAME": "TEST",
          "TEST_PASSWORD": "TEST",
          "TEST_SCHEMANAME": "SCHEMA",
          "TEST_ACTIVEMQNAME": "10.123.56.223",
          "TEST_ACTIVEMQPORT": 8161
        },
        "output": {
          "TEST_DB_HOSTNAME": "10.123.56.222",
          "TEST_DB_PORTNUMBER": 1521,
          "TEST_USERNAME": "TEST",
          "TEST_PASSWORD": "TEST",
          "TEST_SCHEMANAME": "SCHEMA",
          "TEST_ACTIVEMQNAME": "10.123.56.223",
          "TEST_ACTIVEMQPORT": 8161
        }
      }
    ],
    "identifier": 69288043
  },
  {
    "context": [
      "The source JSON contains emojis as Unicode sequences. How can I output these back as emojis?",
      "echo '{\"content\":\"\\u00f0\\u009f\\u00a4\\u00b7\\u00f0\\u009f\\u008f\\u00bf\\u00e2\\u0080\\u008d\\u00e2\\u0099\\u0082\\u00ef\\u00b8\\u008f\"}' | jq -c '.'",
      "Desired result:\n\n    {\"content\":\"\ud83e\uddd1\ud83c\udfff\u200d\u2642\ufe0f\"}",
      "{ \"content\":\"\\u00f0\\u009f\\u00a4\\u00b7\\u00f0\\u009f\\u008f\\u00bf\\u00e2\\u0080\\u008d\\u00e2\\u0099\\u0082\\u00ef\\u00b8\\u008f\"}\n| .content|= (explode| [utf8_decode] | implode)"
    ],
    "utterance": "Convert a string containing UTF-8-encoded Unicode byte escape sequences (e.g., \\u00f0\\u009f\\u00a4\\u00b7) inside a field into properly rendered emoji characters.",
    "expressions": [
      ".content |= (explode | [utf8_decode] | implode)"
    ],
    "data": [
      {
        "input": {
          "content": "\\u00f0\\u009f\\u00a4\\u00b7\\u00f0\\u009f\\u008f\\u00bf\\u00e2\\u0080\\u008d\\u00e2\\u0099\\u0082\\u00ef\\u00b8\\u008f"
        },
        "output": {
          "content": "\ud83e\uddd1\ud83c\udfff\u200d\u2642\ufe0f"
        }
      }
    ],
    "identifier": 69285688
  },
  {
    "context": [
      "And I'd like to flip it inside out so that for each Department, I have a list of people in it, a la:\n\n    {\n        \"Accounting\": [\n            \"Person A\",\n            \"Person B\"\n        ],\n        \"Production\": [\n            \"Person C\",\n            \"Person D\"\n        ],\n        \"Marketing\": [\n            \"Person E\"\n        ]\n    }",
      "reduce to_entries[] as {$key, $value} ({};\n  .[$value] += [$key]\n)"
    ],
    "utterance": "Group object keys by their shared values, producing an object where each value maps to a list of corresponding keys.",
    "expressions": [
      "reduce to_entries[] as {$key, $value} ({}; .[$value] += [$key])",
      "to_entries | group_by(.value) | map({ (.[0].value): [.[].key] }) | add"
    ],
    "data": [
      {
        "input": {
          "Person A": "Accounting",
          "Person B": "Accounting",
          "Person C": "Production",
          "Person D": "Production",
          "Person E": "Marketing"
        },
        "output": {
          "Accounting": [
            "Person A",
            "Person B"
          ],
          "Production": [
            "Person C",
            "Person D"
          ],
          "Marketing": [
            "Person E"
          ]
        }
      }
    ],
    "identifier": 69289006
  },
  {
    "context": [
      "The first example returns an array:\n\n```shell\n$ echo '{\"my_array\":[{\"id\":1},{\"id\":2}]}' | jq '.my_array'\n[\n  {\n    \"id\": 1\n  },\n  {\n    \"id\": 2\n  }\n]\n\n```",
      "While the second example seems to return _each element of the array_:\n\n\n```shell\n$ echo '{\"my_array\":[{\"id\":1},{\"id\":2}]}' | jq '.my_array[]'\n{\n  \"id\": 1\n}\n{\n  \"id\": 2\n}\n```",
      "First, we create an object from the single array value produced by `.my_array`. The entire array becomes the value of the key `x`.\n\n    % echo '{\"my_array\":[{\"id\":1},{\"id\":2}]}' | jq '{x: .my_array}'\n    {\n      \"x\": [\n        {\n          \"id\": 1\n        },\n        {\n          \"id\": 2\n        }\n      ]\n    }",
      "Next, we create *two* objects, one for each object value produced by `.my_array[]`.\n\n    % echo '{\"my_array\":[{\"id\":1},{\"id\":2}]}' | jq '{x: .my_array[]}'\n    {\n      \"x\": {\n        \"id\": 1\n      }\n    }\n    {\n      \"x\": {\n        \"id\": 2\n      }\n    }"
    ],
    "utterance": "Return all top-level objects inside the my_array field as separate outputs.",
    "expressions": [
      ".my_array[]"
    ],
    "data": [
      {
        "input": {
          "my_array": [
            {
              "id": 1
            },
            {
              "id": 2
            }
          ]
        },
        "output": [
          {
            "id": 1
          },
          {
            "id": 2
          }
        ]
      }
    ],
    "identifier": 69288526
  },
  {
    "context": [
      "{ \"a\": \"jdsdjhsandks\" }",
      "How can I compute modular hash of `a` field using JQ expression?",
      "`jq` does not implement hash functions, you have to export the data, apply an external tool and re-import the hash.",
      "data=\"$(jq -r '.a' input.json)\"",
      "md5sum=\"$(printf '%.32s' \"$(md5sum <<< \"${data}\")\")\"",
      "jq --arg md5sum \"${md5sum}\" '.a_md5 = $md5sum' input.json",
      "jq --arg md5sum \"$( printf '%.32s' \"$( md5sum <<< \"$( jq -r '.a' input.json )\" )\" )\" '.a_md5 = $md5sum' input.json"
    ],
    "utterance": "Compute a hash value of the field 'a', optionally applying modulus, and include it in the output as a new field.",
    "expressions": [
      "jq --arg md5sum \"${md5sum}\" '.a_md5 = $md5sum' input.json"
    ],
    "data": [
      {
        "input": {
          "a": "jdsdjhsandks"
        }
      }
    ],
    "identifier": 69300195
  },
  {
    "context": [
      "The input is the json, the output should be the same json, but only the '/pets' route left in (filtering the \"/pets/{id}\" route out).",
      "We will have a list of probably 20 routes, so would like a solution that is clean and allows me to specify the ~20 routes separately as a variable.",
      "I prefer building a lookup table.",
      "jq '\n   ( [\"/pets\"] | map({ (.): true }) | add ) as $whitelist |\n   .paths |= with_entries(select( $whitelist[.key] ))\n'"
    ],
    "utterance": "Filter the object so only specified paths, such as '/pets', are kept under 'paths' while preserving the rest of the structure.",
    "expressions": [
      "( [\"/pets\"] | map({ (.): true }) | add ) as $whitelist | .paths |= with_entries(select( $whitelist[.key] ))"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "info": {},
          "host": "petstore.swagger.io",
          "basePath": "/api",
          "schemes": [],
          "consumes": [],
          "produces": [],
          "paths": {
            "/pets": {},
            "/pets/{id}": {}
          },
          "definitions": {}
        },
        "output": {
          "swagger": "2.0",
          "info": {},
          "host": "petstore.swagger.io",
          "basePath": "/api",
          "schemes": [],
          "consumes": [],
          "produces": [],
          "paths": {
            "/pets": {}
          },
          "definitions": {}
        }
      }
    ],
    "identifier": 69307846
  },
  {
    "context": [
      "Version_List=$(jq -r  '.items[] .version' \"${projectContent}\")",
      "the ${projectContent} is another variable which is result of curl command",
      "when i run the pipeline this is the error /bin/jq: Argument list too long",
      "Use `jq -Rs . <<< \"${projectContent}\"` to convert the variable content into a JSON string (you may even use `curl` directly, like so: `curl \u2026 | jq -Rs`), then import that string into a jq variable using `--slurpfile` with [Process Substitution][1]"
    ],
    "utterance": "Extract the .version fields from all items in the 'items' array stored in a shell variable containing command output.",
    "expressions": [
      "jq -r '.items[] .version' <<< \"$projectContent\"",
      "echo \"$projectContent\" | jq -r '.items[] .version'"
    ],
    "identifier": 69311166
  },
  {
    "context": [
      "How can I extract the value of each key in each JSON block (as the same row) so that I can use it in another process? ... if [ obj[ValueOfHealthStatus] = \"Healthy\" ] && [ obj[ValueLifeCycleState] = \"InService\" ]; then do_something(obj[ValueOfInstanceId]) ...",
      "jq -sj '.[] | select(.HealthStatus == \"Healthy\" and .LifecycleState == \"InService\") | .InstanceId + \"\\u0000\"' a.json | while IFS= read -r -d '' InstanceID; do echo do_something \"$InstanceID\"; done"
    ],
    "utterance": "Extract the InstanceId for each object where HealthStatus is \"Healthy\" and LifecycleState is \"InService\".",
    "expressions": [
      ".[] | select(.HealthStatus == \"Healthy\" and .LifecycleState == \"InService\") | .InstanceId",
      ".[]|if .HealthStatus==\"Healthy\" and .LifecycleState==\"InService\" then .InstanceId else empty end"
    ],
    "data": [
      {
        "input": [
          {
            "InstanceId": "i-jibberish",
            "HealthStatus": "Healthy",
            "LifecycleState": "InService"
          },
          {
            "InstanceId": "i-another",
            "HealthStatus": "Unhealthy",
            "LifecycleState": "InService"
          },
          {
            "InstanceId": "i-more",
            "HealthStatus": "Healthy",
            "LifecycleState": "Pending"
          }
        ],
        "output": [
          "i-jibberish"
        ]
      }
    ],
    "identifier": 69298128
  },
  {
    "context": [
      "If I have a list like:",
      "{ \"animals\": [ \"wolf\", \"bear\", \"cat\", \"lion\", \"snake\", \"tortise\", \"squirrel\" ] }",
      "and I want to remove \"bear\" from the list.",
      "What if I want to remove a value by it's value name ie \"bear\"?"
    ],
    "utterance": "Remove all elements with value 'bear' from the 'animals' list.",
    "expressions": [
      ".animals |= map(select(. != \"bear\"))"
    ],
    "data": [
      {
        "input": {
          "animals": [
            "wolf",
            "bear",
            "cat",
            "lion",
            "snake",
            "tortise",
            "squirrel"
          ]
        },
        "output": {
          "animals": [
            "wolf",
            "cat",
            "lion",
            "snake",
            "tortise",
            "squirrel"
          ]
        }
      }
    ],
    "identifier": 69324998
  },
  {
    "context": [
      "jq: error (at try4.json:58): Cannot index array with string \"1\"",
      "Use `--argjson` instead of `--arg`. That way your variable `v` becomes a number in `jq`, not a string.",
      "jq --raw-output --argjson v $i '.items.item[$v].request.text' try4.json | base64 --decode | sed '1q;d' | awk '{print $2}'",
      "jq -r '.items[].item.request.text| @base64d | split(\"\\n\")[0] | split(\" \")[1]'"
    ],
    "utterance": "Extract the second word from the first line of each base64-decoded request text field in each item under items[].item.",
    "expressions": [
      "jq -r '.items[].item.request.text | @base64d | split(\"\\n\")[0] | split(\" \")[1]'"
    ],
    "identifier": 69314397
  },
  {
    "context": [
      "I have a bash variable `FPR_LOW` which is a multiline content. I want to convert this variable into JSON string so it can be used with curl.",
      "How can I convert this variable into a JSON string using jq so there is no issue when uploading through curl body?"
    ],
    "utterance": "Convert a multiline shell variable's value to a string with all necessary escaping for safe inclusion as a value inside an HTTP body parameter.",
    "expressions": [
      "jq -Rs . <<< \"$FPR_LOW\""
    ],
    "identifier": 69325868
  },
  {
    "context": [
      "When searching in a json by key i want also to print the key I search by:",
      "When search by \".menu.popup\", actual result:",
      "expected output:",
      "An obvious solution is to prefix output with search key, but I wonder if it is possible to include parent key natively for jq.",
      "Construct a new object rather than simply returning the value associated with the key.",
      "jq '{popup: .menu.popup}' tmp.json",
      "If you want to pass the key as an argument, you can.",
      "jq --arg key popup '{($key): .menu|.[$key])}' tmp.json"
    ],
    "utterance": "Return the 'popup' property from the 'menu' object, but include 'popup' as the key in the output object.",
    "expressions": [
      "{popup: .menu.popup}",
      "--arg key popup '{($key): .menu[$key]}'"
    ],
    "data": [
      {
        "input": {
          "menu": {
            "id": "file",
            "value": "File",
            "popup": {
              "menuitem": [
                {
                  "value": "New",
                  "onclick": "CreateNewDoc()"
                },
                {
                  "value": "Open",
                  "onclick": "OpenDoc()"
                },
                {
                  "value": "Close",
                  "onclick": "CloseDoc()"
                }
              ]
            }
          }
        },
        "output": {
          "popup": {
            "menuitem": [
              {
                "value": "New",
                "onclick": "CreateNewDoc()"
              },
              {
                "value": "Open",
                "onclick": "OpenDoc()"
              },
              {
                "value": "Close",
                "onclick": "CloseDoc()"
              }
            ]
          }
        }
      }
    ],
    "identifier": 69316366
  },
  {
    "context": [
      "How can I convert a multiline variable with special characters into a JSON string using JQ?",
      "The above string variable should be a single JSON string.",
      "Pass the value as a `jq` variable (and tell it not to expect input):",
      "jq -n --arg fpr \"$FPR_LOW\" '$fpr'"
    ],
    "utterance": "Convert the contents of a multiline shell variable with special characters into a single properly quoted JSON string.",
    "expressions": [
      "jq -n --arg fpr \"$FPR_LOW\" '$fpr'"
    ],
    "identifier": 69327062
  },
  {
    "context": [
      "I have an already existing json, in which I have to add a new element to a list element which has a specific key-value pair.",
      "So I would like to have this as result:",
      "{\n  \"parent\": {\n    \"child-list\": [\n      {\n        \"usecase\": \"first\"\n      },\n      {\n        \"usecase\": \"second\",\n        \"result\": \"SUCCESS\"\n      },\n      {\n        \"usecase\": \"third\"\n      }\n    ]\n  }\n}",
      "But it prints only the 'child-list' not the whole json.",
      "Use `|=` instead of `|`. It updates the object rather than just taking it as next input (just like you used `+=` not just `+` later on).",
      "jq '.parent.\"child-list\" |= map(select(.\"usecase\"==\"second\") += { \"result\": \"SUCCESS\" })' base.json"
    ],
    "utterance": "Add a field with value SUCCESS to the element in child-list where usecase is second, preserving the full structure.",
    "expressions": [
      ".parent.\"child-list\" |= map(select(.\"usecase\"==\"second\") += { \"result\": \"SUCCESS\" })"
    ],
    "data": [
      {
        "input": {
          "parent": {
            "child-list": [
              {
                "usecase": "first"
              },
              {
                "usecase": "second"
              },
              {
                "usecase": "third"
              }
            ]
          }
        },
        "output": {
          "parent": {
            "child-list": [
              {
                "usecase": "first"
              },
              {
                "usecase": "second",
                "result": "SUCCESS"
              },
              {
                "usecase": "third"
              }
            ]
          }
        }
      }
    ],
    "identifier": 69344994
  },
  {
    "context": [
      "> are there have any way to achieve simply as expected?",
      "it using combine with permutate in default.",
      "**expression** `[{title:.title[],link:.link[]}]`",
      "**expected**\n```json\n[\n  {\n    \"title\": \"title1\",\n    \"link\": \"http://testapi.cn\"\n  },\n  {\n    \"title\": \"title2\",\n    \"link\": \"http://testapi.org\"\n  }\n]\n```",
      "Use `transpose` to generate an array of arrays with one element of each input array.",
      "[.title,.link] | transpose | map({title:.[0],link:.[1]})"
    ],
    "utterance": "Create a list of objects by pairing elements at matching indices from the 'title' and 'link' arrays.",
    "expressions": [
      "[.title, .link] | transpose | map({title: .[0], link: .[1]})"
    ],
    "data": [
      {
        "input": {
          "title": [
            "title1",
            "title2"
          ],
          "link": [
            "http://testapi.cn",
            "http://testapi.org"
          ]
        },
        "output": [
          {
            "title": "title1",
            "link": "http://testapi.cn"
          },
          {
            "title": "title2",
            "link": "http://testapi.org"
          }
        ]
      }
    ],
    "identifier": 69360712
  },
  {
    "context": [
      "I need to update the value with new value (passed as an input argument to the script) when name exists. If different name and value are given, need to append them as new fields in the end.",
      "If existing values given as user3, aws then it has to update the value of user3 as follows",
      "Take an array of only those elements that do not match (`map(select(.name != $name))`) and unconditionally add an element with the new data to it (`+ [{$name,$value}]`). That way, an existing element gets deleted if and only if it matches, and a new one is added in any case.",
      "If the array is ordered, only a truly new element should be added at the end of the array, while updated elements should be replaced at their original positions within the array.",
      "For this, we don't update the whole array as before (`.environment |= \u2026`), just certain elements that matter (`(.environment | \u2026) |= \u2026`). If there are elements matching the condition (`(.[] | select(.name == $name))`), they matter, otherwise (`//`) the element at position `length` (past the end of the array, thus new, as indices go from `0` to only `length-1`) is the one that matters. Whichever elements get through, they will be updated with the data provided (`|= {$name,$value}`):"
    ],
    "utterance": "Update an object's element with a given name if it exists; otherwise, append a new element with that name and value at the end of the environment array.",
    "expressions": [
      ".environment |= if any(.[]; .name == $updateName) then map(if .name == $updateName then .value = $updateVal else . end) else (. + [{\"name\": $updateName, \"value\": $updateVal}] ) end",
      ".environment |= map(select(.name != $name)) + [{$name,$value}]",
      "(.environment | ((.[] | select(.name == $name)) // .[length])) |= {$name,$value}"
    ],
    "data": [
      {
        "input": {
          "environment": [
            {
              "name": "user1",
              "value": "app"
            },
            {
              "name": "user2",
              "value": "admin"
            },
            {
              "name": "user3",
              "value": "db"
            }
          ]
        },
        "output": {
          "environment": [
            {
              "name": "user1",
              "value": "app"
            },
            {
              "name": "user2",
              "value": "admin"
            },
            {
              "name": "user3",
              "value": "db"
            },
            {
              "name": "user4",
              "value": "root"
            }
          ]
        }
      },
      {
        "input": {
          "environment": [
            {
              "name": "user1",
              "value": "app"
            },
            {
              "name": "user2",
              "value": "admin"
            },
            {
              "name": "user3",
              "value": "db"
            }
          ]
        },
        "output": {
          "environment": [
            {
              "name": "user1",
              "value": "app"
            },
            {
              "name": "user2",
              "value": "admin"
            },
            {
              "name": "user3",
              "value": "aws"
            }
          ]
        }
      }
    ],
    "identifier": 69349328
  },
  {
    "context": [
      "I am trying to format the non json output to look something like:\r\n```\r\nCOMMENT|Petes corner store|201449\r\nSPOT|addr|\\@lbl|LOCKED BAY 222|Sydney|9876\r\nTABLE|Product 1|2|4.62|9.24\r\nTABLE|Prod desc 2|18|0.12|2.16\r\nBREAK\r\nTABLE|Product 3|3|4.00|12.00\r\nBREAK\r\nFLUSH\r\n```",
      "With your input, the following jq program produces results which are very similar to what you indicated is expected:\r\n```\r\n.result[0]\r\n| [\"COMMENT\", .name, .dbno],\r\n  ([\"SPOT\", \"addr\", \"\\\\@lbl\"] + .address),\r\n  ( .segments[].lines[].products[] as $p\r\n   | (([\"TABLE\"] + [$p[]]),\r\n      [\"BREAK\"])),\r\n  [\"FLUSH\"]\r\n\r\n| join(\"|\")\r\n```",
      "With the syntax tips given I was able to create a script that is doing exactly what I require. It has the BREAK lines correctly set only after each line array and it will work with multiple .result records in the array. \r\n```\r\n.result\r\n| keys[] as $c\r\n|\r\n  [\"COMMENT\", (.[$c] | \"\\(.name), \\(.dbno)\" )],\r\n  [\"SPOT\", \"addr\",\"\\\\@lbl\"] + (.[$c].address),\r\n  (\r\n    (.[$c].segments | keys[]) as $s |\r\n\t  (.[$c].segments[$s].lines | keys[]) as $l |\r\n \t    (.[$c].segments[$s].lines[$l].products | keys[]) as $p |\r\n\t\t  (if $p > 0 then [\"BREAK\"] else empty end),\r\n \t\t  [\r\n\t\t    \"TABLE\",\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].name,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].qty,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].price_ea,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].extended\r\n\t\t\t]\r\n  ),\r\n[\"FLUSH\"]\r\n| join(\"|\")\r\n```"
    ],
    "utterance": "Format hierarchical shopping data as delimited plain text lines in a specific order, including comment, address, table row for each product, break between segments, and flush at the end.",
    "expressions": [
      ".result[0]\n| [\"COMMENT\", .name, .dbno],\n  ([\"SPOT\", \"addr\", \"\\\\@lbl\"] + .address),\n  ( .segments[].lines[].products[] as $p\n   | (([\"TABLE\"] + [$p[]]),\n      [\"BREAK\"])),\n  [\"FLUSH\"]\n| join(\"|\")",
      ".result\n| keys[] as $c\n|\n  [\"COMMENT\", (.[$c] | \"\\(.name), \\(.dbno)\" )],\n  [\"SPOT\", \"addr\",\"\\\\@lbl\"] + (.[$c].address),\n  (\n    (.[$c].segments | keys[]) as $s |\n\t  (.[$c].segments[$s].lines | keys[]) as $l |\n      (.[$c].segments[$s].lines[$l].products | keys[]) as $p |\n\t\t  (if $p > 0 then [\"BREAK\"] else empty end),\n      [\n\t\t    \"TABLE\",\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].name,\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].qty,\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].price_ea,\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].extended\n\t\t\t]\n  ),\n[\"FLUSH\"]\n| join(\"|\")"
    ],
    "data": [
      {
        "input": {
          "vers": "2.0",
          "result": [
            {
              "name": "Petes corner store",
              "address": [
                "LOCKED BAY 222",
                "Sydney",
                "9876"
              ],
              "dbno": "201449",
              "segments": [
                {
                  "val": "23.40",
                  "lines": [
                    {
                      "val": "11.40",
                      "products": [
                        {
                          "name": "Product 1",
                          "qty": "2",
                          "price_ea": "4.62",
                          "extended": "9.24"
                        },
                        {
                          "name": "Prod desc 2",
                          "qty": "18",
                          "price_ea": "0.12",
                          "extended": "2.16"
                        }
                      ]
                    }
                  ]
                },
                {
                  "val": "16.00",
                  "lines": [
                    {
                      "val": "16.00",
                      "products": [
                        {
                          "name": "Product 3",
                          "qty": "3",
                          "price_ea": "4.00",
                          "extended": "12.00"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ],
          "id": 1
        },
        "output": "COMMENT|Petes corner store|201449\nSPOT|addr|\\@lbl|LOCKED BAY 222|Sydney|9876\nTABLE|Product 1|2|4.62|9.24\nBREAK\nTABLE|Prod desc 2|18|0.12|2.16\nBREAK\nTABLE|Product 3|3|4.00|12.00\nBREAK\nFLUSH"
      }
    ],
    "identifier": 69356930
  },
  {
    "identifier": 69364553
  },
  {
    "context": [
      "If I *only* want the *complete* `foo` object (removing the outer `valid` key), I can get the desired output by using\n```\n{ foo }\n```",
      "Unfortunately, the documentation doesn't mention any way to get the same behaviour, but for **deeper** keys, using the example above, getting an output object with just the `.foo.bar` object would look something like:  \n```\n{ \"foo\": { \"bar\": .foo.bar } }\n```",
      "Which will generate the following (desired) json output:\n```\n{\n  \"foo\": {\n    \"bar\": {\n      \"value\": 42,\n      \"valid\": true\n    }\n  }\n}\n``` ",
      "Is there any short-cut alternative for the above selector to get the same result?\n\nIdeally I'd use something like:\n```\n{ foo.bar }\n```",
      "Not exactly a short-cut alternative, but the path functions can be used for this.",
      "Here is (quite literally) a shorter alternative that's also DRYer, though I don't think it's any clearer:\n\n    {foo} | .foo |= {bar}"
    ],
    "utterance": "Extract a nested object with only the '.foo.bar' path, omitting all other keys and values at the same and higher levels.",
    "expressions": [
      "{ \"foo\": { \"bar\": .foo.bar } }",
      "{foo} | .foo |= {bar}"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": {
              "value": 42,
              "valid": true
            },
            "valid": false
          },
          "valid": false
        },
        "output": {
          "foo": {
            "bar": {
              "value": 42,
              "valid": true
            }
          }
        }
      }
    ],
    "identifier": 69362748
  },
  {
    "context": [
      "And I hope jq can ignore the 3rd line and continue, just like this:\n\n< snippet2.json jq -C -r '.message'\nsent send binary to ws server1\nsent send binary to ws server2\nsent send binary to ws server4\nsent send binary to ws server5",
      "To skip the broken lines you could use:\n\n    jq -Rr 'fromjson? | .message'",
      "Solution #1:\n\n\u276f cat bad.json | jq -r -R 'fromjson? | .message'\nsent send binary to ws server1\nsent send binary to ws server2\nsent send binary to ws server4\nsent send binary to ws server5",
      "It\u2019s notable that it -R and -r can be used together. (Thanks for @peak !)"
    ],
    "utterance": "Extract the value of the field 'message' from each line, skipping lines that cannot be parsed.",
    "expressions": [
      "jq -Rr 'fromjson? | .message'"
    ],
    "data": [
      {
        "input": "{\n  \"level\": \"debug\",\n  \"time\": \"2021-09-24T19:42:47.140+0800\",\n  \"message\": \"sent send binary to ws server1\",\n  \"pid\": 41491,\n  \"cid\": \"32likw\",\n  \"num\": 1,\n  \"count\": 5120\n}\n{\n  \"level\": \"debug\",\n  \"time\": \"2021-09-24T19:42:47.305+0800\",\n  \"message\": \"sent send binary to ws server2\",\n  \"pid\": 41491,\n  \"cid\": \"32likw\",\n  \"num\": 1,\n  \"count\": 5120\n}\n{\n  \"level\": \"debug\",\n  \"time\": \"2021-09-24T19:42:47.469+0800\",\n  \"message\": \"sent send binary to ws server3\",\n  \"pi\n{\n  \"level\": \"debug\",\n  \"time\": \"2021-09-24T19:42:47.499+0800\",\n  \"message\": \"sent send binary to ws server4\",\n  \"pid\": 41491,\n  \"cid\": \"32likw\",\n  \"num\": 1,\n  \"count\": 5120\n}\n{\n  \"level\": \"debug\",\n  \"time\": \"2021-09-24T19:42:47.581+0800\",\n  \"message\": \"sent send binary to ws server5\",\n  \"pid\": 41491,\n  \"cid\": \"32likw\",\n  \"num\": 1,\n  \"count\": 5120\n}\n",
        "output": "sent send binary to ws server1\nsent send binary to ws server2\nsent send binary to ws server4\nsent send binary to ws server5"
      }
    ],
    "identifier": 69333650
  },
  {
    "context": [
      "I need to remove parents: action1, action2, action3, action4 and preserve their children as join, is there a way to do that in jq ?",
      "Will generate",
      "{\n  \"service1\": [\n    \"example1\",\n    \"example2\",\n    \"example3\",\n    \"example4\"\n  ],\n  \"service2\": [\n    \"example5\",\n    \"example6\",\n    \"example7\",\n    \"example8\"\n  ]\n}"
    ],
    "utterance": "For each top-level service, merge all child action arrays into a single array such that only the service names map to the combined arrays.",
    "expressions": [
      ".[] |= add"
    ],
    "data": [
      {
        "input": {
          "service1": {
            "action1": [
              "example1"
            ],
            "action2": [
              "example2",
              "example3",
              "example4"
            ]
          },
          "service2": {
            "action3": [
              "example5"
            ],
            "action4": [
              "example6",
              "example7",
              "example8"
            ]
          }
        },
        "output": {
          "service1": [
            "example1",
            "example2",
            "example3",
            "example4"
          ],
          "service2": [
            "example5",
            "example6",
            "example7",
            "example8"
          ]
        }
      }
    ],
    "identifier": 69368460
  },
  {
    "context": [
      "I have this json data:",
      "I have been trying (but failing) to sort this by the \"seconds\" value.",
      "I&#39;ve tried `jq &#39;.results[].request.path.time|=sort_by(.seconds)&#39; output.json` and it gives me the error `Cannot index number with string \"seconds\"`.",
      "Sort the array instead:",
      "jq &#39;.results |= sort_by(.request.path.time.seconds)&#39; output.json"
    ],
    "utterance": "Sort the results array by the value of request.path.time.seconds.",
    "expressions": [
      ".results |= sort_by(.request.path.time.seconds)"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "request": {
                "metric": "CLOUDFREE_TIME_PERCENT",
                "path": {
                  "fromPoint": {
                    "pointX": -94.2802,
                    "pointY": 23.6687,
                    "pointZ": 564843.0
                  },
                  "time": {
                    "seconds": 1582074350
                  },
                  "toPoint": {
                    "pointX": -118.2258,
                    "pointY": 33.7501,
                    "pointZ": -2.6077032e-08
                  }
                },
                "waveLength": 0
              },
              "response": {
                "dataSources": [],
                "metricValue": 0.0,
                "success": false
              }
            },
            {
              "request": {
                "metric": "CLOUDFREE_TIME_PERCENT",
                "path": {
                  "fromPoint": {
                    "pointX": -20.6361,
                    "pointY": 16.1509,
                    "pointZ": 563070.9
                  },
                  "time": {
                    "seconds": 1582056949
                  },
                  "toPoint": {
                    "pointX": -20.6361,
                    "pointY": 16.1509,
                    "pointZ": 563070.9
                  }
                },
                "waveLength": 0
              },
              "response": {
                "dataSources": [],
                "metricValue": 0.0,
                "success": false
              }
            },
            {
              "request": {
                "metric": "CLOUDFREE_TIME_PERCENT",
                "path": {
                  "fromPoint": {
                    "pointX": -94.2661,
                    "pointY": 23.6066,
                    "pointZ": 564826.16
                  },
                  "time": {
                    "seconds": 1582064349
                  },
                  "toPoint": {
                    "pointX": -118.2258,
                    "pointY": 33.7501,
                    "pointZ": -2.6077032e-08
                  }
                },
                "waveLength": 0
              },
              "response": {
                "dataSources": [],
                "metricValue": 0.0,
                "success": false
              }
            }
          ]
        },
        "output": {
          "results": [
            {
              "request": {
                "metric": "CLOUDFREE_TIME_PERCENT",
                "path": {
                  "fromPoint": {
                    "pointX": -20.6361,
                    "pointY": 16.1509,
                    "pointZ": 563070.9
                  },
                  "time": {
                    "seconds": 1582056949
                  },
                  "toPoint": {
                    "pointX": -20.6361,
                    "pointY": 16.1509,
                    "pointZ": 563070.9
                  }
                },
                "waveLength": 0
              },
              "response": {
                "dataSources": [],
                "metricValue": 0.0,
                "success": false
              }
            },
            {
              "request": {
                "metric": "CLOUDFREE_TIME_PERCENT",
                "path": {
                  "fromPoint": {
                    "pointX": -94.2661,
                    "pointY": 23.6066,
                    "pointZ": 564826.16
                  },
                  "time": {
                    "seconds": 1582064349
                  },
                  "toPoint": {
                    "pointX": -118.2258,
                    "pointY": 33.7501,
                    "pointZ": -2.6077032e-08
                  }
                },
                "waveLength": 0
              },
              "response": {
                "dataSources": [],
                "metricValue": 0.0,
                "success": false
              }
            },
            {
              "request": {
                "metric": "CLOUDFREE_TIME_PERCENT",
                "path": {
                  "fromPoint": {
                    "pointX": -94.2802,
                    "pointY": 23.6687,
                    "pointZ": 564843.0
                  },
                  "time": {
                    "seconds": 1582074350
                  },
                  "toPoint": {
                    "pointX": -118.2258,
                    "pointY": 33.7501,
                    "pointZ": -2.6077032e-08
                  }
                },
                "waveLength": 0
              },
              "response": {
                "dataSources": [],
                "metricValue": 0.0,
                "success": false
              }
            }
          ]
        }
      }
    ],
    "identifier": 69364864
  },
  {
    "context": [
      "How to get a city name specifying the name of a language with the additional condition of \"spoken\" or \"perhaps\"?",
      "Input: en; Output: Paris, London, Moscow",
      "Input: fr; Output: Paris, London",
      "Input: ru; Output: Moscow",
      "retain only those objects that do match your conditions (in the `.value`'s object `.language` the value of a field `$lang` provided as input variable using `--arg` equals any one of `\"spoken\"` or `\"perhaps\"`) and output the original entry's `.key`.",
      "jq -r --arg lang \"fr\" '\n  \n  to_entries[]\n  | select([.value.language[$lang] == (\"spoken\",\"perhaps\")] | any)\n  | .key\n\n' input.json"
    ],
    "utterance": "List city names where the specified language has a value of either \"spoken\" or \"perhaps\".",
    "expressions": [
      "to_entries[] | select([.value.language[$lang] == (\"spoken\",\"perhaps\")] | any) | .key"
    ],
    "data": [
      {
        "input": {
          "Paris": {
            "language": {
              "fr": "spoken",
              "en": "perhaps"
            }
          },
          "London": {
            "language": {
              "en": "spoken",
              "fr": "perhaps",
              "ru": "unused"
            }
          },
          "Moscow": {
            "language": {
              "ru": "spoken",
              "en": "perhaps",
              "fr": "unused"
            }
          }
        },
        "output": [
          {
            "lang": "en",
            "result": [
              "Paris",
              "London",
              "Moscow"
            ]
          },
          {
            "lang": "fr",
            "result": [
              "Paris",
              "London"
            ]
          },
          {
            "lang": "ru",
            "result": [
              "Moscow"
            ]
          }
        ]
      }
    ],
    "identifier": 69368874
  },
  {
    "context": [
      "I want to parse the data with **jq** tool in **streaming mode**(do not load the whole file into memory), because the **real data have 20GB**",
      "The final result I hope it can become as below\n\nA list contains two dict, each dict contain 2 keys",
      "The following produces the required output:\n```\njq -n --stream '\n  [{data: fromstream(5|truncate_stream(inputs))}]\n' input.json \n```",
      "Here's a solution that does not use `truncate_stream`:\n```\njq -n --stream '\n [fromstream( \n   inputs\n   | (.[0] | index(\"data\")) as $ix\n   | select($ix)\n   | .[0] |= .[$ix:] )]\n' input.json\n```",
      "Now all we need to do is convert this stream back to json.\n\nhttps://jqplay.org/s/j2uyzEU_Rc\n\n`[fromstream(inputs)]` gives:\n\n```\n[\n  {\n    \"data\": [\n      {\n        \"time\": \"2021-01-01\",\n        \"value\": 1\n      },\n      {\n        \"time\": \"2021-01-02\",\n        \"value\": 10\n      },\n      {\n        \"time\": \"2021-01-03\",\n        \"value\": 5\n      }\n    ]\n  },\n  {\n    \"data\": [\n      {\n        \"time\": \"2021-01-01\",\n        \"value\": 10\n      },\n      {\n        \"time\": \"2021-01-02\",\n        \"value\": 100\n      },\n      {\n        \"time\": \"2021-01-03\",\n        \"value\": 50\n      }\n    ]\n  }\n]\n```"
    ],
    "utterance": "Extract all objects under tooldatareports[].tooldata[] and output a list each containing their data array, processing in streaming mode without loading the entire file into memory.",
    "expressions": [
      "jq -n --stream '[fromstream( inputs | (.[0] | index(\"data\")) as $ix | select($ix) | .[0] |= .[$ix:] )]' input.json",
      "jq -n --stream '[{data: fromstream(5|truncate_stream(inputs))}]' input.json"
    ],
    "data": [
      {
        "input": {
          "id": {
            "bioguide": "E000295",
            "thomas": "02283",
            "govtrack": 412667,
            "opensecrets": "N00035483",
            "lis": "S376"
          },
          "bio": {
            "gender": "F",
            "birthday": "1970-07-01"
          },
          "tooldatareports": [
            {
              "name": "A",
              "tooldata": [
                {
                  "toolid": 12345,
                  "data": [
                    {
                      "time": "2021-01-01",
                      "value": 1
                    },
                    {
                      "time": "2021-01-02",
                      "value": 10
                    },
                    {
                      "time": "2021-01-03",
                      "value": 5
                    }
                  ]
                },
                {
                  "toolid": 12346,
                  "data": [
                    {
                      "time": "2021-01-01",
                      "value": 10
                    },
                    {
                      "time": "2021-01-02",
                      "value": 100
                    },
                    {
                      "time": "2021-01-03",
                      "value": 50
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "data": [
              {
                "time": "2021-01-01",
                "value": 1
              },
              {
                "time": "2021-01-02",
                "value": 10
              },
              {
                "time": "2021-01-03",
                "value": 5
              }
            ]
          },
          {
            "data": [
              {
                "time": "2021-01-01",
                "value": 10
              },
              {
                "time": "2021-01-02",
                "value": 100
              },
              {
                "time": "2021-01-03",
                "value": 50
              }
            ]
          }
        ]
      }
    ],
    "identifier": 69047630
  },
  {
    "context": [
      "From the entries array, I actually only need:",
      "- entries.sys.id",
      "- entries.sys.contentType.sys.id",
      "- entries.fields",
      "How can I keep the .entries node in the outfile?",
      "We can achieve this by using the following JQ selector:",
      ".entries |= map({ \"sys\": { \"id\": .sys.id }, \"contentType\": { \"sys\": { \"id\": .sys.contentType.sys.id } }, fields })"
    ],
    "utterance": "Retain only id from each object's sys, id from sys.contentType.sys, and the fields object for all entries, while preserving the entries array structure at the top level.",
    "expressions": [
      ".entries |= map({ \"sys\": { \"id\": .sys.id }, \"contentType\": { \"sys\": { \"id\": .sys.contentType.sys.id } }, fields })"
    ],
    "data": [
      {
        "input": {
          "entries": [
            {
              "metadata": {
                "tags": []
              },
              "sys": {
                "space": {
                  "sys": {
                    "type": "Link",
                    "linkType": "Space",
                    "id": "9kn72w8zc6fh"
                  }
                },
                "id": "vcLKKhJ3mZNfGMvVZZi07",
                "type": "Entry",
                "createdAt": "2021-05-20T15:14:01.358Z",
                "updatedAt": "2021-09-20T15:28:30.799Z",
                "environment": {
                  "sys": {
                    "id": "production",
                    "type": "Link",
                    "linkType": "Environment"
                  }
                },
                "publishedVersion": 47,
                "publishedAt": "2021-09-20T15:28:30.799Z",
                "firstPublishedAt": "2021-05-25T10:26:56.722Z",
                "createdBy": {
                  "sys": {
                    "type": "Link",
                    "linkType": "User",
                    "id": "6F84RwUIY9cXNNXBoQemqX"
                  }
                },
                "updatedBy": {
                  "sys": {
                    "type": "Link",
                    "linkType": "User",
                    "id": "6F84RwUIY9cXNNXBoQemqX"
                  }
                },
                "publishedCounter": 4,
                "version": 48,
                "publishedBy": {
                  "sys": {
                    "type": "Link",
                    "linkType": "User",
                    "id": "6F84RwUIY9cXNNXBoQemqX"
                  }
                },
                "contentType": {
                  "sys": {
                    "type": "Link",
                    "linkType": "ContentType",
                    "id": "page"
                  }
                }
              },
              "fields": {
                "title": {
                  "de-DE": "Startseite",
                  "en-US": "Home"
                },
                "description": {
                  "en-US": "foo"
                },
                "keywords": {
                  "en-US": "bar"
                },
                "stageModules": {
                  "en-US": [
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "11AfBBuNK8bx3EygAS3WTY"
                      }
                    }
                  ]
                },
                "contentModules": {
                  "en-US": [
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "7uyuyIBsXWApHqpR7Pgkac"
                      }
                    },
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "4HILHPLjqQkP2H1hA2FeBG"
                      }
                    },
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "QuwRHL3XMSkguqrL1hUzC"
                      }
                    },
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "4ZyVef5oWhQWXK9V1lr3vz"
                      }
                    }
                  ]
                },
                "layout": {
                  "en-US": "Wide"
                }
              }
            }
          ]
        },
        "output": {
          "entries": [
            {
              "sys": {
                "id": "vcLKKhJ3mZNfGMvVZZi07"
              },
              "contentType": {
                "sys": {
                  "id": "page"
                }
              },
              "fields": {
                "title": {
                  "de-DE": "Startseite",
                  "en-US": "Home"
                },
                "description": {
                  "en-US": "foo"
                },
                "keywords": {
                  "en-US": "bar"
                },
                "stageModules": {
                  "en-US": [
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "11AfBBuNK8bx3EygAS3WTY"
                      }
                    }
                  ]
                },
                "contentModules": {
                  "en-US": [
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "7uyuyIBsXWApHqpR7Pgkac"
                      }
                    },
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "4HILHPLjqQkP2H1hA2FeBG"
                      }
                    },
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "QuwRHL3XMSkguqrL1hUzC"
                      }
                    },
                    {
                      "sys": {
                        "type": "Link",
                        "linkType": "Entry",
                        "id": "4ZyVef5oWhQWXK9V1lr3vz"
                      }
                    }
                  ]
                },
                "layout": {
                  "en-US": "Wide"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 69362205
  },
  {
    "context": [
      "How do I use [jq](https://stedolan.github.io/jq/) to convert an **arbitrary** JSON array of objects to CSV, while objects in this array are **nested**?",
      "a generic solution that\n\n1) includes a header row,\n2) works for any JSON input including nested arrays + objects,\n3) allows records that have missing values for keys that are present in other records\n4) does not hard-code any field names,\n5) allows converting the CSV back into the nested JSON structure if needed, and\n6) uses key paths as header names (see the following description).",
      "Here is the `jq` call to convert your array of nested JSON objects to CSV:\n\n```bash\njq -r '(. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | map(tostring) | join(\".\")))] + $rows) | map(@csv) | .[]\n```",
      "The CSV output will have a header row. It will contain all properties that exist anywhere in the input objects, including nested ones, in dot notation. Each input array element will be represented as a single row, properties that are missing will be represented as empty CSV fields.",
      "The output should have a header that includes all fields (even if the object at the first array does not have defined values for all existing key paths).",
      "cat example.json | jq -r '(. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | map(tostring) | join(\".\")))] + $rows) | map(@csv) | .[]'",
      "An example of a key path like this would be `\"a.b.0.c\"` to refer to the deeply nested property",
      "The expected output should look like this:\n\n```csv\n\"a.b.0.c\",\"a.b.0.d\"\n123,\n\"foo \"\" bar\",\"qux\"\n,456\n```"
    ],
    "utterance": "Convert an array of nested objects to CSV where the header row uses dot notation for all key paths, without hardcoding field names, and missing values are represented as empty fields.",
    "expressions": [
      "(. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | map(tostring) | join(\".\")))] + $rows) | map(@csv) | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "a": {
              "b": [
                {
                  "c": 123
                }
              ]
            }
          },
          {
            "a": {
              "b": [
                {
                  "c": "foo \" bar",
                  "d": "qux"
                }
              ]
            }
          },
          {
            "a": {
              "b": [
                {
                  "d": 456
                }
              ]
            }
          }
        ],
        "output": [
          "\"a.b.0.c\",\"a.b.0.d\"",
          "123,",
          "\"foo \"\" bar\",\"qux\"",
          ",456"
        ]
      }
    ],
    "identifier": 69230818
  },
  {
    "context": [
      "Below is my expected result",
      "Assuming the input has been corrected, the following \"regular\" jq program produces the desired result:",
      "[\n .jobname\n | (.keys + .toolJobs[].keys) as $one\n | .toolJobs[]\n | .keys as $two\n | .reports[]\n | (.keys + .property) as $three\n | .datas[]\n | (.keys + {data}) as $four\n | $one + $two + $three + $four\n]"
    ],
    "utterance": "Extract a flat list of objects containing jobid, car, toolid, oiltype, oilcountry, reportid, areaid, and data for each data record in the nested structure.",
    "expressions": [
      "[\n .jobname\n | (.keys + .toolJobs[].keys) as $one\n | .toolJobs[]\n | .keys as $two\n | .reports[]\n | (.keys + .property) as $three\n | .datas[]\n | (.keys + {data}) as $four\n | $one + $two + $three + $four\n]"
    ],
    "data": [
      {
        "input": {
          "jobname": {
            "keys": {
              "jobid": "E000295",
              "car": "BMW"
            },
            "property": {
              "doctype": "File",
              "areadesc": [
                {
                  "areaid": "qaz",
                  "weather": "hot"
                },
                {
                  "areaid": "wsx",
                  "weather": "code"
                },
                {
                  "areaid": "edc",
                  "weather": "hot"
                },
                {
                  "areaid": "rfv",
                  "weather": "hot"
                }
              ]
            },
            "toolJobs": [
              {
                "keys": {
                  "toolid": "123"
                },
                "reports": [
                  {
                    "keys": {
                      "oiltype": "a",
                      "oilcountry": "us"
                    },
                    "property": {
                      "reportid": "001"
                    },
                    "datas": [
                      {
                        "keys": {
                          "areaid": "qaz"
                        },
                        "data": [
                          {
                            "time": "2021-01-01",
                            "value": 1
                          },
                          {
                            "time": "2021-01-02",
                            "value": 3
                          }
                        ]
                      },
                      {
                        "keys": {
                          "areaid": "wsx"
                        },
                        "data": [
                          {
                            "time": "2021-01-03",
                            "value": 5
                          },
                          {
                            "time": "2021-01-04",
                            "value": 7
                          }
                        ]
                      }
                    ]
                  },
                  {
                    "keys": {
                      "oiltype": "b",
                      "oilcountry": "china"
                    },
                    "property": {
                      "reportid": "002"
                    },
                    "datas": [
                      {
                        "keys": {
                          "areaid": "edc"
                        },
                        "data": [
                          {
                            "time": "2021-01-05",
                            "value": 2
                          },
                          {
                            "time": "2021-01-06",
                            "value": 4
                          }
                        ]
                      },
                      {
                        "keys": {
                          "areaid": "rfv"
                        },
                        "data": [
                          {
                            "time": "2021-01-07",
                            "value": 6
                          },
                          {
                            "time": "2021-01-08",
                            "value": 8
                          }
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": [
          {
            "jobid": "E000295",
            "car": "BMW",
            "toolid": "123",
            "oiltype": "a",
            "oilcountry": "us",
            "reportid": "001",
            "areaid": "qaz",
            "data": [
              {
                "time": "2021-01-01",
                "value": 1
              },
              {
                "time": "2021-01-02",
                "value": 3
              }
            ]
          },
          {
            "jobid": "E000295",
            "car": "BMW",
            "toolid": "123",
            "oiltype": "a",
            "oilcountry": "us",
            "reportid": "001",
            "areaid": "wsx",
            "data": [
              {
                "time": "2021-01-03",
                "value": 5
              },
              {
                "time": "2021-01-04",
                "value": 7
              }
            ]
          },
          {
            "jobid": "E000295",
            "car": "BMW",
            "toolid": "123",
            "oiltype": "b",
            "oilcountry": "china",
            "reportid": "002",
            "areaid": "edc",
            "data": [
              {
                "time": "2021-01-05",
                "value": 2
              },
              {
                "time": "2021-01-06",
                "value": 4
              }
            ]
          },
          {
            "jobid": "E000295",
            "car": "BMW",
            "toolid": "123",
            "oiltype": "b",
            "oilcountry": "china",
            "reportid": "002",
            "areaid": "rfv",
            "data": [
              {
                "time": "2021-01-07",
                "value": 6
              },
              {
                "time": "2021-01-08",
                "value": 8
              }
            ]
          }
        ]
      }
    ],
    "identifier": 69085255
  },
  {
    "context": [
      "I have the below json file and I'm trying to parse a particular field from it using jq",
      "jq '.[].value.health' vm_services.json",
      "jq: error (at vm_services.json:432): Cannot index array with string \"value\"",
      "jq '.[] | .value.health' vm_services.json",
      "jq: error (at vm_services.json:432): Cannot index array with string \"value\"",
      "Your JSON starts with:",
      "{",
      "  \"value\": [",
      "This indicates that you're dealing with an object.",
      "To do so, you'll need to select the first `value` key, then use that as an array.",
      "jq '.value[].value.health' tst.input",
      "Will produce:",
      "\"HEALTHY\"",
      "\"HEALTHY\"",
      "null"
    ],
    "utterance": "Extract each health field from every array element under the value key, even if some elements do not have health defined.",
    "expressions": [
      ".value[].value.health"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "value": {
                "name_key": "cis.analytics.ServiceName",
                "startup_type": "AUTOMATIC",
                "health_messages": [],
                "health": "HEALTHY",
                "description_key": "cis.analytics.ServiceDescription",
                "state": "STARTED"
              },
              "key": "analytics"
            },
            {
              "value": {
                "name_key": "cis.imagebuilder.ServiceName",
                "startup_type": "MANUAL",
                "description_key": "cis.imagebuilder.ServiceDescription",
                "state": "STOPPED"
              },
              "key": "imagebuilder"
            }
          ]
        },
        "output": [
          "HEALTHY",
          null
        ]
      }
    ],
    "identifier": 69316726
  }
]