[
  {
    "context": [
      "I have a log file with each line being a json object. I want to view the log lines as pretty json while being able to tail the logs, with maybe `tail` or `less`.",
      "tail -f jsonlines.log | jq \".\"",
      "tail -f logfile | jq ."
    ],
    "utterance": "Continuously display each new line from a growing file as formatted output as soon as it is appended and matches an object per line.",
    "expressions": [
      "tail -f jsonlines.log | jq ."
    ],
    "identifier": 66894559
  },
  {
    "context": [
      "Is there no way to use select while walking through json with something like ```jq '. | select(.techniques[].tactic == \"impact\")'```?",
      "desired output\n```\n{\n  \"viewMode\": 0,\n  \"hideDisabled\": false,\n  \"techniques\": [\n    {\n      \"name\": \"jane\",\n      \"tactic\": \"impact\"\n    }\n  ],\n  \"karma\": \"yes\"\n}\n```",
      "`|=` is your friend, e.g.\n\n    .techniques |= map(select(.tactic == \"impact\"))"
    ],
    "utterance": "Filter techniques to include only those with tactic equal to \"impact\", while preserving all other top-level fields and structure.",
    "expressions": [
      ".techniques |= map(select(.tactic == \"impact\"))"
    ],
    "data": [
      {
        "input": {
          "viewMode": 0,
          "hideDisabled": false,
          "techniques": [
            {
              "name": "john",
              "tactic": "reconnaissance"
            },
            {
              "name": "jane",
              "tactic": "impact"
            },
            {
              "name": "jill",
              "tactic": "execution"
            }
          ],
          "karma": "yes"
        },
        "output": {
          "viewMode": 0,
          "hideDisabled": false,
          "techniques": [
            {
              "name": "jane",
              "tactic": "impact"
            }
          ],
          "karma": "yes"
        }
      }
    ],
    "identifier": 66874366
  },
  {
    "context": [
      "Sample Input:",
      "[{\"name\":\"Student1\",\"value\":\"John\"},{\"name\":\"Student2\",\"value\":\"Jack\"},{\"name\":\"Student3\",\"value\":\"Nick\"},{\"name\":\"Student4\",\"value\":\"Karen\"},{\"name\":\"Student5\",\"value\":\"Jonas\"}]",
      "Expected Output:",
      "Student1:John",
      "Student2:Jack",
      "Student3:Nick",
      "Student4:Karen",
      "Student5:Jonas",
      "You are only missing the additional flag `--raw-output` for jq.",
      "The command should look like",
      "jq --raw-output '.[] | [.name, .value] | join(\":\")' file.json"
    ],
    "utterance": "Output each object's name and value separated by a colon, one per line, with no spaces after the colon.",
    "expressions": [
      ".[] | [.name, .value] | join(\":\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Student1",
            "value": "John"
          },
          {
            "name": "Student2",
            "value": "Jack"
          },
          {
            "name": "Student3",
            "value": "Nick"
          },
          {
            "name": "Student4",
            "value": "Karen"
          },
          {
            "name": "Student5",
            "value": "Jonas"
          }
        ],
        "output": "Student1:John\nStudent2:Jack\nStudent3:Nick\nStudent4:Karen\nStudent5:Jonas"
      }
    ],
    "identifier": 66894756
  },
  {
    "context": [
      "gc listen | jq -c '.eventBody.group.queueId'",
      "if i save that on a file, and do : type test.txt | jq -c '.eventBody.group.queueId' i can get the queueId. And if i save multiple output of the first command, i got multiple id. no problem.",
      "BUT when i try both on the same time, i don't have anything : gc listen | jq -c '.eventBody.group.queueId'"
    ],
    "utterance": "Extract the value of eventBody.group.queueId from each streamed object in the pipeline.",
    "expressions": [
      ".eventBody.group.queueId"
    ],
    "data": [
      {
        "input": {
          "topicName": "v2.analytics.queues.fzef-9208-4078-b012-fzegzeg.observations",
          "version": "2",
          "eventBody": {
            "group": {
              "queueId": "fzef-9208-4078-b012-fzegzeg",
              "mediaType": "voice"
            },
            "data": [
              {
                "interval": "2021-03-30T09:00:00.000Z/2021-03-30T09:30:00.000Z",
                "metrics": [
                  {
                    "metric": "nConnected",
                    "stats": {
                      "count": 1.0
                    }
                  },
                  {
                    "metric": "tAbandon",
                    "stats": {
                      "count": 3.0,
                      "sum": 184416.0,
                      "min": 41981.0,
                      "max": 89420.0
                    }
                  },
                  {
                    "metric": "tHeldComplete",
                    "stats": {
                      "count": 12.0,
                      "sum": 958886.0,
                      "min": 9126.0,
                      "max": 161639.0
                    }
                  },
                  {
                    "metric": "nOffered",
                    "stats": {
                      "count": 59.0
                    }
                  }
                ]
              }
            ]
          },
          "metadata": {
            "CorrelationId": "7f3ef949-d85d-4cea-b92b-6d96b2915568"
          }
        },
        "output": "fzef-9208-4078-b012-fzegzeg"
      }
    ],
    "identifier": 66873163
  },
  {
    "context": [
      "How do I flatten a json structure using jq? I would like to print each element just once, but in a flat structure.",
      "An example output:\r\n\r\n{\r\n  \"id\": \"12\",\r\n  \"category\": \"Beverages\"\r\n},\r\n{\r\n  \"id\": \"10\",\r\n  \"category\": \"Foods\"\r\n},\r\n{\r\n  \"id\": \"33\",\r\n  \"category\": \"Mexican\"\r\n},\r\n{\r\n  \"id\": \"6100\",\r\n  \"category\": \"Tacos\"\r\n}",
      ".. | objects | select( .id and .text) | {id, category: .text}",
      "[ .value | recurse | objects | {id, category: .text} ]",
      ".value[] | recurse(.children[]?) | {id, category: .text}"
    ],
    "utterance": "Flatten all nested elements to extract each object's id and text as id and category fields.",
    "expressions": [
      ".. | objects | select(.id and .text) | {id, category: .text}",
      "[.value | recurse | objects | {id, category: .text}]",
      ".value[] | recurse(.children[]?) | {id, category: .text}"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "id": "12",
              "text": "Beverages",
              "state": "closed",
              "attributes": null,
              "iconCls": null
            },
            {
              "id": "10",
              "text": "Foods",
              "state": "closed",
              "attributes": null,
              "iconCls": null,
              "children": [
                {
                  "id": "33",
                  "text": "Mexican",
                  "state": "closed",
                  "attributes": null,
                  "iconCls": null,
                  "children": [
                    {
                      "id": "6100",
                      "text": "Taco",
                      "count": "3",
                      "attributes": null,
                      "iconCls": ""
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "12",
            "category": "Beverages"
          },
          {
            "id": "10",
            "category": "Foods"
          },
          {
            "id": "33",
            "category": "Mexican"
          },
          {
            "id": "6100",
            "category": "Taco"
          }
        ]
      }
    ],
    "identifier": 66859568
  },
  {
    "context": [
      "I have the following json file (example.json):",
      "{\n  \"examples\": [\n    {\n      \"example\": \"2\"\n    },\n    {\n      \"example\": \"3\"\n    }\n  ]\n}",
      "I'd like to use jq to add a new element to the top of this array (rather than the bottom).",
      "The desired output (in case it's not immediately obvious) would be:",
      "{\n  \"examples\": [\n    {\n      \"example\": \"1\"\n    },\n    {\n      \"example\": \"2\"\n    },\n    {\n      \"example\": \"3\"\n    }\n  ]\n}",
      "You can concatenate arrays with `+` so you can add your new object inside an array and concat the rest:",
      ".examples |= [{example: \"1\"}] + ."
    ],
    "utterance": "Prepend a new object with key 'example' and value '1' to the beginning of the 'examples' array.",
    "expressions": [
      ".examples |= [{example: \"1\"}] + ."
    ],
    "data": [
      {
        "input": {
          "examples": [
            {
              "example": "2"
            },
            {
              "example": "3"
            }
          ]
        },
        "output": {
          "examples": [
            {
              "example": "1"
            },
            {
              "example": "2"
            },
            {
              "example": "3"
            }
          ]
        }
      }
    ],
    "identifier": 66896566
  },
  {
    "context": [
      "I want to export specific fields, including all tags to a csv, so it looks like this:\n\n    id,vol,state,size,colour,shape,weight\n    value,value,value,value,value,value,value",
      "I want to remove \n    { } at beginning and end.\n\nthe key description I would like at top as a header, rather than to the left of the value..\n\n    so for: \"id\":\"I-1234\"\tvol:\"vol-5678\"\n    I would like\n    id, vol\n    I-1234, vol-5678\n\nand the same with the Tags\nremove the Array Name: \"tags:\" ( think its the array name, I'm not a developer, infrastructure dude! ) and just leave\nSize,Colour,Shape,Weight, ...\nlarge,red,square,25kg, ...",
      "jq -r '\n  [\"Size\",\"Colour\",\"Shape\",\"Weight\"] as $Keys\n  | ([\"id\", \"vol\"] + ($Keys|map(ascii_downcase))),\n    ( .[]\n     | (.Tags|from_entries) as $dict\n     | [.InstanceId, .Vol, $dict[$Keys[]]] )\n  | @csv\n'"
    ],
    "utterance": "Output the values of InstanceId and Vol, along with the values of tags with keys Size, Colour, Shape, and Weight, as a CSV where the header is id, vol, size, colour, shape, weight and each row is the corresponding values in those columns.",
    "expressions": [
      "jq -r '[\"Size\",\"Colour\",\"Shape\",\"Weight\"] as $Keys | ([\"id\", \"vol\"] + ($Keys|map(ascii_downcase))), ( .[] | (.Tags|from_entries) as $dict | [.InstanceId, .Vol, $dict[$Keys[]]] ) | @csv'"
    ],
    "data": [
      {
        "input": [
          {
            "InstanceId": "I-1234",
            "Vol": "vol-5678",
            "Delete": false,
            "State": "in-use",
            "Tags": [
              {
                "Key": "Size",
                "Value": "large"
              },
              {
                "Key": "Colour",
                "Value": "red"
              },
              {
                "Key": "Shape",
                "Value": "square"
              },
              {
                "Key": "Weight",
                "Value": "light"
              }
            ]
          }
        ],
        "output": "id,vol,size,colour,shape,weight\nI-1234,vol-5678,large,red,square,light"
      }
    ],
    "identifier": 66872649
  },
  {
    "context": [
      "I would like to convert the time fields from the ISO to epoch-microseconds.",
      "But this remove the entire decimal part and gives me only second granularity. This is trending data and a few events may happen within the same second.",
      "How can I achieve that using jq?",
      "jq '\n    def datestamp2epoch:\n        . | scan(\"(.+?)([.][0-9]+)?Z$\")\n          | [(.[0] + \"Z\" | fromdateiso8601), (.[1] // 0 | tonumber)]\n          | add;\n    map(.time |= datestamp2epoch)\n' file.json",
      "[\n  {\n    \"type\": \"Point\",\n    \"time\": 1617243561.2438664\n  },\n  {\n    \"type\": \"Circle\",\n    \"time\": 1577836800.01\n  },\n  {\n    \"type\": \"Line\",\n    \"time\": 3600\n  }\n]"
    ],
    "utterance": "Convert a string field containing a timestamp in ISO8601 UTC format with fractional seconds to a floating-point epoch value with sub-second precision.",
    "expressions": [
      "def datestamp2epoch: . | scan(\"(.+?)([.][0-9]+)?Z$\") | [(.[0] + \"Z\" | fromdateiso8601), (.[1] // 0 | tonumber)] | add; map(.time |= datestamp2epoch)"
    ],
    "data": [
      {
        "input": [
          {
            "type": "Point",
            "time": "2021-04-01T01:19:21.243866342Z"
          },
          {
            "type": "Circle",
            "time": "2020-01-01T00:00:00.01Z"
          },
          {
            "type": "Line",
            "time": "1970-01-01T01:00:00Z"
          }
        ],
        "output": [
          {
            "type": "Point",
            "time": 1617243561.2438664
          },
          {
            "type": "Circle",
            "time": 1577836800.01
          },
          {
            "type": "Line",
            "time": 3600
          }
        ]
      }
    ],
    "identifier": 66908468
  },
  {
    "context": [
      "I want to flatten and transform the value array object keys/values to a result like below (for each value within each stat object). Basically take the key in values and place that in a field called `nodeId` and take the value and place that in a field called `value`",
      ".stats[]\n| {devid,key} + (.value[] | to_entries[] | {nodeId: .key|tonumber, value})"
    ],
    "utterance": "For each stats item, output objects with devid, key, and for each entry in value, nodeId set to the original key and value set to the value.",
    "expressions": [
      ".stats[] | {devid,key} + (.value[] | to_entries[] | {nodeId: .key|tonumber, value})"
    ],
    "data": [
      {
        "input": {
          "stats": [
            {
              "devid": 3,
              "key": "diskall",
              "value": [
                {
                  "0": 0.0001,
                  "1": 0.0001,
                  "2": 0.0012,
                  "3": 0.0005,
                  "4": 0.0007,
                  "5": 0.0013,
                  "6": 0.0006000000000000001,
                  "7": 0.0006000000000000001,
                  "8": 0.0006000000000000001,
                  "9": 0.0006000000000000001,
                  "10": 0.0005,
                  "11": 0.0005,
                  "12": 0.0005
                }
              ]
            },
            {
              "devid": 7,
              "key": "diskall",
              "value": [
                {
                  "0": 0.0003,
                  "1": 0.0004,
                  "2": 0.0012,
                  "3": 0.0005,
                  "4": 0.0007,
                  "5": 0.0013,
                  "6": 0.00060001
                }
              ]
            }
          ]
        },
        "output": [
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 0,
            "value": 0.0001
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 1,
            "value": 0.0001
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 2,
            "value": 0.0012
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 3,
            "value": 0.0005
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 4,
            "value": 0.0007
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 5,
            "value": 0.0013
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 6,
            "value": 0.0006000000000000001
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 7,
            "value": 0.0006000000000000001
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 8,
            "value": 0.0006000000000000001
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 9,
            "value": 0.0006000000000000001
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 10,
            "value": 0.0005
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 11,
            "value": 0.0005
          },
          {
            "devid": 3,
            "key": "diskall",
            "nodeId": 12,
            "value": 0.0005
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 0,
            "value": 0.0003
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 1,
            "value": 0.0004
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 2,
            "value": 0.0012
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 3,
            "value": 0.0005
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 4,
            "value": 0.0007
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 5,
            "value": 0.0013
          },
          {
            "devid": 7,
            "key": "diskall",
            "nodeId": 6,
            "value": 0.00060001
          }
        ]
      }
    ],
    "identifier": 66890517
  },
  {
    "context": [
      "How can I check with **jq** if all the \"state\" values are equal and use this **true** or **false** status next in my condition? in this example I would get **true** value.",
      "jq 'map(select(.state != \"foo\")) | length == 0'",
      "It would be easy to come up with an inefficient solution, e.g. using `map` or `unique`, but it's also quite easy to use `all/2` to devise an efficient, generic solution.",
      "    allEquals(.[].state)",
      "Of course, if the objects in the array have only one key, as in the sample shown in the Q, one could simply write:",
      "    .[0] as $x | all(.[]; . == $x)",
      "this code `[.[].state == (\"foo\") ] | all` works as expected"
    ],
    "utterance": "Check if all elements in the array have equal values for the 'state' key.",
    "expressions": [
      ".[0].state as $x | all(.[].state; . == $x)",
      "[.[].state == (.[0].state)] | all",
      "([.[].state] | unique | length == 1)",
      "[.[].state == (\"foo\") ] | all"
    ],
    "data": [
      {
        "input": [
          {
            "state": "foo"
          },
          {
            "state": "foo"
          },
          {
            "state": "foo"
          }
        ],
        "output": true
      },
      {
        "input": [
          {
            "state": "foo"
          },
          {
            "state": "foo"
          },
          {
            "state": "bar"
          }
        ],
        "output": false
      }
    ],
    "identifier": 66921373
  },
  {
    "context": [
      "I am trying to merge the following two json files; but I only seem to be able to partially merge; as soon as an element is within an array the reduce fails.",
      "The expected output would be",
      "{\n    \"value1\": 200,\n    \"timestamp\": 1382461861,\n    \"deployment\": [\n        {\n            \"component\": \"whatever\",\n            \"containers\": \"key value\",\n\n            \"autoscaling\": {\n                \"maxReplicas\": 1,\n                \"minReplicas\": 1,\n                \"targetCPUUtilizationPercentage\": 40\n            }\n        }\n    ],\n    \"status\": 200,\n}",
      "the following does produce the result you ask for",
      "def merge($a; $b): \n   if ($a|type) == \"object\" and ($b|type) == \"object\" \n       then reduce (($a + $b)|keys_unsorted[]) as $k ({}; \n         .[$k] = merge($a[$k]; $b[$k]))\n   elif ($a|type) ==\"array\" and ($b|type) == \"array\" then  $a + $b | add\n   elif $b == null then $a\n   else $b\n   end;",
      "consider invoking this as `merge(input;input)`, using the -n command-line option instead of -s."
    ],
    "utterance": "Merge two objects including deeply merging objects inside arrays so that keys at each level are combined.",
    "expressions": [
      "def merge($a; $b): \n   if ($a|type) == \"object\" and ($b|type) == \"object\" \n       then reduce (($a + $b)|keys_unsorted[]) as $k ({}; \n         .[$k] = merge($a[$k]; $b[$k]))\n   elif ($a|type) == \"array\" and ($b|type) == \"array\" then  $a + $b | add\n   elif $b == null then $a\n   else $b\n   end;\n\nmerge(inputs...);"
    ],
    "data": [
      {
        "input": [
          {
            "value1": 200,
            "timestamp": 1382461861,
            "deployment": [
              {
                "component": "whatever",
                "containers": "key value"
              }
            ]
          },
          {
            "status": 200,
            "timestamp": 1382461861,
            "deployment": [
              {
                "autoscaling": {
                  "maxReplicas": 1,
                  "minReplicas": 1,
                  "targetCPUUtilizationPercentage": 40
                }
              }
            ]
          }
        ],
        "output": {
          "value1": 200,
          "timestamp": 1382461861,
          "deployment": [
            {
              "component": "whatever",
              "containers": "key value",
              "autoscaling": {
                "maxReplicas": 1,
                "minReplicas": 1,
                "targetCPUUtilizationPercentage": 40
              }
            }
          ],
          "status": 200
        }
      }
    ],
    "identifier": 66907565
  },
  {
    "context": [
      "The variable `$task_definition` contains json content. I need to update a specific value in that json. The variable `$docker_image` contains value of the image name.",
      "jq '.taskDefinition.containerDefinitions[0].image = \"$docker_image\"' <<< \"$task_definition\" > task-definition.json",
      "Issue was there were quotes around $docker_image in your jq expression and also the argument needed to be defined like so:",
      "--arg <variable_name> <variable_value>",
      "jq -r --arg docker_image \"b6fa739cedf5\" '.taskDefinition.containerDefinitions[0].image = $docker_image' <<< $task_definition > task-definition.json"
    ],
    "utterance": "Update the value of the image key in the first containerDefinitions element to the value of a shell variable called docker_image.",
    "expressions": [
      ".taskDefinition.containerDefinitions[0].image = $docker_image"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "taskDefinitionArn": "arn:aws:ecs:us-east-1:123454566788:task-definition/nodejs-webapp:21",
            "containerDefinitions": [
              {
                "name": "webapp",
                "image": "$docker_image"
              }
            ]
          }
        },
        "output": {
          "taskDefinition": {
            "taskDefinitionArn": "arn:aws:ecs:us-east-1:123454566788:task-definition/nodejs-webapp:21",
            "containerDefinitions": [
              {
                "name": "webapp",
                "image": "b6fa739cedf5"
              }
            ]
          }
        }
      }
    ],
    "identifier": 66932509
  },
  {
    "context": [
      "I would like to get output like this",
      "\"user01\" \"name\" \"User01 Name\"",
      "I'm not able to figure out how to keep the top level key, print the key value pair as each of them is processed.",
      "jq -r 'to_entries[] | .key as $username | .value | to_entries[] | ([$username, .key, .value] | map(tojson) | join(\" \"))'",
      "jq -r 'to_entries[] | [.key]+(.value | to_entries[] | [.key, .value]) | map(tojson) | join(\" \")'"
    ],
    "utterance": "List each user's top-level key along with every field and its value as space-separated values on one line per field.",
    "expressions": [
      "to_entries[] | .key as $username | .value | to_entries[] | ([$username, .key, .value] | map(tojson) | join(\" \"))",
      "to_entries[] | [.key]+(.value | to_entries[] | [.key, .value]) | map(tojson) | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "user01": {
            "name": "User01 Name",
            "age": "20",
            "sex": "male",
            "state": "CA",
            "zip": "92012"
          },
          "user02": {
            "name": "User02 Name",
            "age": "22",
            "sex": "female"
          },
          "user03": {
            "age": "24",
            "sex": "male",
            "zip": "92412"
          },
          "user04": {
            "name": "User05 Name",
            "age": "30",
            "sex": "female",
            "state": "UT",
            "zip": "96232"
          }
        },
        "output": [
          "\"user01\" \"name\" \"User01 Name\"",
          "\"user01\" \"age\" \"20\"",
          "\"user01\" \"sex\" \"male\"",
          "\"user01\" \"state\" \"CA\"",
          "\"user01\" \"zip\" \"92012\"",
          "\"user02\" \"name\" \"User02 Name\"",
          "\"user02\" \"age\" \"22\"",
          "\"user02\" \"sex\" \"female\"",
          "\"user03\" \"age\" \"24\"",
          "\"user03\" \"sex\" \"male\"",
          "\"user03\" \"zip\" \"92412\"",
          "\"user04\" \"name\" \"User05 Name\"",
          "\"user04\" \"age\" \"30\"",
          "\"user04\" \"sex\" \"female\"",
          "\"user04\" \"state\" \"UT\"",
          "\"user04\" \"zip\" \"96232\""
        ]
      }
    ],
    "identifier": 66891879
  },
  {
    "context": [
      "How to go through the contents of .json file to get the following .csv output?\r\n```\r\n1961021111937667, 2021-03-25T09:42:30.681Z,15155147646,bytes,null,null,null,null,null,3\r\n1961021111937667, 2021-03-25T09:42:30.681Z,null,null,1080,seconds,960,seconds,null,null\r\n```",
      "In other words, I want the following headers included:\r\n```\r\niccid,timeStamp,dataUsage,dataUsageUnit,voiceMTUsage,voiceMTUsageUnit,voiceMOUsage,voiceMOUsageUnit,smsmtusage,smsmousage\r\n```",
      "Assuming the input is structured as shown, the following is guaranteed to produce valid CSV (including the header), in accordance with the headers in the question:\r\n```\r\n[\"iccid\",\"timeStamp\"] as $h1\r\n| [\"dataUsage\",\"dataUsageUnit\",\"voiceMTUsage\",\"voiceMTUsageUnit\",\"voiceMOUsage\",\"voiceMOUsageUnit\",\"smsmtusage\",\"smsmousage\"] as $h2\r\n| ($h1+$h2),\r\n  ([.[$h1[]]] + (.deviceCycleUsageInZones[][] | [.[$h2[]]] ))\r\n| @csv\r\n```"
    ],
    "utterance": "Produce CSV rows with columns: iccid, timeStamp, dataUsage, dataUsageUnit, voiceMTUsage, voiceMTUsageUnit, voiceMOUsage, voiceMOUsageUnit, smsmtusage, smsmousage; each row should combine the top-level iccid and timeStamp with each usage record from deviceCycleUsageInZones.",
    "expressions": [
      "[\"iccid\",\"timeStamp\"] as $h1\n| [\"dataUsage\",\"dataUsageUnit\",\"voiceMTUsage\",\"voiceMTUsageUnit\",\"voiceMOUsage\",\"voiceMOUsageUnit\",\"smsmtusage\",\"smsmousage\"] as $h2\n| ($h1+$h2),\n  ([.[$h1[]]] + (.deviceCycleUsageInZones[][] | [.[$h2[]]] ))\n| @csv"
    ],
    "data": [
      {
        "input": {
          "iccid": "1961021111937667",
          "timeStamp": "2021-03-25T09:42:30.681Z",
          "cycleStartDate": "2021-02-28T16:00:00.000Z",
          "cycleEndDate": "2021-03-31T14:59:59.000Z",
          "deviceCycleUsageInZones": {
            "TEST-25GB, 1": [
              {
                "ratePlan": "TEST-25GB",
                "ratePlanVersion": "1",
                "zone": "default zone",
                "dataUsage": 15155147646,
                "dataUsageUnit": "bytes",
                "voiceMTUsage": null,
                "voiceMTUsageUnit": null,
                "voiceMOUsage": null,
                "voiceMOUsageUnit": null,
                "smsmtusage": null,
                "smsmousage": 3
              }
            ],
            "TEST-29GB, 1": [
              {
                "ratePlan": "TEST - 29602",
                "ratePlanVersion": "1",
                "zone": "default zone",
                "dataUsage": null,
                "dataUsageUnit": null,
                "voiceMTUsage": 1080,
                "voiceMTUsageUnit": "seconds",
                "voiceMOUsage": 960,
                "voiceMOUsageUnit": "seconds",
                "smsmtusage": null,
                "smsmousage": null
              }
            ]
          }
        },
        "output": [
          "iccid,timeStamp,dataUsage,dataUsageUnit,voiceMTUsage,voiceMTUsageUnit,voiceMOUsage,voiceMOUsageUnit,smsmtusage,smsmousage",
          "1961021111937667,2021-03-25T09:42:30.681Z,15155147646,bytes,null,null,null,null,null,3",
          "1961021111937667,2021-03-25T09:42:30.681Z,null,null,1080,seconds,960,seconds,null,null"
        ]
      }
    ],
    "identifier": 66906867
  },
  {
    "context": [
      "def _assign(paths; $value): reduce path(paths) as $p (.; setpath($p; $value));",
      "In essence, a formal parameter, $x, is equivalent to having `x` in the formal parameter list, followed by `x as $x` shortly thereafter.",
      "This is briefly mentioned in the [jq manual][1]:",
      "def addvalue($f): ...;"
    ],
    "utterance": "Understand the semantics of using $value as a formal parameter in function definitions.",
    "expressions": [
      "def _assign(paths; $value): reduce path(paths) as $p (.; setpath($p; $value));",
      "def _assign(paths; vv): vv as $value | reduce path(paths) as $p (.; setpath($p; $value));"
    ],
    "identifier": 66936632
  },
  {
    "context": [
      "I want to use jq (or anything else when it's the wrong tool) to concatenate a json object like this:",
      "the values must be handled differently depending on the object name.",
      "\"https://github.com\" + \"/\" + $user_name + \"/\" + $repository_name + \"/archive/refs/heads/\" + $version + \".tar.gz\"",
      "\"https://gitlab.com\" + \"/\" + $user_name + \"/\" + $repository_name + \"/-/archive/\" + $version + \"/\" + $repository_name + \"-\" + $version + \".tar.gz\"",
      "First, let's focus on the jq code alone:",
      "| if $site == \"https://github.com\" then\n    \"\\($site)/\\($user)/\\($repository_name)/archive/refs/heads/\\($version).tar.gz\"\n  else\n    \"\\($site)/\\($user)/\\($repository_name)/-/archive/\\($version)/\\($repository_name)-\\($version).tar.gz\"\n  end"
    ],
    "utterance": "Produce an array of archive download URLs, using one format for GitHub and another for GitLab, assembling each URL from the correct nested user, repository, and version values depending on the site key.",
    "expressions": [
      "to_entries[]\n| .key as $site\n| .value\n| to_entries[]\n| .key as $user\n| .value\n| to_entries[]\n| .key as $repository_name\n| .value as $version\n| if $site == \"https://github.com\" then\n    \"\\($site)/\\($user)/\\($repository_name)/archive/refs/heads/\\($version).tar.gz\"\n  else\n    \"\\($site)/\\($user)/\\($repository_name)/-/archive/\\($version)/\\($repository_name)-\\($version).tar.gz\"\n  end"
    ],
    "data": [
      {
        "input": {
          "https://github.com": {
            "user-one": {
              "repository-one": "version-one",
              "repository-two": "version-two"
            },
            "user-two": {
              "repository-three": "version-three",
              "repository-four": "version-four"
            }
          },
          "https://gitlab.com": {
            "user-three": {
              "repository-five": "version-five",
              "repository-six": "version-six"
            },
            "user-four": {
              "repository-seven": "version-seven",
              "repository-eight": "version-eight"
            }
          }
        },
        "output": [
          "https://github.com/user-one/repository-one/archive/refs/heads/version-one.tar.gz",
          "https://github.com/user-one/repository-two/archive/refs/heads/version-two.tar.gz",
          "https://github.com/user-two/repository-three/archive/refs/heads/version-three.tar.gz",
          "https://github.com/user-two/repository-four/archive/refs/heads/version-four.tar.gz",
          "https://gitlab.com/user-three/repository-five/-/archive/version-five/repository-five-version-five.tar.gz",
          "https://gitlab.com/user-three/repository-six/-/archive/version-six/repository-six-version-six.tar.gz",
          "https://gitlab.com/user-four/repository-seven/-/archive/version-seven/repository-seven-version-seven.tar.gz",
          "https://gitlab.com/user-four/repository-eight/-/archive/version-eight/repository-eight-version-eight.tar.gz"
        ]
      }
    ],
    "identifier": 66923126
  },
  {
    "context": [
      "From the output shown, I was looking for `solr : xcfrtgyhujikolpu` in a shell script:",
      "[{\"username\":\"zookeeper\",\"password\":\"sdfrtghuioklhq\"}, {\"username\":\"solr\",\"password\":\"xcfrtgyhujikolpu\"}]",
      "jq --arg username solr -r '.[] | select( .username == $username ) | .username + \" : \" + .password'"
    ],
    "utterance": "Find the entry with username equal to 'solr' and output 'solr : xcfrtgyhujikolpu'.",
    "expressions": [
      ".[] | select(.username == $username) | .username + \" : \" + .password"
    ],
    "data": [
      {
        "input": [
          {
            "username": "zookeeper",
            "password": "sdfrtghuioklhq"
          },
          {
            "username": "solr",
            "password": "xcfrtgyhujikolpu"
          }
        ],
        "output": "solr : xcfrtgyhujikolpu"
      }
    ],
    "identifier": 66978161
  },
  {
    "context": [
      "I\u2019d like to change an array of numbers into an array of objects with a key for each value (number).",
      "Let\u2019s say I have a JSON file like this:",
      "{\n\"foo\": [1519739200, 1519739600, 1519740000]\n}",
      "Then my desired output would be:",
      "{\n\"foo\": [\n    {\n       \"id\": 1519739200\n    },\n    {\n       \"id\": 1519739600\n    },\n    {\n       \"id\": 1519740000\n    },\n  ]\n}",
      "{ foo : [ { id : .foo[] } ] }",
      "$ jq -c '{ foo: [ { id: .foo[] } ] }'",
      "$ jq -c '.foo |= [{id: .[]}]'"
    ],
    "utterance": "Transform an object's array of numbers under the 'foo' key into an array of objects, each with an 'id' key holding the original number.",
    "expressions": [
      "{ foo: [ { id: .foo[] } ] }",
      "{ foo: [ { id: .foo[] } ] }",
      ".foo |= [{id: .[]}]"
    ],
    "data": [
      {
        "input": {
          "foo": [
            1519739200,
            1519739600,
            1519740000
          ]
        },
        "output": {
          "foo": [
            {
              "id": 1519739200
            },
            {
              "id": 1519739600
            },
            {
              "id": 1519740000
            }
          ]
        }
      }
    ],
    "identifier": 66969364
  },
  {
    "context": [
      "I want to match entries starting with a number `\\d` (or `[0-9]`) and ending in `linux`.",
      "I don't think `startwith` doesn't support regular expression.",
      "I'm reading that `match` supports regular expression, but I cannot find proper documentation or examples about it.",
      "A simple `'jq '.tags[]| match(\"\\d.*linux\")'` doesn't work and gives a syntax error message:",
      "Ok I found how to do it!",
      "jq -r '.tags[] | select(test(\"^[0-9].*linux\"))'",
      "The arguments to regex functions must be JSON strings, so any regex backslash must be escaped.  Thus, instead of `match(\"\\d.*linux\")` you'd write: `match(\"\\\\d.*linux\")`"
    ],
    "utterance": "Return all values from 'tags' that start with a digit and end with 'linux'.",
    "expressions": [
      ".tags[] | select(test(\"^[0-9].*linux\"))",
      ".tags[] | select(test(\"^\\d.*linux\"))"
    ],
    "data": [
      {
        "input": {
          "tags": [
            "1.2_linux",
            "abc_linux",
            "2beta_linux",
            "linux",
            "3.0windows",
            "4alpha_linux"
          ]
        },
        "output": [
          "1.2_linux",
          "2beta_linux",
          "4alpha_linux"
        ]
      }
    ],
    "identifier": 66955804
  },
  {
    "context": [
      "I want to replace each element in `failureMessages` with either a generic `failed` message or with a truncated version (let's say 100 characters) of itself.",
      "The simplest solution is:\r\n\r\n```jq\r\n.testResults[].assertionResults[].failureMessages[] |= .[0:100]\r\n```"
    ],
    "utterance": "Truncate each string in all failureMessages arrays to the first 100 characters.",
    "expressions": [
      ".testResults[].assertionResults[].failureMessages[] |= .[0:100]"
    ],
    "data": [
      {
        "input": {
          "numFailedTestSuites": 1,
          "numFailedTests": 1,
          "numPassedTestSuites": 1,
          "numPassedTests": 1,
          "testResults": [
            {
              "assertionResults": [
                {
                  "failureMessages": [
                    "Error: error message here"
                  ],
                  "status": "failed",
                  "title": "matches snapshot"
                },
                {
                  "failureMessages": [
                    "Error: another error message here",
                    "Error: yet another error message here"
                  ],
                  "status": "failed",
                  "title": "matches another snapshot"
                }
              ],
              "endTime": 1617720396223,
              "startTime": 1617720393320,
              "status": "failed",
              "summary": ""
            },
            {
              "assertionResults": [
                {
                  "failureMessages": [],
                  "status": "passed"
                },
                {
                  "failureMessages": [],
                  "status": "passed"
                }
              ]
            }
          ]
        },
        "output": {
          "numFailedTestSuites": 1,
          "numFailedTests": 1,
          "numPassedTestSuites": 1,
          "numPassedTests": 1,
          "testResults": [
            {
              "assertionResults": [
                {
                  "failureMessages": [
                    "Error: error message here"
                  ],
                  "status": "failed",
                  "title": "matches snapshot"
                },
                {
                  "failureMessages": [
                    "Error: another error message here",
                    "Error: yet another error message here"
                  ],
                  "status": "failed",
                  "title": "matches another snapshot"
                }
              ],
              "endTime": 1617720396223,
              "startTime": 1617720393320,
              "status": "failed",
              "summary": ""
            },
            {
              "assertionResults": [
                {
                  "failureMessages": [],
                  "status": "passed"
                },
                {
                  "failureMessages": [],
                  "status": "passed"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 66972699
  },
  {
    "context": [
      "I want to filter the exported output values of this command `aws cloudformation list-exports` using **jq** or **query**.",
      "I'm looking for a command that can return the **Value** and filter by **Name**",
      "Example: if i search by **Name** equal to `My-RSC-NAME` the result will be `My-RSC-VALUE`",
      "Using jq:\r\n\r\n\r\n    .Exports[] | select(.Name == \"My-RSC-NAME\").Value"
    ],
    "utterance": "Return the Value of the export with Name equal to My-RSC-NAME",
    "expressions": [
      ".Exports[] | select(.Name == \"My-RSC-NAME\").Value"
    ],
    "data": [
      {
        "input": {
          "Exports": [
            {
              "ExportingStackId": "arn:aws...",
              "Name": "RSC-NAME-2",
              "Value": "RSC-VALUE-2"
            },
            {
              "ExportingStackId": "arn:aws...",
              "Name": "My-RSC-NAME",
              "Value": "My-RSC-VALUE"
            }
          ]
        },
        "output": "My-RSC-VALUE"
      }
    ],
    "identifier": 66990112
  },
  {
    "identifier": 67027634
  },
  {
    "context": [
      "A jq-only solution can easily be built-up using `sub` beginning like so:\n```\n.\"test.yaml\" |= sub(\"(?<key>start-date: )(?<date>[-0-9:T]+)\"; \"\\(.key)2013-06-27T10:00:00\")\n```",
      "You would add additional `sub` filters (like the one shown) to the RHS for each key of interest, using the pattern:\n\n    .\"test-yaml\" |= (sub(...) | sub(...) ...)\n",
      "with valid JSON, use jq e.g.:\n\n    jq '.start-date=\"2013-06-27T10:00:00\" | .end-date=\"2013-06-27T10:00:00\" | .proposed-date=\"2013-06-27T10:00:00\"' dummy-file.json"
    ],
    "utterance": "Replace the value of start-date with 2013-06-27T10:00:00 inside the test.yaml string value.",
    "expressions": [
      ".\"test.yaml\" |= sub(\"(?<key>start-date: )(?<date>[-0-9:T]+)\", \"\\(.key)2013-06-27T10:00:00\")"
    ],
    "data": [
      {
        "input": {
          "test.yaml": "# Copyright (c) 2019-2020 .\n# All Rights Reserved.\n#\n#\ntrace1:\n  - trace-id:\n      - \"immm-0555555555\"\n      - \"mncid-6666666666\"\n    test-service:\n      - \"test-data\"\n    proposed-date: 2019-06-26T16:32:52\n    start-date: 2019-06-27T10:00:00\n    end-date: 2050-06-27T10:30:00\n    test-type: \"HIGH\""
        },
        "output": {
          "test.yaml": "# Copyright (c) 2019-2020 .\n# All Rights Reserved.\n#\n#\ntrace1:\n  - trace-id:\n      - \"immm-0555555555\"\n      - \"mncid-6666666666\"\n    test-service:\n      - \"test-data\"\n    proposed-date: 2019-06-26T16:32:52\n    start-date: 2013-06-27T10:00:00\n    end-date: 2050-06-27T10:30:00\n    test-type: \"HIGH\""
        }
      }
    ],
    "identifier": 66981336
  },
  {
    "context": [
      "I would like to search and replace a specific value in a json line-based data using jq and keep the object unmodified if the match is false.",
      ". | if (select(.foo.bar == \"one\")) then .foo.bar |= \"ok\" else . end",
      "produces result:\n\n{\"foo\":{\"bar\":\"ok\"}}",
      "desired output:\n{\"foo\":{\"bar\":\"ok\"}}\n{\"foo\":{\"bar\":\"two\"}}",
      "Don't use `select`:",
      ". | if .foo.bar == \"one\" then .foo.bar |= \"ok\" else . end"
    ],
    "utterance": "Replace the value of .foo.bar with \"ok\" if it equals \"one\"; otherwise leave the object unchanged.",
    "expressions": [
      ". | if .foo.bar == \"one\" then .foo.bar |= \"ok\" else . end"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": "one"
          }
        },
        "output": {
          "foo": {
            "bar": "ok"
          }
        }
      },
      {
        "input": {
          "foo": {
            "bar": "two"
          }
        },
        "output": {
          "foo": {
            "bar": "two"
          }
        }
      }
    ],
    "identifier": 66992079
  },
  {
    "context": [
      "I want to create a new object where the keys are top level keys (iter_n) and the value of each key is an array of the nested values.",
      "Use `map_values`:\r\n\r\n    jq 'map_values([.[]])' file.json",
      "map_values([.[]])"
    ],
    "utterance": "Convert each top-level object's values into an array, keeping their keys.",
    "expressions": [
      "map_values([.[]])"
    ],
    "data": [
      {
        "input": {
          "iter_1": {
            "rv_0": "rv_0",
            "rv_1": "rv_1",
            "rv_2": "rv_2",
            "rv_3": "rv_3",
            "rv_4": "rv_4",
            "rv_5": "rv_5",
            "rv_6": "rv_6",
            "rv_7": "rv_7",
            "rv_8": "rv_8",
            "rv_9": "rv_9",
            "rv_10": "rv_10",
            "rv_11": "rv_11",
            "rv_12": "rv_12",
            "rv_13": "rv_13",
            "rv_14": "rv_14",
            "rv_15": "rv_15"
          },
          "iter_2": {
            "rv_0": "rv_1",
            "rv_1": "rv_2",
            "rv_2": "rv_4",
            "rv_3": "rv_6",
            "rv_4": "rv_8",
            "rv_5": "rv_11",
            "rv_6": "rv_13",
            "rv_7": "rv_14"
          },
          "iter_4": {
            "rv_0": "rv_1",
            "rv_1": "rv_6",
            "rv_2": "rv_8",
            "rv_3": "rv_14"
          },
          "iter_8": {
            "rv_0": "rv_1",
            "rv_1": "rv_14"
          },
          "iter_16": {
            "rv_0": "rv_1"
          }
        },
        "output": {
          "iter_1": [
            "rv_0",
            "rv_1",
            "rv_2",
            "rv_3",
            "rv_4",
            "rv_5",
            "rv_6",
            "rv_7",
            "rv_8",
            "rv_9",
            "rv_10",
            "rv_11",
            "rv_12",
            "rv_13",
            "rv_14",
            "rv_15"
          ],
          "iter_2": [
            "rv_1",
            "rv_2",
            "rv_4",
            "rv_6",
            "rv_8",
            "rv_11",
            "rv_13",
            "rv_14"
          ],
          "iter_4": [
            "rv_1",
            "rv_6",
            "rv_8",
            "rv_14"
          ],
          "iter_8": [
            "rv_1",
            "rv_14"
          ],
          "iter_16": [
            "rv_1"
          ]
        }
      }
    ],
    "identifier": 66989639
  },
  {
    "context": [
      "I need merged them via jq to have the following format associative array in php (For other systems that need this format that I can't control.)",
      "$ jq -s 'reduce .[] as $line ({}; . + {($line | .DB): $line} )' /tmp/1.jq /tmp/2.jq",
      "jq -n 'INDEX(inputs; .DB)'  ...",
      "With the help of https://blog.differentpla.net/blog/2019/01/11/jq-reduce/ and https://stedolan.github.io/jq/manual/ I was able to output the expected output with these input files:"
    ],
    "utterance": "Merge multiple objects from files into a single object keyed by the DB field, where each value is the corresponding original object.",
    "expressions": [
      "jq -s 'reduce .[] as $line ({}; . + {($line | .DB): $line} )' /tmp/1.jq /tmp/2.jq",
      "jq -n 'INDEX(inputs; .DB)' /tmp/1.jq /tmp/2.jq"
    ],
    "data": [
      {
        "input": [
          {
            "DB": "jaap_35290",
            "DBUSER": "jaap_35290",
            "HOST": "localhost",
            "TYPE": "mysql",
            "CHARSET": "UTF8"
          },
          {
            "DB": "db_2",
            "DBUSER": "jaap_35290",
            "HOST": "localhost",
            "TYPE": "mysql",
            "CHARSET": "UTF8"
          }
        ],
        "output": {
          "jaap_35290": {
            "DB": "jaap_35290",
            "DBUSER": "jaap_35290",
            "HOST": "localhost",
            "TYPE": "mysql",
            "CHARSET": "UTF8"
          },
          "db_2": {
            "DB": "db_2",
            "DBUSER": "jaap_35290",
            "HOST": "localhost",
            "TYPE": "mysql",
            "CHARSET": "UTF8"
          }
        }
      }
    ],
    "identifier": 67023548
  },
  {
    "context": [
      "Trying to see how I can read the first line of a text file using `jq`",
      "cat newfile.txt | jq &#39;.[0]&#39;",
      "Use the `-R` argument (aka `--raw-input`) to tell `jq` that it&#39;s receiving input as strings rather than JSON, and use `input` to read only a single item at a time. Thus:",
      "jq -Rn input &lt;yourfile",
      "...will output:\r\n\r\n```json\r\n&quot;5584157003&quot;\r\n```",
      "If you want to convert it to a number, that&#39;s what `tonumber` is for:",
      "jq -Rn &#39;input | tonumber&#39; &lt;yourfile",
      "...which will output:\r\n\r\n```json\r\n5584157003\r\n```"
    ],
    "utterance": "Read the first line from a text file and optionally convert it to a number.",
    "expressions": [
      "jq -Rn input <newfile.txt",
      "jq -Rn 'input | tonumber' <newfile.txt"
    ],
    "data": [
      {
        "input": "5584157003\n5584158003\n5584159003\n5584160003\n",
        "output": "\"5584157003\""
      },
      {
        "input": "5584157003\n5584158003\n5584159003\n5584160003\n",
        "output": 5584157003
      }
    ],
    "identifier": 67027391
  },
  {
    "context": [
      "The objective is to get only the objects that contain the id (to remove the **{\"uiComponent\": \"Spacer\"}** objects) and get only the **subFields** with these tags inside the array:",
      "Can you help me improve those JQ pattern I created to get the intended results?",
      "The following produces your first alternative:",
      "```\n.subFields[]\n| select(.id?)\n| { id, title, description, type} +\n    (.subFields[] \n     | select(.type?) \n     | [.type,.label,.value] | join(\",\")\n     |  { questions: .} )\n```"
    ],
    "utterance": "For each object in the top-level subFields array with an id, return multiple objects with fields id, title, description, type, and questions, where questions contains comma-separated type, label, and value for each sub-field that has a type, skipping entries without type or without id.",
    "expressions": [
      ".subFields[]\n| select(.id?)\n| { id, title, description, type } +\n    (.subFields[] \n     | select(.type?) \n     | [.type,.label,.value] | join(\",\")\n     | { questions: . })"
    ],
    "data": [
      {
        "input": {
          "subFields": [
            {
              "id": "question_1",
              "type": "radioGroup",
              "description": "Description1",
              "title": "title1",
              "subFields": [
                {
                  "type": "radio",
                  "label": "Yes",
                  "value": 1
                },
                {
                  "type": "radio",
                  "label": "No",
                  "value": 0
                },
                {
                  "uiComponent": "SmallContent",
                  "componentProps": {
                    "text": "* If the answer to the above question is \u201cYes\u201d, please contact the Support immediately."
                  }
                }
              ]
            },
            {
              "uiComponent": "Spacer"
            }
          ]
        },
        "output": [
          {
            "id": "question_1",
            "title": "title1",
            "description": "Description1",
            "type": "radioGroup",
            "questions": "radio,Yes,1"
          },
          {
            "id": "question_1",
            "title": "title1",
            "description": "Description1",
            "type": "radioGroup",
            "questions": "radio,No,0"
          }
        ]
      }
    ],
    "identifier": 66976506
  },
  {
    "context": [
      "$ ./Error_CLIENT.sh | /home/USER/jq -rj '.[] | .job.Name, \"\\t\\t\" ,.Atrributes.userData, \"\\n\"'",
      "I would like to get:\n\n    HOME22                  pte\n    HOME23                  pte\n    HOUSEABI                pdt all\n    HOUSEAB2                pdt all",
      "A jq-only solution is certainly possible, but it would almost certainly be much easier to use jq\u2019s `@tsv` in conjunction with  `column -t` or perhaps `pr -e`"
    ],
    "utterance": "Display each entry's job name and userData in aligned columns with consistent spacing so the output is tabulated and columns are visually aligned.",
    "expressions": [
      ".[] | [.job.Name, .Atrributes.userData] | @tsv"
    ],
    "identifier": 67070932
  },
  {
    "context": [
      "Basically I have a bash script that at one point makes an API call and a cert and key are generated and returned in json. I pipe it to jq and can select either the cert or the key and store it in a variable.",
      "I want to store each in its own variable but I can&#39;t make the call twice because it will generate a new cert/key.",
      "I am curious if jq offers a direct way to selectively store each value in its own variable?",
      "apiResult=$(API call)\ncert=$(jq -r '.certificate' <<<\"$apiResult\")\nkey=$(jq -r '.key' <<<\"$apiResult\")",
      "read cert key < <( echo '{\"certificate\": \"foo\", \"key\": \"bar\"}' | jq -r .certificate,.key | tr \\n ' ')",
      "API call | jq -r '.certificate, .key'",
      "eval \"$( data_source | jq -r '@sh \"certificate=\\( .certificate )\\nkey=\\( .key )\"' )\"",
      "eval `API_CALL | jq -r '\"VAR1=\"+.var1,\"VAR2=\"+.var2'`"
    ],
    "utterance": "Extract both the 'certificate' and 'key' values from an API response and assign them to separate shell variables without making the API call multiple times.",
    "expressions": [
      "jq -r '.certificate' <<<\"$apiResult\"",
      "jq -r '.key' <<<\"$apiResult\"",
      "jq -r .certificate,.key",
      "jq -r '@sh \"certificate=\\( .certificate )\\nkey=\\( .key )\"'",
      "jq -r '\"VAR1=\"+.var1,\"VAR2=\"+.var2'"
    ],
    "data": [
      {
        "input": {
          "certificate": "foo",
          "key": "bar"
        },
        "output": [
          "foo",
          "bar"
        ]
      }
    ],
    "identifier": 67030229
  },
  {
    "context": [
      "Now I want to remove the \".fifo\" suffix from the value of **ALL** the `suffix_name` fields, at any level",
      "I want to know, if there is a better way, using recurse or something, to parse through all keys and if the key is `suffix_name`, trim the \".fifo\" from the value.",
      "You could use `walk`:",
      "walk(if type==\"object\" and .suffix_name \n     then .suffix_name |= sub(\"[.]fifo$\";\"\") else . end)",
      "Alternatively, just use `|=`:",
      "(.. | select(type == \"object\" and .suffix_name) | .suffix_name) \n  |=  sub(\"[.]fifo$\";\"\") ",
      "An alternate to `walk` using the `path` functions - `getpath` and `setpath`",
      "reduce ( paths | select(.[-1] | endswith(\"suffix_name\")? ) ) as $p \n  ( .; setpath($p; getpath($p) | sub(\"[.]fifo$\";\"\") ) )"
    ],
    "utterance": "Remove the '.fifo' suffix from the value of every 'suffix_name' key, regardless of its location in the structure.",
    "expressions": [
      "walk(if type==\"object\" and .suffix_name then .suffix_name |= sub(\"[.]fifo$\";\"\") else . end)",
      "(.. | select(type == \"object\" and .suffix_name) | .suffix_name) |= sub(\"[.]fifo$\";\"\")",
      "reduce ( paths | select(.[-1] | endswith(\"suffix_name\")? ) ) as $p ( .; setpath($p; getpath($p) | sub(\"[.]fifo$\";\"\") ) )"
    ],
    "data": [
      {
        "input": {
          "description": "this is a fake description",
          "owner": "john",
          "region": "us-east-1",
          "topics": {
            "For collecting responses for prod1": {
              "suffix_name": "response-to-hogwarts.fifo",
              "tags": {}
            }
          },
          "queues": {
            "For collecting responses and requests from test1": {
              "suffix_name": "rr_sf_name.fifo",
              "tags": {}
            },
            "For collecting responses for test2": {
              "suffix_name": "response-to-hogwarts.fifo",
              "tags": {}
            }
          },
          "subscriptions": {
            "For receiving harry_potter requests": {
              "topic": {
                "suffix_name": "harry_potter.fifo",
                "tag": "staging"
              },
              "queue": {
                "suffix_name": "rr_sf_name.fifo"
              }
            },
            "For receiving harry_potter requests from test3": {
              "topic": {
                "suffix_name": "harry_potter.fifo",
                "tag": "harry_potter_hogwarts"
              },
              "queue": {
                "suffix_name": "rr_sf_name.fifo"
              }
            },
            "For receiving demo requests": {
              "topic": {
                "suffix_name": "demo.fifo",
                "tag": "staging"
              },
              "queue": {
                "suffix_name": "rr_sf_name.fifo"
              }
            },
            "For receiving demo requests from test4 through connector": {
              "topic": {
                "suffix_name": "demo.fifo",
                "tag": "harry_potter_hogwarts"
              },
              "queue": {
                "suffix_name": "rr_sf_name.fifo"
              }
            },
            "For receiving testing responses for hogwarts": {
              "topic": {
                "suffix_name": "response-to-hogwarts.fifo"
              },
              "queue": {
                "suffix_name": "response-to-hogwarts.fifo"
              }
            }
          }
        },
        "output": {
          "description": "this is a fake description",
          "owner": "john",
          "region": "us-east-1",
          "topics": {
            "For collecting responses for prod1": {
              "suffix_name": "response-to-hogwarts",
              "tags": {}
            }
          },
          "queues": {
            "For collecting responses and requests from test1": {
              "suffix_name": "rr_sf_name",
              "tags": {}
            },
            "For collecting responses for test2": {
              "suffix_name": "response-to-hogwarts",
              "tags": {}
            }
          },
          "subscriptions": {
            "For receiving harry_potter requests": {
              "topic": {
                "suffix_name": "harry_potter",
                "tag": "staging"
              },
              "queue": {
                "suffix_name": "rr_sf_name"
              }
            },
            "For receiving harry_potter requests from test3": {
              "topic": {
                "suffix_name": "harry_potter",
                "tag": "harry_potter_hogwarts"
              },
              "queue": {
                "suffix_name": "rr_sf_name"
              }
            },
            "For receiving demo requests": {
              "topic": {
                "suffix_name": "demo",
                "tag": "staging"
              },
              "queue": {
                "suffix_name": "rr_sf_name"
              }
            },
            "For receiving demo requests from test4 through connector": {
              "topic": {
                "suffix_name": "demo",
                "tag": "harry_potter_hogwarts"
              },
              "queue": {
                "suffix_name": "rr_sf_name"
              }
            },
            "For receiving testing responses for hogwarts": {
              "topic": {
                "suffix_name": "response-to-hogwarts"
              },
              "queue": {
                "suffix_name": "response-to-hogwarts"
              }
            }
          }
        }
      }
    ],
    "identifier": 67015851
  },
  {
    "context": [
      "I want to filter it based on the certain conditioning and get the result as an array",
      "here is the output which I am getting:\n\n\"vpc-yyyyyyyyyyyyyyyyy\"\n\"vpc-zzzzzzzzzzzzzzzzz\"\n\"vpc-XXXXXXXXXxxxxxxxx\"\n\nI want the output as \n[\n\"vpc-yyyyyyyyyyyyyyyyy\",\n\"vpc-zzzzzzzzzzzzzzzzz\",\n\"vpc-XXXXXXXXXxxxxxxxx\"\n]\n\nso that I can pass it to the terraform.",
      "Replace `.[].VpcId.S` with `map(.VpcId.S)`. The `.[]` syntax takes the elements out of the array.",
      "You can combine your different `jq` filters together in this way:\n\n```\n.Items | map(select(.VpcId.S != \"None\") | .VpcId.S)\n```"
    ],
    "utterance": "Return all VpcId.S values that are not equal to \"None\" as an array.",
    "expressions": [
      ".Items | map(select(.VpcId.S != \"None\") | .VpcId.S)"
    ],
    "data": [
      {
        "input": {
          "Items": [
            {
              "VpcId": {
                "S": "vpc-yyyyyyyyyyyyyyyyy"
              }
            },
            {
              "VpcId": {
                "S": "None"
              }
            },
            {
              "VpcId": {
                "S": "vpc-xxxxxxxxxxxxxxxxx"
              }
            }
          ]
        },
        "output": [
          "vpc-yyyyyyyyyyyyyyyyy",
          "vpc-xxxxxxxxxxxxxxxxx"
        ]
      }
    ],
    "identifier": 67089955
  },
  {
    "identifier": 67104115
  },
  {
    "context": [
      "I want to convert the data to csv ( space separated) similar to the following: [As Shown in the ATTACHED IMAGE][1]",
      "jq -r '.data.ticker | to_entries[] | [.key, (.value | (.vol|tonumber), (.low|tonumber))] | @csv'"
    ],
    "utterance": "List each ticker with its name, volume, and low price as rows.",
    "expressions": [
      ".data.ticker | to_entries[] | [.key, (.value | .vol | tonumber), (.value | .low | tonumber)] | @csv"
    ],
    "data": [
      {
        "input": {
          "code": 0,
          "data": {
            "date": 1617978312600,
            "ticker": {
              "KAVAUSDT": {
                "vol": "15022.96236047",
                "low": "7.0419",
                "open": "7.8990",
                "high": "8.1997",
                "last": "7.1516",
                "buy": "7.1516",
                "buy_amount": "11.02402741",
                "sell": "7.1699",
                "sell_amount": "37.46319593"
              },
              "CFXUSDT": {
                "vol": "108550.36674746",
                "low": "1.226636",
                "open": "1.267724",
                "high": "1.378400",
                "last": "1.273187",
                "buy": "1.272200",
                "buy_amount": "14.65071234",
                "sell": "1.294900",
                "sell_amount": "84.88000789"
              },
              "SUSHIBTC": {
                "vol": "5644.10352324",
                "low": "0.00024680",
                "open": "0.00024857",
                "high": "0.00026493",
                "last": "0.00025704",
                "buy": "0.00025563",
                "buy_amount": "104.74291100",
                "sell": "0.00025730",
                "sell_amount": "94.16400000"
              },
              "SUNUSDT": {
                "vol": "7058.81491709",
                "low": "37.3431",
                "open": "37.9590",
                "high": "44.0446",
                "last": "40.6945",
                "buy": "40.1001",
                "buy_amount": "25.40000000",
                "sell": "41.0771",
                "sell_amount": "3.40000000"
              }
            }
          },
          "message": "OK"
        },
        "output": "\"KAVAUSDT\",15022.96236047,7.0419\n\"CFXUSDT\",108550.36674746,1.226636\n\"SUSHIBTC\",5644.10352324,0.0002468\n\"SUNUSDT\",7058.81491709,37.3431"
      }
    ],
    "identifier": 67073322
  },
  {
    "context": [
      "What I want is that I get is a first field with a secuencial number (1 ....) like these:",
      "1     AAA        PENDING",
      "One way would be to start your pipeline with:",
      "range(0;length) as $i | .[$i] ",
      "You then can use $i in the remainder of the program."
    ],
    "utterance": "Output each record prefixed by a sequential number starting from 1.",
    "expressions": [
      "range(0;length) as $i | .[$i] | \"\\($i+1) \\(.job.Name) \\(.atrib.data)\""
    ],
    "identifier": 67104920
  },
  {
    "context": [
      "I\u2019d like to be able to grab the USERNAME, STORAGE_ID, and then the CUSTOM_FIELDS > KEY and CUSTOM_FIELDS > VALUE WHEN the Key = expiry-event and the VALUE for that key is prior to today\u2019s date.",
      "def prior($yymmdd): sub(\"-(?<d>\\\\d)-\"; \"-0\\(.d)-\") <= ($yymmdd);",
      "(now|strflocaltime(\"%Y-%m-%d\")) as $now | .Passwords[] | {username, storage, custom_fields : .custom_fields | map(select(.key == \"expiry-event\" and (.value|prior($now)))) }"
    ],
    "utterance": "Select objects where the key 'expiry-event' exists in custom_fields and its value is before today, then output their username, storage, and those custom_fields.",
    "expressions": [
      "def prior($yymmdd): sub(\"-(?<d>\\\\d)-\"; \"-0\\(.d)-\") <= ($yymmdd);\n\n(now|strflocaltime(\"%Y-%m-%d\")) as $now\n| .Passwords[]\n| {username,\n   storage,\n   custom_fields : .custom_fields | map(select(.key == \"expiry-event\" and (.value|prior($now)))) }"
    ],
    "data": [
      {
        "input": {
          "total_count": 34,
          "Passwords": [
            {
              "username": "testusername",
              "category": null,
              "device_ids": [],
              "view_users": "",
              "view_groups": "",
              "last_pw_change": "2021-04-13T13:30:03Z",
              "notes": "",
              "storage": "Normal",
              "use_only_users": "",
              "label": "EXPIRED",
              "view_edit_groups": "",
              "first_added": "2021-04-13T13:30:03.790Z",
              "use_only_groups": "",
              "storage_id": 1,
              "view_edit_users": "admin",
              "password": "",
              "id": 36,
              "custom_fields": [
                {
                  "notes": null,
                  "key": "expiry-event",
                  "value": "2021-4-13"
                }
              ]
            }
          ]
        },
        "output": {
          "username": "testusername",
          "storage": "Normal",
          "custom_fields": [
            {
              "notes": null,
              "key": "expiry-event",
              "value": "2021-4-13"
            }
          ]
        }
      }
    ],
    "identifier": 67096008
  },
  {
    "context": [
      "I need to get the values of 'code' and second 'message'. Is it possible?",
      "My current code is:\n\n```sh\njq -r '.[].status.code && .[].message'\n```\n\n...and it fails with:",
      "Coming together, this looks like:\n\n```\n#!/usr/bin/env bash\nwhile IFS= read -r -d '' code && IFS= read -r -d '' message; do\n  echo \"Got code: <$code> and message: <$message>\"\ndone < <(jq -j '.[] | (.status.code, \"\\u0000\", .message, \"\\u0000\")' <input.json)\n```"
    ],
    "utterance": "Extract the value of 'status.code' and the top-level 'message' field from each object in the array.",
    "expressions": [
      ".[] | .status.code, .message",
      ".[] | [.status.code, .message]"
    ],
    "data": [
      {
        "input": [
          {
            "long_message": {
              "just": "a",
              "bunch": "of",
              "unrelated": "data",
              "can be": "omitted"
            },
            "status": {
              "message": "CRITICAL",
              "code": 1
            },
            "service": "SERVICE_NAME",
            "message": "you messed up"
          }
        ],
        "output": [
          1,
          "you messed up"
        ]
      }
    ],
    "identifier": 67109361
  },
  {
    "context": [
      "The output I'm trying to achieve is this:\n\n{\n  \"connections\": [\n    {\n      \"label\": \"my-label\",\n      \"sentinels\": [\n        {\n          \"host\": \"name1.development.svc.cluster.local\",\n          \"port\": 26379\n        },\n        {\n          \"host\": \"name2.development.svc.cluster.local\",\n          \"port\": 26379\n        },\n        {\n          \"host\": \"name3.staging.svc.cluster.local\",\n          \"port\": 26379\n        }\n      ],\n      \"sentinelName\": \"mymaster\",\n      \"dbIndex\": 0\n    }\n  ]\n}",
      "Using `map` with .items is probably a better way to go, along the lines of:\n\n```\n.items\n| {\n    label: \"my-label\",\n    sentinels: map(\n      { host: (.metadata.name + \".\"\n\t      + .metadata.namespace + \".\"\n\t      + \"svc\" + \".\"\n\t      + \"cluster\" + \".\"\n\t      + \"local\"),\n        port: .spec.ports[0].port\n      } ),\n    sentinelName: \"mymaster\",\n    dbIndex: 0\n  }\n| {connections: [.] }\n\n```"
    ],
    "utterance": "Produce a single object with a 'connections' array containing one object whose 'sentinels' array includes all service endpoints, each with 'host' and 'port', and with 'label' set to 'my-label', 'sentinelName' to 'mymaster', and 'dbIndex' to 0.",
    "expressions": [
      ".items\n| {\n    label: \"my-label\",\n    sentinels: map({ host: (.metadata.name + \".\" + .metadata.namespace + \".svc.cluster.local\"), port: .spec.ports[0].port }),\n    sentinelName: \"mymaster\",\n    dbIndex: 0\n  }\n| {connections: [.] }"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "name1",
                "namespace": "development"
              },
              "spec": {
                "ports": [
                  {
                    "port": 26379
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "name2",
                "namespace": "development"
              },
              "spec": {
                "ports": [
                  {
                    "port": 26379
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "name3",
                "namespace": "staging"
              },
              "spec": {
                "ports": [
                  {
                    "port": 26379
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "connections": [
            {
              "label": "my-label",
              "sentinels": [
                {
                  "host": "name1.development.svc.cluster.local",
                  "port": 26379
                },
                {
                  "host": "name2.development.svc.cluster.local",
                  "port": 26379
                },
                {
                  "host": "name3.staging.svc.cluster.local",
                  "port": 26379
                }
              ],
              "sentinelName": "mymaster",
              "dbIndex": 0
            }
          ]
        }
      }
    ],
    "identifier": 67124379
  },
  {
    "context": [
      "The JSON data that I can retrieve from the url above is this",
      "{\n\"lastUpdateId\":18891938,\n\t\"bids\":[\n\t\t[\"3.23600000\",\"101.76600000\"],\n\t\t[\"3.23500000\",\"2161.63600000\"],\n\t\t[\"3.23100000\",\"30.95000000\"],\n\t\t[\"3.23000000\",\"3.12600000\"],\n\t\t[\"3.22900000\",\"303.95100000\"]\n\t],\n\t\"asks\":[\n\t\t[\"3.24100000\",\"15.90200000\"],\n\t\t[\"3.24200000\",\"1679.00000000\"],\n\t\t[\"3.24500000\",\"953.98800000\"],\n\t\t[\"3.24800000\",\"7.57700000\"],\n\t\t[\"3.25400000\",\"37.26700000\"]\n\t]}",
      "How can I export it as csv file something like this below",
      "\"bids\",\"3.23600000\",\"101.76600000\"",
      "\"asks\",\"3.24100000\",\"15.90200000\"",
      "jq -r 'keys[] as $k | select(.[$k]|type==\"array\") |[$k]+.[$k][]|@csv'",
      "keys[] as $k |[$k]+.[$k][]? | @csv"
    ],
    "utterance": "Export all entries under 'bids' and 'asks', each as a row with the key name and both values, in CSV format.",
    "expressions": [
      "keys[] as $k | [$k] + .[$k][] | @csv",
      "keys[] as $k | select(.[$k]|type==\"array\") | [$k] + .[$k][] | @csv"
    ],
    "data": [
      {
        "input": {
          "lastUpdateId": 18891938,
          "bids": [
            [
              "3.23600000",
              "101.76600000"
            ],
            [
              "3.23500000",
              "2161.63600000"
            ],
            [
              "3.23100000",
              "30.95000000"
            ],
            [
              "3.23000000",
              "3.12600000"
            ],
            [
              "3.22900000",
              "303.95100000"
            ]
          ],
          "asks": [
            [
              "3.24100000",
              "15.90200000"
            ],
            [
              "3.24200000",
              "1679.00000000"
            ],
            [
              "3.24500000",
              "953.98800000"
            ],
            [
              "3.24800000",
              "7.57700000"
            ],
            [
              "3.25400000",
              "37.26700000"
            ]
          ]
        },
        "output": [
          "\"bids\",\"3.23600000\",\"101.76600000\"",
          "\"bids\",\"3.23500000\",\"2161.63600000\"",
          "\"bids\",\"3.23100000\",\"30.95000000\"",
          "\"bids\",\"3.23000000\",\"3.12600000\"",
          "\"bids\",\"3.22900000\",\"303.95100000\"",
          "\"asks\",\"3.24100000\",\"15.90200000\"",
          "\"asks\",\"3.24200000\",\"1679.00000000\"",
          "\"asks\",\"3.24500000\",\"953.98800000\"",
          "\"asks\",\"3.24800000\",\"7.57700000\"",
          "\"asks\",\"3.25400000\",\"37.26700000\""
        ]
      }
    ],
    "identifier": 67135550
  },
  {
    "context": [
      "I would like to use jq to create the aforementioned structure and then populate the json file with the values in the input file.",
      "Here is a simple solution:\r\n```\r\n< input.txt jq -nR '\r\n  reduce (inputs | split(\",\")) as $line ({};\r\n    getpath($line[0:2]) as $v\r\n    | setpath($line[0:2]; $v + [{value1: $line[2], value2: $line[3]} ] ) )\r\n'\r\n```"
    ],
    "utterance": "Transform each CSV line containing environment, component, and values into a nested data structure grouped by environment and component, populating arrays of objects with specified value fields.",
    "expressions": [
      "reduce (inputs | split(\",\")) as $line ({}; getpath($line[0:2]) as $v | setpath($line[0:2]; $v + [{value1: $line[2], value2: $line[3]} ] ) )"
    ],
    "data": [
      {
        "input": [
          "ENV1,Middleware,Mqwerty,Mqwerty",
          "ENV1,Middleware,Mqwerty,Mqwerty",
          "ENV1,Middleware,Mqwerty,Mqwerty",
          "ENV1,System,Sqwerty,Sqwerty,Sqwerty",
          "ENV1,Application,Aqwerty,Aqwerty",
          "ENV1,Application,Aqwerty,Aqwerty",
          "ENV1,Utility,Uqwerty,Uqwerty,Uqwerty",
          "ENV3,Middleware,Mqwerty,Mqwerty",
          "ENV3,Middleware,Mqwerty,Mqwerty"
        ],
        "output": {
          "ENV": {
            "ENV1": {
              "Middleware": [
                {
                  "value1": "Mqwerty",
                  "value2": "Mqwerty"
                },
                {
                  "value1": "Mqwerty",
                  "value2": "Mqwerty"
                },
                {
                  "value1": "Mqwerty",
                  "value2": "Mqwerty"
                }
              ],
              "System": [
                {
                  "value1": "Sqwerty",
                  "value2": "Sqwerty",
                  "value3": "Sqwerty"
                }
              ],
              "Application": [
                {
                  "value1": "Aqwerty",
                  "value2": "Aqwerty"
                },
                {
                  "value1": "Aqwerty",
                  "value2": "Aqwerty"
                }
              ],
              "Utility": [
                {
                  "value1": "Uqwerty",
                  "value2": "Uqwerty",
                  "value3": "Uqwerty"
                }
              ]
            },
            "ENV2": {
              "Middleware": [],
              "System": [],
              "Application": [],
              "Utility": []
            },
            "ENV3": {
              "Middleware": [
                {
                  "value1": "Mqwerty",
                  "value2": "Mqwerty"
                },
                {
                  "value1": "Mqwerty",
                  "value2": "Mqwerty"
                }
              ],
              "System": [],
              "Application": [],
              "Utility": []
            },
            "ENV4": {
              "Middleware": [],
              "System": [],
              "Application": [],
              "Utility": []
            }
          }
        }
      }
    ],
    "identifier": 67084209
  },
  {
    "context": [
      "I have json something like this",
      "\"bids\":[ [\"3.23600000\",\"101.76600000\"], [\"3.23500000\",\"2161.63600000\"], ... ]",
      "Then I would like to export it to CSV with the result of multiplication for every rows",
      "\"bids\",\"3.23600000\",\"101.76600000\",\"329.314776\" <- this is calculated from 3.23600000 * 101.76600000",
      "How can I export the result of multiplication together in the end of each line?",
      "You only need add one line to the jq program:",
      "| .[length]= (.[-2:]|map(tonumber)|.[0]*.[1])",
      "|@csv"
    ],
    "utterance": "Export rows from both 'bids' and 'asks' arrays, each row including the key, the two string values, and their product as the fourth CSV column.",
    "expressions": [
      "keys[] as $k | select(.[$k]|type==\"array\") | [$k]+.[$k][] | .[length]= (.[-2:]|map(tonumber)|.[0]*.[1]) | @csv"
    ],
    "data": [
      {
        "input": {
          "lastUpdateId": 18891938,
          "bids": [
            [
              "3.23600000",
              "101.76600000"
            ],
            [
              "3.23500000",
              "2161.63600000"
            ],
            [
              "3.23100000",
              "30.95000000"
            ],
            [
              "3.23000000",
              "3.12600000"
            ],
            [
              "3.22900000",
              "303.95100000"
            ]
          ],
          "asks": [
            [
              "3.24100000",
              "15.90200000"
            ],
            [
              "3.24200000",
              "1679.00000000"
            ],
            [
              "3.24500000",
              "953.98800000"
            ],
            [
              "3.24800000",
              "7.57700000"
            ],
            [
              "3.25400000",
              "37.26700000"
            ]
          ]
        },
        "output": "\"bids\",\"3.23600000\",\"101.76600000\",329.314776\n\"bids\",\"3.23500000\",\"2161.63600000\",6993.49826\n\"bids\",\"3.23100000\",\"30.95000000\",99.97345\n\"bids\",\"3.23000000\",\"3.12600000\",10.10498\n\"bids\",\"3.22900000\",\"303.95100000\",981.287179\n\"asks\",\"3.24100000\",\"15.90200000\",51.555482\n\"asks\",\"3.24200000\",\"1679.00000000\",5444.318\n\"asks\",\"3.24500000\",\"953.98800000\",3095.44706\n\"asks\",\"3.24800000\",\"7.57700000\",24.601296\n\"asks\",\"3.25400000\",\"37.26700000\",121.351918"
      }
    ],
    "identifier": 67137631
  },
  {
    "context": [
      "what if I want another columns for the minimum value of all asks(Here, it's 6)?,\nthe sums for each asks and bid, and the ratio against the sums for each asks and bids?",
      "So I'd like to have the CSV result something like this(4-6th columns are the new that I want)",
      "Next, we can adapt the solution you mentioned by first computing the minimum of the \"ask\" values:",
      "([.asks[][] | tonumber] | min) as $min\n  | keys[] as $k \n  | select(.[$k]|type==\"array\")\n  | ([.[$k][] | mul] | add) as $sum\n  | [$k]+.[$k][] \n  | (.[-2:]|mul) as $c4\n  | . + [$c4, $min, $sum, $c4 / $sum]\n  | @csv"
    ],
    "utterance": "Output each entry from asks and bids including the entry label, its values, their product, the minimum ask price, the sum of products for the type, and the ratio of the product to the sum.",
    "expressions": [
      "def mul: (.[0]|tonumber) * (.[1]|tonumber); ([.asks[][] | tonumber] | min) as $min | keys[] as $k | select(.[$k]|type==\"array\") | ([.[$k][] | mul] | add) as $sum | [$k]+.[$k][] | (.[-2:]|mul) as $c4 | . + [$c4, $min, $sum, $c4 / $sum] | @csv"
    ],
    "data": [
      {
        "input": {
          "lastUpdateId": 18891938,
          "bids": [
            [
              "1",
              "50"
            ],
            [
              "2",
              "40"
            ],
            [
              "3",
              "30"
            ],
            [
              "4",
              "20"
            ],
            [
              "5",
              "10"
            ]
          ],
          "asks": [
            [
              "6",
              "10"
            ],
            [
              "7",
              "20"
            ],
            [
              "8",
              "30"
            ],
            [
              "9",
              "40"
            ],
            [
              "10",
              "50"
            ]
          ]
        },
        "output": [
          "\"asks\",\"6\",\"10\",60,6,1300,0.046153846",
          "\"asks\",\"7\",\"20\",140,6,1300,0.107692308",
          "\"asks\",\"8\",\"30\",240,6,1300,0.184615385",
          "\"asks\",\"9\",\"40\",360,6,1300,0.276923077",
          "\"asks\",\"10\",\"50\",500,6,1300,0.384615385",
          "\"bids\",\"1\",\"50\",50,6,350,0.142857143",
          "\"bids\",\"2\",\"40\",80,6,350,0.228571429",
          "\"bids\",\"3\",\"30\",90,6,350,0.257142857",
          "\"bids\",\"4\",\"20\",80,6,350,0.228571429",
          "\"bids\",\"5\",\"10\",50,6,350,0.142857143"
        ]
      }
    ],
    "identifier": 67140403
  },
  {
    "context": [
      "jq '.station_conf.log_level=\"ERROR\"' station.conf",
      "To pass in a shell variable, consider:",
      "jq \u2014-arg v \"$LOG_LEVEL\" '\n       .station_conf.log_level=$v' station.conf",
      "You are getting `invalid numeric literal error` because at least your example input is not valid json. As you can see, it contains `/* comment */`, which is not supported by jq."
    ],
    "utterance": "Set the value of station_conf.log_level to a specified value",
    "expressions": [
      ".station_conf.log_level = \"ERROR\"",
      "--arg v \"$LOG_LEVEL\" '.station_conf.log_level = $v'"
    ],
    "data": [
      {
        "input": {
          "SX1301_conf": {
            "lorawan_public": true,
            "clksrc": 1,
            "radio_0": {
              "type": "SX1257",
              "rssi_offset": -166.0,
              "tx_enable": true,
              "antenna_gain": 0
            },
            "radio_1": {
              "type": "SX1257",
              "rssi_offset": -166.0,
              "tx_enable": false
            }
          },
          "station_conf": {
            "log_file": "stderr",
            "log_level": "DEBUG",
            "log_size": 10000000,
            "log_rotate": 3,
            "CUPS_RESYNC_INTV": "1s"
          }
        },
        "output": {
          "SX1301_conf": {
            "lorawan_public": true,
            "clksrc": 1,
            "radio_0": {
              "type": "SX1257",
              "rssi_offset": -166.0,
              "tx_enable": true,
              "antenna_gain": 0
            },
            "radio_1": {
              "type": "SX1257",
              "rssi_offset": -166.0,
              "tx_enable": false
            }
          },
          "station_conf": {
            "log_file": "stderr",
            "log_level": "ERROR",
            "log_size": 10000000,
            "log_rotate": 3,
            "CUPS_RESYNC_INTV": "1s"
          }
        }
      }
    ],
    "identifier": 67161075
  },
  {
    "context": [
      "But trying to call the env variable:\n\n`jq -e '.station_conf.log_level=\"$LOG_LEVEL\"' test.conf > test.conf.tmp && cp test.conf.tmp test.conf`\n\nResults in:\n\n    {\n    \t\"log_level\":\"$LOG_LEVEL\"\n    }\n\nWhich of course is because of the double quotes in the jq command.  How do I escape them to let the variable through, but still end up with properly formatted json with the double quotes around the value?"
    ],
    "utterance": "Update the log_level field to the value of the LOG_LEVEL shell variable and ensure the output contains the variable's value, not the literal string \"$LOG_LEVEL\".",
    "expressions": [
      "jq --arg LOG_LEVEL \"$LOG_LEVEL\" '.log_level=$LOG_LEVEL' test.conf > test.conf.tmp && cp test.conf.tmp test.conf"
    ],
    "data": [
      {
        "input": {
          "log_level": "INFO"
        },
        "output": {
          "log_level": "WARN"
        }
      }
    ],
    "identifier": 67163254
  },
  {
    "context": [
      "But my challege here is I need to replace that values array with words in a text or csv file:",
      "My output needs to have (although I could probably get away with the words all on one line...):",
      "\"values\": [\n  \"this this this\",\n  \"is is\",\n  \"an an\",\n  \"array\"\n],",
      "jq --rawfile txt file '.data[].values |= ( $txt | split(\"\\n\")[:-1] | group_by(.) | map(join(\" \")) )' json",
      "produces\n\n{\n  \"data\": [\n    {\n      \"name\": \"table\",\n      \"values\": [\n        \"an an\",\n        \"array\",\n        \"is is\",\n        \"this this this\"\n      ]\n    }\n  ]\n}\n"
    ],
    "utterance": "Replace the values array so that each element is a group of identical adjacent words from the input file joined by spaces, resulting in [\"this this this\", \"is is\", \"an an\", \"array\"]",
    "expressions": [
      ".data[].values |= ( $txt | split(\"\\n\")[:-1] | group_by(.) | map(join(\" \")) )"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "table",
              "values": [
                "This is old data",
                "that needs to be",
                "replaced."
              ]
            }
          ]
        },
        "output": {
          "data": [
            {
              "name": "table",
              "values": [
                "an an",
                "array",
                "is is",
                "this this this"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67180122
  },
  {
    "context": [
      "I have a json file that is formatted in this way:\r\n\r\n    {\"key1\": \"value1\"}\r\n    {\"key2\": \"value2\"}\r\n    {\"key3\": \"value3\"}\r\n\r\nI would like to convert this json to csv. However, the keys in all the objects in the file are not the same. I have a list of all the possible keys but some of them may be missing in any json object.  So if that is the case I would like to just insert a null value for that column.",
      "I would like to convert example.json into a CSV file with all columns and would have null values for objects with any missing columns.",
      "If understood the problem correctly, what you can do is have a json file with all the keys set to null and then merge it with the file that has missing keys. You will then have a new json file with all the keys, which you can later convert to csv as usual.",
      "$keys, (inputs | [.[$keys[]]]) | @csv",
      "$ jq -sr '([.[] | keys[]] | unique) as $keys | $keys, (.[] | [.[$keys[]]]) | @csv' input.json"
    ],
    "utterance": "Convert a line-delimited file where each object may have missing keys into a CSV, using a predefined list of all possible keys as columns, inserting null for absent values.",
    "expressions": [
      "$keys, (inputs | [.[$keys[]]]) | @csv",
      "jq -sr '([.[] | keys[]] | unique) as $keys | $keys, (.[] | [.[$keys[]]]) | @csv'"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1",
            "key2": "value2"
          },
          {
            "key1": "value3",
            "key2": "value4",
            "key3": "value5"
          },
          {
            "key1": "value6",
            "key2": "value7",
            "key4": "value8"
          }
        ],
        "output": [
          [
            "key1",
            "key2",
            "key3",
            "key4"
          ],
          [
            "value1",
            "value2",
            null,
            null
          ],
          [
            "value3",
            "value4",
            "value5",
            null
          ],
          [
            "value6",
            "value7",
            null,
            "value8"
          ]
        ]
      }
    ],
    "identifier": 67164295
  },
  {
    "context": [
      "To remove duplicates and get ip and ports.",
      "Or can one explain to me how to get unique values from both IP and ports.",
      "group_by(.ip) | \nmap\n( \n  { \n    ip:    .[0].ip, \n    ports: [ .[].ports[].port ] | unique \n  } \n)",
      "Expected output\n[\n\t{\"ip:\" \"67.89.378.82\", \"ports:\"[2000, 2080]},\n\t{\"ip:\" \"78.45.196.23\", \"ports:\"[5060, 5080]}\n]"
    ],
    "utterance": "Get a list where each entry has a unique ip and all its unique ports.",
    "expressions": [
      "group_by(.ip) | map({ ip: .[0].ip, ports: [ .[].ports[].port ] | unique })"
    ],
    "data": [
      {
        "input": [
          {
            "ip": "78.45.196.23",
            "timestamp": "1616566245",
            "ports": [
              {
                "port": 5060,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 50
              }
            ]
          },
          {
            "ip": "67.89.378.82",
            "timestamp": "1616566255",
            "ports": [
              {
                "port": 2000,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 50
              }
            ]
          },
          {
            "ip": "67.89.378.82",
            "timestamp": "1616566255",
            "ports": [
              {
                "port": 2080,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 50
              }
            ]
          },
          {
            "ip": "78.45.196.23",
            "timestamp": "1616566245",
            "ports": [
              {
                "port": 5060,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 50
              }
            ]
          },
          {
            "ip": "67.89.378.82",
            "timestamp": "1616566255",
            "ports": [
              {
                "port": 2000,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 50
              }
            ]
          },
          {
            "ip": "78.45.196.23",
            "timestamp": "1616566245",
            "ports": [
              {
                "port": 5080,
                "proto": "tcp",
                "status": "open",
                "reason": "syn-ack",
                "ttl": 50
              }
            ]
          }
        ],
        "output": [
          {
            "ip": "67.89.378.82",
            "ports": [
              2000,
              2080
            ]
          },
          {
            "ip": "78.45.196.23",
            "ports": [
              5060,
              5080
            ]
          }
        ]
      }
    ],
    "identifier": 67193713
  },
  {
    "context": [
      "I would like to extract the \"name\" value only if \"id\"=\"2520949\" and \"lastReportedStatus\"=\"STOPPED\" using jq.",
      "In my example I would like to get \"name1\" and \"name3\".",
      "jq '.data[] \r\n        | select(.targets[] | .lastReportedStatus==\"STOPPED\" and .id==2520949)\r\n        | .name' file.json"
    ],
    "utterance": "Return the name for entries where at least one target has id 2520949 and lastReportedStatus STOPPED.",
    "expressions": [
      ".data[] | select(.targets[] | .lastReportedStatus==\"STOPPED\" and .id==2520949) | .name"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 60573936,
              "timeCreated": 1615458564202,
              "timeUpdated": 1615458564202,
              "name": "name1",
              "desiredStatus": "UNMANAGED",
              "defaultStatus": "STARTED",
              "targets": [
                {
                  "id": 2520949,
                  "lastReportedStatus": "STOPPED"
                },
                {
                  "id": 702881,
                  "lastReportedStatus": "STARTED"
                }
              ]
            },
            {
              "id": 60574370,
              "timeCreated": 1615458812565,
              "timeUpdated": 1615458812565,
              "name": "name2",
              "desiredStatus": "UNMANAGED",
              "defaultStatus": "STARTED",
              "targets": [
                {
                  "id": 2520949,
                  "lastReportedStatus": "STARTED"
                },
                {
                  "id": 702881,
                  "lastReportedStatus": "STOPPED"
                }
              ]
            },
            {
              "id": 60574329,
              "timeCreated": 1615458775053,
              "timeUpdated": 1615458775053,
              "name": "name3",
              "desiredStatus": "UNMANAGED",
              "defaultStatus": "STARTED",
              "targets": [
                {
                  "id": 2520949,
                  "lastReportedStatus": "STOPPED"
                },
                {
                  "id": 702881,
                  "lastReportedStatus": "STARTED"
                }
              ]
            }
          ]
        },
        "output": [
          "name1",
          "name3"
        ]
      }
    ],
    "identifier": 67203735
  },
  {
    "context": [
      "Wherever the below key and value pair are present in a file, the entire object should be removed.",
      "{ \"name\": \"exception\" }",
      "walk(if type==\"object\" and .name == \"exception\"\n         then empty else . end)",
      "Equivalently:",
      "walk(select(type==\"object\" and .name == \"exception\" | not))",
      "del(..|select(type==\"object\" and .name==\"exception\"))"
    ],
    "utterance": "Remove every object containing a key 'name' with value 'exception' from all levels of the data.",
    "expressions": [
      "walk(if type==\"object\" and .name == \"exception\" then empty else . end)",
      "walk(select(type==\"object\" and .name == \"exception\" | not))",
      "del(..|select(type==\"object\" and .name==\"exception\"))"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "id": "a21f5193-881e-11eb-a0c1-3726f4a71fa9",
              "retailerId": "1",
              "category": "exception",
              "context": {
                "sourceEvents": [
                  "902bd449-881e-11eb-b603-29eb6c297e7d"
                ],
                "entityType": "ORDER"
              },
              "eventStatus": "FAILED",
              "attributes": [
                {
                  "name": "exception",
                  "value": {
                    "code": 400,
                    "message": "Failed to execute http call",
                    "stackTrace": [
                      {
                        "fileName": "ReadOnlyFluentApiClient.java",
                        "className": "com.fluentretail.api.v2.client.ReadOnlyFluentApiClient"
                      }
                    ],
                    "suppressed": [],
                    "suppressedExceptions": []
                  },
                  "type": "OBJECT"
                },
                {
                  "name": "lastRule",
                  "value": "ETOSUAT.base.ProposedFulfilmentWithoutInventory",
                  "type": "String"
                },
                {
                  "name": "lastRuleSet",
                  "value": "FindAndCreateDigitalFulfilment",
                  "type": "String"
                },
                {
                  "name": "message",
                  "value": "Failed to execute http call",
                  "type": "String"
                }
              ],
              "source": null,
              "generatedBy": "Rubix User",
              "generatedOn": "2021-03-18T19:17:51.517+0000"
            },
            {
              "id": "a21f5193-881e-11eb-a0c1-3726f4a71fa9",
              "retailerId": "1",
              "category": "exception",
              "context": {
                "sourceEvents": [
                  "902bd449-881e-11eb-b603-29eb6c297e7d"
                ],
                "entityType": "ORDER"
              },
              "eventStatus": "FAILED",
              "attributes": [
                {
                  "name": "exception",
                  "value": {
                    "code": 400,
                    "message": "Failed to execute http call",
                    "stackTrace": [
                      {
                        "fileName": "ReadOnlyFluentApiClient.java",
                        "className": "com.fluentretail.api.v2.client.ReadOnlyFluentApiClient"
                      }
                    ],
                    "suppressed": [],
                    "suppressedExceptions": []
                  },
                  "type": "OBJECT"
                },
                {
                  "name": "lastRule",
                  "value": "ETOSUAT.base.ProposedFulfilmentWithoutInventory",
                  "type": "String"
                },
                {
                  "name": "lastRuleSet",
                  "value": "FindAndCreateDigitalFulfilment",
                  "type": "String"
                },
                {
                  "name": "message",
                  "value": "Failed to execute http call",
                  "type": "String"
                }
              ],
              "source": null,
              "generatedBy": "Rubix User",
              "generatedOn": "2021-03-18T19:17:51.517+0000"
            }
          ]
        },
        "output": {
          "results": [
            {
              "id": "a21f5193-881e-11eb-a0c1-3726f4a71fa9",
              "retailerId": "1",
              "category": "exception",
              "context": {
                "sourceEvents": [
                  "902bd449-881e-11eb-b603-29eb6c297e7d"
                ],
                "entityType": "ORDER"
              },
              "eventStatus": "FAILED",
              "attributes": [
                {
                  "name": "lastRule",
                  "value": "ETOSUAT.base.ProposedFulfilmentWithoutInventory",
                  "type": "String"
                },
                {
                  "name": "lastRuleSet",
                  "value": "FindAndCreateDigitalFulfilment",
                  "type": "String"
                },
                {
                  "name": "message",
                  "value": "Failed to execute http call",
                  "type": "String"
                }
              ],
              "source": null,
              "generatedBy": "Rubix User",
              "generatedOn": "2021-03-18T19:17:51.517+0000"
            },
            {
              "id": "a21f5193-881e-11eb-a0c1-3726f4a71fa9",
              "retailerId": "1",
              "category": "exception",
              "context": {
                "sourceEvents": [
                  "902bd449-881e-11eb-b603-29eb6c297e7d"
                ],
                "entityType": "ORDER"
              },
              "eventStatus": "FAILED",
              "attributes": [
                {
                  "name": "lastRule",
                  "value": "ETOSUAT.base.ProposedFulfilmentWithoutInventory",
                  "type": "String"
                },
                {
                  "name": "lastRuleSet",
                  "value": "FindAndCreateDigitalFulfilment",
                  "type": "String"
                },
                {
                  "name": "message",
                  "value": "Failed to execute http call",
                  "type": "String"
                }
              ],
              "source": null,
              "generatedBy": "Rubix User",
              "generatedOn": "2021-03-18T19:17:51.517+0000"
            }
          ]
        }
      }
    ],
    "identifier": 67071152
  },
  {
    "context": [
      "I am trying to get values base on key of this JSON:",
      "To add the keys into the mix you can use `to_entries`, which extracts the key/value pairs from an object:",
      "Pulling out the different fields then becomes:",
      "$ jq -c '.streams | to_entries[] | [.key, .value.version, .value.branch, .value.hash]' vs.json",
      "jq -c '.streams | to_entries[] | [.key, (.value | .version, .branch, .hash)]' vs.json"
    ],
    "utterance": "Extract an array with the key and the corresponding version, branch, and hash for each entry under the streams object.",
    "expressions": [
      ".streams | to_entries[] | [.key, .value.version, .value.branch, .value.hash]",
      ".streams | to_entries[] | [.key, (.value | .version, .branch, .hash)]"
    ],
    "data": [
      {
        "input": {
          "streams": {
            "vs-first": {
              "version": "2.33.0",
              "branch": "ewewew",
              "hash": "ewewewewe",
              "widgets": []
            },
            "vs-second": {
              "version": "1.58.0",
              "branch": "ewewew",
              "hash": "ewewew",
              "widgets": []
            },
            "vs-third": {
              "version": "1.42.0",
              "branch": "ewewew",
              "hash": "ewewe",
              "widgets": []
            },
            "vs-fourth": {
              "version": "1.58.0",
              "branch": "eewfwfef",
              "hash": "vvfffsfsf",
              "widgets": []
            },
            "vs-fifth": {
              "version": "1.39.0",
              "branch": "fvrvvsdvds",
              "hash": "vvsvdsvds",
              "widgets": [
                "1",
                "2",
                "3",
                "4"
              ]
            }
          }
        },
        "output": [
          [
            "vs-first",
            "2.33.0",
            "ewewew",
            "ewewewewe"
          ],
          [
            "vs-second",
            "1.58.0",
            "ewewew",
            "ewewew"
          ],
          [
            "vs-third",
            "1.42.0",
            "ewewew",
            "ewewe"
          ],
          [
            "vs-fourth",
            "1.58.0",
            "eewfwfef",
            "vvfffsfsf"
          ],
          [
            "vs-fifth",
            "1.39.0",
            "fvrvvsdvds",
            "vvsvdsvds"
          ]
        ]
      }
    ],
    "identifier": 67190912
  },
  {
    "context": [
      "I have two arrays in a structure but between elements of arrays has logical connections. (Eg. `comments[1]` belongs to `records[1]`, `comments[2]` belongs to `records[2]`)",
      "These arrays are sorted by alpabetical order of records array.",
      "When I want to add a new element for both array then I have sort both arrays. For records array it is easy, but the elements of comments array have to move same way as each element of record.",
      "Expected sorted output:",
      "{\r\n  \"records\":[\r\n     {\"content\":\"a\"},\r\n     {\"content\":\"b\"},\r\n     {\"content\":\"z\"}\r\n  ],\r\n  \"comments\":[\r\n     {\"content\":\"something\"},\r\n     {\"content\":\"new element\"},\r\n     {\"content\":\"anything\"}\r\n  ]\r\n}",
      "You might find this helper function useful:\r\n\r\n    def insert($x;$i): .[:$i]+[$x]+.[$i:];",
      "Here then is a solution for the problem at hand:",
      "def insert_into_sorted($x; f; $y; g):\r\n  def insert($x;$i): .[:$i]+[$x]+.[$i:];\r\n  (f|bsearch($x)) as $ix\r\n  | (if $ix > -1 then $ix else -1 - $ix end) as $i\r\n  | f|=insert($x; $i)\r\n  | g|=insert($y; $i) ;\r\n\r\ninsert_into_sorted( {\"content\": \"b\"}; .records; \r\n                    {\"content\": \"new element\"}; .comments)"
    ],
    "utterance": "Insert a new record with content \"b\" and its comment at the correct position in the records array sorted by content, keeping comments aligned with their corresponding record.",
    "expressions": [
      "def insert_into_sorted($x; f; $y; g):\n  def insert($x;$i): .[:$i]+[$x]+.[$i:];\n  (f|bsearch($x)) as $ix\n  | (if $ix > -1 then $ix else -1 - $ix end) as $i\n  | f|=insert($x; $i)\n  | g|=insert($y; $i) ;\n\ninsert_into_sorted( {\"content\": \"b\"}; .records; {\"content\": \"new element\"}; .comments)"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "content": "a"
            },
            {
              "content": "z"
            },
            {
              "content": "b"
            }
          ],
          "comments": [
            {
              "content": "something"
            },
            {
              "content": "anything"
            },
            {
              "content": "new element"
            }
          ]
        },
        "output": {
          "records": [
            {
              "content": "a"
            },
            {
              "content": "b"
            },
            {
              "content": "z"
            }
          ],
          "comments": [
            {
              "content": "something"
            },
            {
              "content": "new element"
            },
            {
              "content": "anything"
            }
          ]
        }
      }
    ],
    "identifier": 67194822
  },
  {
    "context": [
      "I am trying to convert JSON file from the command below to CSV format:",
      "desired output is like:",
      "1619094720  0.01738857  0.01742868  0.01742868  0.01737360  1.24151689  0.0215974650849251  BCHBTC",
      "There is no need for `to_entries`, just apply the filter directly to the arrays, e.g.:",
      "jq -r '.data[] | .[0:-1] | map(tonumber) | @tsv'",
      "jq -r '.data[] | @tsv' solved the problem, thanks @ Inian"
    ],
    "utterance": "Print each sub-array in the data field as a line of tab-separated values, preserving all values as shown in the example output.",
    "expressions": [
      ".data[] | @tsv"
    ],
    "identifier": 67215109
  },
  {
    "context": [
      "What I need is to replace the field `roles` with two new fields: `roleRead` and `roleWrite` where this new fields will have corresponding values from the array.",
      "One way would be to add the objects together with the `.roles` array and delete it after",
      ".categories[][].resources[] |= ( \n  . + { readRole: .roles[0], writeRole: .roles[1] } | del(.roles)\n)"
    ],
    "utterance": "Replace the 'roles' array in every resource with 'readRole' and 'writeRole' fields using the first and second values of the original array.",
    "expressions": [
      ".categories[][].resources[] |= ( . + { readRole: .roles[0], writeRole: .roles[1] } | del(.roles) )"
    ],
    "data": [
      {
        "input": {
          "base": "/templates",
          "title": "Templates",
          "categories": {
            "category1": {
              "propertiesResources": {
                "resources": {
                  "cliTemplate": {
                    "type": "CLIENT",
                    "path": "properties/cli.json",
                    "roles": [
                      "ROLE_SYSTEM_READ",
                      "ROLE_SYSTEM_WRITE"
                    ]
                  },
                  "viewerTemplate": {
                    "type": "SERVER",
                    "path": "properties/server.json",
                    "roles": [
                      "ROLE_CONFIGURATOR_READ",
                      "ROLE_CONFIGURATOR_WRITE"
                    ]
                  }
                }
              }
            }
          }
        },
        "output": {
          "base": "/templates",
          "title": "Templates",
          "categories": {
            "category1": {
              "propertiesResources": {
                "resources": {
                  "cliTemplate": {
                    "type": "CLIENT",
                    "path": "properties/cli.json",
                    "readRole": "ROLE_SYSTEM_READ",
                    "writeRole": "ROLE_SYSTEM_WRITE"
                  },
                  "viewerTemplate": {
                    "type": "SERVER",
                    "path": "properties/server.json",
                    "readRole": "ROLE_CONFIGURATOR_READ",
                    "writeRole": "ROLE_CONFIGURATOR_WRITE"
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 67208669
  },
  {
    "context": [
      "We are doing this with jq, like this: \n```\njq -Rs \\\n   --arg contentFormat \"xml\" \\\n   '{properties: {format: $contentFormat, value: . }}' <${policy}\n```",
      "Try this:\n\n    policy=`cat <path of file>/test.xml`\n    jq -Rs    --arg contentFormat \"rawxml\"    '{properties: {format: $contentFormat, value: . }}' <<< $policy"
    ],
    "utterance": "Create an object with properties.format set to 'rawxml' and properties.value containing the literal contents of an XML file.",
    "expressions": [
      "jq -Rs --arg contentFormat \"rawxml\" '{properties: {format: $contentFormat, value: . }}' <<< \"$policy\""
    ],
    "identifier": 67229148
  },
  {
    "context": [
      "I\u0019m expecting the output of the JQ query to be in a [SARIF](https://docs.oasis-open.org/sarif/sarif/v2.1.0/sarif-v2.1.0.html) format as below:",
      "Once the missing closing braces and brackets (`}}]}`) are added to your script, it is possible to start fixing it. You are trying to iterate over a nested `.Summary[]` array, even though you are already iterating over the top level one.",
      "So instead of doing `.Summary[] | .SummaryId` in the inner levels, access `.SummaryId` directly, because you are already in the context of a single list item. (or `.summaryId`? unclear from your example, you mix both cases.",
      "rules: .Summary\n    | map(select(.FilePath != \".\"))\n    | map({\n        id: .SummaryId,\n        help: {\n            text: .Description,\n            markdown: .Description\n        },\n        properties: {\n            tags: [\n                if (.SummaryId//.summaryId) | contains(\"prod\")? then \"prod\"\n                else \"test\" end\n            ]\n        },\n        results: [\n            {\n                ruleId: (.SummaryId//.summaryId),\n                level: \"warning\",\n                locations: [\n                    {\n                        physicalLocation: {\n                            artifactLocation: {\n                                uri: .FilePath\n                            },\n                            region: {\n                                startLine: .StartLine,\n                                endLine: .EndLine\n                            }\n                        }\n                    }\n                ],\n                message: {\n                    text: .Description | split(\".\") | first\n                }\n            }\n        ]\n    })"
    ],
    "utterance": "Transform an object with a Summary array of findings into a SARIF object with rules and results formatted as specified, using appropriate ids, descriptions, file paths, line numbers, and tags based on prod or test in ids.",
    "expressions": [
      "{\n    version: \"2.1.0\",\n    \"$schema\": \"http://json.schemastore.org/sarif-2.1.0-rtm.4\",\n    runs: [\n        {\n            tool: {\n                driver: {\n                    name: \"Tool Name\",\n                    informationUri: \"google.com\",\n                    rules: .Summary\n                        | map(select(.FilePath != \".\"))\n                        | map({\n                            id: (.SummaryId // .summaryId // .RecommendationId),\n                            help: {\n                                text: .Description,\n                                markdown: .Description\n                            },\n                            properties: {\n                                tags: [\n                                    if ((.SummaryId // .summaryId // .RecommendationId) | contains(\"prod\")) then \"prod\"\n                                    else \"test\" end\n                                ]\n                            }\n                        })\n                }\n            },\n            results: (.Summary | map(select(.FilePath != \".\")) | map({\n                ruleId: (.SummaryId // .summaryId // .RecommendationId),\n                level: \"warning\",\n                locations: [\n                    {\n                        physicalLocation: {\n                            artifactLocation: {\n                                uri: .FilePath\n                            },\n                            region: {\n                                startLine: .StartLine,\n                                endLine: .EndLine\n                            }\n                        }\n                    }\n                ],\n                message: {\n                    text: .Description | split(\".\") | first\n                }\n            }))\n        }\n    ]\n}"
    ],
    "data": [
      {
        "input": {
          "Summary": [
            {
              "FilePath": "src/main/java/com/mycompany/app/App.java",
              "summaryId": "prod-123",
              "StartLine": 26,
              "EndLine": 26,
              "Description": "Okay"
            },
            {
              "FilePath": "src/main/java/com/mycompany/app/App.java",
              "RecommendationId": "test-321",
              "StartLine": 26,
              "EndLine": 26,
              "Description": "Bad"
            }
          ]
        },
        "output": {
          "version": "2.1.0",
          "$schema": "http://json.schemastore.org/sarif-2.1.0-rtm.4",
          "runs": [
            {
              "tool": {
                "driver": {
                  "name": "Tool Name",
                  "informationUri": "google.com",
                  "rules": [
                    {
                      "id": "prod-123",
                      "help": {
                        "text": "Okay",
                        "markdown": "Okay"
                      },
                      "properties": {
                        "tags": [
                          "prod"
                        ]
                      }
                    },
                    {
                      "id": "test-321",
                      "help": {
                        "text": "Bad",
                        "markdown": "Bad"
                      },
                      "properties": {
                        "tags": [
                          "test"
                        ]
                      }
                    }
                  ]
                }
              },
              "results": [
                {
                  "ruleId": "prod-123",
                  "level": "warning",
                  "locations": [
                    {
                      "physicalLocation": {
                        "artifactLocation": {
                          "uri": "src/main/java/com/mycompany/app/App.java"
                        },
                        "region": {
                          "startLine": 26,
                          "endLine": 26
                        }
                      }
                    }
                  ],
                  "message": {
                    "text": "Okay"
                  }
                },
                {
                  "ruleId": "test-321",
                  "level": "warning",
                  "locations": [
                    {
                      "physicalLocation": {
                        "artifactLocation": {
                          "uri": "src/main/java/com/mycompany/app/App.java"
                        },
                        "region": {
                          "startLine": 26,
                          "endLine": 26
                        }
                      }
                    }
                  ],
                  "message": {
                    "text": "Bad"
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67122766
  },
  {
    "context": [
      "The line doing that is:\r\n\r\n    cat &lt;&lt;&lt; $(jq '.eslintConfig.extends=\"@gbrachetta/eslint-config\" | .+ {prettier: \"@gbrachetta/prettier-config\"}' package.json) > package.json",
      "Simply use `jq` directly, without `cat` and without any indirections:",
      "jq '.eslintConfig.extends=\"@gbrachetta/eslint-config\" | . + {prettier: \"@gbrachetta/prettier-config\"}' package.json > package.json.tmp\r\nmv package.json.tmp package.json"
    ],
    "utterance": "Overwrite the file so that the eslintConfig.extends property is set to \"@gbrachetta/eslint-config\" and add a prettier property with the value \"@gbrachetta/prettier-config\", preserving formatting.",
    "expressions": [
      "jq '.eslintConfig.extends=\"@gbrachetta/eslint-config\" | . + {prettier: \"@gbrachetta/prettier-config\"}' package.json > package.json.tmp\nmv package.json.tmp package.json"
    ],
    "identifier": 67237200
  },
  {
    "context": [
      "Here is the following code: \n```read VPC_ID VPC_CIDR VPC_NAME <<<$(aws ec2 describe-vpcs --filters \"Name=tag:Name,Values=${AWS_PROFILE}-vpc\" --output json | jq -r '.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==\"Name\")|.Value)')```",
      "When I run ```aws ec2 describe-vpcs --filters \"Name=tag:Name,Values=${AWS_PROFILE}-vpc\" --output json | jq -r '.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==\"Name\")|.Value)'``` \n\nI get my expected output...",
      "aws ec2 describe-vpcs --filters \"Name=tag:Name,Values=${AWS_PROFILE}-vpc\" --output json \\\n  | jq -r '.Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==\"Name\")|.Value)'"
    ],
    "utterance": "Extract VpcId, CidrBlock, and the value of the tag with Key equal to Name from each element in the Vpcs array.",
    "expressions": [
      ".Vpcs[] | .VpcId,.CidrBlock, (.Tags[]|select(.Key==\"Name\")|.Value)"
    ],
    "identifier": 67237070
  },
  {
    "context": [
      "So I have the following JSON:\r\n\r\n    {\r\n      \"key1\" : { \r\n         \"someKey\": \"someValue\"\r\n      },\r\n      \"key2\" : { \r\n         \"someKey\": \"someValue\"\r\n      }\r\n    }",
      "and the output that I'm looking for is:\r\n\r\n    [\r\n      { \r\n         \"someKey\": \"someValue\",\r\n         \"$key\" : \"key1\"\r\n      },\r\n      { \r\n         \"someKey\": \"someValue\",\r\n         \"$key\" : \"key2\"\r\n      }\r\n    ]",
      "So basically I need to append the 'key' to the value as a separate property in the value of that key's object using jq.",
      "I found the solution using the following command:\r\n\r\n[ to_entries[] | {\"$key\": .key} * .value ]"
    ],
    "utterance": "Produce an array of objects where each object includes all properties from each original value along with a new \"$key\" property set to its original top-level key.",
    "expressions": [
      "[ to_entries[] | {\"$key\": .key} * .value ]"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "someKey": "someValue"
          },
          "key2": {
            "someKey": "someValue"
          }
        },
        "output": [
          {
            "someKey": "someValue",
            "$key": "key1"
          },
          {
            "someKey": "someValue",
            "$key": "key2"
          }
        ]
      }
    ],
    "identifier": 67232668
  },
  {
    "context": [
      "I have json like this:",
      "To import into the db (BigQuery), I would like them formatted like:",
      "We can't have the unnecessary arrays around each key/value object, we can't import nested arrays in BigQuery, and here they are redundant.",
      "I would like this all in done in jq.",
      "The direct, efficient, and robust approach:",
      ".searchResult |= map(to_entries[])"
    ],
    "utterance": "Convert objects inside the searchResult array to key/value objects without introducing extra arrays around each key/value object.",
    "expressions": [
      ".searchResult |= map(to_entries[])"
    ],
    "data": [
      {
        "input": {
          "searchResult": [
            {
              "mac": "xx:xx:xx:xx:xx:xx"
            },
            {
              "time": "2021_04_11 23:45:01"
            },
            {
              "field_1": "87"
            }
          ]
        },
        "output": {
          "searchResult": [
            {
              "key": "mac",
              "value": "xx:xx:xx:xx:xx:xx"
            },
            {
              "key": "time",
              "value": "2021_04_11 23:45:01"
            },
            {
              "key": "field_1",
              "value": "87"
            }
          ]
        }
      },
      {
        "input": {
          "searchResult": [
            {
              "mac": "xx:xx:xx:xx:xx:xx"
            },
            {
              "time": "2021_04_11 01:10:29"
            },
            {
              "field_2": "Some text"
            },
            {
              "field_3": "8"
            }
          ]
        },
        "output": {
          "searchResult": [
            {
              "key": "mac",
              "value": "xx:xx:xx:xx:xx:xx"
            },
            {
              "key": "time",
              "value": "2021_04_11 01:10:29"
            },
            {
              "key": "field_2",
              "value": "Some text"
            },
            {
              "key": "field_3",
              "value": "8"
            }
          ]
        }
      }
    ],
    "identifier": 67239806
  },
  {
    "context": [
      "I am required to print it as a table. I have managed to come up with below query using jq in BASH to print the data in TOTAL section but unable to get headers including AN,BN part(whats the technical term?) of JSON.",
      "required format for output:\n\n      Name           Total\n    \n        -----------------------------------\n    \n        AN        xxxxxxx\n    \n        BN        xxxxxxx\n",
      "jq -r 'to_entries[] |\n  [.key,\n   (.value | .total | \"\\(.confirmed)-\\(.deceased)-\\(.recovered)-\\(.tested)\")]|@tsv' input.json\nAN\t5527-65-5309-357442\nBN\t5527-65-5309-357442"
    ],
    "utterance": "Print each top-level object key and its .total values concatenated as confirmed-deceased-recovered-tested, one line per key.",
    "expressions": [
      "to_entries[] | [.key, (.value | .total | \"\\(.confirmed)-\\(.deceased)-\\(.recovered)-\\(.tested)\")] | @tsv"
    ],
    "data": [
      {
        "input": {
          "AN": {
            "delta7": {
              "confirmed": 238,
              "deceased": 2,
              "recovered": 199,
              "tested": 9953,
              "vaccinated": 24243
            },
            "districts": {
              "Unknown": {
                "delta7": {
                  "confirmed": 238,
                  "deceased": 2,
                  "recovered": 199,
                  "tested": 9953
                },
                "meta": {
                  "tested": {
                    "last_updated": "2021-04-21",
                    "source": "https://dhs.andaman.gov.in/NewEvents/642.pdf"
                  }
                },
                "total": {
                  "confirmed": 5527,
                  "deceased": 65,
                  "recovered": 5309,
                  "tested": 357442
                }
              }
            },
            "meta": {
              "last_updated": "2021-04-23T00:10:19+05:30",
              "population": 397000,
              "tested": {
                "last_updated": "2021-04-21",
                "source": "https://dhs.andaman.gov.in/NewEvents/642.pdf"
              }
            },
            "total": {
              "confirmed": 5527,
              "deceased": 65,
              "recovered": 5309,
              "tested": 357442,
              "vaccinated": 91977
            }
          },
          "BN": {
            "delta7": {
              "confirmed": 238,
              "deceased": 2,
              "recovered": 199,
              "tested": 9953,
              "vaccinated": 24243
            },
            "districts": {
              "Unknown": {
                "delta7": {
                  "confirmed": 238,
                  "deceased": 2,
                  "recovered": 199,
                  "tested": 9953
                },
                "meta": {
                  "tested": {
                    "last_updated": "2021-04-21",
                    "source": "https://dhs.andaman.gov.in/NewEvents/642.pdf"
                  }
                },
                "total": {
                  "confirmed": 5527,
                  "deceased": 65,
                  "recovered": 5309,
                  "tested": 357442
                }
              }
            },
            "meta": {
              "last_updated": "2021-04-23T00:10:19+05:30",
              "population": 397000,
              "tested": {
                "last_updated": "2021-04-21",
                "source": "https://dhs.andaman.gov.in/NewEvents/642.pdf"
              }
            },
            "total": {
              "confirmed": 5527,
              "deceased": 65,
              "recovered": 5309,
              "tested": 357442,
              "vaccinated": 91977
            }
          }
        },
        "output": "AN\t5527-65-5309-357442\nBN\t5527-65-5309-357442"
      }
    ],
    "identifier": 67231685
  },
  {
    "context": [
      "There will be a max of 4 environments that I want to be shown even if there are no content within them, and example output can be found below the structure.",
      "The categories also have a predefined key:value structure that follows:",
      "Application (keys): domain, host, user",
      "Utility: domain, health, version",
      "Middleware: name, release",
      "System: name, tag",
      "even in environments that don&#39;t have information, the &#39;template&#39; of middleware, system, application and utility (lets call these categories) is still there.",
      "jq would be invoked with `-nR`.",
      "def initial:\n  null\n  | .[\"DEV\", \"SIT\", \"UAT\", \"PROD\"][\"Middleware\", \"System\", \"Application\", \"Utility\"] = [];",
      "def objectify($keys):\n  . as $in\n  | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = ($in[$i]) );",
      "def object:\n  .[0] as $top\n  | .[1:] \n  | if   $top == \"Middleware\"  then objectify([\"name\", \"release\"])\n    elif $top == \"System\"      then objectify([\"domain\", \"tag\"])\n    elif $top == \"Application\" then objectify([\"domain\", \"host\", \"user\"])\n    elif $top == \"Utility\"     then objectify([\"domain\", \"health\", \"version\"])\n    else objectify( map(tostring) )  # or raise an error, or ...\n    end;",
      "reduce (inputs | split(\",\")) as $line (initial;\n  getpath($line[0:2]) as $v\n  | setpath($line[0:2]; $v + [$line[1:] | object] ))\n| {ENV: .}",
      "def categories:\n    { \"Middleware\":  [\"name\", \"release\"],\n      \"System\":      [\"domain\", \"tag\"],\n      \"Application\": [\"domain\", \"host\", \"user\"],\n      \"Utility\":    [\"domain\", \"health\", \"version\"] };",
      "def initial:\n  null\n  | .[\"DEV\", \"SIT\", \"UAT\", \"PROD\"][ categories | keys[]] = [];",
      "def object:\n  categories[.[0]] as $keys\n  | .[1:] \n  | objectify($keys // [range(0;length) | tostring]);",
      "reduce (inputs | split(\",\")) as $line (initial;\n  getpath($line[0:2]) as $v\n  | setpath($line[0:2]; $v + [$line[1:] | object] ))\n| {ENV: .}"
    ],
    "utterance": "Convert lines of text specifying environment, category, and values into a structure where all four environments each always contain the four categories as keys (populated or empty), and for each category, parse values into objects with category-dependent keys.",
    "expressions": [
      "def initial:\n  null\n  | .[\"DEV\", \"SIT\", \"UAT\", \"PROD\"][\"Middleware\", \"System\", \"Application\", \"Utility\"] = [];\n\ndef objectify($keys):\n  . as $in\n  | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = ($in[$i]) );\n\ndef object:\n  .[0] as $top\n  | .[1:] \n  | if   $top == \"Middleware\"  then objectify([\"name\", \"release\"])\n    elif $top == \"System\"      then objectify([\"domain\", \"tag\"])\n    elif $top == \"Application\" then objectify([\"domain\", \"host\", \"user\"])\n    elif $top == \"Utility\"     then objectify([\"domain\", \"health\", \"version\"])\n    else objectify( map(tostring) )  # or raise an error, or ...\n    end;\n\nreduce (inputs | split(\",\")) as $line (initial;\n  getpath($line[0:2]) as $v\n  | setpath($line[0:2]; $v + [$line[1:] | object] ))\n| {ENV: .}",
      "def categories:\n    { \"Middleware\":  [\"name\", \"release\"],\n      \"System\":      [\"domain\", \"tag\"],\n      \"Application\": [\"domain\", \"host\", \"user\"],\n      \"Utility\":    [\"domain\", \"health\", \"version\"] };\n\ndef initial:\n  null\n  | .[\"DEV\", \"SIT\", \"UAT\", \"PROD\"][ categories | keys[]] = [];\n\ndef objectify($keys):\n  . as $in\n  | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = ($in[$i]) );\n\ndef object:\n  categories[.[0]] as $keys\n  | .[1:] \n  | objectify($keys // [range(0;length) | tostring]);\n\nreduce (inputs | split(\",\")) as $line (initial;\n  getpath($line[0:2]) as $v\n  | setpath($line[0:2]; $v + [$line[1:] | object] ))\n| {ENV: .}"
    ],
    "data": [
      {
        "input": [
          "DEV,Middleware,Mqwerty,Mqwerty",
          "DEV,Middleware,Mqwerty,Mqwerty",
          "DEV,Middleware,Mqwerty,Mqwerty",
          "DEV,System,Sqwerty,Sqwerty",
          "DEV,Application,Aqwerty,Aqwerty,Aqwerty",
          "UAT,Application,Aqwerty,Aqwerty,Aqwerty",
          "DEV,Utility,Uqwerty,Uqwerty,Uqwerty",
          "PROD,Middleware,Mqwerty,Mqwerty",
          "DEV,Middleware,Mqwerty,Mqwerty"
        ],
        "output": {
          "ENV": {
            "DEV": {
              "Middleware": [
                {
                  "name": "Mqwerty",
                  "release": "Mqwerty"
                },
                {
                  "name": "Mqwerty",
                  "release": "Mqwerty"
                },
                {
                  "name": "Mqwerty",
                  "release": "Mqwerty"
                },
                {
                  "name": "Mqwerty",
                  "release": "Mqwerty"
                }
              ],
              "System": [
                {
                  "domain": "Sqwerty",
                  "tag": "Sqwerty"
                }
              ],
              "Application": [
                {
                  "domain": "Aqwerty",
                  "host": "Aqwerty",
                  "user": "Aqwerty"
                }
              ],
              "Utility": [
                {
                  "domain": "Uqwerty",
                  "health": "Uqwerty",
                  "version": "Uqwerty"
                }
              ]
            },
            "SIT": {
              "Middleware": [],
              "System": [],
              "Application": [],
              "Utility": []
            },
            "UAT": {
              "Middleware": [],
              "System": [],
              "Application": [
                {
                  "domain": "Aqwerty",
                  "host": "Aqwerty",
                  "user": "Aqwerty"
                }
              ],
              "Utility": []
            },
            "PROD": {
              "Middleware": [
                {
                  "name": "Mqwerty",
                  "release": "Mqwerty"
                }
              ],
              "System": [],
              "Application": [],
              "Utility": []
            }
          }
        }
      }
    ],
    "identifier": 67102884
  },
  {
    "context": [
      "It looks like you just want the top-level keys with scalar values, so, using jq, you could write:",
      "jq -r '\n  ((.recipes[0]\n    | with_entries(select(.value|scalars)))\n    | keys_unsorted) as $keys\n  | $keys,\n    (.recipes[] | [ .[$keys[]] ])\n  | @csv\n'",
      "This produces a row of headers, and assumes that the objects under `.recipes` are sufficiently conformal.",
      "I'm expecting a JSON that I can convert to CSV:\n\nand get the following as headers:",
      "\"vegetarian\"\n\"vegan\"\n\"glutenFree\"\n\"dairyFree\"\n\"veryHealthy\"\n\"cheap\"\n\"veryPopular\"\n\"sustainable\"\n\"weightWatcherSmartPoints\"\n\"gaps\"\n\"lowFodmap\"\n\"aggregateLikes\"\n\"spoonacularScore\"\n\"healthScore\"\n\"pricePerServing\"",
      "\"id\"\n\"title\": \n\"readyInMinutes\"\n\"servings\"\n\"sourceUrl\"\n\"image\"\n\"summary\"\n\"cuisines\"\n\"dishTypes\"\n\"diets\"\n\"occasions\"\n\"instructions\""
    ],
    "utterance": "Extract all top-level scalar fields from each recipe and output them as CSV with a header row.",
    "expressions": [
      "jq -r '((.recipes[0] | with_entries(select(.value|scalars))) | keys_unsorted) as $keys | $keys, (.recipes[] | [ .[$keys[]] ]) | @csv'"
    ],
    "data": [
      {
        "input": {
          "recipes": [
            {
              "vegetarian": true,
              "vegan": true,
              "glutenFree": true,
              "dairyFree": true,
              "veryHealthy": false,
              "cheap": false,
              "veryPopular": false,
              "sustainable": false,
              "weightWatcherSmartPoints": 4,
              "gaps": "no",
              "lowFodmap": false,
              "aggregateLikes": 224,
              "spoonacularScore": 55.0,
              "healthScore": 7.0,
              "creditsText": "Full Belly Sisters",
              "license": "CC BY-SA 3.0",
              "sourceName": "Full Belly Sisters",
              "pricePerServing": 138.79,
              "extendedIngredients": [
                {
                  "id": 2069,
                  "aisle": "Oil, Vinegar, Salad Dressing",
                  "image": "balsamic-vinegar.jpg",
                  "consistency": "liquid",
                  "name": "balsamic vinegar",
                  "nameClean": "balsamic vinegar",
                  "original": "2T balsamic vinegar",
                  "originalString": "2T balsamic vinegar",
                  "originalName": "balsamic vinegar",
                  "amount": 2.0,
                  "unit": "T",
                  "meta": [],
                  "metaInformation": [],
                  "measures": {
                    "us": {
                      "amount": 2.0,
                      "unitShort": "Tbsps",
                      "unitLong": "Tbsps"
                    },
                    "metric": {
                      "amount": 2.0,
                      "unitShort": "Tbsps",
                      "unitLong": "Tbsps"
                    }
                  }
                }
              ],
              "id": 716413,
              "title": "Oven Roasted Tomato Sauce",
              "readyInMinutes": 45,
              "servings": 4,
              "sourceUrl": "http://fullbellysisters.blogspot.com/2011/10/oven-roasted-tomato-sauce.html",
              "image": "https://spoonacular.com/recipeImages/716413-556x370.jpg",
              "imageType": "jpg",
              "summary": "Oven Roasted Tomato Sauce might be just the sauce you are searching for.",
              "cuisines": [],
              "dishTypes": [
                "sauce"
              ],
              "diets": [
                "gluten free",
                "dairy free",
                "paleolithic",
                "lacto ovo vegetarian",
                "primal",
                "vegan"
              ],
              "occasions": [],
              "instructions": "",
              "analyzedInstructions": [],
              "originalId": null,
              "spoonacularSourceUrl": "https://spoonacular.com/oven-roasted-tomato-sauce-716413"
            }
          ]
        }
      }
    ],
    "identifier": 67169611
  },
  {
    "context": [
      "How do I filter using jq which contains string \"edp-api-dev\"",
      "aws ecs list-services --cluster splat-dev --profile mfa | jq -r '.serviceArns[] | select( . | contains(\"edp-api-dev\")'",
      "I forgot the closing parenthesis:",
      "jq -r '.serviceArns[] | select(contains(\"edp-api-dev\"))'"
    ],
    "utterance": "List all values in serviceArns that contain the substring \"edp-api-dev\".",
    "expressions": [
      ".serviceArns[] | select(contains(\"edp-api-dev\"))"
    ],
    "data": [
      {
        "input": {
          "serviceArns": [
            "arn:aws:ecs:us-east-1:1234:service/splat-dev/abc-api-dev-ecs-abc-api-man-1920299",
            "arn:aws:ecs:us-east-1:1234:service/edp-api-dev-ecs-edp-api-man-721g8a7d",
            "arn:aws:ecs:us-east-1:1234:service/tsm-frontend-dev-ecs-tsm-frontend-man",
            "arn:aws:ecs:us-east-1:1234:service/doc-svc-dev-ecs-doc-svc-man",
            "arn:aws:ecs:us-east-1:1234:service/wwk-frontend-dev-ecs-wwk-frontend-man-8fea6a0b",
            "arn:aws:ecs:us-east-1:1234:service/xyaz-fsse-ecs-xyaz-fsse-man"
          ]
        },
        "output": "arn:aws:ecs:us-east-1:1234:service/edp-api-dev-ecs-edp-api-man-721g8a7d"
      }
    ],
    "identifier": 67250481
  },
  {
    "context": [
      "So the question is, how to pretty-print without such preprocessing?",
      "Or (would be better in this particular case) how to merge keys and values in one big JSON, where Redis keys, accessible on the upper level, will be followed by dicts of their values?",
      "cat file | jq --raw-input --raw-output '. as $raw | try fromjson catch $raw'",
      "cat file \\\n    | jq --raw-input --null-input '[inputs] | _nwise(2) | {(.[0]): .[1] | fromjson}' \\\n    | jq --null-input '[inputs] | add'",
      "cat file | jq --raw-input --null-input     '[ [inputs] | _nwise(2) | {(.[0]): .[1] | fromjson} ] | add'"
    ],
    "utterance": "Merge alternating string keys and serialized value lines into one object with keys from the odd lines and values parsed from the even lines.",
    "expressions": [
      "[ [inputs] | _nwise(2) | {(.[0]): .[1] | fromjson} ] | add"
    ],
    "data": [
      {
        "input": [
          "redis_key1",
          "{\"value1__key1\": \"value1__value1\", \"value1__key2\": \"value1__value2\"}",
          "redis_key2",
          "{\"value2__key1\": \"value2__value1\", \"value2__key2\": \"value2__value2\"}"
        ],
        "output": {
          "redis_key1": {
            "value1__key1": "value1__value1",
            "value1__key2": "value1__value2"
          },
          "redis_key2": {
            "value2__key1": "value2__value1",
            "value2__key2": "value2__value2"
          }
        }
      }
    ],
    "identifier": 67263181
  },
  {
    "context": [
      "I have a JSON file and a text file as shown below :",
      "Using jq, I want to add values of values.txt as an array to the symbols field of the json.",
      "The last jq command fails because the values in values.txt are not enclosed by \"\" .",
      "Is there any way to add double quotes without changing values.txt?",
      "< input.json jq --rawfile text values.txt '.symbols = [$text|splits(\"\\n\")|select(length>0)] | .symbols_count = (.symbols|length)'"
    ],
    "utterance": "Set the symbols field to an array of all non-empty lines from the text file, and set symbols_count to the number of such lines.",
    "expressions": [
      "< input.json jq --rawfile text values.txt '.symbols = [$text|splits(\"\\n\")|select(length>0)] | .symbols_count = (.symbols|length)'"
    ],
    "data": [
      {
        "input": {
          "symbols": null,
          "symbols_count": null
        },
        "output": {
          "symbols": [
            "VALUE1",
            "VALUE2",
            "VALUE3"
          ],
          "symbols_count": 3
        }
      }
    ],
    "identifier": 67269732
  },
  {
    "context": [
      "If u look at the output particularly in `compile` key it has \" in beginning and in the end, which break breaks python code, which consumes this, i need to get rid of the double quotes within compile, any help aprreaciated.",
      "To create an array from that string, use;\ncompile: $c | split(\",\")",
      "Will produce:\n{ \"brfc_tag\": \"\", \"upload_to\": \"s3\", \"compile\": [ \"bfc\", \"punch\", \"mld\", \"extended_mld\", \"chargingstation\", \"ch\" ], \"region\": \"world\", \"project\": \"bfc\" }"
    ],
    "utterance": "Create an array from the string 'bfc,punch,mld,extended_mld,chargingstation,ch' so that each value becomes an element and there are no extra quotes.",
    "expressions": [
      "$c | split(\",\")"
    ],
    "data": [
      {
        "input": {
          "TEST": "bfc,punch,mld,extended_mld,chargingstation,ch"
        },
        "output": [
          "bfc",
          "punch",
          "mld",
          "extended_mld",
          "chargingstation",
          "ch"
        ]
      }
    ],
    "identifier": 67264339
  },
  {
    "context": [
      "but the email address is not returning in an array as I need.",
      "Desired output:",
      "\"to\": [ {\"email\": \"some-email1@gmail.com\"} ]",
      "Replace `.to` with `[.to]`",
      "jq --slurp '{\"personalizations\": [.[].root | .to = [.to]]}'"
    ],
    "utterance": "For each item, wrap the 'to' object in an array so that 'to' becomes a one-element array containing the original object.",
    "expressions": [
      "[.[].root | .to = [.to]]"
    ],
    "data": [
      {
        "input": [
          {
            "root": {
              "to": {
                "email": "some-email1@gmail.com"
              },
              "dynamic_template_data": {
                "FIRSTNAME": "BLANCA",
                "last_4": "9999",
                "OFFERCODE": "88888888888888888"
              }
            }
          },
          {
            "root": {
              "to": {
                "email": "some-other-email1@gmail.com"
              },
              "dynamic_template_data": {
                "FIRSTNAME": "Michael",
                "last_4": "8888",
                "OFFERCODE": "9999999999999999999999"
              }
            }
          }
        ],
        "output": [
          {
            "to": [
              {
                "email": "some-email1@gmail.com"
              }
            ],
            "dynamic_template_data": {
              "FIRSTNAME": "BLANCA",
              "last_4": "9999",
              "OFFERCODE": "88888888888888888"
            }
          },
          {
            "to": [
              {
                "email": "some-other-email1@gmail.com"
              }
            ],
            "dynamic_template_data": {
              "FIRSTNAME": "Michael",
              "last_4": "8888",
              "OFFERCODE": "9999999999999999999999"
            }
          }
        ]
      }
    ],
    "identifier": 67289078
  },
  {
    "context": [
      "I want  to grep the value of the items in data (`id`,`name`,`symbol`,`slug`, `num_market_pairs`, etc.) ignoring: \u201c`tags`\u201d.",
      "Desired output format:\n\n        data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\tdata__platform\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated",
      ".data[0]\n| [paths(scalars) | select( all(.[]; type==\"string\")) ] as $paths\n| ($paths |  map([\"data\"] + . | join(\"__\"))),\n  [ getpath($paths[]) ]\n| @tsv"
    ],
    "utterance": "Extract all scalar values under data[0], except for those in tags, and output them as tab-separated columns with header names reflecting their nested paths joined by double underscores.",
    "expressions": [
      ".data[0]\n| [paths(scalars) | select( all(.[]; type==\"string\")) ] as $paths\n| ($paths |  map([\"data\"] + . | join(\"__\"))),\n  [ getpath($paths[]) ]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "status": {
            "timestamp": "2021-04-24T15:51:59.165Z",
            "error_code": 0,
            "error_message": null,
            "elapsed": 12,
            "credit_count": 1,
            "notice": null,
            "total_count": 4824
          },
          "data": [
            {
              "id": 1,
              "name": "Bitcoin",
              "symbol": "BTC",
              "slug": "bitcoin",
              "num_market_pairs": 9553,
              "date_added": "2013-04-28T00:00:00.000Z",
              "tags": [
                "mineable",
                "pow"
              ],
              "max_supply": 21000000,
              "circulating_supply": 18690125,
              "total_supply": 18690125,
              "platform": null,
              "cmc_rank": 1,
              "last_updated": "2021-04-24T15:51:02.000Z",
              "quote": {
                "USD": {
                  "price": 50199.80286231888,
                  "volume_24h": 54839569429.87117,
                  "percent_change_1h": 1.35143147,
                  "percent_change_24h": 1.22964148,
                  "percent_change_7d": -17.56716272,
                  "percent_change_30d": -2.51591082,
                  "percent_change_60d": 7.55313111,
                  "percent_change_90d": 56.29697475,
                  "market_cap": 938240590472.0977,
                  "last_updated": "2021-04-24T15:51:02.000Z"
                }
              }
            }
          ]
        },
        "output": [
          "data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\tdata__platform\tdata__cmc_rank\tdata__last_updated\tdata__quote__USD__price\tdata__quote__USD__volume_24h\tdata__quote__USD__percent_change_1h\tdata__quote__USD__percent_change_24h\tdata__quote__USD__percent_change_7d\tdata__quote__USD__percent_change_30d\tdata__quote__USD__percent_change_60d\tdata__quote__USD__percent_change_90d\tdata__quote__USD__market_cap\tdata__quote__USD__last_updated",
          "1\tBitcoin\tBTC\tbitcoin\t9553\t2013-04-28T00:00:00.000Z\t21000000\t18690125\t18690125\tnull\t1\t2021-04-24T15:51:02.000Z\t50199.80286231888\t54839569429.87117\t1.35143147\t1.22964148\t-17.56716272\t-2.51591082\t7.55313111\t56.29697475\t938240590472.0977\t2021-04-24T15:51:02.000Z"
        ]
      }
    ],
    "identifier": 67246269
  },
  {
    "context": [
      "I have the following two json files and I am trying to merge the DEV object.",
      "jq --slurpfile other jsonFile2.json '.ENV.DEV *= $other[].ENV.DEV' jsonFile1.json",
      "jq --argfile f2 jsonFile2.json '.ENV.DEV=$f2.ENV.DEV' jsonFile1.json"
    ],
    "utterance": "Merge the DEV object from the second file into the DEV object of the first file, preserving the rest of the first file unchanged.",
    "expressions": [
      ".ENV.DEV *= $other[].ENV.DEV",
      ".ENV.DEV = $f2.ENV.DEV"
    ],
    "data": [
      {
        "input": {
          "jsonFile1.json": {
            "ENV": {
              "DEV": {},
              "ST": {
                "middleware": [],
                "system": [],
                "application": [],
                "utility": []
              },
              "ESIT": {
                "middleware": [],
                "system": [],
                "application": [],
                "utility": []
              }
            }
          },
          "jsonFile2.json": {
            "ENV": {
              "DEV": {
                "middleware": [],
                "system": [],
                "application": [
                  {
                    "artefact": "abc",
                    "domain": "df",
                    "hostname": "sfa"
                  },
                  {
                    "artefact": "awe",
                    "domain": "csd",
                    "hostname": "wer"
                  }
                ],
                "utility": []
              }
            }
          }
        },
        "output": {
          "ENV": {
            "DEV": {
              "middleware": [],
              "system": [],
              "application": [
                {
                  "artefact": "abc",
                  "domain": "df",
                  "hostname": "sfa"
                },
                {
                  "artefact": "awe",
                  "domain": "csd",
                  "hostname": "wer"
                }
              ],
              "utility": []
            },
            "ST": {
              "middleware": [],
              "system": [],
              "application": [],
              "utility": []
            },
            "ESIT": {
              "middleware": [],
              "system": [],
              "application": [],
              "utility": []
            }
          }
        }
      }
    ],
    "identifier": 67294619
  },
  {
    "context": [
      "The final path should be `/{.Member.Name}/{.DebugConfig.Services.Name}/{.DebugConfig.Services.Checks.CheckID}`",
      "jq -r '{a:.Member.Name, b:.DebugConfig.Services[]} | select(.b.Name==\"cassandra\") | {a:.a, b:.b.Name, c:.b.Checks[].CheckID} | [.a, .b, .c] | join(\"/\")'",
      ".DebugConfig.Services[] as $s\n| \"/\\(.Member.Name)/\\($s.Name)/\\($s.Checks[].CheckID)\"",
      "Since you only want the \"cassandra\" strings, you just need to interject a \"select\" filter:\n\n.DebugConfig.Services[] as $s\n| \"/\\(.Member.Name)/\\($s.Name)/\" +\n    ($s\n     | select(.Name == \"cassandra\")\n     | .Checks[].CheckID)"
    ],
    "utterance": "Produce all paths of the form /staging-data-0/cassandra/{CheckID} where the service name is 'cassandra'.",
    "expressions": [
      "{a:.Member.Name, b:.DebugConfig.Services[]} | select(.b.Name==\"cassandra\") | {a:.a, b:.b.Name, c:.b.Checks[].CheckID} | [.a, .b, .c] | join(\"/\")",
      ".DebugConfig.Services[] as $s | select($s.Name == \"cassandra\") | \"/\u007f.Member.Name)/\u007f($s.Name)/\u007f($s.Checks[].CheckID)\""
    ],
    "data": [
      {
        "input": {
          "DebugConfig": {
            "ServerPort": 8300,
            "Services": [
              {
                "Checks": [
                  {
                    "CheckID": "cassandra-client-port",
                    "Timeout": "1s"
                  },
                  {
                    "CheckID": "cassandra-gossip-port",
                    "Timeout": "1s"
                  }
                ],
                "Name": "cassandra"
              },
              {
                "Checks": [
                  {
                    "CheckID": "cockroachdb-tcp",
                    "Timeout": "1s"
                  }
                ],
                "Name": "cockroachdb"
              }
            ]
          },
          "Member": {
            "Name": "staging-data-0"
          },
          "Meta": {
            "consul-network-segment": ""
          }
        },
        "output": [
          "staging-data-0/cassandra/cassandra-client-port",
          "staging-data-0/cassandra/cassandra-gossip-port"
        ]
      }
    ],
    "identifier": 67289391
  },
  {
    "context": [
      "I'm trying to extract part of the string in elements of an array, and create a new array with these extractions.",
      "[ \"local/binaries/app-2.21.0.tar.gz\", \"local/binaries/app-2.20.0.tar.gz\", \"local/binaries/app-2.19.1.tar.gz\", \"local/binaries/app-2.19.0.tar.gz\", \"local/binaries/app-2.18.0.tar.gz\" ]",
      "Desired output",
      "[ \"app-2.21.0\", \"app-2.20.0\", \"app-2.19.1\", \"app-2.19.0\", \"app-2.18.0\" ]",
      "You can use jq's `capture` function with regular expressions.",
      "jq '[.[] | capture(\"(?<captured>app-[0-9]+\\.[0-9]+\\.[0-9]+)\") | .[]]'"
    ],
    "utterance": "Extract the portion of each array element matching 'app-X.Y.Z' from filenames and create a new array with these substrings.",
    "expressions": [
      "[.[] | capture(\"(?<captured>app-[0-9]+\\.[0-9]+\\.[0-9]+)\") | .captured]"
    ],
    "data": [
      {
        "input": [
          "local/binaries/app-2.21.0.tar.gz",
          "local/binaries/app-2.20.0.tar.gz",
          "local/binaries/app-2.19.1.tar.gz",
          "local/binaries/app-2.19.0.tar.gz",
          "local/binaries/app-2.18.0.tar.gz"
        ],
        "output": [
          "app-2.21.0",
          "app-2.20.0",
          "app-2.19.1",
          "app-2.19.0",
          "app-2.18.0"
        ]
      }
    ],
    "identifier": 67305962
  },
  {
    "context": [
      "I need to do the following:\n[\n  {\n    \"name\": \"TESTING\",\n    \"online\": 1\n  },\n  {\n    \"id0\": 0,\n    \"type0\": 34,\n    \"name0\": \"Blabla\",\n    \"rate0\": 31768897891,\n    \"temp0\": 0,\n    \"percent0\": 100\n    \"id1\": 1,\n    \"type1\": 23,\n    \"name1\": \"AlbAlb\",\n    \"rate1\": 317681675432345670000,\n    \"temp1\": 1,\n    \"percent1\": 99\n    \"id2\": 2,\n    \"type2\": 98,\n    \"name2\": \"TztS\",\n    \"rate2\": 6324,\n    \"temp2\": 0,\n    \"percent2\": 80\n  }\n]",
      "[ {name, online},\n  (.test_list\n   | . as $in\n   | reduce range(0; length) as $i ({}; . + ($in[$i] | with_entries(.key = \"\\(.key)\\($i)\")))\n   )\n]",
      "[ {name, online},\n  (.test_list\n   | with_entries(.key |= tostring\n         | .key as $k\n\t\t | .value |= with_entries(.key += $k))\n   | add\n  )\n]"
    ],
    "utterance": "Produce an array of two objects: the first with the top-level name and online fields, and the second containing selected fields (id, type, name, rate, temp, percent) from each element of test_list, each object's keys suffixed with their index.",
    "expressions": [
      "[ {name, online}, (.test_list | . as $in | reduce range(0; length) as $i ({}; . + ($in[$i] | {id, type, name, rate, temp, percent} | with_entries(.key = \"\\(.key)\\($i)\")))) ]",
      "[ {name, online}, (.test_list | with_entries(.key |= tostring | .key as $k | .value |= with_entries(.key += $k)) | map({id, type, name, rate, temp, percent}) | add) ]"
    ],
    "data": [
      {
        "input": {
          "id": 88888,
          "name": "TESTING",
          "online": 1,
          "test_list": [
            {
              "id": 0,
              "type": 34,
              "name": "Blabla",
              "used": 9870,
              "rate": 31768897891,
              "temp": 2,
              "percent": 100,
              "enabled": 0,
              "reset": 0
            },
            {
              "id": 1,
              "type": 23,
              "name": "AlbAlb",
              "used": 865,
              "rate": 317681675432345678951,
              "temp": 1,
              "percent": 99,
              "enabled": 0,
              "reset": 0,
              "target": 2
            },
            {
              "id": 2,
              "type": 98,
              "name": "TztS",
              "used": 65,
              "rate": 6324,
              "temp": 0,
              "percent": 80,
              "enabled": 0,
              "reset": 0,
              "target": 2
            }
          ],
          "info": {
            "version": "1.0",
            "no": "123",
            "sw": "321",
            "version_detail": {
              "date": "2021-03-30",
              "build": "11",
              "cot": "dfgdfgd"
            }
          }
        },
        "output": [
          {
            "name": "TESTING",
            "online": 1
          },
          {
            "id0": 0,
            "type0": 34,
            "name0": "Blabla",
            "rate0": 31768897891,
            "temp0": 0,
            "percent0": 100,
            "id1": 1,
            "type1": 23,
            "name1": "AlbAlb",
            "rate1": 317681675432345678951,
            "temp1": 1,
            "percent1": 99,
            "id2": 2,
            "type2": 98,
            "name2": "TztS",
            "rate2": 6324,
            "temp2": 0,
            "percent2": 80
          }
        ]
      }
    ],
    "identifier": 67287642
  },
  {
    "context": [
      "I want this result.\r\n\r\n    {\r\n      \"name\": \"Test\",\r\n      \"attribute36\": \"bli\",\r\n      \"attribute39\": \"blo\"\r\n    }\r\n    {\r\n      \"name\": \"Test\",\r\n      \"attribute36\": \"xxx\",\r\n      \"attribute39\": \"yyy\"\r\n    }",
      "At any rate, the following filter does produce the desired result:\r\n```\r\n.objectEntries[]\r\n| .objectType.name as $name\r\n| foreach ((attributes[] | to_o), null ) as $o ({};\r\n     if $o == null then .emit = .object\r\n     elif .object|has($o|keys_unsorted[0])\r\n     then .emit=.object | .object=$o\r\n     else .emit=null | .object += $o\r\n     end;\r\n     select(.emit) | .emit)\r\n| {$name} + .\r\n\r\n```"
    ],
    "utterance": "For each object under objectEntries, produce a flat object containing the name and the values of attribute36 and attribute39, grouped together as pairs from the nested referencedObject structure.",
    "expressions": [
      ".objectEntries[]\n| .objectType.name as $name\n| def attributes: [ .attributes[] | select(.objectTypeAttributeId==8) | .objectAttributeValues[].referencedObject.attributes[] | select(.objectTypeAttributeId==15) | .objectAttributeValues[].referencedObject.attributes[] ];\n  def to_o: { (\"attribute\" + (.objectTypeAttributeId|tostring)): first(.objectAttributeValues[].value)};\n  foreach ((attributes[] | to_o), null ) as $o ({};\n       if $o == null then .emit = .object\n       elif .object|has($o|keys_unsorted[0])\n       then .emit=.object | .object=$o\n       else .emit=null | .object += $o\n       end;\n       select(.emit) | .emit)\n| {name: $name} + ."
    ],
    "data": [
      {
        "input": {
          "objectEntries": [
            {
              "objectType": {
                "name": "Test"
              },
              "attributes": [
                {
                  "id": 16,
                  "objectTypeAttributeId": 8,
                  "objectAttributeValues": [
                    {
                      "referencedObject": {
                        "id": 17,
                        "label": "TestTest",
                        "attributes": [
                          {
                            "id": 20,
                            "objectTypeAttributeId": 11,
                            "objectAttributeValues": [
                              {
                                "value": "bli"
                              }
                            ],
                            "objectId": 12
                          },
                          {
                            "id": 21,
                            "objectTypeAttributeId": 13,
                            "objectAttributeValues": [
                              {
                                "value": "blo"
                              }
                            ],
                            "objectId": 14
                          },
                          {
                            "id": 22,
                            "objectTypeAttributeId": 15,
                            "objectAttributeValues": [
                              {
                                "referencedObject": {
                                  "id": 30,
                                  "label": "TestTest",
                                  "attributes": [
                                    {
                                      "id": 35,
                                      "objectTypeAttributeId": 36,
                                      "objectAttributeValues": [
                                        {
                                          "value": "bli"
                                        }
                                      ],
                                      "objectId": 37
                                    },
                                    {
                                      "id": 38,
                                      "objectTypeAttributeId": 39,
                                      "objectAttributeValues": [
                                        {
                                          "value": "blo"
                                        }
                                      ],
                                      "objectId": 40
                                    }
                                  ]
                                }
                              }
                            ],
                            "objectId": 16
                          }
                        ]
                      }
                    }
                  ]
                },
                {
                  "id": 16,
                  "objectTypeAttributeId": 8,
                  "objectAttributeValues": [
                    {
                      "referencedObject": {
                        "id": 17,
                        "label": "TestTest",
                        "attributes": [
                          {
                            "id": 20,
                            "objectTypeAttributeId": 11,
                            "objectAttributeValues": [
                              {
                                "value": "bli"
                              }
                            ],
                            "objectId": 12
                          },
                          {
                            "id": 21,
                            "objectTypeAttributeId": 13,
                            "objectAttributeValues": [
                              {
                                "value": "blo"
                              }
                            ],
                            "objectId": 14
                          },
                          {
                            "id": 22,
                            "objectTypeAttributeId": 15,
                            "objectAttributeValues": [
                              {
                                "referencedObject": {
                                  "id": 30,
                                  "label": "TestTest",
                                  "attributes": [
                                    {
                                      "id": 35,
                                      "objectTypeAttributeId": 36,
                                      "objectAttributeValues": [
                                        {
                                          "value": "xxx"
                                        }
                                      ],
                                      "objectId": 37
                                    },
                                    {
                                      "id": 38,
                                      "objectTypeAttributeId": 39,
                                      "objectAttributeValues": [
                                        {
                                          "value": "yyy"
                                        }
                                      ],
                                      "objectId": 40
                                    }
                                  ]
                                }
                              }
                            ],
                            "objectId": 16
                          }
                        ]
                      }
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "Test",
            "attribute36": "bli",
            "attribute39": "blo"
          },
          {
            "name": "Test",
            "attribute36": "xxx",
            "attribute39": "yyy"
          }
        ]
      }
    ],
    "identifier": 67207989
  },
  {
    "context": [
      "I need to print those pairs whose key does not match the value.",
      "In `jq` you can use the `with_entries()` function. It puts the keys and values of each record in the object into named variables `.key` and `.value` and you basically have to evaluate if they are _not_ the same.",
      "jq 'with_entries(select(.key != .value))'"
    ],
    "utterance": "Print all key-value pairs from the top-level object where the key is not equal to the value.",
    "expressions": [
      "with_entries(select(.key != .value))"
    ],
    "data": [
      {
        "input": {
          "Aaa aaa aaa": "Aaa aaa aaa",
          "Bbb bbb bbb": "Bbb bbb bbb",
          "Ccc ccc ccc": "Xxx xxx xxx",
          "Ddd ddd ddd": "Ddd ddd ddd",
          "Eee eee eee": "Yyy yyy yyy"
        },
        "output": {
          "Ccc ccc ccc": "Xxx xxx xxx",
          "Eee eee eee": "Yyy yyy yyy"
        }
      }
    ],
    "identifier": 67317017
  },
  {
    "context": [
      "how to add entry to object inside array using jq",
      "So far I get this:\n    echo '[{\"a\": \"A\", \"b\": \"B\"}, {\"c\": \"C\", \"d\": \"D\"}]' | jq '.[] + {x:\"X\"}'\nWhich will result to this:\n    {\n      \"a\": \"A\",\n      \"b\": \"B\",\n      \"x\": \"X\"\n    }\n    {\n      \"c\": \"C\",\n      \"d\": \"D\",\n      \"x\": \"X\"\n    }\n\nbut it will not \"wrap\" the result in array and also does not add comma after each entry.",
      "jq '[.[] + {x:\"X\"}]'\n\nOr you could use `map`"
    ],
    "utterance": "Add an entry with key x and value X to every object inside the array, keeping the result as an array.",
    "expressions": [
      "[.[] + {x:\"X\"}]",
      "map(. + {x:\"X\"})"
    ],
    "data": [
      {
        "input": [
          {
            "a": "A",
            "b": "B"
          },
          {
            "c": "C",
            "d": "D"
          }
        ],
        "output": [
          {
            "a": "A",
            "b": "B",
            "x": "X"
          },
          {
            "c": "C",
            "d": "D",
            "x": "X"
          }
        ]
      }
    ],
    "identifier": 67319985
  },
  {
    "context": [
      "inlist=$(jq -r '.field | join(\" \")' file.json)",
      "It prints `lista: ['6 7 8']`",
      "But the behavior wanted is `lista: ['6', '7', '8']`",
      "$ python app_parsing_lists.py --lista $(echo '{\"field\": [6, 7, 8]}' | jq -r .field[])\nlista: ['6', '7', '8']"
    ],
    "utterance": "Extract all elements of the 'field' array at the top level and print each on a separate line.",
    "expressions": [
      ".field[]",
      "-r .field[]"
    ],
    "data": [
      {
        "input": {
          "field": [
            6,
            7,
            8
          ]
        },
        "output": [
          "6",
          "7",
          "8"
        ]
      }
    ],
    "identifier": 67323578
  },
  {
    "context": [
      "The Challenge - Generate an array of allowed **Action**s (`Effect == Allow`).",
      "My Solution (not good enough):",
      "jq '.Statement | map(select(.Effect == \"Allow\"))[].Action | if type == \"string\" then . else .[] end' iampolicy.json",
      "Desired output:",
      "[\n  \"cloudformation:UpdateStack\",\n  \"lambda:UpdateFunctionConfiguration\",\n  \"lambda:InvokeFunction\",\n  \"cloudfront:GetDistribution\",\n  \"cloudfront:UpdateDistribution\",\n  \"apigateway:GET\",\n  \"apigateway:HEAD\",\n  \"apigateway:OPTIONS\",\n  \"apigateway:PUT\",\n  \"iam:GetRole\",\n  \"iam:PassRole\",\n  \"lambda:GetFunctionConfiguration\"\n]",
      "One solution therefore would be to enclose your entire expression in square brackets; one of several better alternatives would be:",
      ".Statement\n| [.[]\n   | select(.Effect == \"Allow\")\n   | .Action\n   | if type == \"string\" then . else .[] end ]",
      "Ok that was silly, surrounding my final output with `[]` did the trick",
      ".Statement | [map(select(.Effect == \"Allow\"))[].Action | if type == \"string\" then . else .[] end]"
    ],
    "utterance": "Produce an array containing all Action values from Statement entries where Effect equals Allow, treating both string and array forms of Action as elements of the result array.",
    "expressions": [
      ".Statement | [map(select(.Effect == \"Allow\"))[].Action | if type == \"string\" then . else .[] end]",
      ".Statement | [.[] | select(.Effect == \"Allow\") | .Action | if type == \"string\" then . else .[] end ]"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Action": "cloudformation:UpdateStack",
              "Resource": "arn:aws:cloudformation:eu-west-1:123456789012:stack/sokker-stack-dev/*",
              "Effect": "Allow"
            },
            {
              "Action": [
                "lambda:UpdateFunctionConfiguration",
                "lambda:InvokeFunction"
              ],
              "Resource": "arn:aws:lambda:eu-west-1:123456789012:function:sokker-api-dev-GetApiKeyValueFunction-MYDISTRIBID",
              "Effect": "Allow"
            },
            {
              "Action": [
                "cloudfront:GetDistribution",
                "cloudfront:UpdateDistribution"
              ],
              "Resource": "arn:aws:cloudfront::*:distribution/MYDISTRIBID",
              "Effect": "Allow"
            },
            {
              "Action": [
                "apigateway:GET",
                "apigateway:HEAD",
                "apigateway:OPTIONS",
                "apigateway:PUT",
                "iam:GetRole",
                "iam:PassRole",
                "lambda:GetFunctionConfiguration"
              ],
              "Resource": "*",
              "Effect": "Allow"
            }
          ]
        },
        "output": [
          "cloudformation:UpdateStack",
          "lambda:UpdateFunctionConfiguration",
          "lambda:InvokeFunction",
          "cloudfront:GetDistribution",
          "cloudfront:UpdateDistribution",
          "apigateway:GET",
          "apigateway:HEAD",
          "apigateway:OPTIONS",
          "apigateway:PUT",
          "iam:GetRole",
          "iam:PassRole",
          "lambda:GetFunctionConfiguration"
        ]
      }
    ],
    "identifier": 67308772
  },
  {
    "context": [
      "I have some json input that comes as a list of objects (not as a json array) like, for which I want to count the number of active, and the number of inactive:",
      "I want to transform using only JQ (in fact it will be handled by jackson-jq in java code, so I can not use some shell tricks).",
      "Example of output is :\n```\n2\n2\n2\n```\n (I have 3 objects with 2 fields that match value=\"active)\n\nThe output that I expect is :\n```\n3\n```",
      "With this, you would invoke jq with the -n command-line option and run a query such as:\n```\ncount(inputs|.value; .==\"active\"; .==\"inactive\")\n```\n"
    ],
    "utterance": "Count objects in the input stream where value is \"active\".",
    "expressions": [
      "reduce inputs as $o (0; if $o.value == \"active\" then .+1 else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "key": "state",
            "value": "active"
          },
          {
            "key": "state",
            "value": "active"
          },
          {
            "key": "state",
            "value": "active"
          },
          {
            "key": "state",
            "value": "inactive"
          }
        ],
        "output": 3
      }
    ],
    "identifier": 67335453
  },
  {
    "context": [
      "I want to filter output \u2018csv\u2019 file, get interested  fields (`data__id`,`data__name`,`data__symbol`,`data__slug`,`data__num_market_pairs`,`data__date_added`,`data__max_supply`,`data__circulating_supply`,`data__total_supply` )and exclude rest.",
      "To emit the headers just once, you would use the template: `HEADERS, TABLE`:",
      "def relevantPaths:\n   \"id,name,symbol,slug,num_market_pairs,date_added,max_supply,circulating_supply,total_supply\"\n  | split(\",\")\n  | map([.]) ;\n\nrelevantPaths as $paths\n| ([[\"data\"] + $paths[]] | map(join(\"__\"))),\n  (.data[] | [ getpath($paths[]) ])\n| @tsv"
    ],
    "utterance": "Select only the fields id, name, symbol, slug, num_market_pairs, date_added, max_supply, circulating_supply, and total_supply for each item under data, outputting a single-header tab-separated table with all other fields excluded.",
    "expressions": [
      "def relevantPaths:\n   \"id,name,symbol,slug,num_market_pairs,date_added,max_supply,circulating_supply,total_supply\"\n  | split(\",\")\n  | map([.]) ;\n\nrelevantPaths as $paths\n| ([[\"data\"] + $paths[]] | map(join(\"__\"))),\n  (.data[] | [ getpath($paths[]) ])\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 1,
              "name": "Bitcoin",
              "symbol": "BTC",
              "slug": "bitcoin",
              "num_market_pairs": 9547,
              "date_added": "2013-04-28T00:00:00.000Z",
              "max_supply": 21000000,
              "circulating_supply": 18691931,
              "total_supply": 18691931,
              "other_field": "ignore"
            },
            {
              "id": 1027,
              "name": "Ethereum",
              "symbol": "ETH",
              "slug": "ethereum",
              "num_market_pairs": 6312,
              "date_added": "2015-08-07T00:00:00.000Z",
              "max_supply": 115629413.749,
              "circulating_supply": 115629413.749,
              "total_supply": 2,
              "other_field": "ignore"
            }
          ]
        },
        "output": "data__id\tdata__name\tdata__symbol\tdata__slug\tdata__num_market_pairs\tdata__date_added\tdata__max_supply\tdata__circulating_supply\tdata__total_supply\n1\tBitcoin\tBTC\tbitcoin\t9547\t2013-04-28T00:00:00.000Z\t21000000\t18691931\t18691931\n1027\tEthereum\tETH\tethereum\t6312\t2015-08-07T00:00:00.000Z\t115629413.749\t115629413.749\t2"
      }
    ],
    "identifier": 67272032
  },
  {
    "context": [
      "I'm trying to Transform the following json ... To the following ...",
      "jq -r \".application[] | select(.name==\\\"app1\\\") | .policies[] | {\\\".name\\\" : .orderNumber}\"",
      "I was able to get ... Any idea how I can merge them.",
      "Use `map` to create a single array instead of two independent objects, then use `add` to merge its contents.",
      "jq '.application[]\n    | select(.name == \"app1\")\n    | .policies\n    | map({ (.name) : .orderNumber } )\n    | add'"
    ],
    "utterance": "Extract all policies of the application named app1 as a single object mapping policy name to order number.",
    "expressions": [
      ".application[] | select(.name == \"app1\") | .policies | map({ (.name): .orderNumber }) | add"
    ],
    "data": [
      {
        "input": {
          "application": [
            {
              "name": "app1",
              "policies": [
                {
                  "name": "pol_1",
                  "orderNumber": "10"
                },
                {
                  "name": "pol_2",
                  "orderNumber": "20"
                }
              ]
            },
            {
              "name": "app2",
              "policies": [
                {
                  "name": "pol_A",
                  "orderNumber": "10"
                },
                {
                  "name": "pol_B",
                  "orderNumber": "20"
                }
              ]
            }
          ]
        },
        "output": {
          "pol_1": "10",
          "pol_2": "20"
        }
      }
    ],
    "identifier": 67335790
  },
  {
    "context": [
      "I would like to take two JSON objects and merge them non-recursively.",
      "should result in",
      "{\n\t\"a\": {\n\t\t\"1\": \"1\",\n\t\t\"2\": \"2\"\n\t},\n\t\"b\": {\n\t\t\"1\": \"1\"\n\t}\n}",
      "It looks like I needed `--slurp` combined with a simple `add`.",
      "jq -s 'add' b.json a.json"
    ],
    "utterance": "Merge two objects so that top-level keys from the second input replace or add to those in the first input without merging nested objects.",
    "expressions": [
      "-s 'add'"
    ],
    "data": [
      {
        "input": [
          {
            "a": {
              "1": "1",
              "2": "2"
            }
          },
          {
            "a": {
              "3": "3"
            },
            "b": {
              "1": "1"
            }
          }
        ],
        "output": {
          "a": {
            "1": "1",
            "2": "2"
          },
          "b": {
            "1": "1"
          }
        }
      }
    ],
    "identifier": 67339472
  },
  {
    "context": [
      "For each object having an `assignment/import` I would like to extract all roles of the corresponding `assignment-role/create` (objects having an `assignment-role/create` and whose `assignmentName` equals the `name` of the corresponding object having an `assignment/import`) and add these roles to it.",
      "This produces an object of the form ... which we can convert to the desired array of objects with `to_entries|map`.",
      "`reduce .[] as ...` and `| to_entries | map(...)`"
    ],
    "utterance": "For each object where endpoint_url is \"assignment/import\", add a roles array containing all roleName values from objects where endpoint_url is \"assignment-role/create\" and assignmentName matches the name.",
    "expressions": [
      "reduce .[] as { body_payload: { $name, $description, $roleName, $assignmentName } } ( null; if $name and $description then .[$name] += {name: $name, description: $description} elif $roleName and $assignmentName then .[$assignmentName].roles += [$roleName] else . end ) | to_entries | map({ endpoint_url: \"assignment/import\", body_payload: .value })"
    ],
    "data": [
      {
        "input": [
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment1",
              "description": "assignment 1 description"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role1",
              "assignmentName": "assignment1"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role2",
              "assignmentName": "assignment1"
            }
          },
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment2",
              "description": "assignment 2 description"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role3",
              "assignmentName": "assignment2"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role4",
              "assignmentName": "assignment2"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role5",
              "assignmentName": "assignment2"
            }
          },
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment3",
              "description": "assignment 3 description"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role6",
              "assignmentName": "assignment3"
            }
          }
        ],
        "output": [
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment1",
              "description": "assignment 1 description",
              "roles": [
                "role1",
                "role2"
              ]
            }
          },
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment2",
              "description": "assignment 2 description",
              "roles": [
                "role3",
                "role4",
                "role5"
              ]
            }
          },
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment3",
              "description": "assignment 3 description",
              "roles": [
                "role6"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 67334934
  },
  {
    "context": [
      "How can I produce output like below ?\r\n\r\n1,1234,abc\r\n\r\n2,5678,def",
      "jq '.Users[] .Attributes[] .Value' test.json\r\n\r\nproduces\r\n\r\n1\r\n1234\r\nabc\r\n2\r\n5678\r\ndef",
      "the following will get the desired output:\r\n.Users[].Attributes | map(.Value) | @csv",
      ".Users[].Attributes\r\n| from_entries\r\n| [.[]]\r\n| join(\",\")",
      "(.Users[0] | [.Attributes[] | .Name]) as $keys\r\n| .Users[]\r\n| .Attributes\r\n| from_entries\r\n| [.[ $keys[] ]]\r\n| join(\",\")"
    ],
    "utterance": "List each user's sub, phone_number, and referral_code values as comma-separated lines in the order shown.",
    "expressions": [
      ".Users[].Attributes | map(.Value) | @csv",
      ".Users[].Attributes | from_entries | [.[]] | join(\",\")",
      "(.Users[0] | [.Attributes[] | .Name]) as $keys | .Users[] | .Attributes | from_entries | [.[ $keys[] ]] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "Users": [
            {
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": "1"
                },
                {
                  "Name": "phone_number",
                  "Value": "1234"
                },
                {
                  "Name": "referral_code",
                  "Value": "abc"
                }
              ]
            },
            {
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": "2"
                },
                {
                  "Name": "phone_number",
                  "Value": "5678"
                },
                {
                  "Name": "referral_code",
                  "Value": "def"
                }
              ]
            }
          ]
        },
        "output": [
          "1,1234,abc",
          "2,5678,def"
        ]
      }
    ],
    "identifier": 67339698
  },
  {
    "context": [
      "For each object that satisfies `.endpoint_url == \"assignment/import\"` identify the objects that have the same assignment name (e.g. `.body_payload.name == .body_payload.assignmentName`) and add the role name to the roles array (e.g. if .body_payload.roles then .body_payload.roles += .body_payload.roleName else .body_payload += {\"roles\": []} end`",
      "A valid minimal input can be as follows:",
      "[",
      "  {",
      "    \"endpoint_url\": \"assignment/import\",",
      "    \"body_payload\": {",
      "      \"name\": \"assignment1\",",
      "      \"description\": \"assignment 1 description\"",
      "    }",
      "  },",
      "  {",
      "    \"endpoint_url\": \"assignment-role/create\",",
      "    \"body_payload\": {",
      "      \"roleName\": \"role1\",",
      "      \"assignmentName\": \"assignment1\"",
      "    }",
      "  },",
      "  {",
      "    \"endpoint_url\": \"assignment-role/create\",",
      "    \"body_payload\": {",
      "      \"roleName\": \"role2\",",
      "      \"assignmentName\": \"assignment1\"",
      "    }",
      "  },",
      "  {",
      "    \"endpoint_url\": \"assignment-role/create\",",
      "    \"body_payload\": {",
      "      \"roleName\": \"role3\",",
      "      \"assignmentName\": \"assignment1\"",
      "    }",
      "  }",
      "]",
      "The expected output can be just:",
      "{",
      "  \"endpoint_url\": \"assignment/import\",",
      "  \"body_payload\": {",
      "    \"name\": \"assignment1\",",
      "    \"description\": \"assignment 1 description\",",
      "    \"roles\": [ \"role1\", \"role2\", \"role3\" ]",
      "  }",
      "}",
      "One way using `jq` would be to do",
      "jq '",
      "  ( map ( select( .endpoint_url == \"assignment/import\" ) ) ) as $d |",
      "  ( map ( select( .body_payload.assignmentName == $d[].body_payload.name ) ) ) as $l | ",
      "  $d | ",
      "  map( .body_payload += { roles : [ $l[].body_payload.roleName ] } )' json"
    ],
    "utterance": "For each object where endpoint_url is \"assignment/import\", collect all roleName values from objects where endpoint_url is \"assignment-role/create\" and assignmentName matches the import name, and add them as a roles array in the body_payload.",
    "expressions": [
      "( map ( select( .endpoint_url == \"assignment/import\" ) ) ) as $d | ( map ( select( .body_payload.assignmentName == $d[].body_payload.name ) ) ) as $l | $d | map( .body_payload += { roles : [ $l[].body_payload.roleName ] } )"
    ],
    "data": [
      {
        "input": [
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment1",
              "description": "assignment 1 description"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role1",
              "assignmentName": "assignment1"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role2",
              "assignmentName": "assignment1"
            }
          },
          {
            "endpoint_url": "assignment-role/create",
            "body_payload": {
              "roleName": "role3",
              "assignmentName": "assignment1"
            }
          }
        ],
        "output": [
          {
            "endpoint_url": "assignment/import",
            "body_payload": {
              "name": "assignment1",
              "description": "assignment 1 description",
              "roles": [
                "role1",
                "role2",
                "role3"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 67333141
  },
  {
    "context": [
      "The output from the `aks list --subscriptions` command looks something like",
      "[{\"name\": \"foo\", \"resourceGroup\": \"bar\", \"subscription\": \"/subscriptions/I-need-Selecting/resourcegroups/blahblah/blahblah\"}, ... ]",
      "... how to reduce the \"subscription\" parameter to just a substring, try",
      "jq '.[] |  \"az aks get-credentials --name \\(.name) --resource-group \\(.resourceGroup) --subscription=\\(.id | split(\"/\")[3])\"'"
    ],
    "utterance": "Generate a command string for each object using the name and resourceGroup fields, and set the subscription parameter to the third segment of the id field split by '/'.",
    "expressions": [
      ".[] | \"az aks get-credentials --name \\(.name) --resource-group \\(.resourceGroup) --subscription=\\(.id | split(\"/\")[3])\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "tarzan",
            "resourceGroup": "froup",
            "id": "/subscriptions/I-need-Selecting/resourcegroups/blahblah/blahblah"
          }
        ],
        "output": "az aks get-credentials --name tarzan --resource-group froup --subscription=I-need-Selecting"
      }
    ],
    "identifier": 67367991
  },
  {
    "context": [
      "I am looking for a way to search/replace portion of the text in some of the values. In this example, I am looking to search for \"abc\" and replace with \"xyz\".",
      "No need for \"contains\". If there's no `abc`, it won't be replaced.",
      "[ .[] | .name |= gsub(\"abc\"; \"XYZ\") ]",
      "or, shorter and cleaner using `map`:",
      "map(.name |= gsub(\"abc\"; \"XYZ\"))"
    ],
    "utterance": "Replace all occurrences of 'abc' with 'XYZ' in every 'name' field in a list of objects.",
    "expressions": [
      "[ .[] | .name |= gsub(\"abc\"; \"XYZ\") ]",
      "map(.name |= gsub(\"abc\"; \"XYZ\"))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 202,
            "name": "abctext123",
            "module_name": "xxxxxxxxxxx"
          },
          {
            "id": 223,
            "name": "abcanothertext789",
            "module_name": "yyyyyyyyyyy"
          },
          {
            "id": 202,
            "name": "anypattern",
            "module_name": "zzzzzzzzzzz"
          },
          {
            "id": 223,
            "name": "anothertest",
            "module_name": "anothervalue"
          }
        ],
        "output": [
          {
            "id": 202,
            "name": "XYZtext123",
            "module_name": "xxxxxxxxxxx"
          },
          {
            "id": 223,
            "name": "XYZanothertext789",
            "module_name": "yyyyyyyyyyy"
          },
          {
            "id": 202,
            "name": "anypattern",
            "module_name": "zzzzzzzzzzz"
          },
          {
            "id": 223,
            "name": "anothertest",
            "module_name": "anothervalue"
          }
        ]
      }
    ],
    "identifier": 67369023
  },
  {
    "context": [
      "Add some filter:\r\n- if .module == $MODULE_SEARCH and .name ==\r\n   $FILTER_SEARCH\r\n\r\nAnd then do an update: \r\n- (.type |=$TO_UPDATE)",
      "But with this command, i&#39;m destroying my json",
      "I have two issues with this:\r\n - between each module the comma &quot;,&quot; was removed.\r\n - I have to put it back in &quot;resources&quot;: [] and then back to my original input file but i don&#39;t know how",
      "You just need to add an equal sign :\r\n\r\n```\r\n&lt; tfplan.json jq --arg MODULE_SEARCH &#39;module.cname[&quot;tiger2&quot;]&#39; \\\r\n                 --arg FILTER_SEARCH service \\\r\n                 --arg TO_UPDATE new_service \\\r\n&#39;.resources[] |= if .module == $MODULE_SEARCH and\r\n                    .name == $FILTER_SEARCH\r\n                 then .type |= $TO_UPDATE\r\n                 else . end&#39;\r\n```"
    ],
    "utterance": "Update the type of elements inside resources where module equals 'module.cname[\"tiger2\"]' and name equals 'service' to 'new_service', keeping the overall structure unchanged.",
    "expressions": [
      ".resources[] |= if .module == $MODULE_SEARCH and .name == $FILTER_SEARCH then .type |= $TO_UPDATE else . end"
    ],
    "data": [
      {
        "input": {
          "version": 4,
          "terraform_version": "0.13.4",
          "serial": 1,
          "lineage": "xxx",
          "resources": [
            {
              "module": "module.cname[\"tiger2\"]",
              "mode": "managed",
              "type": "service",
              "name": "service",
              "xxx": "xxx"
            },
            {
              "module": "module.cname[\"tiger2\"]",
              "mode": "managed",
              "type": "user",
              "name": "other1",
              "xxx": "xxx"
            },
            {
              "module": "module.cname[\"tiger1\"]",
              "mode": "managed",
              "type": "project",
              "name": "other2",
              "xxx": "xxx"
            }
          ]
        },
        "output": {
          "version": 4,
          "terraform_version": "0.13.4",
          "serial": 1,
          "lineage": "xxx",
          "resources": [
            {
              "module": "module.cname[\"tiger2\"]",
              "mode": "managed",
              "type": "new_service",
              "name": "service",
              "xxx": "xxx"
            },
            {
              "module": "module.cname[\"tiger2\"]",
              "mode": "managed",
              "type": "user",
              "name": "other1",
              "xxx": "xxx"
            },
            {
              "module": "module.cname[\"tiger1\"]",
              "mode": "managed",
              "type": "project",
              "name": "other2",
              "xxx": "xxx"
            }
          ]
        }
      }
    ],
    "identifier": 67345336
  },
  {
    "context": [
      "I\u2019m trying to extract the ARN\u2019s (.StackId) of all AWS CloudFormation stacks which match a specific string in key StackName and StackStatus of \"CREATE COMPLETE\" or \"UPDATE_COMPLETE\".",
      "All of the above commands return boolean value instead of the StackId itself. How can I get the StackId instead of a boolean value?",
      "jq -r '\n   .StackSummaries[] |\n   select( \n      .StackName == \"some-service-name\" and (\n         .StackStatus == \"CREATE_COMPLETE\" or\n         .StackStatus == \"UPDATE_COMPLETE\"\n       )\n   ) |\n   .StackId\n'"
    ],
    "utterance": "Extract StackId values for stacks where StackName equals \"some-service-name\" and StackStatus equals \"CREATE_COMPLETE\" or \"UPDATE_COMPLETE\".",
    "expressions": [
      ".StackSummaries[] | select(.StackName == \"some-service-name\" and (.StackStatus == \"CREATE_COMPLETE\" or .StackStatus == \"UPDATE_COMPLETE\")) | .StackId"
    ],
    "data": [
      {
        "input": {
          "StackSummaries": [
            {
              "StackId": "arn:aws:cloudformation:us-east-1:AWS_ACCOUNT_ID:stack/some-service-name/9ad489b0-ab22-11eb-af8f-0a56fXXXX8ad",
              "StackName": "some-service-name",
              "CreationTime": "2021-05-02T08:44:28.106000+00:00",
              "StackStatus": "CREATE_COMPLETE",
              "DriftInformation": {
                "StackDriftStatus": "NOT_CHECKED"
              }
            },
            {
              "StackId": "arn:aws:cloudformation:us-east-1:AWS_ACCOUNT_ID:stack/some-service-name/44239210-9703-11eb-b085-12daXXXX6186",
              "StackName": "some-service-name",
              "TemplateDescription": "some-service-name",
              "CreationTime": "2021-04-06T18:09:45.470000+00:00",
              "LastUpdatedTime": "2021-04-13T13:09:37.683000+00:00",
              "StackStatus": "UPDATE_COMPLETE",
              "DriftInformation": {
                "StackDriftStatus": "NOT_CHECKED"
              }
            }
          ]
        },
        "output": [
          "arn:aws:cloudformation:us-east-1:AWS_ACCOUNT_ID:stack/some-service-name/9ad489b0-ab22-11eb-af8f-0a56fXXXX8ad",
          "arn:aws:cloudformation:us-east-1:AWS_ACCOUNT_ID:stack/some-service-name/44239210-9703-11eb-b085-12daXXXX6186"
        ]
      }
    ],
    "identifier": 67355917
  },
  {
    "context": [
      "Running a gcloud query and trying to get the output of the json to only include the actual machine type in stead of the full url.",
      "It currently prints out the full machineType, wondering if anyone knows of a way to short the url to get just the machine type as the string instead of the full url.",
      "edit: found some potential with split in jq",
      "gcloud compute instances list --project $projectname --format=json | jq -r '.[]|(.machineType|split(\"https://www.googleapis.com/compute/v1/projects/\"))'"
    ],
    "utterance": "Extract only the machine type name from the machineType URL for each instance and print it with the instance name, separated by a comma.",
    "expressions": [
      ".[] | .name + \",\" + (.machineType | split(\"/\") | .[-1])",
      ".[] | [.name, (.machineType | split(\"/\") | .[-1])] | @csv"
    ],
    "identifier": 67402087
  },
  {
    "context": [
      "I am trying to create a markdown block for a slack bot using [jq](https://stedolan.github.io/jq/manual/) inside of a bash script.",
      "See [this post](https://stackoverflow.com/questions/67391180/use-newline-with-jq/67391273#67391273) for instructions to escape the markdown string",
      "# Create the json string",
      "json_string=$( jq -nr \\",
      "    --arg jq_fallback_message \"$fallback_message\" \\",
      "    --arg jq_section_type \"section\" \\",
      "    --arg jq_markdown_type \"mrkdwn\" \\",
      "    --arg jq_markdown_message \"$markdown_message_unescaped\" \\",
      "    '{",
      "        text: $jq_fallback_message, ",
      "        blocks: [",
      "            {",
      "                type: $jq_section_type,",
      "                text: {",
      "                    type: $jq_markdown_type, ",
      "                    text: $jq_markdown_message",
      "                }",
      "            }",
      "        ]",
      "    }'"
    ],
    "utterance": "Construct an object with a top-level text property and a blocks array containing a section block with mrkdwn text and multiline support.",
    "expressions": [
      "jq -nr --arg jq_fallback_message \"$fallback_message\" --arg jq_section_type \"section\" --arg jq_markdown_type \"mrkdwn\" --arg jq_markdown_message \"$markdown_message_unescaped\" '{ text: $jq_fallback_message, blocks: [ { type: $jq_section_type, text: { type: $jq_markdown_type, text: $jq_markdown_message } } ] }'"
    ],
    "data": [
      {
        "input": {
          "fallback_message": "TEST MESSAGE - HOSTNAME",
          "markdown_message_unescaped": "TEST MESSAGE - HOSTNAME \n Hi <@U12345678>\n```Can we do a\nmultiline code block```"
        },
        "output": {
          "text": "TEST MESSAGE - HOSTNAME",
          "blocks": [
            {
              "type": "section",
              "text": {
                "type": "mrkdwn",
                "text": "TEST MESSAGE - HOSTNAME \n Hi <@U12345678>\n```Can we do a\nmultiline code block```"
              }
            }
          ]
        }
      }
    ],
    "identifier": 67389971
  },
  {
    "context": [
      "How I can sort it based `status-timestamps.planned-at`?",
      "Among other things I tried this `jq '[.data[].attributes | sort_by(.status-timestamps.planned-at) ]'`",
      "Does this achieve what you wanted ?",
      "jq '.data |= sort_by(.attributes.\"status-timestamps\".\"planned-at\")'"
    ],
    "utterance": "Sort the top-level data array by the planned-at field inside each item's attributes.status-timestamps.",
    "expressions": [
      ".data |= sort_by(.attributes.\"status-timestamps\".\"planned-at\")"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "run-bWSq4YeYpfrW4mx7",
              "type": "runs",
              "attributes": {
                "source": "tfe-configuration-version",
                "status": "planned",
                "status-timestamps": {
                  "planned-at": "2017-11-28T22:52:51+00:00"
                }
              }
            },
            {
              "id": "run-bWSq4YeYpfrW4ft7",
              "type": "runs",
              "attributes": {
                "source": "tfe-configuration-version",
                "status": "planned",
                "status-timestamps": {
                  "planned-at": "2017-11-28T21:52:51+00:00"
                }
              }
            }
          ]
        },
        "output": {
          "data": [
            {
              "id": "run-bWSq4YeYpfrW4ft7",
              "type": "runs",
              "attributes": {
                "source": "tfe-configuration-version",
                "status": "planned",
                "status-timestamps": {
                  "planned-at": "2017-11-28T21:52:51+00:00"
                }
              }
            },
            {
              "id": "run-bWSq4YeYpfrW4mx7",
              "type": "runs",
              "attributes": {
                "source": "tfe-configuration-version",
                "status": "planned",
                "status-timestamps": {
                  "planned-at": "2017-11-28T22:52:51+00:00"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 67371792
  },
  {
    "context": [
      "I need the newlines to remain as \\n and not be escaped to \\\\n.",
      "Make sure your shell variables contain _actual newlines_, not `\\n` sequences.",
      "If you want bash to convert escape sequences in a string into the characters they refer to, `printf %b` can be used for this purpose.",
      "# create markdown_message_unescaped with an unescaped version of markdown_message",
      "printf -v markdown_message_unescaped %b \"$markdown_message\"",
      "jq -n \\",
      "  --arg textMessage \"$markdown_message_unescaped\" \\",
      "  --arg fallbackMessage \"$fallback_message\" \\",
      "  --arg sectionType section --arg markdownType markdown '",
      "    {",
      "      text: $fallbackMessage, ",
      "      blocks: [",
      "        {",
      "          type: $sectionType,",
      "          text: {",
      "                    type: $markdownType, ",
      "                    text: $textMessage",
      "                }",
      "            }",
      "        ]",
      "    }'"
    ],
    "utterance": "Produce output containing literal newlines in text fields so that newlines are not escaped as \\n but are preserved as actual newline characters.",
    "expressions": [
      "jq -n --arg textMessage \"$markdown_message_unescaped\" --arg fallbackMessage \"$fallback_message\" --arg sectionType section --arg markdownType markdown '{ text: $fallbackMessage, blocks: [ { type: $sectionType, text: { type: $markdownType, text: $textMessage } } ] }'"
    ],
    "data": [
      {
        "input": {
          "fallback_message": "TEST MESSAGE - YOUR_HOSTNAME",
          "markdown_message_unescaped": "TEST MESSAGE - YOUR_HOSTNAME (0x0a) (\\n)\nHi <@U12345789>\n```\nCan we do a multiline code block\n```"
        },
        "output": {
          "text": "TEST MESSAGE - YOUR_HOSTNAME",
          "blocks": [
            {
              "type": "section",
              "text": {
                "type": "markdown",
                "text": "TEST MESSAGE - YOUR_HOSTNAME (0x0a) (\\n)\nHi <@U12345789>\n```\nCan we do a multiline code block\n```"
              }
            }
          ]
        }
      }
    ],
    "identifier": 67391180
  },
  {
    "context": [
      "1.\tGet 1st 5 objects from the whole list and save them in a separate file (i.e FirstTopObject.json)",
      "2.\tGet another set-off 5 objects and store them into another file (i.e SecondTopObject.json)",
      "3.\tGet the last 5 objects and store them into another file (i.e ThirdTopObject.json)",
      "cat input | jq --slurp -c .[] | head -5 | jq . > FirstTopObject.json",
      "cat input | jq --slurp -c .[] | sed '6,10!d' | jq . > SecondTopObject.json",
      "cat input | jq --slurp -c .[] | tail -5 | jq . > ThirdTopObject.json"
    ],
    "utterance": "Select the first, second, and last five objects from a list and output each set to a separate file.",
    "expressions": [
      "jq --slurp '.[0:5]' input.json > FirstTopObject.json",
      "jq --slurp '.[5:10]' input.json > SecondTopObject.json",
      "jq --slurp '.[-5:]' input.json > ThirdTopObject.json"
    ],
    "data": [
      {
        "input": [
          {
            "storeId": "0001"
          },
          {
            "storeId": "0002"
          },
          {
            "storeId": "0003"
          },
          {
            "storeId": "0004"
          },
          {
            "storeId": "0005"
          },
          {
            "storeId": "0006"
          },
          {
            "storeId": "0007"
          },
          {
            "storeId": "0008"
          },
          {
            "storeId": "0009"
          },
          {
            "storeId": "00010"
          },
          {
            "storeId": "00011"
          },
          {
            "storeId": "00012"
          },
          {
            "storeId": "00013"
          },
          {
            "storeId": "00014"
          },
          {
            "storeId": "00015"
          }
        ],
        "output": [
          [
            {
              "storeId": "0001"
            },
            {
              "storeId": "0002"
            },
            {
              "storeId": "0003"
            },
            {
              "storeId": "0004"
            },
            {
              "storeId": "0005"
            }
          ],
          [
            {
              "storeId": "0006"
            },
            {
              "storeId": "0007"
            },
            {
              "storeId": "0008"
            },
            {
              "storeId": "0009"
            },
            {
              "storeId": "00010"
            }
          ],
          [
            {
              "storeId": "00011"
            },
            {
              "storeId": "00012"
            },
            {
              "storeId": "00013"
            },
            {
              "storeId": "00014"
            },
            {
              "storeId": "00015"
            }
          ]
        ]
      }
    ],
    "identifier": 67404726
  },
  {
    "context": [
      "I was wondering is it possible to read the files with `jq` directly from the `gz` format?",
      "you could avoid writing the unzipped file to disk and the time related to that. This would be achieved by using one of the following:",
      "gunzip -c file.gz | jq -r '[ .a, .b, .time ] | @tsv' >file.tsv",
      "gunzip <file.gz | jq -r '[ .a, .b, .time ] | @tsv' >file.tsv"
    ],
    "utterance": "Extract the values of the fields 'a', 'b', and 'time' as TSV from each record in a large gzip-compressed file, without manually decompressing the file to disk.",
    "expressions": [
      "gunzip -c file.gz | jq -r '[.a, .b, .time] | @tsv'"
    ],
    "data": [
      {
        "input": [
          "{\"a\": \"foo\", \"b\": \"bar\", \"time\": \"2022-01-01T12:00:00\"}",
          "{\"a\": \"baz\", \"b\": \"qux\", \"time\": \"2022-01-01T13:00:00\"}"
        ],
        "output": [
          "foo\tbar\t2022-01-01T12:00:00",
          "baz\tqux\t2022-01-01T13:00:00"
        ]
      }
    ],
    "identifier": 67414225
  },
  {
    "context": [
      "The output I would like is:\r\n\r\n    a        a        2021-02-10 10:10:00\r\n    b        b        2021-02-10 11:10:00",
      "You can do it in sed, but you can also call `sub` directly in `jq`:\r\n\r\n    jq -r '[.a, .b,\r\n               ( .time \r\n                 | sub(\"(?<y>\\\\d{4})(?<m>\\\\d{2})(?<d>\\\\d{2})T\";\r\n                       .y+\"-\"+.m+\"-\"+.d+\" \")\r\n               )\r\n           ] | @tsv'",
      "Use `strptime` for date interpretation and `strftime` for formatting:\r\n\r\n_parse.jq_\r\n\r\n```jq\r\n[ \r\n  .a,\r\n  .b,\r\n  ( .time\r\n    | strptime(\"%Y%m%dT%H:%M:%S\")\r\n    | strftime(\"%Y-%d-%m %H:%M:%S\")\r\n  )\r\n] | @tsv\r\n```",
      "Since speed is an issue, and since there does not appear to be a need for anything more than string splitting, you could compare string splitting done with jq using\r\n\r\n    [.a, .b,\r\n     (.time | \"\\(.[:4])-\\(.[4:6])-\\(.[6:8]) \\(.[9:])\"]\r\n"
    ],
    "utterance": "Format the time field as 'YYYY-MM-DD HH:MM:SS' and print fields a, b, and the reformatted time as tab-separated values.",
    "expressions": [
      "[.a, .b, (.time | \"\\(.[:4])-\\(.[4:6])-\\(.[6:8]) \\(.[9:])\")] | @tsv",
      "[.a, .b, (.time | sub(\"(?<y>\\\\d{4})(?<m>\\\\d{2})(?<d>\\\\d{2})T\"; .y+\"-\"+.m+\"-\"+.d+\" \"))] | @tsv",
      "[.a, .b, (.time | strptime(\"%Y%m%dT%H:%M:%S\") | strftime(\"%Y-%m-%d %H:%M:%S\"))] | @tsv"
    ],
    "data": [
      {
        "input": {
          "a": "a",
          "b": "a",
          "time": "20210210T10:10:00"
        },
        "output": "a\ta\t2021-02-10 10:10:00"
      },
      {
        "input": {
          "a": "b",
          "b": "b",
          "time": "20210210T11:10:00"
        },
        "output": "b\tb\t2021-02-10 11:10:00"
      }
    ],
    "identifier": 67402313
  },
  {
    "context": [
      "I would like to parse it with jq.",
      "I\u2019ve this type of data :\n[\n  \"foo1:         xxxxxx\",\n  \"foo2:    xxxxxx\",\n  \"foo3:     xxxxxx\",\n  \"foo4:         xxxxxx\",\n  \"foo5:   xxxxxx\",\n  \"foo6:       xxxxxx\"\n]",
      "If you want to get the `xxxxxx` that is in the string beginning with `foo1:`, you can do something like this:",
      "$ jq '.[] | select(startswith(\"foo1\")) | sub(\"foo1:\\\\s+\"; \"\")' file.txt",
      "If you want to turn your input into an actual JSON object, you can iterate over each string, use `capture` to get the key and value, and then use `from_entries` to stitch it all back together into a single object. At this point, you can append your original `.foo1` and you'll get the behavior you originally expected.",
      "$ jq 'map(capture(\"^(?<key>.*):\\\\s*(?<value>.*)$\")) | from_entries' file.txt"
    ],
    "utterance": "Extract the value associated with 'foo1' from an array of colon-separated key-value strings.",
    "expressions": [
      ".[] | select(startswith(\"foo1\")) | sub(\"foo1:\\s+\"; \"\")",
      "map(capture(\"^(?<key>.*):\\s*(?<value>.*)$\")) | from_entries | .foo1"
    ],
    "data": [
      {
        "input": [
          "foo1:         xxxxxx",
          "foo2:    xxxxxx",
          "foo3:     xxxxxx",
          "foo4:         xxxxxx",
          "foo5:   xxxxxx",
          "foo6:       xxxxxx"
        ],
        "output": "xxxxxx"
      }
    ],
    "identifier": 67405114
  },
  {
    "context": [
      "I require this type of output:\r\n\r\n    611,0.389165\r\n    ABC,59.99\r\n    ACP,0.014931\r\n    ACT,0.021098\r\n    ACT*,0.017178\r\n    ADA,1.460965",
      "You can use `@csv` to generate CSV output from arrays, and `to_entries` to break up the object's elements into said arrays:\r\n\r\n```sh\r\n$ jq -r '.rates | to_entries[] | [ .key, .value ] | @csv' input.json\r\n\"611\",0.389165\r\n\"ABC\",59.99\r\n\"ACP\",0.014931\r\n\"ACT\",0.021098\r\n\"ACT*\",0.017178\r\n\"ADA\",1.460965\r\n```"
    ],
    "utterance": "Print each key and value in the rates object as CSV rows with the key and value separated by a comma.",
    "expressions": [
      ".rates | to_entries[] | [ .key, .value ] | @csv"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "terms": "https://coinlayer.com/terms",
          "privacy": "https://coinlayer.com/privacy",
          "timestamp": 1620244806,
          "target": "USD",
          "rates": {
            "611": 0.389165,
            "ABC": 59.99,
            "ACP": 0.014931,
            "ACT": 0.021098,
            "ACT*": 0.017178,
            "ADA": 1.460965
          }
        },
        "output": [
          "\"611\",0.389165",
          "\"ABC\",59.99",
          "\"ACP\",0.014931",
          "\"ACT\",0.021098",
          "\"ACT*\",0.017178",
          "\"ADA\",1.460965"
        ]
      }
    ],
    "identifier": 67408791
  },
  {
    "context": [
      "With `jq` I want to sort and filter the json to get the latest version of 84.3400 branch. Which is tag `84.3400.2`.",
      "Here is an adapted json: \n{\n  \"Repository\": \"registry.example:8080/my-namespace/my-app\",\n  \"Tags\": [\n    \"84.3400.1\",\n    \"84.3400.12\",\n    \"84.3400.2\",\n    \"latest\"\n  ]\n}",
      "You can pass the base version as a variable and sort on that. E.g. for your provided input\n\njq --arg base \"84.3400\" '.Tags | map(select(startswith($base))) | sort | last'\n",
      "\"84.3400\" as $base | .Tags | map(select(startswith($base))) | sort | last"
    ],
    "utterance": "Find the highest tag for the 84.3400 branch, prioritizing correct version ordering, such that 84.3400.12 is considered newer than 84.3400.2.",
    "expressions": [
      "jq --arg base \"84.3400\" '.Tags | map(select(startswith($base))) | sort | last'",
      "\"84.3400\" as $base | .Tags | map(select(startswith($base))) | sort | last"
    ],
    "data": [
      {
        "input": {
          "Repository": "registry.example:8080/my-namespace/my-app",
          "Tags": [
            "84.3400.1",
            "84.3400.12",
            "84.3400.2",
            "latest"
          ]
        },
        "output": "84.3400.12"
      }
    ],
    "identifier": 67434948
  },
  {
    "context": [
      "The goal is to add an element to the Properties node of any TopB child where .Type == \"that\". And the kicker is that I need to put the child node's key into the new element value with an added prefix.",
      "So essentially I need the last element to look like this:",
      "\"AAD76465\": {\n  \"Type\": \"that\",\n  \"Properties\": {\n    \"lots\": 7,\n    \"of\": 8,\n    \"values\": 9,\n    \"newElement\": \"Prefix-AAD76465\"\n  }\n}",
      "reduce path(.TopB[] | select(.Type == \"that\") .Properties.newElement) as $p (.; setpath($p; \"Prefix-\\($p[1])\"))",
      "walk(if (type == \"object\") and .TopB\n     then .TopB |= with_entries( \n       .key as $key\n       | if .value.Type == \"that\" \n         then .value.Properties += { newElement: (\"Prefix-\" + $key) }\n         else . end)\n     else . end)"
    ],
    "utterance": "For each child of TopB where Type equals \"that\", add a new element newElement to its Properties object, setting its value to \"Prefix-<child key>\".",
    "expressions": [
      "reduce path(.TopB[] | select(.Type == \"that\") .Properties.newElement) as $p (.; setpath($p; \"Prefix-\\($p[1])\"))",
      "walk(if (type == \"object\") and .TopB\n     then .TopB |= with_entries( \n       .key as $key\n       | if .value.Type == \"that\" \n         then .value.Properties += { newElement: (\"Prefix-\" + $key) }\n         else . end)\n     else . end)"
    ],
    "data": [
      {
        "input": {
          "TopA": {
            "stuff": "here"
          },
          "TopB": {
            "C591AB7E": {
              "Type": "this",
              "Properties": {
                "lots": 1,
                "of": 2,
                "values": 3
              }
            },
            "7E16765A": {
              "Type": "this",
              "Properties": {
                "lots": 4,
                "of": 5,
                "values": 6
              }
            },
            "AAD76465": {
              "Type": "that",
              "Properties": {
                "lots": 7,
                "of": 8,
                "values": 9
              }
            }
          }
        },
        "output": {
          "TopA": {
            "stuff": "here"
          },
          "TopB": {
            "C591AB7E": {
              "Type": "this",
              "Properties": {
                "lots": 1,
                "of": 2,
                "values": 3
              }
            },
            "7E16765A": {
              "Type": "this",
              "Properties": {
                "lots": 4,
                "of": 5,
                "values": 6
              }
            },
            "AAD76465": {
              "Type": "that",
              "Properties": {
                "lots": 7,
                "of": 8,
                "values": 9,
                "newElement": "Prefix-AAD76465"
              }
            }
          }
        }
      }
    ],
    "identifier": 67433142
  },
  {
    "context": [
      "I do want to filter few values inside data *(data.lines.data[])* like **id**, **plan** and inside plan the **id**, **currency** and **product** for example.",
      "Desired result should look like:",
      "[",
      "  \"DESIRED_ID\",",
      "  1,",
      "  \"value_retrieved_ok\",",
      "  unixtime_ok,",
      "  \"SOME_ID_OK\",",
      "  \"customer_mail@ok.com\",",
      "  \"id\"             // the id inside lines.data{}",
      "    [\"id\",         // the id inside lines.data.plan",
      "     \"currency\",   // the currency inside lines.data.plan",
      "     \"product\"     // the product inside lines.data.plan",
      "    ]",
      "  true,",
      "  \"paid\"",
      "]",
      "the following is either what you&#39;re looking for, or very close to it:",
      ".data[]",
      "| [.id,.attempt_count,.billing_reason,.created,.customer,.customer_email]",
      "  + (.lines.data[] | [.id, [.plan.id, .plan.currency, .plan.product]])",
      "  + [.paid,.status]"
    ],
    "utterance": "Extract the top-level invoice fields id, attempt_count, billing_reason, created, customer, customer_email, then for each line item include its id and its plan's id, currency, and product, followed by paid and status.",
    "expressions": [
      ".data[] | [.id,.attempt_count,.billing_reason,.created,.customer,.customer_email] + (.lines.data[] | [.id, [.plan.id, .plan.currency, .plan.product]]) + [.paid,.status]"
    ],
    "data": [
      {
        "input": {
          "object": "list",
          "data": [
            {
              "id": "INVOICE_ID",
              "object": "invoice",
              "account_country": "COUNTRY",
              "account_name": "MY_BUSYNESS_NAME",
              "account_tax_ids": null,
              "amount_due": 1000,
              "amount_paid": 1000,
              "amount_remaining": 0,
              "application_fee_amount": null,
              "attempt_count": 1,
              "attempted": true,
              "auto_advance": false,
              "billing_reason": "subscription_create",
              "charge": "CHARGE_ID",
              "collection_method": "charge_automatically",
              "created": 1685000000,
              "currency": "usd",
              "custom_fields": null,
              "customer": "CUSTOMER_ID",
              "customer_address": null,
              "customer_email": "CUSTOMER_EMAIL",
              "customer_name": null,
              "customer_phone": "CUSTOMER_PHONE",
              "customer_shipping": null,
              "customer_tax_exempt": "none",
              "customer_tax_ids": [],
              "default_payment_method": null,
              "default_source": null,
              "default_tax_rates": [],
              "description": null,
              "discount": null,
              "discounts": [],
              "due_date": null,
              "ending_balance": 0,
              "footer": null,
              "hosted_invoice_url": "INVOICE_URL_GOES_HERE",
              "invoice_pdf": "INVOICE_PDF_URL_GOES_HERE",
              "last_finalization_error": null,
              "lines": {
                "object": "list",
                "data": [
                  {
                    "id": "LINE_ID",
                    "object": "line_item",
                    "amount": 1000,
                    "currency": "usd",
                    "description": "PLAN_DESCRIPTION",
                    "discount_amounts": [],
                    "discountable": true,
                    "discounts": [],
                    "livemode": false,
                    "metadata": {},
                    "period": {
                      "end": 1685080000,
                      "start": 1685000000
                    },
                    "plan": {
                      "id": "PRICE_ID_HERE",
                      "object": "plan",
                      "active": true,
                      "aggregate_usage": null,
                      "amount": 1000,
                      "amount_decimal": "1000",
                      "billing_scheme": "per_unit",
                      "created": 1685000000,
                      "currency": "usd",
                      "interval": "month",
                      "interval_count": 1,
                      "livemode": false,
                      "metadata": {},
                      "nickname": null,
                      "product": "PRODUCT_ID_HERE",
                      "tiers_mode": null,
                      "transform_usage": null,
                      "trial_period_days": null,
                      "usage_type": "licensed"
                    },
                    "price": {
                      "id": "MORE_ID_HERE",
                      "object": "price",
                      "active": true,
                      "billing_scheme": "per_unit",
                      "created": 1685000000,
                      "currency": "usd",
                      "livemode": false,
                      "lookup_key": null,
                      "metadata": {},
                      "nickname": null,
                      "product": "PRODUCT_ID_HERE",
                      "recurring": {
                        "aggregate_usage": null,
                        "interval": "month",
                        "interval_count": 1,
                        "trial_period_days": null,
                        "usage_type": "licensed"
                      },
                      "tiers_mode": null,
                      "transform_quantity": null,
                      "type": "recurring",
                      "unit_amount": 1000,
                      "unit_amount_decimal": "1000"
                    },
                    "proration": false,
                    "quantity": 1,
                    "subscription": "SUBSCRIPTION_ID_HERE",
                    "subscription_item": "SUBS_ITEM_ID_HERE",
                    "tax_amounts": [],
                    "tax_rates": [],
                    "type": "subscription"
                  }
                ],
                "has_more": false,
                "total_count": 1,
                "url": "IV_URL_HERE"
              },
              "livemode": false,
              "metadata": {},
              "next_payment_attempt": null,
              "number": "NUMBER_IV_XXXX",
              "on_behalf_of": null,
              "paid": true,
              "payment_intent": "PAYMENT_INTENT_ID_HERE",
              "payment_settings": {
                "payment_method_options": null,
                "payment_method_types": null
              },
              "period_end": 1685080000,
              "period_start": 1685000000,
              "post_payment_credit_notes_amount": 0,
              "pre_payment_credit_notes_amount": 0,
              "receipt_number": null,
              "starting_balance": 0,
              "statement_descriptor": null,
              "status": "paid",
              "status_transitions": {
                "finalized_at": 1685090000,
                "marked_uncollectible_at": null,
                "paid_at": 1685100000,
                "voided_at": null
              },
              "subscription": "SUBSCRIPTION_ID_HERE",
              "subtotal": 1000,
              "tax": null,
              "total": 1000,
              "total_discount_amounts": [],
              "total_tax_amounts": [],
              "transfer_data": null,
              "webhooks_delivered_at": 1685110000
            }
          ],
          "has_more": false,
          "url": "/some_path"
        },
        "output": [
          [
            "INVOICE_ID",
            1,
            "subscription_create",
            1685000000,
            "CUSTOMER_ID",
            "CUSTOMER_EMAIL",
            "LINE_ID",
            [
              "PRICE_ID_HERE",
              "usd",
              "PRODUCT_ID_HERE"
            ],
            true,
            "paid"
          ]
        ]
      }
    ],
    "identifier": 67305277
  }
]