[
  {
    "context": [
      "I want output something like -\n{\n        \"AddOnModules\": {\n                \"Description\": \"add on modules\",\n                \"Type\": \"Array\",\n                \"AllowedValues\": [\n                    \"a\",\n                    \"b\",\n                    \"c\"\n                ],\n                \"value\": [\"a\",\"b\"]\n            }\n }",
      "jq -r --argjson add_on_modules \"$add_on_modules\" '\n .AddOnModules.value  += $add_on_modules\n' sample.json",
      "jq -r --arg add_on_modules \"$add_on_modules\" '\n  .AddOnModules.value  += ($add_on_modules|split(\",\")|map(fromjson)) \n  ' sample.json"
    ],
    "utterance": "Update AddOnModules.value by adding values provided in a variable (such as \"a\",\"b\") so that the resulting array contains those string elements.",
    "expressions": [
      "jq -r --argjson add_on_modules \"$add_on_modules\" '.AddOnModules.value  += $add_on_modules' sample.json",
      "jq -r --arg add_on_modules \"$add_on_modules\" '.AddOnModules.value  += ($add_on_modules|split(\",\")|map(fromjson))' sample.json"
    ],
    "data": [
      {
        "input": {
          "AddOnModules": {
            "Description": "add on modules",
            "Type": "Array",
            "AllowedValues": [
              "a",
              "b",
              "c"
            ],
            "value": []
          }
        },
        "output": {
          "AddOnModules": {
            "Description": "add on modules",
            "Type": "Array",
            "AllowedValues": [
              "a",
              "b",
              "c"
            ],
            "value": [
              "a",
              "b"
            ]
          }
        }
      }
    ],
    "identifier": 64561584
  },
  {
    "context": [
      "azure cli `az group list` return data like  \r\n```json\r\n[\r\n  \"demo3\",\r\n  \"demo\",\r\n  \"demo2\",\r\n  \"NetworkWatcherRG\"\r\n]\r\n```",
      "I\u2019d like to foreach it\u2019s value on ubuntu bash then printing below result  \r\n```\r\ndemo3\r\ndemo\r\ndemo2\r\nNetworkWatcherRG\r\n```",
      "az group list | jq -c '.[]'"
    ],
    "utterance": "Print each value from an array of names as a separate line in the terminal.",
    "expressions": [
      ".[]",
      "jq -c '.[]'"
    ],
    "data": [
      {
        "input": [
          "demo3",
          "demo",
          "demo2",
          "NetworkWatcherRG"
        ],
        "output": [
          "demo3",
          "demo",
          "demo2",
          "NetworkWatcherRG"
        ]
      }
    ],
    "identifier": 64176625
  },
  {
    "context": [
      "I want to convert the json to resemble the following",
      "{\r\n    \"URLPath\": \"https://home-automation-service.jakeworld.com\",\r\n    \"Port\": \"8080\"\r\n}",
      "A jq solution:",
      "map( {(.OutputKey) : .OutputValue} ) | add"
    ],
    "utterance": "Transform an array of objects with OutputKey and OutputValue fields into a single object where each OutputKey becomes a key with its corresponding OutputValue as value.",
    "expressions": [
      "map({(.OutputKey): .OutputValue}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "OutputKey": "URLPath",
            "OutputValue": "https://home-automation-service.jakeworld.com"
          },
          {
            "OutputKey": "Port",
            "OutputValue": "8080"
          }
        ],
        "output": {
          "URLPath": "https://home-automation-service.jakeworld.com",
          "Port": "8080"
        }
      }
    ],
    "identifier": 64180396
  },
  {
    "context": [
      "I want the return value to be like\n\n    .editorconfig\n    .gitattributes\n    .gitignore\n    .revision-hash\n    .travis.yml\n    .version\n    COPYING.md\n    HACKING.md\n    INSTALL.md\n    Makefile\n    README.md\n    changelog.md\n    docs\n    docs/highlighters.md\n    docs/highlighters\n    docs/highlighters/brackets.md\n    docs/highlighters/cursor.md\n    docs/highlighters/line.md\n    ....",
      "Use [tag:jq]'s `-r` option ([docs](https://stedolan.github.io/jq/manual/#Invokingjq)):\n```\njq -r '.tree[]|.path'\n```\n\nResult:\n```\n.editorconfig\n.gitattributes\n.gitignore\n.revision-hash\n.travis.yml\n.version\nCOPYING.md\nHACKING.md\n...\n```"
    ],
    "utterance": "Print each value in the array under the 'tree[].path' property as a plain text line.",
    "expressions": [
      ".tree[] | .path",
      ".tree[].path"
    ],
    "data": [
      {
        "input": {
          "tree": [
            {
              "path": ".editorconfig"
            },
            {
              "path": ".gitattributes"
            },
            {
              "path": ".gitignore"
            }
          ]
        },
        "output": [
          ".editorconfig",
          ".gitattributes",
          ".gitignore"
        ]
      }
    ],
    "identifier": 64483462
  },
  {
    "context": [
      "I have to merge ~1000 large json files (1M .. 500M) into a single file (~80GB) on Ubuntu 18.",
      "jq -s 'reduce .[] as $item ({}; . * $item)' ~/ml/train-*.json > train.json",
      "Using -s is here both unnecessary and asking for trouble. You could try using `inputs` with the -n option instead.",
      "jq -n 'reduce inputs as $item (null; . + $item)'"
    ],
    "utterance": "Merge approximately 1000 large files by combining their object keys and values into one file using object addition.",
    "expressions": [
      "jq -n 'reduce inputs as $item (null; . + $item)'"
    ],
    "identifier": 64154303
  },
  {
    "context": [
      "az group list --query \"[?name != 'product'].name\" | jq -c '.[]' | while read g; do     az group delete -n $g --no-wait -y;  don",
      "sa@DESKTOP-WEI:~$ az group list --query \"[?name != 'product'].name\" | jq -c '.[]' | while read g; do     echo $g; done",
      "\"NetworkWatcherRG\"",
      "for rg in $(az group list --query \"[?name != 'product'].name\" | jq -r '.[]'); \\",
      "do az group delete -n ${rg};\\",
      "done"
    ],
    "utterance": "Extract all values from the array, each representing a resource group name excluding 'product', and output them as plain strings without quotes.",
    "expressions": [
      ".[]",
      "-r '.[]'"
    ],
    "identifier": 64184270
  },
  {
    "context": [
      "let's say I want to update the status where the name is \"lan\"",
      ".interface_settings |= map( if .name == \"lan\" then .status = \"up\" else . end)",
      "Just the first such",
      ".interface_settings |= (reduce .[] as $x (null;\n\t  if .done\n\t  then .ans += [$x]\n      elif $x.name == \"lan\"\n      then .ans += [$x | .status = \"up\"] | .done = true\n      else .ans += [$x]\n      end) | .ans)"
    ],
    "utterance": "Change the value of the status key to \"up\" only for the first object in interface_settings where name is \"lan\".",
    "expressions": [
      ".interface_settings |= (reduce .[] as $x (null;\n  if .done\n  then .ans += [$x]\n  elif $x.name == \"lan\"\n  then .ans += [$x | .status = \"up\"] | .done = true\n  else .ans += [$x]\n  end) | .ans)"
    ],
    "data": [
      {
        "input": {
          "interface_settings": [
            {
              "name": "lan",
              "status": "down"
            },
            {
              "name": "lan",
              "status": "down"
            },
            {
              "name": "lte1",
              "status": "down"
            }
          ]
        },
        "output": {
          "interface_settings": [
            {
              "name": "lan",
              "status": "up"
            },
            {
              "name": "lan",
              "status": "down"
            },
            {
              "name": "lte1",
              "status": "down"
            }
          ]
        }
      }
    ],
    "identifier": 64454740
  },
  {
    "context": [
      "First I need to append a new key-value pair to all files with `\"CaseId\": \"[filename]\"` and then merge them all into one big array and save it as a new json manifest file.",
      "You\u2019re looking for [input_filename](https://stedolan.github.io/jq/manual/#input_filename).\n```\njq -n '[ inputs | .CaseId = input_filename ]' *.json\n```",
      "You can use `reduce` adding on one input object at a time. Use `input_filename` to get the UTF-8 encoded filename and form the record with `CaseId`\n\n```\njq -n 'reduce inputs as $d (null; . + [ $d + { CaseId: input_filename } ] )' *.json\n```"
    ],
    "utterance": "Merge all files in the directory into a single array, adding a CaseId property with each object's filename as its value.",
    "expressions": [
      "jq -n '[ inputs | .CaseId = input_filename ]' *.json",
      "jq -n 'reduce inputs as $d (null; . + [ $d + { CaseId: input_filename } ] )' *.json"
    ],
    "data": [
      {
        "input": [
          {
            "Active": true,
            "CaseType": "CaseType",
            "CustomerGroup": [
              "Core",
              "Extended"
            ]
          },
          {
            "Active": true,
            "CaseType": "CaseType",
            "CustomerGroup": [
              "Core",
              "Extended"
            ]
          }
        ],
        "output": [
          {
            "Active": true,
            "CaseType": "CaseType",
            "CustomerGroup": [
              "Core",
              "Extended"
            ],
            "CaseId": "43d47f66-5a0a-4b86-88d6-1f1f893098d2"
          },
          {
            "Active": true,
            "CaseType": "CaseType",
            "CustomerGroup": [
              "Core",
              "Extended"
            ],
            "CaseId": "e3x47f66-5a0a-4b86-88d6-1f1f893098d2"
          }
        ]
      }
    ],
    "identifier": 64424113
  },
  {
    "context": [
      "I try to do the average of all the `\"3xx\"` fields.",
      "The desired output with my example above would be `11` as `(2 + 14 + 17) / 3`, those number all coming from the `3xx`'s items field.",
      "You can get the value directly from jq:",
      "$ jq '[.stats.cluster[][\"3xx\"]] | add / length' <<< \"$data\"",
      "11"
    ],
    "utterance": "Calculate the average value of all \"3xx\" fields inside all entries under stats.cluster.",
    "expressions": [
      "[.stats.cluster[][\"3xx\"]] | add / length"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "earliest_ts": 1601425980,
            "latest_ts": 1601482740,
            "interval": "minutes",
            "level": "cluster",
            "entity_id": "xxxxx-xxxxx-xxxxx-xxxxx-xxxxx",
            "stat_labels": [
              "status_code_classes_per_workspace_total"
            ],
            "entity_type": "workspace",
            "start_ts": "1601425980"
          },
          "stats": {
            "cluster": {
              "1601431620": {
                "3xx": 2,
                "4xx": 87,
                "5xx": 31,
                "2xx": 352
              },
              "1601472780": {
                "3xx": 14,
                "4xx": 296,
                "5xx": 2,
                "2xx": 3811
              },
              "1601479140": {
                "3xx": 17,
                "4xx": 397,
                "5xx": 19,
                "2xx": 4399
              }
            }
          }
        },
        "output": 11
      }
    ],
    "identifier": 64142411
  },
  {
    "context": [
      "Judging from your requirements, it seems you need an expression to select objects  in the `.Body[]` array where `.webServerName` key is `www.example.com:443` or the key basically exists",
      ".[].Body |= map(select(.webServerName == \"www.example.com:443\" or has(\"webServerName\") ))",
      "Both your attempts though valid are really convoluted. The standard pattern to selectively filter out objects inside the array is to use the `|=` operator with the right `select` expression.",
      "The `| {Tenant: $x, Body: [$y]}` is wrong, because it is applied to each of the 2 objects you filtered in the previous expression. So each of the result has a `Tenant` field created. Since you have no change in key names (same key `Tenant`), there is really no purpose to re-create new objects with `{..}`."
    ],
    "utterance": "Filter each object's Body array to keep only entries where webServerName equals www.example.com:443.",
    "expressions": [
      ".[].Body |= map(select(.webServerName == \"www.example.com:443\"))"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Tenant": "T1"
            },
            "Body": [
              {
                "agentTechnologyType": "JAVA",
                "entityId": "SERVICE-EDA448F07EDBDAA6",
                "serviceType": "WebRequest",
                "webServerName": "www.example.com:443"
              },
              {
                "agentTechnologyType": "TOMCAT",
                "entityId": "SERVICE-728B1FF49D132C89",
                "serviceType": "WebRequest",
                "webServerName": "www.example.com:80"
              },
              {
                "agentTechnologyType": "JAVA",
                "entityId": "SERVICE-42A0FB8666B36EB4",
                "serviceType": "Process"
              },
              {
                "agentTechnologyType": "APACHE",
                "serviceType": "WebRequest",
                "webServerName": "www.example.com:443"
              }
            ]
          }
        ],
        "output": [
          {
            "Header": {
              "Tenant": "T1"
            },
            "Body": [
              {
                "agentTechnologyType": "JAVA",
                "entityId": "SERVICE-EDA448F07EDBDAA6",
                "serviceType": "WebRequest",
                "webServerName": "www.example.com:443"
              },
              {
                "agentTechnologyType": "APACHE",
                "serviceType": "WebRequest",
                "webServerName": "www.example.com:443"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 64264926
  },
  {
    "context": [
      "My rows in csv should have the data inside each ```_source``` tag. So my columns would be ```alertId``` , ```alertCategory``` , ```description``` and ```logId``` with its respective data.",
      "your expression should have been below. Use it along with `-r` flag to put the output in raw output format",
      "```jq\n.hits.hits[]._source | [ .alertID, .alertCategory, .description, .logId ] | @csv\n```",
      "To add the column name as the header in the output CSV format, you could use the `@csv` or the `join(\",\")` function in raw output format `-r`",
      "```jq\n[ \"alertId\" , \"alertCategory\" , \"description\", \"logId\" ], \n( .hits.hits[]._source |  [ .alertID, .alertCategory, .description, .logId // \"null\" ]) | @csv\n```",
      "If your fields are `null`, the string representation of your null field value results in just `\"\"`. If you want an explicit `\"null\"` string representation, use the alternate operator along with the field you expect to be null, e.g. instead of `.logId`, you can do `(.logId // \"null\")`"
    ],
    "utterance": "Extract the alertID, alertCategory, description, and logId fields from each object inside all _source keys under hits.hits, and output as CSV including a header row.",
    "expressions": [
      ".hits.hits[]._source | [ .alertID, .alertCategory, .description, .logId ] | @csv",
      "[ \"alertId\" , \"alertCategory\" , \"description\", \"logId\" ], ( .hits.hits[]._source |  [ .alertID, .alertCategory, .description, .logId // \"null\" ]) | @csv",
      "[ \"alertId\" , \"alertCategory\" , \"description\", \"logId\" ], ( .hits.hits[]._source |  [ .alertID, .alertCategory, .description, .logId // \"null\" ]) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "took": 111,
          "timed_out": false,
          "_shards": {
            "total": 1,
            "successful": 1,
            "skipped": 0,
            "failed": 0
          },
          "hits": {
            "total": {
              "value": 2,
              "relation": "eq"
            },
            "max_score": 1.0,
            "hits": [
              {
                "_index": "alerts",
                "_type": "_doc",
                "_id": "1",
                "_score": 1.0,
                "_source": {
                  "alertID": "639387c3-0fbe-4c2b-9387-c30fbe7c2bc6",
                  "alertCategory": "Server Alert",
                  "description": "Successfully started.",
                  "logId": null
                }
              },
              {
                "_index": "alerts",
                "_type": "_doc",
                "_id": "2",
                "_score": 1.0,
                "_source": {
                  "alertID": "2",
                  "alertCategory": "Server Alert",
                  "description": "Successfully stoped.",
                  "logId": null
                }
              }
            ]
          }
        },
        "output": [
          "\"alertId\",\"alertCategory\",\"description\",\"logId\"",
          "\"639387c3-0fbe-4c2b-9387-c30fbe7c2bc6\",\"Server Alert\",\"Successfully started.\",\"null\"",
          "\"2\",\"Server Alert\",\"Successfully stoped.\",\"null\""
        ]
      }
    ],
    "identifier": 64553171
  },
  {
    "context": [
      "I want to match on the word \"Hello\" and return the `_id` only for fields containing \"Hello\". The expected result is:\n\n    1\n    55",
      ".[]\n| select( .body | test(\"Hello\") )._id",
      "jq -nr --stream '\n  fromstream(1|truncate_stream(inputs))\n  | select(.body | test(\"Hello\"))\n  | ._id\n'",
      "fromstream(1|truncate_stream(inputs?))\n  | select(.body | test(\"Hello\"))\n  | ._id"
    ],
    "utterance": "Return the _id values of posts whose body contains the substring 'Hello'.",
    "expressions": [
      ".[] | select(.body | test(\"Hello\"))._id",
      "jq -nr --stream 'fromstream(1|truncate_stream(inputs)) | select(.body | test(\"Hello\")) | ._id'",
      "fromstream(1|truncate_stream(inputs?)) | select(.body | test(\"Hello\")) | ._id"
    ],
    "data": [
      {
        "input": [
          [
            {
              "_id": "1",
              "@": {},
              "article": false,
              "body": "Hello world",
              "comments": "3",
              "createdAt": "20201007200628",
              "creator": {
                "id": "4a7ba8fd719d43598b977dd548eed6aa",
                "bio": "",
                "blocked": false,
                "followed": false,
                "human": false,
                "integration": false,
                "joined": "20201007200628",
                "muted": false,
                "name": "mkscott",
                "rss": false,
                "private": false,
                "username": "mkscott",
                "verified": false,
                "verifiedComments": false,
                "badges": [],
                "score": "0",
                "interactions": 258,
                "state": 1
              },
              "depth": "0",
              "depthRaw": 0,
              "hashtags": [],
              "id": "2d4126e342ed46509b55facb49b992a5",
              "impressions": "3",
              "links": [],
              "sensitive": false,
              "state": 4,
              "upvotes": "0"
            },
            {
              "_id": "2",
              "@": {},
              "article": false,
              "body": "Goodbye world",
              "comments": "3",
              "createdAt": "20201007200628",
              "creator": {
                "id": "4a7ba8fd719d43598b977dd548eed6aa",
                "bio": "",
                "blocked": false,
                "followed": false,
                "human": false,
                "integration": false,
                "joined": "20201007200628",
                "muted": false,
                "name": "mkscott",
                "rss": false,
                "private": false,
                "username": "mkscott",
                "verified": false,
                "verifiedComments": false,
                "badges": [],
                "score": "0",
                "interactions": 258,
                "state": 1
              },
              "depth": "0",
              "depthRaw": 0,
              "hashtags": [],
              "id": "2d4126e342ed46509b55facb49b992a5",
              "impressions": "3",
              "links": [],
              "sensitive": false,
              "state": 4,
              "upvotes": "0"
            }
          ],
          [
            {
              "_id": "55",
              "@": {},
              "article": false,
              "body": "Hello world",
              "comments": "3",
              "createdAt": "20201007200628",
              "creator": {
                "id": "3a7ba8fd719d43598b977dd548eed6aa",
                "bio": "",
                "blocked": false,
                "followed": false,
                "human": false,
                "integration": false,
                "joined": "20201007200628",
                "muted": false,
                "name": "mkscott",
                "rss": false,
                "private": false,
                "username": "jkscott",
                "verified": false,
                "verifiedComments": false,
                "badges": [],
                "score": "0",
                "interactions": 258,
                "state": 1
              },
              "depth": "0",
              "depthRaw": 0,
              "hashtags": [],
              "id": "2d4126e342ed46509b55facb49b992a5",
              "impressions": "3",
              "links": [],
              "sensitive": false,
              "state": 4,
              "upvotes": "0"
            },
            {
              "_id": "56",
              "@": {},
              "article": false,
              "body": "Goodbye world",
              "comments": "3",
              "createdAt": "20201007200628",
              "creator": {
                "id": "3a7ba8fd719d43598b977dd548eed6aa",
                "bio": "",
                "blocked": false,
                "followed": false,
                "human": false,
                "integration": false,
                "joined": "20201007200628",
                "muted": false,
                "name": "mkscott",
                "rss": false,
                "private": false,
                "username": "jkscott",
                "verified": false,
                "verifiedComments": false,
                "badges": [],
                "score": "0",
                "interactions": 258,
                "state": 1
              },
              "depth": "0",
              "depthRaw": 0,
              "hashtags": [],
              "id": "2d4126e342ed46509b55facb49b992a5",
              "impressions": "3",
              "links": [],
              "sensitive": false,
              "state": 4,
              "upvotes": "0"
            }
          ]
        ],
        "output": [
          "1",
          "55"
        ]
      }
    ],
    "identifier": 64252276
  },
  {
    "context": [
      "data:",
      "    [{\"id\": \"first\", \"val\": 1}, {\"id\": \"second\", \"val\": 2}, {\"id\": \"second\", \"val\": 3}]",
      "query:",
      "    .[] | map(select(.id == \"second\"))",
      "expected:",
      "    {\"id\": \"second\", \"val\": 2}, {\"id\": \"second\", \"val\": 3}",
      "result:",
      "    Cannot index string with string \"id\"",
      "`map(select(.id == \"second\"))` expects an array of objects, however `.[]` takes them out of the array so everything after that must be able to work on single item.",
      "In your jqplay example your filter is `.[] | select(.id == \"second\")` and is working fine."
    ],
    "utterance": "Return all objects whose id is equal to \"second\".",
    "expressions": [
      "map(select(.id == \"second\"))",
      ".[] | select(.id == \"second\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "first",
            "val": 1
          },
          {
            "id": "second",
            "val": 2
          },
          {
            "id": "second",
            "val": 3
          }
        ],
        "output": [
          {
            "id": "second",
            "val": 2
          },
          {
            "id": "second",
            "val": 3
          }
        ]
      }
    ],
    "identifier": 64042640
  },
  {
    "context": [
      "The condition is to have all elements (no matter the length of the array) to have value == true.",
      "You can use the `all` function to reduce an array of Booleans* to `true` if all the Booleans are true. `jq` will output that value, which you can capture using command substitution.",
      "result=$(jq 'map(.value) | all' tmp.json)"
    ],
    "utterance": "Check if all objects in the array have the property 'value' set to true.",
    "expressions": [
      "map(.value) | all"
    ],
    "data": [
      {
        "input": [
          {
            "key": "Org1",
            "value": true
          },
          {
            "key": "Org2",
            "value": false
          }
        ],
        "output": false
      },
      {
        "input": [
          {
            "key": "Org1",
            "value": true
          },
          {
            "key": "Org2",
            "value": true
          }
        ],
        "output": true
      }
    ],
    "identifier": 64577842
  },
  {
    "context": [
      "I set a variable using `curl` and `jq` inside backquotes (reading from my Trello daily to-do list and returning card.id and card.name for everything but a specific card):",
      "curl -s \"https://api.trello.com/1/lists/$DailyTasksListID/cards\\\n?$WhoMe\\\n&fields=name,id,pos\\\n\"\\\n| jq  '\\\n    .[] | \\\n    if .name | test (\"Tasks here are copied.*\") \\\n    then empty \\\n    else .id, .name \\\n    end \\\n    '\\\n",
      "But if I replace the backquotes with `$( ... )`, I get an error from `jq`:",
      "You can certainly use `\\` to escape end-of-lines inside a `$(...)` expression. Also note that you **don't** need those `\\`'s in the `jq` expression inside the single quotes.",
      "I would probably write it something like this:",
      "AllCardsInDTL=$(curl -s \"https://api.trello.com/1/lists/$DailyTasksListID/cards\\\n?$WhoMe\\\n&fields=name,id,pos\" |\njq  '.[] |\n    if .name | test (\"Tasks here are copied.*\")\n    then empty\n    else .id, .name\n    end\n    '\n)"
    ],
    "utterance": "Output the id and name of each card unless the name matches the regex 'Tasks here are copied.*'.",
    "expressions": [
      ".[] | if .name | test(\"Tasks here are copied.*\") then empty else .id, .name end"
    ],
    "identifier": 64565972
  },
  {
    "context": [
      "I want to remove the slash so the response can be used as a table in JQ:",
      "or if you still want to remove the `/`, use gsub() function",
      "jq -r '([\"Names\",\"Image\"] | (., map(length*\"-\"))), ([ (.Names[] | gsub(\"^/\";\"\")), .Image]) | @tsv'"
    ],
    "utterance": "Extract the container name without a leading slash and the image name, formatted in tab-separated form.",
    "expressions": [
      "([\"Names\",\"Image\"] | (., map(length*\"-\"))), ([ (.Names[] | gsub(\"^/\";\"\")), .Image]) | @tsv"
    ],
    "data": [
      {
        "input": {
          "Id": "8dfafdbc3a40",
          "Names": [
            "/boring_feynman"
          ],
          "Image": "ubuntu:latest",
          "ImageID": "d74508fb6632491cea586a1fd7d748dfc5274cd6fdfedee309ecdcbc2bf5cb82",
          "Command": "echo 1",
          "Created": 1367854155,
          "State": "Exited",
          "Status": "Exit 0",
          "Ports": [
            {
              "PrivatePort": 2222,
              "PublicPort": 3333,
              "Type": "tcp"
            }
          ],
          "Labels": {
            "com.example.vendor": "Acme",
            "com.example.license": "GPL",
            "com.example.version": "1.0"
          },
          "SizeRw": 12288,
          "SizeRootFs": 0,
          "HostConfig": {
            "NetworkMode": "default"
          },
          "NetworkSettings": {
            "Networks": {}
          },
          "Mounts": [
            {
              "Name": "fac362...80535",
              "Source": "/data",
              "Destination": "/data",
              "Driver": "local",
              "Mode": "ro,Z",
              "RW": false,
              "Propagation": ""
            }
          ]
        },
        "output": "Names\tImage\n-----\t-----\nboring_feynman\tubuntu:latest"
      }
    ],
    "identifier": 64423634
  },
  {
    "context": [
      "\"It shows timestamp in a different format `\"timestamp\":{\"$date\":\"2020-08-01T00:00:00Z\"}}` . I want to convert this timestamp object to a string like `\"timestamp\":\"2020-08-01T00:00:00Z\"` .\"",
      "Consider:\r\n\r\n    walk( if type == \"object\" and has(\"$date\")\r\n          then .[\"$date\"] else . end )",
      "cat test.json | jq ' .location.timestamp = .location.timestamp[\"$date\"]' | sponge test.json"
    ],
    "utterance": "Replace any object with a single $date key with the string value of $date, so that timestamp fields become strings instead of objects.",
    "expressions": [
      "walk( if type == \"object\" and has(\"$date\") then .[\"$date\"] else . end )",
      ".location.timestamp = .location.timestamp[\"$date\"]"
    ],
    "data": [
      {
        "input": {
          "timestamp": {
            "$date": "2020-08-01T00:00:00Z"
          }
        },
        "output": {
          "timestamp": "2020-08-01T00:00:00Z"
        }
      },
      {
        "input": {
          "timestamp": {
            "$date": "2020-08-01T00:00:00.123Z"
          }
        },
        "output": {
          "timestamp": "2020-08-01T00:00:00.123Z"
        }
      }
    ],
    "identifier": 64510632
  },
  {
    "context": [
      "The objects in my JSON have properties about images. The properties I will be using from the JSON are:\n\n    num = each image is assigned a number, 1 to infinity\n    filename = the name of the image file\n    name = the title of the image",
      "I want to take the parsed JSON properties and output it to some PHP code. Each image in the JSON code will output two lines of PHP that look like this (JSON values are shown between asterisks):\n\n    if($link == *num*) { $linkURL = \"*filename*\";}\n    if($link == *num*) { $altText = \"*name*\";}\n",
      "How can I use `printf` to print out the PHP and insert the values from the JSON?",
      "You can process your JSON directly with a stand-alone `jq` script as follow:\n\n`json2php`\n```jq\n#!/usr/bin/env -S jq -sjf\n\n.[] |\n(\n  # JSON string literal\n  \"if($link == \"\n\n  # Concat with num JSON object member converted to JSON string\n  + ( .num | tostring )\n\n  # Concat with JSON string literal\n  + \") { $linkURL = \\\"\"\n\n  # Concat with filename JSON object member filtered %coded to URI\n  + ( .filename | @uri )\n\n  # Concat with JSON string literal including newline\n  + \"\\\";}\\nif($link == \"\n\n  # Concat with num JSON object member converted to JSON string\n  + ( .num | tostring )\n\n  # Concat with JSON string literal\n  + \") { $altText = \\\"\"\n\n  # Concat with name JSON object member filtered to HTML entities if needed\n  + ( .name | @html ) + \"\\\";}\\n\"\n)\n```",
      "Example `input.json` (notice the spaces and quotes to probe test the filter works as intended):\n```json\n{\n   \"num\": 1,\n   \"filename\": \"trees-in-nature.jpg\",\n   \"name\": \"Trees In Nature\"\n}\n{\n   \"num\": 2,\n   \"filename\": \"running dogs.jpg\",\n   \"name\": \"Running \\\"Dogs\\\"\"\n}\n{\n   \"num\": 3,\n   \"filename\": \"beautiful-lake.jpg\",\n   \"name\": \"Beautiful' Lake\"\n}\n```",
      "Generated php code from the above input:\n```php\nif($link == 1) { $linkURL = \"trees-in-nature.jpg\";}\nif($link == 1) { $altText = \"Trees In Nature\";}\nif($link == 2) { $linkURL = \"running%20dogs.jpg\";}\nif($link == 2) { $altText = \"Running &quot;Dogs&quot;\";}\nif($link == 3) { $linkURL = \"beautiful-lake.jpg\";}\nif($link == 3) { $altText = \"Beautiful&apos; Lake\";}\n```"
    ],
    "utterance": "For each object, output two PHP lines: one assigning $linkURL to the filename (URI encoded) if $link equals num, and one assigning $altText to the name (HTML entity encoded) if $link equals num.",
    "expressions": [
      ".[] | (\"if($link == \" + (.num|tostring) + \") { $linkURL = \\\"\" + (.filename|@uri) + \"\\\";}\\nif($link == \" + (.num|tostring) + \") { $altText = \\\"\" + (.name|@html) + \"\\\";}\\n\")"
    ],
    "data": [
      {
        "input": [
          {
            "num": 1,
            "filename": "trees-in-nature.jpg",
            "name": "Trees In Nature"
          },
          {
            "num": 2,
            "filename": "running dogs.jpg",
            "name": "Running \"Dogs\""
          },
          {
            "num": 3,
            "filename": "beautiful-lake.jpg",
            "name": "Beautiful' Lake"
          }
        ],
        "output": "if($link == 1) { $linkURL = \"trees-in-nature.jpg\";}\nif($link == 1) { $altText = \"Trees In Nature\";}\nif($link == 2) { $linkURL = \"running%20dogs.jpg\";}\nif($link == 2) { $altText = \"Running &quot;Dogs&quot;\";}\nif($link == 3) { $linkURL = \"beautiful-lake.jpg\";}\nif($link == 3) { $altText = \"Beautiful&apos; Lake\";}\n"
      }
    ],
    "identifier": 64419432
  },
  {
    "context": [
      "I have a `JSON` object `` {\"b\":1,\"c\":2}`` and want to put this object under the object with the key named ``xyz``.",
      "However, the key name is coming from the shell variable.",
      "So in other words, I first need to get the key name, and after that put ``{\"b\":1,\"c\":2}`` under it so the result looks like following:",
      "jq -n --arg a \"xyz\"  '{\"b\":1,\"c\":2} as $new | {$new} | with_entries(if .key == \"new\" then .key = $a else . end)'",
      "You can do it very simply as below",
      "jq -n --arg a \"xyz\" '{ ($a): { \"b\": 1 ,\"c\": 2 } }'",
      "or with contents from stdin",
      "echo '{ \"b\": 1 ,\"c\": 2 }' | jq -n --arg a \"xyz\" '{ ($a): inputs }'",
      "or without `-n`",
      "echo '{ \"b\": 1 ,\"c\": 2 }' | jq --arg a \"xyz\" '{ ($a): . }'",
      "or with both keyname and the object configurable",
      "jq -n --arg k \"xyz\" --argjson v '{ \"b\": 1 ,\"c\": 2 }' '{ ($k): $v }'"
    ],
    "utterance": "Wrap an object as the value of a new object whose key is provided dynamically via a shell variable named 'xyz'.",
    "expressions": [
      "jq -n --arg a \"xyz\" '{ ($a): { \"b\": 1 ,\"c\": 2 } }'",
      "echo '{ \"b\": 1 ,\"c\": 2 }' | jq -n --arg a \"xyz\" '{ ($a): inputs }'",
      "echo '{ \"b\": 1 ,\"c\": 2 }' | jq --arg a \"xyz\" '{ ($a): . }'",
      "jq -n --arg k \"xyz\" --argjson v '{ \"b\": 1 ,\"c\": 2 }' '{ ($k): $v }'"
    ],
    "data": [
      {
        "input": {
          "b": 1,
          "c": 2
        },
        "output": {
          "xyz": {
            "b": 1,
            "c": 2
          }
        }
      }
    ],
    "identifier": 64202896
  },
  {
    "context": [
      "I would like to display an arbitrary object's key names and the lengths of their constituent parts.",
      "But how do I get both on the same (or I would even accept alternating) line?",
      "\"bbq\" 2\n\"lol\" 1\n\"wtf\" 4",
      "jq -r 'keys_unsorted[] as $k | [$k, (.[$k]|length)] | join(\" \")'",
      "keys_unsorted[] as $k | \"\\\"\\($k)\\\" \\(.[$k]|length)\""
    ],
    "utterance": "List each top-level key and the length of its value on the same line, with the key quoted.",
    "expressions": [
      "keys_unsorted[] as $k | \"\\\"\\($k)\\\" \\(.[$k]|length)\"",
      "jq -r 'keys_unsorted[] as $k | [$k, (.[$k]|length)] | join(\" \")'"
    ],
    "data": [
      {
        "input": {
          "lol": 1,
          "wtf": [
            1,
            2,
            3,
            4
          ],
          "bbq": {
            "omg": "yes",
            "afk": "always"
          }
        },
        "output": [
          "\"bbq\" 2",
          "\"lol\" 1",
          "\"wtf\" 4"
        ]
      }
    ],
    "identifier": 64490635
  },
  {
    "context": [
      "I am using jq to set the values of A,B and c",
      "Something like this",
      "expression='. | to_entries | .[] | .key + \"=\\\"\" + .value + \"\\\"\"'",
      "But the problem is with c where i get the output as",
      "[g\\u003eQ)M\\u0026.N+v8",
      "so $x> and & are getting converted to unicode.",
      "Can I fix the expression to avoid this?",
      "I fixed it using",
      "expression='to_entries | map(\"\\(.key)=\\(.value | @sh)\") | .[]'",
      "expression='to_entries[] | .key + \"=\\\"\" + .value + \"\\\"\"'",
      "mypython | jq -r \"$expression\"",
      "expression='to_entries[] | .key + \\\"=\\\\\\\"\\\" + .value + \\\"\\\\\\\"\\\"'",
      "eval \"mypython | jq -r \\\"$expression\\\"\"",
      "A=\"ab3241c\"",
      "B=\"d12e31234f\"",
      "c=\"[g$x>Q)M&.N+v8\""
    ],
    "utterance": "Output each key and value as key=\"value\", preserving all special characters in the value including $ and & without converting them to unicode escapes.",
    "expressions": [
      "to_entries[] | .key + \"=\\\"\" + .value + \"\\\"\"",
      "to_entries | map(\"\\(.key)=\\(.value | @sh)\") | .[]"
    ],
    "data": [
      {
        "input": {
          "A": "ab3241c",
          "B": "d12e31234f",
          "c": "[g$x>Q)M&.N+v8"
        },
        "output": [
          "A=\"ab3241c\"",
          "B=\"d12e31234f\"",
          "c=\"[g$x>Q)M&.N+v8\""
        ]
      }
    ],
    "identifier": 64219781
  },
  {
    "context": [
      "how can I change it with bash `jq` command so that it has the exact same data, structure and indentation but the values for key `sfuid` become `sfuid`, `sfu_email_alias` become `sfu_email_alias`, `phone_number` become `0`, `github_username` become `github_username` and `gmail` become `gmail`.",
      "the following jq program will perform the required transformations:",
      "map( reduce (\"sfuid\", \"sfu_email_alias\", \"github_username\", \"gmail\") as $k (.;\n         if .fields[$k] then .fields[$k] = $k else . end)\n       | if .fields.phone_number then .fields.phone_number = 0 else . end )",
      "def update($PATH; VALUE):\n  . as $in\n  | if ($PATH | select(IN($in|paths)) // null) \n    then setpath($PATH;VALUE) else . end;\n\nmap( reduce (\"sfuid\", \"sfu_email_alias\", \"github_username\", \"gmail\") as $k (.;\n         update( [\"fields\", $k]; $k )\n       | update( [\"fields\", \"phone_number\"]; 0) ))"
    ],
    "utterance": "Replace the values of the keys 'sfuid', 'sfu_email_alias', 'github_username', and 'gmail' in all 'fields' objects with the key name as a string, and set 'phone_number' to 0, preserving the structure and other data.",
    "expressions": [
      "map( reduce (\"sfuid\", \"sfu_email_alias\", \"github_username\", \"gmail\") as $k (.; if .fields[$k] then .fields[$k] = $k else . end) | if .fields.phone_number then .fields.phone_number = 0 else . end )",
      "def update($PATH; VALUE):\n  . as $in\n  | if ($PATH | select(IN($in|paths)) // null) \n    then setpath($PATH;VALUE) else . end;\n\nmap( reduce (\"sfuid\", \"sfu_email_alias\", \"github_username\", \"gmail\") as $k (.; update( [\"fields\", $k]; $k ) | update( [\"fields\", \"phone_number\"]; 0) ))"
    ],
    "data": [
      {
        "input": [
          {
            "model": "about.term",
            "pk": 20202,
            "fields": {
              "term": "Summer",
              "year": 2020
            }
          },
          {
            "model": "about.term",
            "pk": 20203,
            "fields": {
              "term": "Fall",
              "year": 2020
            }
          },
          {
            "model": "about.officer",
            "pk": 1,
            "fields": {
              "position": "President",
              "term_position_number": 0,
              "name": "Person 1",
              "start_date": "1984-01-01T00:00:00",
              "sfuid": "",
              "sfu_email_alias": "",
              "phone_number": 11111111111,
              "github_username": "",
              "gmail": "",
              "course1": "",
              "course2": "",
              "language1": "",
              "language2": "",
              "bio": "",
              "image": "about_static/exec-photos/stockPhoto.jpg",
              "elected_term": 19841,
              "sfu_officer_mailing_list_email": "NONE"
            }
          },
          {
            "model": "about.officer",
            "pk": 2,
            "fields": {
              "position": "Vice President",
              "term_position_number": 1,
              "name": "Person 2",
              "start_date": "1984-01-01T00:00:00",
              "sfuid": "",
              "sfu_email_alias": "",
              "phone_number": 2222222222222,
              "github_username": "",
              "gmail": "",
              "course1": "",
              "course2": "",
              "language1": "",
              "language2": "",
              "bio": "",
              "image": "about_static/exec-photos/stockPhoto.jpg",
              "elected_term": 19841,
              "sfu_officer_mailing_list_email": "NONE"
            }
          }
        ],
        "output": [
          {
            "model": "about.term",
            "pk": 20202,
            "fields": {
              "term": "Summer",
              "year": 2020
            }
          },
          {
            "model": "about.term",
            "pk": 20203,
            "fields": {
              "term": "Fall",
              "year": 2020
            }
          },
          {
            "model": "about.officer",
            "pk": 1,
            "fields": {
              "position": "President",
              "term_position_number": 0,
              "name": "Person 1",
              "start_date": "1984-01-01T00:00:00",
              "sfuid": "sfuid",
              "sfu_email_alias": "sfu_email_alias",
              "phone_number": 0,
              "github_username": "github_username",
              "gmail": "gmail",
              "course1": "",
              "course2": "",
              "language1": "",
              "language2": "",
              "bio": "",
              "image": "about_static/exec-photos/stockPhoto.jpg",
              "elected_term": 19841,
              "sfu_officer_mailing_list_email": "NONE"
            }
          },
          {
            "model": "about.officer",
            "pk": 2,
            "fields": {
              "position": "Vice President",
              "term_position_number": 1,
              "name": "Person 2",
              "start_date": "1984-01-01T00:00:00",
              "sfuid": "sfuid",
              "sfu_email_alias": "sfu_email_alias",
              "phone_number": 0,
              "github_username": "github_username",
              "gmail": "gmail",
              "course1": "",
              "course2": "",
              "language1": "",
              "language2": "",
              "bio": "",
              "image": "about_static/exec-photos/stockPhoto.jpg",
              "elected_term": 19841,
              "sfu_officer_mailing_list_email": "NONE"
            }
          }
        ]
      }
    ],
    "identifier": 64180946
  },
  {
    "context": [
      "What I'm trying to do is replace values of `text`s with another value, depending on the value of `title`.",
      "Basically I want to modify a value depending on the value of another key *always in the same object*.",
      "Assuming the new value of .text depends on .title in the *same* JSON object, one model you could follow would be:\r\n\r\n    map(if .title | test(\"REGEX\") then .text = ... else ... end)",
      "If you want to make a change in all objects with both .title and .text, you could use `walk/1` along the following lines:\r\n\r\n    walk(if type == \"object\" and has(\"title\") and has(\"text\")\r\n         then if .title | test(\"REGEX\") then .text = ... else ... end\r\n         else . end)",
      "Edit by @Arainty: using `test` is just for illustration; use `==` to match the exact value. (`.title==\"STRING\"`)"
    ],
    "utterance": "Replace the value of the key 'text' with a new value when the value of 'title' in the same object matches a specific string.",
    "expressions": [
      "map(if .title == \"title1\" then .text = \"NEW_VALUE\" else . end)",
      "walk(if type == \"object\" and has(\"title\") and has(\"text\") then if .title == \"title1\" then .text = \"NEW_VALUE\" else . end else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "class": "classOne",
            "title": "title1",
            "text": "text1"
          },
          {
            "class": "classTwo",
            "title": "title2",
            "text": "text2"
          }
        ],
        "output": [
          {
            "class": "classOne",
            "title": "title1",
            "text": "NEW_VALUE"
          },
          {
            "class": "classTwo",
            "title": "title2",
            "text": "text2"
          }
        ]
      }
    ],
    "identifier": 64407206
  },
  {
    "context": [
      "Group the objects based on the label.env (for now only using one env), then inserting those objects  from the original json into an object named projects.",
      "What I'm aiming for is",
      "{\n  \"prod\": {\n    \"projects\": {\n      \"createTime\": \"2020-06-25T14:16:45.720Z\",\n      \"labels\": {\n        \"cb_domain\": \"cloud-services\",\n        \"cb_product\": \"infra\",\n        \"env\": \"prod\",\n        \"owner\": \"cloud-server\"\n      },\n      \"lifecycleState\": \"ACTIVE\",\n      \"name\": \"projectname\",\n      \"parent\": {\n        \"id\": \"770593713153\",\n        \"type\": \"folder\"\n      },\n      \"projectId\": \"projectname-324234\",\n      \"projectNumber\": \"962363417856\"\n    },\n    {\n      \"createTime\": \"2020-06-24T19:45:42.851Z\",\n      \"labels\": {\n        \"cb_domain\": \"cloud-services\",\n        \"cb_product\": \"ad\",\n        \"env\": \"prod\",\n        \"owner\": \"cloud-server\"\n      },\n      \"lifecycleState\": \"ACTIVE\",\n      \"name\": \"projectname2\",\n      \"parent\": {\n        \"id\": \"4352564765437\",\n        \"type\": \"folder\"\n      },\n      \"projectId\": \"projectname2-4567\",\n      \"projectNumber\": \"3243456324\"\n    }\n  }\n}",
      "Allowing for some minor discrepancies in the Q, the following variant of your jq program seems to do what you're trying to achieve:",
      "group_by(.labels.env)\n| .[]\n| .[0].labels.env as $key\n| { ($key) : { projects: . } }"
    ],
    "utterance": "Group all objects having the same labels.env value under a top-level key with that value, and place all corresponding objects into a projects array under that key.",
    "expressions": [
      "group_by(.labels.env)\n| .[]\n| .[0].labels.env as $key\n| { ($key) : { projects: . } }"
    ],
    "data": [
      {
        "input": [
          {
            "createTime": "2020-06-25T14:16:45.720Z",
            "labels": {
              "cb_domain": "cloud-services",
              "cb_product": "infra",
              "env": "prod",
              "owner": "cloud-server"
            },
            "lifecycleState": "ACTIVE",
            "name": "projectname",
            "parent": {
              "id": "123456577",
              "type": "folder"
            },
            "projectId": "projectname-324234",
            "projectNumber": "962363417856"
          },
          {
            "createTime": "2020-06-24T19:45:42.851Z",
            "labels": {
              "cb_domain": "cloud-services",
              "cb_product": "ad",
              "env": "prod",
              "owner": "cloud-server"
            },
            "lifecycleState": "ACTIVE",
            "name": "projectname2",
            "parent": {
              "id": "4352564765437",
              "type": "folder"
            },
            "projectId": "projectname2-4567",
            "projectNumber": "3243456324"
          }
        ],
        "output": {
          "prod": {
            "projects": [
              {
                "createTime": "2020-06-25T14:16:45.720Z",
                "labels": {
                  "cb_domain": "cloud-services",
                  "cb_product": "infra",
                  "env": "prod",
                  "owner": "cloud-server"
                },
                "lifecycleState": "ACTIVE",
                "name": "projectname",
                "parent": {
                  "id": "123456577",
                  "type": "folder"
                },
                "projectId": "projectname-324234",
                "projectNumber": "962363417856"
              },
              {
                "createTime": "2020-06-24T19:45:42.851Z",
                "labels": {
                  "cb_domain": "cloud-services",
                  "cb_product": "ad",
                  "env": "prod",
                  "owner": "cloud-server"
                },
                "lifecycleState": "ACTIVE",
                "name": "projectname2",
                "parent": {
                  "id": "4352564765437",
                  "type": "folder"
                },
                "projectId": "projectname2-4567",
                "projectNumber": "3243456324"
              }
            ]
          }
        }
      }
    ],
    "identifier": 64033257
  },
  {
    "context": [
      "I need to search for a version `1.15` having the higher patch version inside the `validNodeVersions` array. So here I wanted to retrieve the value `1.15.12-gke.20` and that is the highest 1.15 versions for the array list.",
      "Basically I am looking always to pick the highest patch release for any of the version. for `1.15` it is `1.15.12-gke.20`.",
      "jq -r '.validNodeVersions[]' file.json | grep \"^1\\.15\" | sort -V | tail -1",
      "`jq` is doing a simple selection of values here, `grep` filters these values by version and after sorting by version we get the highest."
    ],
    "utterance": "Select the highest patch version from the validNodeVersions array for versions starting with 1.15.",
    "expressions": [
      ".validNodeVersions[] | select(startswith(\"1.15\"))",
      ".validNodeVersions | map(select(startswith(\"1.15\"))) | sort | last"
    ],
    "data": [
      {
        "input": {
          "channels": [
            {
              "channel": "REGULAR",
              "defaultVersion": "1.17.9-gke.1504",
              "validVersions": [
                "1.17.9-gke.6300",
                "1.17.9-gke.1504"
              ]
            },
            {
              "channel": "STABLE",
              "defaultVersion": "1.16.13-gke.401",
              "validVersions": [
                "1.16.13-gke.401",
                "1.15.12-gke.20"
              ]
            }
          ],
          "defaultClusterVersion": "1.16.13-gke.401",
          "defaultImageType": "COS",
          "validImageTypes": [
            "UBUNTU",
            "UBUNTU_CONTAINERD"
          ],
          "validMasterVersions": [
            "1.17.12-gke.500",
            "1.14.10-gke.50"
          ],
          "validNodeVersions": [
            "1.17.12-gke.500",
            "1.16.8-gke.12",
            "1.15.12-gke.20",
            "1.15.12-gke.17",
            "1.15.12-gke.16",
            "1.15.12-gke.13",
            "1.15.12-gke.9",
            "1.15.12-gke.6",
            "1.15.12-gke.3",
            "1.15.12-gke.2",
            "1.15.11-gke.17",
            "1.15.11-gke.15",
            "1.15.11-gke.13",
            "1.15.11-gke.12",
            "1.15.11-gke.11",
            "1.15.11-gke.9",
            "1.15.11-gke.5",
            "1.15.11-gke.3",
            "1.15.11-gke.1",
            "1.15.9-gke.26",
            "1.15.8-gke.3",
            "1.15.7-gke.23",
            "1.15.4-gke.22",
            "1.14.10-gke.0",
            "1.14.9-gke.0"
          ]
        },
        "output": "1.15.12-gke.20"
      }
    ],
    "identifier": 64286774
  },
  {
    "context": [
      "I need to use these variable values to get the version value. In this example `project` is \"example.com\" and `app` is \"backend\"",
      "I tried this\n\n    jq --arg p \"$project\" --arg a \"$app\" '.[$p].[$a]' file.json\n\nBut I do get the error\n\n    jq: error: syntax error, unexpected '['...",
      "You may use it like this:\n\n    jq -r --arg p \"$project\" --arg a \"$app\" '.[$p][$a]' file.json",
      "or else:\n\n    jq -r --arg p \"$project\" --arg a \"$app\" '.[$p] | .[$a]' file.json"
    ],
    "utterance": "Retrieve the value associated with a second-level key, where both key names are provided as variables named project and app, respectively.",
    "expressions": [
      ".[$p][$a]",
      ".[$p] | .[$a]"
    ],
    "data": [
      {
        "input": {
          "example.com": {
            "backend": "1.3.7"
          }
        },
        "output": "1.3.7"
      }
    ],
    "identifier": 64287645
  },
  {
    "context": [
      "First one : I want to tranform the parents elements to an pure text value",
      "Second one : I want to remove one specific level in the JSON tree",
      "I achieved to do the second change : delete one level of the JSON array  by using the command\r\n\r\n    jq  'keys[] as $k | map( .mappings =.mappings._doc   )' template.json",
      "But i don't know how to do the first change and the 2nd change in the same time .",
      "jq -j 'to_entries[] | .key as $template_name | .value as $template_content | ($template_name, \"\\u0000\", ($template_content | (.mappings = .mappings._doc) | tojson), \"\\u0000\")' < infile.json"
    ],
    "utterance": "For each top-level key, output the key as text prefixed by 'PUT _template/' followed by the corresponding object with the '.mappings' field replaced by its '_doc' subobject.",
    "expressions": [
      "to_entries[] | .key as $template_name | .value as $template_content | \"PUT _template/\u007f$template_name\", ($template_content | (.mappings = .mappings._doc))"
    ],
    "data": [
      {
        "input": {
          "template_first": {
            "order": 0,
            "index_patterns": [
              "first"
            ],
            "settings": {
              "index": {
                "codec": "best_compression",
                "refresh_interval": "30s",
                "analysis": {
                  "normalizer": {
                    "norm_case_insensitive": {
                      "filter": "lowercase",
                      "type": "custom"
                    }
                  }
                },
                "number_of_shards": "1",
                "number_of_replicas": "1"
              }
            },
            "mappings": {
              "_doc": {
                "dynamic": true,
                "dynamic_templates": [
                  {
                    "strings": {
                      "mapping": {
                        "type": "keyword"
                      },
                      "match_mapping_type": "string"
                    }
                  }
                ],
                "properties": {
                  "log.id": {
                    "type": "keyword"
                  },
                  "host.indexer.hostname": {
                    "type": "keyword"
                  },
                  "ts_indexer": {
                    "format": "strict_date_optional_time||epoch_millis",
                    "type": "date"
                  }
                }
              }
            }
          },
          "template_second": {
            "order": 0,
            "index_patterns": [
              "second"
            ],
            "settings": {
              "index": {
                "codec": "best_compression",
                "refresh_interval": "30s",
                "analysis": {
                  "normalizer": {
                    "norm_case_insensitive": {
                      "filter": "lowercase",
                      "type": "custom"
                    }
                  }
                },
                "number_of_shards": "1",
                "number_of_replicas": "1"
              }
            },
            "mappings": {
              "_doc": {
                "dynamic": true,
                "dynamic_templates": [
                  {
                    "strings": {
                      "mapping": {
                        "type": "keyword"
                      },
                      "match_mapping_type": "string"
                    }
                  }
                ],
                "properties": {
                  "log.id": {
                    "type": "keyword"
                  },
                  "host.indexer.hostname": {
                    "type": "keyword"
                  },
                  "ts_indexer": {
                    "format": "strict_date_optional_time||epoch_millis",
                    "type": "date"
                  }
                }
              }
            }
          }
        },
        "output": [
          "PUT _template/template_first",
          {
            "order": 0,
            "index_patterns": [
              "first"
            ],
            "settings": {
              "index": {
                "codec": "best_compression",
                "refresh_interval": "30s",
                "analysis": {
                  "normalizer": {
                    "norm_case_insensitive": {
                      "filter": "lowercase",
                      "type": "custom"
                    }
                  }
                },
                "number_of_shards": "1",
                "number_of_replicas": "1"
              }
            },
            "mappings": {
              "dynamic": true,
              "dynamic_templates": [
                {
                  "strings": {
                    "mapping": {
                      "type": "keyword"
                    },
                    "match_mapping_type": "string"
                  }
                }
              ],
              "properties": {
                "log.id": {
                  "type": "keyword"
                },
                "host.indexer.hostname": {
                  "type": "keyword"
                },
                "ts_indexer": {
                  "format": "strict_date_optional_time||epoch_millis",
                  "type": "date"
                }
              }
            }
          },
          "PUT _template/template_second",
          {
            "order": 0,
            "index_patterns": [
              "second"
            ],
            "settings": {
              "index": {
                "codec": "best_compression",
                "refresh_interval": "30s",
                "analysis": {
                  "normalizer": {
                    "norm_case_insensitive": {
                      "filter": "lowercase",
                      "type": "custom"
                    }
                  }
                },
                "number_of_shards": "1",
                "number_of_replicas": "1"
              }
            },
            "mappings": {
              "dynamic": true,
              "dynamic_templates": [
                {
                  "strings": {
                    "mapping": {
                      "type": "keyword"
                    },
                    "match_mapping_type": "string"
                  }
                }
              ],
              "properties": {
                "log.id": {
                  "type": "keyword"
                },
                "host.indexer.hostname": {
                  "type": "keyword"
                },
                "ts_indexer": {
                  "format": "strict_date_optional_time||epoch_millis",
                  "type": "date"
                }
              }
            }
          }
        ]
      }
    ],
    "identifier": 64431085
  },
  {
    "context": [
      "now i need to parse values dynamically (i = birds or fish)",
      "arr1=(`jq .$i.names  123.json | sed...`)",
      "Or by defining a variable for jq and using it (same concept):",
      "i=bird",
      "arr1=(`jq --arg animal \"$i\" '.[$animal].names' 123.json | sed...`)"
    ],
    "utterance": "Retrieve the value of the 'names' attribute under a dynamic top-level key specified by a variable (e.g., 'bird' or 'fish').",
    "expressions": [
      ".[$animal].names"
    ],
    "identifier": 64198823
  },
  {
    "context": [
      "I was also hoping to be able to have it only pull chapters labeled as \"video\" but I haven't quite figured that one out yet.",
      "FOR /F \"delims=\" %%i in ('jq .chapters[2].start ^< 01x01.json') DO SET /A start1=%%i",
      "you want to remove the \"*Advertisement*\"-chapters. This could probably be done entirely with FFprobe...",
      "First of all, you don't have to save FFprobe's output to a JSON-file. You can just pipe it to Xidel and select the objects / chapters labeled as \"Video\":",
      "you could use something like:\njq '.chapters[] | select(.tags.title==\"Video\")' 01x01.json",
      "To calculate the duration (in seconds) of the 4 chapters:",
      "jq -r '.chapters[] | select(.tags.title==\"Video\") | [.start, .end] | @tsv' 01x01.json"
    ],
    "utterance": "Extract all chapter objects where the tags.title field equals \"Video\".",
    "expressions": [
      ".chapters[] | select(.tags.title==\"Video\")",
      "jq '.chapters[] | select(.tags.title==\"Video\")' 01x01.json"
    ],
    "data": [
      {
        "input": {
          "chapters": [
            {
              "id": 0,
              "time_base": "1/1000",
              "start": 0,
              "start_time": "0.000000",
              "end": 5590,
              "end_time": "5.590000",
              "tags": {
                "title": "Video"
              }
            },
            {
              "id": 1,
              "time_base": "1/1000",
              "start": 5590,
              "start_time": "5.590000",
              "end": 13994,
              "end_time": "13.994000",
              "tags": {
                "title": "Advertisement"
              }
            }
          ]
        },
        "output": [
          {
            "id": 0,
            "time_base": "1/1000",
            "start": 0,
            "start_time": "0.000000",
            "end": 5590,
            "end_time": "5.590000",
            "tags": {
              "title": "Video"
            }
          }
        ]
      }
    ],
    "identifier": 64192235
  },
  {
    "context": [
      "I'm trying to use a `jq v1.6` filter that has a regex, which contains a negative look-behind and negative look-ahead expressions, but they are failing with `Regex failure: invalid pattern in look-behind`",
      "After testing a few things, I found out that this works:",
      "jq -n '(\"baz\", \"foo baz\", \"bla baz\", \"baz bars\") | test(\"(?<!foo|bar)baz(?! foo| bars)\")'",
      "In your case, since you are using negative lookbehinds, you can do without alternation, just split the lookbehind into two:",
      "(?<!foo )(?<!bars )baz(?! foo| bars)",
      "Then, you do not have to care how many chars each lookbehind has to check."
    ],
    "utterance": "Test if a string matches 'baz' not preceded by 'foo ' or 'bars ', and not followed by ' foo' or ' bars'.",
    "expressions": [
      "test(\"(?<!foo )(?<!bars )baz(?! foo| bars)\")"
    ],
    "data": [
      {
        "input": [
          "baz",
          "foo baz",
          "bla baz",
          "baz bars"
        ],
        "output": [
          true,
          false,
          true,
          false
        ]
      }
    ],
    "identifier": 64146690
  },
  {
    "context": [
      "for imageTag in $(jq -r '.imageIds[].imageTag' < ecr.json); do",
      "if [ $imageTag = \"1.0\" ]; then",
      "You can try the following in your `build`:",
      "for imageTag in $(jq -r '.imageIds[].imageTag' < ecr.json); do"
    ],
    "utterance": "Extract all imageTag values from the imageIds array and iterate to check if any equals 1.0.",
    "expressions": [
      ".imageIds[].imageTag",
      "jq -r '.imageIds[].imageTag' < ecr.json"
    ],
    "data": [
      {
        "input": {
          "imageIds": [
            {
              "imageTag": "latest"
            },
            {
              "imageTag": "1.0"
            },
            {
              "imageTag": "2.0"
            }
          ]
        },
        "output": [
          "latest",
          "1.0",
          "2.0"
        ]
      }
    ],
    "identifier": 64458304
  },
  {
    "context": [
      "I need to set them to value 0 *if* the value of one particular key - `.numberOfVisits` from a *different* `JSON` file - `consumption.json` equals to zero.",
      "If the `.numberOfVisits` from `consumption.json` does *not* equal to zero, when `timeframe=\"Week\"` or when `timeframe=\"Month\"` in the same block, then the above two keys need to set to -1 *and* all other keys in the `license.json` file which have the value equal to 9223372036854776000 need to have that value replaced to -1.",
      "can all the above logic combined into a single `jq` call?",
      "jq --argfile visits consumption.json '\n    ( $visits | .Body | map( .Metrics[] | select(.numberOfVisits == 0)) | length ) as $data |\n    if $data != 2 then\n        with_entries( select(.value == 9223372036854776000).value = -1 ) |\n          ( .visitsAnnualQuota, .visitsQuota ) |= -1\n    elif $data == 2 then\n        ( .visitsAnnualQuota, .visitsQuota ) |= 0\n    else\n        .\n    end' license.json"
    ],
    "utterance": "Set visitsAnnualQuota and visitsQuota to 0 if both Week and Month numberOfVisits in consumption.json are zero; otherwise, set both to -1 and also replace all values of 9223372036854776000 with -1 in license.json.",
    "expressions": [
      "jq --argfile visits consumption.json '\n    ( $visits | .Body | map( .Metrics[] | select(.numberOfVisits == 0)) | length ) as $data |\n    if $data != 2 then\n        with_entries( select(.value == 9223372036854776000).value = -1 ) |\n          ( .visitsAnnualQuota, .visitsQuota ) |= -1\n    elif $data == 2 then\n        ( .visitsAnnualQuota, .visitsQuota ) |= 0\n    else\n        .\n    end' license.json"
    ],
    "data": [
      {
        "input": {
          "customMetricsLimit": 9223372036854776000,
          "customMetricsOverageLimit": 9223372036854776000,
          "UnitsAnnualQuota": 9223372036854776000,
          "UnitsQuota": 9223372036854776000,
          "expirationTime": 1652572799000,
          "infrastructureSupportedTechnologies": {
            "maxInfrastructureOnlyAgents": 9223372036854776000,
            "networkAgent": true,
            "pluginAgent": true
          },
          "logAnalyticsIngressQuota": 9223372036854776000,
          "logAnalyticsIngressQuotaAnnually": 9223372036854776000,
          "maxAgents": 2147483647,
          "maxHostUnitsQuota": -1,
          "maxPaasAgents": 2147483647,
          "maxWebChecks": 9223372036854776000,
          "maxWebChecksAnnual": 9223372036854776000,
          "replayStorageDomQuotaInMb": 9223372036854776000,
          "replayStorageDomRetention": 86400000,
          "retentionCode": 864000000,
          "retentionService": 1209600000,
          "retentionWebcheck": 864000000,
          "symbolicationFileStorageQuota": 1024,
          "syntheticEnabled": true,
          "useHostUnitWeighting": false,
          "visitsAnnualQuota": 120000,
          "visitsQuota": 10000
        }
      },
      {
        "input": {
          "Header": {
            "Tenant": "Tenant-1"
          },
          "Body": [
            {
              "Metrics": [
                {
                  "timeframe": "Week",
                  "numberOfVisits": 0
                },
                {
                  "timeframe": "Month",
                  "numberOfVisits": 0
                },
                {
                  "timeframe": "Year",
                  "numberOfVisits": 247648006
                }
              ],
              "tags": [
                {
                  "context": "ENVIRONMENT",
                  "key": "srch"
                }
              ],
              "webServerName": "localhost"
            }
          ]
        }
      }
    ],
    "identifier": 64029410
  },
  {
    "context": [
      "I am looking for way to convert array of objects as mentioned in example below to just an object using `jq`.",
      "You could just `add` the array of objects together. Use the `|=` operator to write it back to `.target` itself",
      "jq '.target |= add'"
    ],
    "utterance": "Merge the 'target' array of objects into a single object and assign it back to 'target' in the parent.",
    "expressions": [
      ".target |= add"
    ],
    "data": [
      {
        "input": {
          "appName": "ABC",
          "target": [
            {
              "connectedApp_SalesforceServiceCloud": "false"
            },
            {
              "connectedApp_SalesforceSalesCloud": "false"
            },
            {
              "connectedApp_DataDotcom": "true"
            },
            {
              "connectedApp_SalesforceChatter": "true"
            }
          ]
        },
        "output": {
          "appName": "ABC",
          "target": {
            "connectedApp_SalesforceServiceCloud": "false",
            "connectedApp_SalesforceSalesCloud": "false",
            "connectedApp_DataDotcom": "true",
            "connectedApp_SalesforceChatter": "true"
          }
        }
      }
    ],
    "identifier": 64259063
  },
  {
    "context": [
      "Since config1.json is a stream of JSON entities, you could use the --slurpfile option:",
      "jq --slurpfile config1 config1.json '.config += $config1' config.json"
    ],
    "utterance": "Merge the array at the config key in one file with all objects from another file containing a stream of objects as additional elements.",
    "expressions": [
      "jq --slurpfile config1 config1.json '.config += $config1' config.json"
    ],
    "identifier": 64457685
  },
  {
    "context": [
      "I currently have output from `jq` that looks like this: \r\n\r\n```\r\n1\u00a7\r\n{\"id\":\"1\",\"name\":\"River Street , Clerkenwell\",\"lastUpdate\":\"1601461560941\"}\r\n2\u00a7\r\n{\"id\":\"2\",\"name\":\"Phillimore Gardens, Kensington\",\"lastUpdate\":\"1601461560941\"}\r\n```\r\n\r\nand I would like it join the output lines per record, i.e.: \r\n\r\n```\r\n1\u00a7{\"id\":\"1\",\"name\":\"River Street , Clerkenwell\",\"lastUpdate\":\"1601461560941\"}\r\n2\u00a7{\"id\":\"2\",\"name\":\"Phillimore Gardens, Kensington\",\"lastUpdate\":\"1601461560941\"}\r\n```\r\n",
      "One way would be to use the `join` function by empty string on the created objects. Note that the object you are creating needs to converted to string type for it to work. Use the filter below with the `--raw-output/-r` mode\r\n\r\n    .stations.station[] + { lastUpdate: .stations.\"@lastUpdate\" } | \r\n    [ .id + \"\u00a7\", tostring ] | \r\n    join(\"\")"
    ],
    "utterance": "Output each record as a single line containing the id, the \u00a7 symbol, and the JSON string of the object, one per line.",
    "expressions": [
      ".stations.station[] + { lastUpdate: .stations.\"@lastUpdate\" } | [ .id + \"\u00a7\", tostring ] | join(\"\")"
    ],
    "data": [
      {
        "input": {
          "stations": {
            "@lastUpdate": "1601461560941",
            "station": [
              {
                "id": "1",
                "name": "River Street , Clerkenwell"
              },
              {
                "id": "2",
                "name": "Phillimore Gardens, Kensington"
              }
            ]
          }
        },
        "output": [
          "1\u00a7{\"id\":\"1\",\"name\":\"River Street , Clerkenwell\",\"lastUpdate\":\"1601461560941\"}",
          "2\u00a7{\"id\":\"2\",\"name\":\"Phillimore Gardens, Kensington\",\"lastUpdate\":\"1601461560941\"}"
        ]
      }
    ],
    "identifier": 64136304
  },
  {
    "context": [
      "Is there a way in jq to create that element in the json object if one already does not exist?",
      "jq '.properties.foo += [ { \"id\": \"<id3>\", \"bar3\": [ { \"baz3\": \"*\"} ] } ]' <<< \"$json3\""
    ],
    "utterance": "Add an object to the 'foo' array under 'properties', creating 'foo' if it does not already exist.",
    "expressions": [
      ".properties.foo += [ { \"id\": \"<id3>\", \"bar3\": [ { \"baz3\": \"*\"} ] } ]"
    ],
    "data": [
      {
        "input": {
          "id": "<id>>",
          "name": "<name>",
          "properties": {
            "State": "<state>",
            "requests": []
          }
        },
        "output": {
          "id": "<id>>",
          "name": "<name>",
          "properties": {
            "State": "<state>",
            "requests": [],
            "foo": [
              {
                "id": "<id3>",
                "bar3": [
                  {
                    "baz3": "*"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 64033057
  },
  {
    "context": [
      "I need to remove duplicates inside every array in the JSON file. So the result should look like following",
      "Array key names are not known in advance. There might be multiple arrays inside the ``Arrays`` object.",
      "you can use `unique` and `|=`:",
      "$ jq '[].Arrays[] |= unique' file.json",
      "the only \"problem\" is that `unique` sorts the elements of the array, so for example contents of `\"dddd0003\"` array are not in the same order of your expected result.",
      "walk( if type == \"array\" then unique else . end)"
    ],
    "utterance": "Remove duplicate elements from all arrays inside every 'Arrays' object, regardless of array key names.",
    "expressions": [
      ".[].Arrays[] |= unique",
      "walk( if type == \"array\" then unique else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "first",
            "Arrays": {
              "dddd0001": [
                "A",
                "A",
                "B",
                "B",
                "C",
                "C",
                "C",
                "C",
                "D",
                "E",
                "F"
              ]
            }
          },
          {
            "name": "second",
            "Arrays": {
              "dddd0002": [
                "AA",
                "AA",
                "BA",
                "BB",
                "CC",
                "CC",
                "CC",
                "CC",
                "DD",
                "DD",
                "FF"
              ]
            }
          },
          {
            "name": "third",
            "Arrays": {
              "dddd0003": [
                "1",
                "1",
                "2",
                "3",
                "3",
                "4",
                "4",
                "4",
                "0",
                "0",
                "0"
              ]
            }
          }
        ],
        "output": [
          {
            "name": "first",
            "Arrays": {
              "dddd0001": [
                "A",
                "B",
                "C",
                "D",
                "E",
                "F"
              ]
            }
          },
          {
            "name": "second",
            "Arrays": {
              "dddd0002": [
                "AA",
                "BA",
                "BB",
                "CC",
                "DD",
                "FF"
              ]
            }
          },
          {
            "name": "third",
            "Arrays": {
              "dddd0003": [
                "1",
                "2",
                "3",
                "4",
                "0"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 64183692
  },
  {
    "context": [
      "Here\u0019s a sample JSON:\r\n\r\n    [\r\n    \t{\r\n    \t\t\"title\": \"channel 1\",\r\n    \t\t\"url\": \"rtsp://thelink\"\r\n    \t},\r\n    \t{\r\n    \t\t\"title\": \"channel UFO\",\r\n    \t\t\"url\": \"rtsp://thatlink\"\r\n    \t},\r\n    \t{\r\n    \t\t\"title\": \"channel oreo\",\r\n    \t\t\"url\": \"rtsp://thatotherlink\"\r\n    \t},\r\n    \t{\r\n    \t\t\"title\": \"channel blabla\",\r\n    \t\t\"url\": \"rtsp://yetanotherlink\"\r\n    \t},\r\n    \t{\r\n    \t\t\"title\": \"channel potato\",\r\n    \t\t\"url\": \"rtsp://anotherlinkwhatnow\"\r\n    \t}\r\n    ]",
      "Here\u0019s what it should look like:\r\n\r\n\t{\r\n\t\t\"channel 1\": \"rtsp://thelink\",\r\n\t\t\"channel UFO\": \"rtsp://thatlink\",\r\n\t\t\"channel oreo\": \"rtsp://thatotherlink\",\r\n\t\t\"channel blabla\": \"rtsp://yetanotherlink\",\r\n\t\t\"channel potato\": \"rtsp://anotherlinkwhatnow\"\r\n\t}",
      "Use `map` to map the array of objects to key-value pairs based on the fields you\u0019re interested in, then `add` to merge these pairs into an object.",
      "$ jq 'map({(.title): .url}) | add' test.json"
    ],
    "utterance": "Transform an array of objects with 'title' and 'url' fields into an object where each key is the value of 'title' and each value is the corresponding 'url'.",
    "expressions": [
      "map({(.title): .url}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "title": "channel 1",
            "url": "rtsp://thelink"
          },
          {
            "title": "channel UFO",
            "url": "rtsp://thatlink"
          },
          {
            "title": "channel oreo",
            "url": "rtsp://thatotherlink"
          },
          {
            "title": "channel blabla",
            "url": "rtsp://yetanotherlink"
          },
          {
            "title": "channel potato",
            "url": "rtsp://anotherlinkwhatnow"
          }
        ],
        "output": {
          "channel 1": "rtsp://thelink",
          "channel UFO": "rtsp://thatlink",
          "channel oreo": "rtsp://thatotherlink",
          "channel blabla": "rtsp://yetanotherlink",
          "channel potato": "rtsp://anotherlinkwhatnow"
        }
      }
    ],
    "identifier": 64288520
  },
  {
    "context": [
      "With `jq` this is easy: `if .|type == \"string\" then . else .value end`",
      "An input of `\"abc\"` would return `\"abc\"`. An input of `{\"value\":\"def\"}` would return `\"def\"`"
    ],
    "utterance": "Return the input itself if it is a string; otherwise, return the value of the 'value' property.",
    "expressions": [
      "if type==\"string\" then . else .value end"
    ],
    "data": [
      {
        "input": "abc",
        "output": "abc"
      },
      {
        "input": {
          "value": "def"
        },
        "output": "def"
      }
    ],
    "identifier": 64308650
  },
  {
    "context": [
      "I need to transform the json with cumulate fields.",
      "This is the expected result:",
      "I just don't know how to do this with multiples fields ?",
      "You can use the whole object instead of just a field as the current element in _foreach_.",
      "jq '[foreach .[] as $row ({nbrMembers: 0, nbrWallets: 0}; {nbrMembers: ($row.nbrMembers + .nbrMembers), nbrWallets:  ($row.nbrWallets + .nbrWallets)  }; . as $x | $row | .nbrMembers = $x.nbrMembers | .nbrWallets = $x.nbrWallets) ]' test.json",
      "jq '[foreach .[] as $row (\n      {nbrMembers: 0, nbrWallets: 0};\n      { \n        nbrMembers: ($row.nbrMembers + .nbrMembers), \n        nbrWallets: ($row.nbrWallets + .nbrWallets)\n      }; \n     $row * .  \n    )]' test.json",
      "jq '[ foreach .[] as $row (null;\n          .nbrMembers += $row.nbrMembers\n        | .nbrWallets += $row.nbrWallets;\n        $row + . ) ]\n' test.json"
    ],
    "utterance": "Transform an array of objects so that the 'nbrMembers' and 'nbrWallets' fields are replaced with their running cumulative sums across the array.",
    "expressions": [
      "[foreach .[] as $row ({nbrMembers: 0, nbrWallets: 0}; {nbrMembers: ($row.nbrMembers + .nbrMembers), nbrWallets:  ($row.nbrWallets + .nbrWallets)  }; . as $x | $row | .nbrMembers = $x.nbrMembers | .nbrWallets = $x.nbrWallets) ]",
      "[foreach .[] as $row ({nbrMembers: 0, nbrWallets: 0}; {nbrMembers: ($row.nbrMembers + .nbrMembers), nbrWallets: ($row.nbrWallets + .nbrWallets)}; $row * . )]",
      "[ foreach .[] as $row (null; .nbrMembers += $row.nbrMembers | .nbrWallets += $row.nbrWallets; $row + . ) ]"
    ],
    "data": [
      {
        "input": [
          {
            "date": "25-09-20",
            "nbrMembers": 1,
            "nbrWallets": 4
          },
          {
            "date": "26-09-20",
            "nbrMembers": 3,
            "nbrWallets": 1
          },
          {
            "date": "27-09-20",
            "nbrMembers": 0,
            "nbrWallets": 2
          },
          {
            "date": "28-09-20",
            "nbrMembers": 7,
            "nbrWallets": 3
          }
        ],
        "output": [
          {
            "date": "25-09-20",
            "nbrMembers": 1,
            "nbrWallets": 4
          },
          {
            "date": "26-09-20",
            "nbrMembers": 4,
            "nbrWallets": 5
          },
          {
            "date": "27-09-20",
            "nbrMembers": 4,
            "nbrWallets": 7
          },
          {
            "date": "28-09-20",
            "nbrMembers": 11,
            "nbrWallets": 10
          }
        ]
      }
    ],
    "identifier": 64146079
  },
  {
    "context": [
      "#Take 2 arguments (Latitude, Longitude) and return 2 variables $State, $City",
      "The JSON:",
      "        \"address\": {\r\n          \"city\": \"Aurora\",\r\n          ...\r\n          \"state\": \"Illinois\"",
      "set address (echo $location | jq --raw-output  '.address.state,.address.city')"
    ],
    "utterance": "Extract the state and city values from the 'address' field.",
    "expressions": [
      ".address.state, .address.city",
      ".address | [.state, .city] | @tsv"
    ],
    "data": [
      {
        "input": {
          "address": {
            "city": "Aurora",
            "country": "United States of America",
            "country_code": "us",
            "county": "Kane County",
            "postcode": "60504",
            "road": "Ridge Road",
            "state": "Illinois"
          },
          "boundingbox": [
            "41.729347",
            "41.730247",
            "-88.264466",
            "-88.261979"
          ],
          "display_name": "Ridge Road, Aurora, Kane County, Illinois, 60504, USA",
          "importance": 0.2,
          "lat": "41.729476",
          "licence": "https://locationiq.com/attribution",
          "lon": "-88.263423",
          "place_id": "333878957973"
        },
        "output": [
          "Illinois",
          "Aurora"
        ]
      }
    ],
    "identifier": 64330473
  },
  {
    "context": [
      "The problem with this solution is that I have to hard code the column names. What If my json gets a few additions under ```_source``` tag later? I need a solution which can handle the dynamic data under ```_source```.",
      "Simply use `keys_unsorted` (or `keys` if you want them sorted)."
    ],
    "utterance": "Extract all fields present in each _source object under hits.hits as CSV, ensuring column names adapt dynamically as fields change.",
    "expressions": [
      "jq -r '\n  ([.hits.hits[]._source | keys_unsorted] | add | unique) as $cols\n  | ( $cols, (.hits.hits[]._source[] | [.[$cols[]]]) )\n  | @csv'\n"
    ],
    "data": [
      {
        "input": {
          "took": 111,
          "timed_out": false,
          "_shards": {
            "total": 1,
            "successful": 1,
            "skipped": 0,
            "failed": 0
          },
          "hits": {
            "total": {
              "value": 2,
              "relation": "eq"
            },
            "max_score": 1.0,
            "hits": [
              {
                "_index": "alerts",
                "_type": "_doc",
                "_id": "1",
                "_score": 1.0,
                "_source": {
                  "alertID": "639387c3-0fbe-4c2b-9387-c30fbe7c2bc6",
                  "alertCategory": "Server Alert",
                  "description": "Successfully started.",
                  "logId": null
                }
              },
              {
                "_index": "alerts",
                "_type": "_doc",
                "_id": "2",
                "_score": 1.0,
                "_source": {
                  "alertID": "2",
                  "alertCategory": "Server Alert",
                  "description": "Successfully stoped.",
                  "logId": null
                }
              }
            ]
          }
        },
        "output": "\"alertID\",\"alertCategory\",\"description\",\"logId\"\n\"639387c3-0fbe-4c2b-9387-c30fbe7c2bc6\",\"Server Alert\",\"Successfully started.\",\n\"2\",\"Server Alert\",\"Successfully stoped.\",\n"
      }
    ],
    "identifier": 64576887
  },
  {
    "context": [
      "With jq '[].Data[] | length' I can get the length of each array, but I need to create Length key under Data object and assign to it the length of the array which is in the Data object.",
      "The problem here is that in my example the object name holding the array (Data in my example) and the array name itself (AB00001/CD00002/EF00003) are not known in advance.",
      "The array might be empty, so in this case, the Length should be 0.",
      "This seems to be what you want:",
      "jq '[].Data |= . + { length:.[]|length } ' data.json",
      "A solution to the immediate problem (in which .Data is a single-key object with an array-valued key) could be as simple as:\n    map( .Data.Length = (.Data[]|length) )",
      "A general solution can now be written using `walk`:\nwalk(if type == \"object\" and has(\"name\")\n     then addLength\n     else . end)"
    ],
    "utterance": "For each object in an array, add a Length key to its Data object that equals the length of the array value in Data, regardless of the unknown key name; if the array is empty, Length should be 0.",
    "expressions": [
      ".[].Data |= . + { length:.[]|length }",
      "map( .Data.Length = (.Data[]|length) )",
      "walk(if type == \"object\" and has(\"name\")\n     then (first(keys_unsorted[] as $k\n          | select(.[$k]|type == \"object\")\n          | .[$k]\n              | keys_unsorted[] as $l \n          | select(.[$l]|type == \"array\")\n          | [$k,$l]) // null) as $a\n     | if $a \n       then setpath([$a[0],\"Length\"]; getpath($a)|length)\n       else .\n       end\n    )\n     else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "California",
            "Data": {
              "AB00001": [
                "Los Angeles",
                "San Francisco",
                "Sacramento",
                "Fresno",
                "San Jose",
                "Palo Alto"
              ]
            }
          },
          {
            "name": "Oregon",
            "Data": {
              "CD00002": [
                "Portland",
                "Salem",
                "Hillsboro"
              ]
            }
          },
          {
            "name": "Washington",
            "Data": {
              "EF00003": [
                "Seattle",
                "Tacoma",
                "Spokane",
                "Bellevue"
              ]
            }
          }
        ],
        "output": [
          {
            "name": "California",
            "Data": {
              "AB00001": [
                "Los Angeles",
                "San Francisco",
                "Sacramento",
                "Fresno",
                "San Jose",
                "Palo Alto"
              ],
              "Length": 6
            }
          },
          {
            "name": "Oregon",
            "Data": {
              "CD00002": [
                "Portland",
                "Salem",
                "Hillsboro"
              ],
              "Length": 3
            }
          },
          {
            "name": "Washington",
            "Data": {
              "EF00003": [
                "Seattle",
                "Tacoma",
                "Spokane",
                "Bellevue"
              ],
              "Length": 4
            }
          }
        ]
      }
    ],
    "identifier": 64191907
  },
  {
    "context": [
      "I am trying to get all the `ip_ranges` associated with the keys starting with \"us_cell_*\" and I have not found a way to do it.",
      "You can use the following :",
      "    to_entries | map(select(.key | startswith(\"us_cell_\")) | .value.ip_ranges) | add",
      "We filter that to retain only those which have a key starting with \"us_cell_\", map it further to keep only the ip ranges and finally merge those arrays together."
    ],
    "utterance": "Get all ip_ranges values for keys whose name starts with 'us_cell_'.",
    "expressions": [
      "to_entries | map(select(.key | startswith(\"us_cell_\")) | .value.ip_ranges) | add"
    ],
    "identifier": 64281133
  },
  {
    "context": [
      "What I want instead - to create a new object with the original (from updated.json) and new (from downloaded.json) files, so it should look the following way:\n    \"Original\": {\n        \"davisDataUnitsEnabled\": false,\n        \"expirationTime\": 1652572799000,\n        \"hostUnitsQuota\": 2147483647,\n        \"isRumEnabled\": false\n    },\n    \"Updated\": {\n        \"davisDataUnitsEnabled\": true,\n        \"expirationTime\": 0,\n        \"hostUnitsQuota\": -1,\n        \"isRumEnabled\": true\n    }\n}",
      "Instead, the correct `jq` command which produces the result I wanted is the following:",
      "jq -n \\\n--argfile original original.json \\\n--argfile download downloaded.json \\\n--argfile template template.json \\\n'$original |($original +=$template | to_entries) as $x |\n($download | to_entries) as $y | \n($y - $x | from_entries) as $new |\n($x - $y | from_entries) as $old |\n[{\"Original\":$old,\"Updated\": $new}]'"
    ],
    "utterance": "List all keys whose values differ between the updated and downloaded files, and output two objects: 'Original' for values from updated.json and 'Updated' for values from downloaded.json, each containing only the differing keys.",
    "expressions": [
      "jq -n \\\n--argfile original original.json \\\n--argfile download downloaded.json \\\n--argfile template template.json \\\n'$original |($original +=$template | to_entries) as $x |\n($download | to_entries) as $y | \n($y - $x | from_entries) as $new |\n($x - $y | from_entries) as $old |\n[{\"Original\":$old,\"Updated\": $new}]'"
    ],
    "data": [
      {
        "input": {
          "updated.json": {
            "davisDataUnitsEnabled": false,
            "expirationTime": 1652572799000,
            "hostUnitsQuota": 2147483647,
            "isRumEnabled": false
          },
          "downloaded.json": {
            "davisDataUnitsEnabled": true,
            "expirationTime": 0,
            "hostUnitsQuota": -1,
            "isRumEnabled": true
          }
        },
        "output": [
          {
            "Original": {
              "davisDataUnitsEnabled": false,
              "expirationTime": 1652572799000,
              "hostUnitsQuota": 2147483647,
              "isRumEnabled": false
            },
            "Updated": {
              "davisDataUnitsEnabled": true,
              "expirationTime": 0,
              "hostUnitsQuota": -1,
              "isRumEnabled": true
            }
          }
        ]
      }
    ],
    "identifier": 64198097
  },
  {
    "context": [
      "I have a JSON file like this:\r\n{\r\n  \"name\": {\r\n    \"0\": \"fred\",\r\n    \"1\": \"barney\"\r\n  },\r\n  \"loudness\": {\r\n    \"0\": \"extreme\",\r\n    \"1\": \"not so loud\"\r\n  }\r\n}",
      "... and I would like to generate a JSON array like this:\r\n[\r\n  {\r\n    \"name\": \"fred\",\r\n    \"loudness\": \"extreme\"\r\n  },\r\n  {\r\n    \"name\": \"barney\",\r\n    \"loudness\": \"not so loud\"\r\n  }\r\n]",
      "How can jq create the desired output while being key-agnostic for my much larger JSON file?",
      ". as $data | \r\nreduce paths(scalars) as $p (\r\n  [];\r\n  setpath(\r\n    [ $p[1] | tonumber, $p[0] ];\r\n    ( $data | getpath($p) ) \r\n  ) \r\n)",
      "keys_unsorted as $keys\r\n| [.[] | [.[]]] | transpose\r\n| map(objectify($keys))",
      "def objectify($keys):\r\n  . as $in | reduce range(0;length) as $i ({}; .[$keys[$i]] = $in[$i]);"
    ],
    "utterance": "Transform an object of objects where inner keys are indices into an array of objects, so each element collects values at the same index across all top-level keys, regardless of the keys' names.",
    "expressions": [
      ". as $data | reduce paths(scalars) as $p ([]; setpath([ $p[1] | tonumber, $p[0] ]; ( $data | getpath($p) )))",
      "def objectify($keys): . as $in | reduce range(0;length) as $i ({}; .[$keys[$i]] = $in[$i]); keys_unsorted as $keys | [.[] | [.[]]] | transpose | map(objectify($keys))"
    ],
    "data": [
      {
        "input": {
          "name": {
            "0": "fred",
            "1": "barney"
          },
          "loudness": {
            "0": "extreme",
            "1": "not so loud"
          }
        },
        "output": [
          {
            "name": "fred",
            "loudness": "extreme"
          },
          {
            "name": "barney",
            "loudness": "not so loud"
          }
        ]
      }
    ],
    "identifier": 64455986
  },
  {
    "context": [
      "I need to count the number of elements inside the `vulnerabilities[]` arrays",
      "So how do I get the number of vulnerabilities from `vulnerabilities[]` depending the number of element from the array?",
      "{ id: .dependencyId, vulnCount: (.vulnerabilities|length) }",
      "The issue with your attempt was `[]` exposes all the objects inside the array and the `length` function on the object counts the number of key/value pairs in a given object."
    ],
    "utterance": "For each object, output the dependencyId and the number of elements in its vulnerabilities array.",
    "expressions": [
      "{ id: .dependencyId, vulnCount: (.vulnerabilities | length) }"
    ],
    "data": [
      {
        "input": [
          {
            "dependencyId": 129707,
            "isVirtual": "false",
            "vulnerabilities": [
              {
                "name": "vul",
                "severity": "LOW"
              }
            ]
          },
          {
            "dependencyId": 129708,
            "isVirtual": "false",
            "vulnerabilities": [
              {
                "name": "vul",
                "severity": "LOW"
              },
              {
                "name": "vul",
                "severity": "HIGH"
              }
            ]
          },
          {
            "dependencyId": 129709,
            "isVirtual": "false",
            "vulnerabilities": []
          }
        ],
        "output": [
          {
            "id": 129707,
            "vulnCount": 1
          },
          {
            "id": 129708,
            "vulnCount": 2
          },
          {
            "id": 129709,
            "vulnCount": 0
          }
        ]
      }
    ],
    "identifier": 64243574
  },
  {
    "context": [
      "I want to get the value of `health`, which is `up`.\nThe result should be based on the `__address__`.",
      "`cat 1.json | jq -r '.data.activeTargets[] | select(.discoveredLabels.__address__ == \"prometheus.1.de\") | .health'`"
    ],
    "utterance": "Extract the health value for the entry where discoveredLabels.__address__ equals \"prometheus.1.de\".",
    "expressions": [
      ".data.activeTargets[] | select(.discoveredLabels.__address__ == \"prometheus.1.de\") | .health"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": {
            "activeTargets": [
              {
                "discoveredLabels": {
                  "__address__": "prometheus.1.de",
                  "__metrics_path__": "/federate",
                  "__param_match[]": "{job=~\\\".*\\\"}",
                  "__scheme__": "http",
                  "job": "federate"
                },
                "labels": {
                  "instance": "prometheus.1.de:80",
                  "job": "federate"
                },
                "scrapePool": "federate",
                "scrapeUrl": "http://prometheus.1.de:80/federate?match%5B%5D=%7Bjob%3D~%22.%2A%22%7D",
                "globalUrl": "http://prometheus.1.de:80/federate?match%5B%5D=%7Bjob%3D~%22.%2A%22%7D",
                "lastError": "",
                "lastScrape": "2020-10-13T06:35:59.96463521Z",
                "lastScrapeDuration": 3.339807114,
                "health": "up"
              },
              {
                "discoveredLabels": {
                  "__address__": "localhost:9090",
                  "__metrics_path__": "/metrics",
                  "__scheme__": "http",
                  "job": "prometheus"
                },
                "labels": {
                  "instance": "localhost:9090",
                  "job": "prometheus"
                },
                "scrapePool": "prometheus",
                "scrapeUrl": "http://localhost:9090/metrics",
                "globalUrl": "http://prometheus-2:9090/metrics",
                "lastError": "",
                "lastScrape": "2020-10-13T06:35:53.366524719Z",
                "lastScrapeDuration": 0.005405697,
                "health": "up"
              }
            ],
            "droppedTargets": []
          }
        },
        "output": "up"
      }
    ],
    "identifier": 64329995
  },
  {
    "context": [
      "I have the following JSON & I need to extract FOUR values i.e. SAUCE_KEY, sauceKey, SAUCE_VALUE, sauceValue etc. And I need to covert these bash variables as i.e.\n\n    SAUCE_KEY=sauceKey\n    SAUCE_VALUE=sauceValue",
      "jq -r '.env_vars[] | \"\\(.name)\\u0001\\(.value)\"' saucy.json"
    ],
    "utterance": "Extract all pairs of name and value from env_vars and format as NAME=VALUE assignments for use as Bash variables, e.g., SAUCE_KEY=sauceKey.",
    "expressions": [
      ".env_vars[] | \"\u001b[33m\\(.name)=\\(.value)\u001b[0m\"",
      ".env_vars[] | \"\\(.name)=\\(.value)\""
    ],
    "data": [
      {
        "input": {
          "@type": "env_vars",
          "env_vars": [
            {
              "@type": "env_var",
              "@href": "/repo/xxxxx/env_var/xxxxx",
              "@representation": "standard",
              "@permissions": {
                "read": true,
                "write": true
              },
              "name": "SAUCE_KEY",
              "value": "sauceKey"
            },
            {
              "@type": "env_var",
              "@href": "/repo/xxxxx/env_var/xxxxx",
              "@representation": "standard",
              "@permissions": {
                "read": true,
                "write": true
              },
              "name": "SAUCE_VALUE",
              "value": "sauceValue"
            }
          ]
        },
        "output": [
          "SAUCE_KEY=sauceKey",
          "SAUCE_VALUE=sauceValue"
        ]
      }
    ],
    "identifier": 64379263
  },
  {
    "context": [
      "got to this section of json with jq -r '.update[]' now need to find, operation:restrictions:user:results:username,userKey",
      "Assuming the input as shown has been tidied a bit to make it valid JSON, running\n```\njq -r '\n  .update\n  | [.operation] + (.restrictions.user.results[] | [.username, .userKey])\n  | @csv\n'\n```\nagainst it would yield:\n```\n\"update\",\"xxxx\",\"yyyyy\"\n```\n"
    ],
    "utterance": "Extract the operation value and, for each user result, output their username and userKey fields as CSV.",
    "expressions": [
      ".update\n  | [.operation] + (.restrictions.user.results[] | [.username, .userKey])\n  | @csv"
    ],
    "data": [
      {
        "input": {
          "update": {
            "operation": "update",
            "restrictions": {
              "user": {
                "results": [
                  {
                    "type": "known",
                    "username": "xxxx",
                    "userKey": "yyyyy",
                    "profilePicture": {
                      "path": "/download/attachments/49710215/user-avatar",
                      "width": 48,
                      "height": 48,
                      "isDefault": false
                    },
                    "displayName": "xxxyyyzzz",
                    "_links": {
                      "self": "aa"
                    },
                    "_expandable": {
                      "status": ""
                    }
                  }
                ]
              }
            }
          }
        },
        "output": "\"update\",\"xxxx\",\"yyyyy\""
      }
    ],
    "identifier": 64360375
  },
  {
    "context": [
      "I want to convert it to CSV format, where each row corresponds to an entry in `rssiSignature` (I have added the header row for visualization purposes):",
      "How can I use jq to generate different rows for each entry of the `rssiSignature` array?",
      "jq -r '.timestamp as $t | .transmitterId as $tid |\n       .rssiSignature[] | [ $t, $tid, .receiverId, .rssi] | @csv\n      ' file.json",
      "jq -r '\n  [\"timestamp\",\"transmitterId\",\"receiverId\",\"rssi\"],\n   [.timestamp, .transmitterId] + (.rssiSignature[] | [.receiverId,.rssi])\n  | @csv'"
    ],
    "utterance": "Output each entry of rssiSignature as a row with timestamp, transmitterId, receiverId, and rssi columns, suitable for CSV.",
    "expressions": [
      ".timestamp as $t | .transmitterId as $tid | .rssiSignature[] | [ $t, $tid, .receiverId, .rssi] | @csv",
      "[\"timestamp\",\"transmitterId\",\"receiverId\",\"rssi\"], [.timestamp, .transmitterId] + (.rssiSignature[] | [.receiverId,.rssi]) | @csv"
    ],
    "data": [
      {
        "input": {
          "transmitterId": "30451155eda2",
          "rssiSignature": [
            {
              "receiverId": "001bc509408201d5",
              "receiverIdType": 1,
              "rssi": -52,
              "numberOfDecodings": 5,
              "rssiSum": -52
            },
            {
              "receiverId": "001bc50940820228",
              "receiverIdType": 1,
              "rssi": -85,
              "numberOfDecodings": 5,
              "rssiSum": -85
            }
          ],
          "timestamp": 1574228579837
        },
        "output": [
          "1574228579837,\"30451155eda2\",\"001bc509408201d5\",-52",
          "1574228579837,\"30451155eda2\",\"001bc50940820228\",-85"
        ]
      }
    ],
    "identifier": 64326827
  },
  {
    "context": [
      "To delete the `localhost` this works `. allowed_origin |= map(select(index(\"http://localhost\")|not))`.",
      "But how to do the other one? I tried somethings but I did not have any success.",
      "I used `del` to remove an entry instead of `|=` with `map`.",
      "command=\"del(.allowed_origin[.allowed_origin|$indices])\""
    ],
    "utterance": "Remove specific URLs from the allowed_origin array so that only http://localhost and http://companydev.com remain for the dev environment, or only http://company.com for the prod environment.",
    "expressions": [
      ".allowed_origin |= map(select(. != \"http://company.com\"))",
      "// for dev",
      ".allowed_origin |= map(select(. == \"http://company.com\"))",
      "// for prod",
      "del(.allowed_origin[.allowed_origin|index(\"http://company.com\")])",
      "// for dev (removes company.com)",
      "del(.allowed_origin[.allowed_origin|index(\"http://localhost\")]), del(.allowed_origin[.allowed_origin|index(\"http://companydev.com\")])",
      "// for prod (removes localhost and companydev.com)"
    ],
    "data": [
      {
        "input": {
          "allowed_origin": [
            "http://localhost",
            "http://companydev.com",
            "http://company.com"
          ]
        },
        "output": {
          "allowed_origin": [
            "http://localhost",
            "http://companydev.com"
          ]
        }
      },
      {
        "input": {
          "allowed_origin": [
            "http://localhost",
            "http://companydev.com",
            "http://company.com"
          ]
        },
        "output": {
          "allowed_origin": [
            "http://company.com"
          ]
        }
      }
    ],
    "identifier": 64212113
  },
  {
    "context": [
      "And for all nested objects with keys in [\"1\", \"2\"], I want to delete the `bar` object, and otherwise I want to delete the `foo` object, so the output expected being:",
      "Using your approach, you could write:",
      "```\n.[] |= with_entries(\n   if (.key == \"1\" or .key == \"2\") \n   then .value |= del(.bar) \n   else .value |= del(.foo)\n   end)\n```"
    ],
    "utterance": "For nested objects where the key is '1' or '2', remove the 'bar' field; otherwise, remove the 'foo' field.",
    "expressions": [
      ".[] |= with_entries(if (.key == \"1\" or .key == \"2\") then .value |= del(.bar) else .value |= del(.foo) end)"
    ],
    "data": [
      {
        "input": {
          "A": {
            "1": {
              "bar": 1,
              "foo": 0
            }
          },
          "B": {
            "2": {
              "not_here": 0,
              "foo": 0
            },
            "3": {
              "bar": 0,
              "foo": 1
            }
          },
          "C": {
            "4": {
              "bar": 0,
              "foo": 1
            }
          }
        },
        "output": {
          "A": {
            "1": {
              "foo": 0
            }
          },
          "B": {
            "2": {
              "not_here": 0,
              "foo": 0
            },
            "3": {
              "bar": 0
            }
          },
          "C": {
            "4": {
              "bar": 0
            }
          }
        }
      }
    ],
    "identifier": 64014015
  },
  {
    "context": [
      "I'm trying to create a single json output based on a nested Json:",
      "What would be the best way to iterate over an inner array and at the same time fetch the outer object data?",
      "The key to brevity (or at least DRY-ness) here is that the jq expression `{$x}` expands to `{\"x\": $x}`.",
      ".Id as $Id\n| .items\n| [ range(0; length) as $index_position\n   | {$Id} + .[$index_position] + {$index_position} ]"
    ],
    "utterance": "Produce an array where each item includes the outer object's id field, all fields of the inner array item, and the array index as index_position.",
    "expressions": [
      ".Id as $Id | .items | [ range(0; length) as $index_position | {$Id} + .[$index_position] + {$index_position} ]"
    ],
    "data": [
      {
        "input": {
          "Id": "1",
          "items": [
            {
              "item_name": "shirt",
              "value": 10
            },
            {
              "item_name": "dress",
              "value": 20
            },
            {
              "item_name": "ice cream",
              "value": 30
            }
          ]
        },
        "output": [
          {
            "Id": "1",
            "item_name": "shirt",
            "value": 10,
            "index_position": 0
          },
          {
            "Id": "1",
            "item_name": "dress",
            "value": 20,
            "index_position": 1
          },
          {
            "Id": "1",
            "item_name": "ice cream",
            "value": 30,
            "index_position": 2
          }
        ]
      }
    ],
    "identifier": 64343527
  },
  {
    "context": [
      "I would like to query the data using the pure dot syntax .cars.big-trucks but I was unable to find any tool that would do the conversion for me.",
      "My ideal usage would be:",
      "query=$(jq-query-convert \".cars.big-trucks\")",
      "For jq users an example json would be:",
      "{\n \"cars\": {\n  \"big-trucks\": 42\n }\n}",
      "queried by \ncat cars.json | jq \"$q\"",
      "Well I came up with this python3 one-liner that serves my intentions so far but if anyone know more robust solutions I am happy to accept it.",
      "returns \\\n.[\"cars\"][\"big-trucks\"]"
    ],
    "utterance": "Convert .cars.big-trucks into a valid jq expression that properly escapes special characters in keys.",
    "expressions": [
      ".[\"cars\"][\"big-trucks\"]"
    ],
    "data": [
      {
        "input": {
          "cars": {
            "big-trucks": 42
          }
        },
        "output": 42
      }
    ],
    "identifier": 64316280
  },
  {
    "context": [
      "jq --arg sslc \"/etc/letsencrypt/live/$2/fullchain.pem\" \\",
      ". + {ssl_certificate: $sslc, ssl_certificate_key: $sslck }'",
      "jq --arg ssl_certificate \"/etc/letsencrypt/live/$2/fullchain.pem\" \\",
      ". + {$ssl_certificate, $ssl_certificate_key }'",
      "myFunc() {\n    local file=\"$1\" site=\"$2\"\n    local JSON=(\n        --arg ssl_certificate \"/etc/letsencrypt/live/$site/fullchain.pem\"\n        --arg ssl_certificate_key \"/etc/letsencrypt/live/$site/fullchain.pem\"\n        '. + {$ssl_certificate, $ssl_certificate_key}' # this syntax\n    )\n    jq \"${JSON[@]}\" <\"$file\"\n}"
    ],
    "utterance": "Add fields ssl_certificate and ssl_certificate_key with the value /etc/letsencrypt/live/somesite.com/fullchain.pem, substituting somesite.com with a positional argument, to an existing file.",
    "expressions": [
      "jq --arg sslc \"/etc/letsencrypt/live/$2/fullchain.pem\" --arg sslck \"/etc/letsencrypt/live/$2/fullchain.pem\" '. + {ssl_certificate: $sslc, ssl_certificate_key: $sslck }'",
      "jq --arg ssl_certificate \"/etc/letsencrypt/live/$2/fullchain.pem\" --arg ssl_certificate_key \"/etc/letsencrypt/live/$2/fullchain.pem\" '. + {$ssl_certificate, $ssl_certificate_key}'"
    ],
    "data": [
      {
        "input": {
          "key1": "value1",
          "key2": "value2"
        },
        "output": {
          "key1": "value1",
          "key2": "value2",
          "ssl_certificate": "/etc/letsencrypt/live/somesite.com/fullchain.pem",
          "ssl_certificate_key": "/etc/letsencrypt/live/somesite.com/fullchain.pem"
        }
      }
    ],
    "identifier": 64568269
  },
  {
    "context": [
      "How can I create a nested JSON object from the flat keys in an object with jq?",
      "My input is\n{\n    \"foo.bar\": \"lorem\",\n    \"foo.baz\": \"ipsum\",\n    \"bar.foo\": \"dolor\"\n}",
      "and the output should look like\n{\n    \"foo\": {\n        \"bar\": \"lorem\",\n        \"baz\": \"ipsum\"\n    },\n    \"bar\": {\n        \"foo\": \"dolor\"\n    }\n}",
      "One way uses `reduce` and `setpath` to build up the new object from the keys of the original:",
      "$ jq '. as $orig | reduce keys[] as $key ({}; setpath($key | split(\".\"); $orig[$key]))' input.json"
    ],
    "utterance": "Transform an object with flat keys separated by dots into a corresponding nested object where each segment becomes a level.",
    "expressions": [
      ". as $orig | reduce keys[] as $key ({}; setpath($key | split(\".\"); $orig[$key]))"
    ],
    "data": [
      {
        "input": {
          "foo.bar": "lorem",
          "foo.baz": "ipsum",
          "bar.foo": "dolor"
        },
        "output": {
          "foo": {
            "bar": "lorem",
            "baz": "ipsum"
          },
          "bar": {
            "foo": "dolor"
          }
        }
      }
    ],
    "identifier": 64596039
  },
  {
    "context": [
      "I would like to do something like this: `jq .key.first`. But yea, taking into consideration that the `key` is a string and need to be first parsed to json.",
      "Use `fromjson`, e.g.\r\n\r\n    jq '.key|fromjson|.first'\r\n\r\nAs pointed out in a comment, this can be abbreviated by omitting the last pipe character.\r\n\r\nIn general, it\u2019s better to avoid calling jq twice when one call is sufficient."
    ],
    "utterance": "Extract the value associated with 'first' from an object encoded as a string in the 'key' field, after parsing that string as structured data.",
    "expressions": [
      ".key | fromjson | .first"
    ],
    "data": [
      {
        "input": {
          "key": "{\"first\":\"123\",\"second\":\"456\"}"
        },
        "output": "123"
      }
    ],
    "identifier": 64206982
  },
  {
    "context": [
      "I want to filter out the status of each cluster and server in below format",
      "name            cluster/server status",
      "gw-ext-1        CLUSTER        RUNNING",
      "gw-jpg208765-1  SERVER         RUNNING",
      "gw-jpg208765-2  SERVER         DISCONNECTED",
      "jq -r '[ \"name\", \"cluster/server\", \"status\" ],\n       ( .data[] | [.name, .type, .status], ( .servers[] | [.name, .type, .status] ) ) | @tsv'"
    ],
    "utterance": "Return a table listing each cluster followed by its servers, showing their name, type, and status.",
    "expressions": [
      "[ \"name\", \"cluster/server\", \"status\" ], (.data[] | [.name, .type, .status], (.servers[] | [.name, .type, .status])) | @tsv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 7865,
              "timeCreated": 1602589399294,
              "timeUpdated": 1602748892149,
              "name": "gw-ext-1",
              "type": "CLUSTER",
              "status": "RUNNING",
              "multicastEnabled": false,
              "primaryNodeId": 546,
              "servers": [
                {
                  "id": 768,
                  "timeCreated": 1602589028419,
                  "timeUpdated": 1602747941321,
                  "name": "gw-jpg208765-1",
                  "type": "SERVER",
                  "serverType": "GATEWAY",
                  "status": "RUNNING",
                  "addresses": [
                    {
                      "networkInterface": "eng123"
                    },
                    {
                      "networkInterface": "eng124"
                    }
                  ],
                  "clusterId": 98,
                  "clusterName": "gw-ext-1",
                  "currentClusteringPort": 897,
                  "runtimeInformation": {
                    "Information": {
                      "runtime": {
                        "name": "abctech",
                        "version": "1.6.8"
                      },
                      "specification": {
                        "vendor": "rrr",
                        "name": "rrrt",
                        "version": "1.8.89"
                      }
                    },
                    "osInformation": {
                      "name": "LX",
                      "version": "35",
                      "architecture": "klh"
                    },
                    "mExpirationDate": 98765589283662
                  }
                },
                {
                  "id": 876,
                  "timeCreated": 1602589007370,
                  "timeUpdated": 1602748894901,
                  "name": "gw-jpg208765-2",
                  "type": "SERVER",
                  "serverType": "GATEWAY",
                  "mVersion": "3.9.1",
                  "gaVersion": "3.9.1",
                  "agentVersion": "1.9.5",
                  "ExpirationDate": 1665661007000,
                  "status": "DISCONNECTED",
                  "addresses": [
                    {
                      "networkInterface": "engg"
                    },
                    {
                      "networkInterface": "engg"
                    }
                  ],
                  "clusterId": 768,
                  "clusterName": "gw-ext-1",
                  "serverPort": 987,
                  "currentClusteringPort": 987,
                  "runtimeInformation": {
                    "abcInfo": {
                      "runtime": {
                        "name": "abc",
                        "version": "1.2.3"
                      },
                      "specification": {
                        "vendor": "RRR",
                        "name": "RTR",
                        "version": "1.8.0"
                      }
                    },
                    "osInformation": {
                      "name": "LX",
                      "version": "4.78",
                      "architecture": "eng"
                    },
                    "ExpirationDate": 8765478999765
                  }
                }
              ],
              "visibilityMap": {
                "mapNodes": [
                  {
                    "serverId": 765,
                    "visibleNodeIds": [
                      765,
                      876
                    ],
                    "unknownNodeIps": []
                  },
                  {
                    "serverId": 876,
                    "visibleNodeIds": [
                      765,
                      876
                    ],
                    "unknownNodeIps": []
                  }
                ]
              }
            }
          ]
        },
        "output": "name\tcluster/server\tstatus\ngw-ext-1\tCLUSTER\tRUNNING\ngw-jpg208765-1\tSERVER\tRUNNING\ngw-jpg208765-2\tSERVER\tDISCONNECTED"
      }
    ],
    "identifier": 64386912
  },
  {
    "context": [
      "I want to convert below data:\r\n\r\n    {\r\n      &quot;host1&quot;: &quot;10.1.2.3&quot; ,\r\n      &quot;host2&quot;:  &quot;10.1.2.2&quot; ,\r\n      &quot;host3&quot;: &quot;10.1.18.1&quot;\r\n    }\r\n\r\nto this below format:\r\n\r\n    host1 : 10.1.2.3\r\n    host2 : 10.1.2.2\r\n    host3 : 10.1.18.1\r\n",
      "$ jq -r 'to_entries[] | \"\\(.key) : \\(.value)\"' tmp.json",
      "jq -r 'keys_unsorted[] as $k | [ $k, .[$k] ] | join(\" : \")' "
    ],
    "utterance": "Print each key-value pair as 'key : value' lines, one per line.",
    "expressions": [
      "to_entries[] | \"\\(.key) : \\(.value)\"",
      "keys_unsorted[] as $k | [ $k, .[$k] ] | join(\" : \")"
    ],
    "data": [
      {
        "input": {
          "host1": "10.1.2.3",
          "host2": "10.1.2.2",
          "host3": "10.1.18.1"
        },
        "output": "host1 : 10.1.2.3\nhost2 : 10.1.2.2\nhost3 : 10.1.18.1"
      }
    ],
    "identifier": 64370295
  },
  {
    "context": [
      "Using my input file data which has a start and end date times of my program, I want to capture all the logfile lines in between my Start Time and End Time and write it to a file.",
      "I expect my new log file to be like this:",
      "{ \"Utility\":\"DBUpdate\", \"StartDate\":\"2020-09-23\", \"StartTime\":\"14:41:12\", ... , \"EndDate\":\"2020-09-23\", \"EndTime\":\"14:41:29\", ... }",
      "{ \"Utility\":\"DBUpdate\", \"StartDate\":\"2020-09-23\", \"StartTime\":\"14:42:12\", ... , \"EndDate\":\"2020-09-23\", \"EndTime\":\"14:43:21\", ... }",
      "In general, to filter your json and get only those with a field value inside a range:",
      "jq 'select(.StartDate > \"2000-09-22\" and .StartDate < \"2020-09-24\")' file.json",
      "Now, you can add any variables, any conditions for StartDate, StartTime, and get what you want.",
      "here is a simple way to concatenate {Start|End}{Date|Time} of your JSON into easily sortable datetime fields.",
      "jq -c '.StartDate = \"\\(.StartDate)_\\(.StartTime)\" | .EndDate = \"\\(.EndDate)_\\(.EndTime)\" | del(.StartTime, .EndTime)' file.json"
    ],
    "utterance": "Extract all log entries whose start and end datetime fall within the interval from 2020-09-23 14:41:12 to 2020-09-23 14:43:21.",
    "expressions": [
      ".StartDate = \"\\(.StartDate)_\\(.StartTime)\" | .EndDate = \"\\(.EndDate)_\\(.EndTime)\" | del(.StartTime, .EndTime)",
      "select(.StartDate >= \"2020-09-23_14:41:12\" and .EndDate <= \"2020-09-23_14:43:21\")"
    ],
    "data": [
      {
        "input": [
          {
            "Utility": "DBUpdate",
            "StartDate": "2020-09-21",
            "StartTime": "14:41:12",
            "Server": "eaidev",
            "Userid": "sx50067",
            "TrueExit": "No",
            "WaitInterval": 30,
            "Cluster": "1",
            "Source": "MANNING1",
            "Target": "MANNING2",
            "ClusterListCt": 5,
            "ListCt": 55,
            "RequestServer": "MANNING3",
            "Reply": "JOT4",
            "ISC(Source)": 0,
            "EndDate": "2020-09-21",
            "EndTime": "14:41:21",
            "ExitCode": 0
          },
          {
            "Utility": "DBUpdate",
            "StartDate": "2020-09-22",
            "StartTime": "14:41:12",
            "Server": "eaidev",
            "Userid": "sx50067",
            "TrueExit": "No",
            "WaitInterval": 30,
            "Cluster": "1",
            "Source": "MANNING1",
            "Target": "MANNING2",
            "ClusterListCt": 5,
            "ListCt": 55,
            "RequestServer": "MANNING3",
            "Reply": "JOT4",
            "ISC(Source)": 0,
            "EndDate": "2020-09-22",
            "EndTime": "14:41:21",
            "ExitCode": 0
          },
          {
            "Utility": "DBUpdate",
            "StartDate": "2020-09-23",
            "StartTime": "14:41:12",
            "Server": "eaidev",
            "Userid": "sx50067",
            "TrueExit": "No",
            "WaitInterval": 30,
            "Cluster": "1",
            "Source": "MANNING1",
            "Target": "MANNING2",
            "ClusterListCt": 5,
            "ListCt": 55,
            "RequestServer": "MANNING3",
            "Reply": "JOT4",
            "ISC(Source)": 0,
            "EndDate": "2020-09-23",
            "EndTime": "14:41:29",
            "ExitCode": 0
          },
          {
            "Utility": "DBUpdate",
            "StartDate": "2020-09-23",
            "StartTime": "14:42:12",
            "Server": "eaidev",
            "Userid": "sx50067",
            "TrueExit": "No",
            "WaitInterval": 30,
            "Cluster": "1",
            "Source": "MANNING1",
            "Target": "MANNING2",
            "ClusterListCt": 5,
            "ListCt": 55,
            "RequestServer": "MANNING3",
            "Reply": "JOT4",
            "ISC(Source)": 0,
            "EndDate": "2020-09-23",
            "EndTime": "14:43:21",
            "ExitCode": 0
          }
        ],
        "output": [
          {
            "Utility": "DBUpdate",
            "StartDate": "2020-09-23",
            "StartTime": "14:41:12",
            "Server": "eaidev",
            "Userid": "sx50067",
            "TrueExit": "No",
            "WaitInterval": 30,
            "Cluster": "1",
            "Source": "MANNING1",
            "Target": "MANNING2",
            "ClusterListCt": 5,
            "ListCt": 55,
            "RequestServer": "MANNING3",
            "Reply": "JOT4",
            "ISC(Source)": 0,
            "EndDate": "2020-09-23",
            "EndTime": "14:41:29",
            "ExitCode": 0
          },
          {
            "Utility": "DBUpdate",
            "StartDate": "2020-09-23",
            "StartTime": "14:42:12",
            "Server": "eaidev",
            "Userid": "sx50067",
            "TrueExit": "No",
            "WaitInterval": 30,
            "Cluster": "1",
            "Source": "MANNING1",
            "Target": "MANNING2",
            "ClusterListCt": 5,
            "ListCt": 55,
            "RequestServer": "MANNING3",
            "Reply": "JOT4",
            "ISC(Source)": 0,
            "EndDate": "2020-09-23",
            "EndTime": "14:43:21",
            "ExitCode": 0
          }
        ]
      }
    ],
    "identifier": 64037572
  },
  {
    "context": [
      "Using `inputs` is the way to go, whether or not any parallelization techniques are brought to bear.",
      "In the jq module for inducing structural schema that I wrote some time ago (https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed), there&#39;s a filter, `schema/1` defined as:",
      "def schema(stream):\n  reduce stream as $x (\"null\";  typeUnion(.; $x|typeof));",
      "This can therefore be used as suggested by this snippet:",
      "jq -n 'include \"schema\"; schema(inputs)' FILESPECIFICATIONS"
    ],
    "utterance": "Infer the structural schema from a large dataset using a memory-efficient method that can handle many records.",
    "expressions": [
      "jq -n 'include \"schema\"; schema(inputs)' FILESPECIFICATIONS"
    ],
    "identifier": 64340429
  },
  {
    "context": [
      "need to append the new name into `.root.application.names`, but if the name passed in has prefix (everything before `-`, in below example it's `jr`), then find the list with same prefix names already present, and update it, if there is only one names list or if there is no matching list, then update first list.",
      "`$application == 'application1' and $name == <whatever>; just update first list under application1, as there is only one list under application1, nothing to choose from.`",
      "` $application == 'application2' and if $name has no prefix delimiter \"-\" or unmatched prefix (say sr-allen); then update the first list under application2.names, because foo has no or unmatched prefix.`",
      "` $application == 'application2' and say $name == jr-allen; then update the second list under application2, because $name has prefix \"jr-\" and there is a list with items matching this prefix.`",
      "def updateFirstNamesArrayWithMatchingPrefix($prefix; $value):\n  (first( range(0; length) as $i\n          | if any(.[$i].names[]; startswith($prefix))\n\t        then $i else empty end) // 0) as $i\n  | .[$i].names += [$value] ;",
      ".root |=\n  if .[$app] | length == 1 \n  then .[$app][0].names += [ $name ]\n  elif .[$app] | length > 1\n  then \n    ( $name | split(\"-\") ) as $components\n    | if $components|length==1  # no prefix\n      then .[$app][0].names += [ $name  ]\n      else ($components[0] + \"-\" ) as $prefix\n      | .[$app] |= updateFirstNamesArrayWithMatchingPrefix($prefix; $name)\n      end\n  else .\n  end"
    ],
    "utterance": "Append a given name to the names array under the specified application; if the name has a prefix matching an existing names list, update that list, otherwise or if only one exists, update the first list.",
    "expressions": [
      "def updateFirstNamesArrayWithMatchingPrefix($prefix; $value):\n  (first( range(0; length) as $i\n    | if any(.[$i].names[]; startswith($prefix))\n      then $i else empty end) // 0) as $i\n  | .[$i].names += [$value];\n\n.root |=\n  if .[$app] | length == 1 \n  then .[$app][0].names += [ $name ]\n  elif .[$app] | length > 1\n  then \n    ( $name | split(\"-\") ) as $components\n    | if $components|length==1\n      then .[$app][0].names += [ $name  ]\n      else ($components[0] + \"-\" ) as $prefix\n      | .[$app] |= updateFirstNamesArrayWithMatchingPrefix($prefix; $name)\n      end\n  else .\n  end"
    ],
    "data": [
      {
        "input": {
          "root": {
            "application1": [
              {
                "names": [
                  "john"
                ],
                "project": "generic"
              }
            ],
            "application2": [
              {
                "names": [
                  "peter",
                  "jack"
                ],
                "project": "generic"
              },
              {
                "names": [
                  "jr-sam",
                  "jr-mike",
                  "jr-rita"
                ],
                "project": "junior-project"
              }
            ]
          }
        }
      }
    ],
    "identifier": 64213506
  },
  {
    "context": [
      "is it possible to use JQ / sed or any other shell tool to remove the segments of json that contain the corrupt pattern? if so how can i achieve this?",
      "here's a jq filter that solves the problem in accordance with my understanding of the criterion you defined:",
      ".odds.data |= map(if keys_unsorted[0:2] - [\"label\",\"value\"] == [] \n                  then empty else . end)",
      "Or, if the ordering of the keys is relevant:",
      ".odds.data |= map(select(keys_unsorted[0:2] != [\"label\",\"value\"]))"
    ],
    "utterance": "Remove any object from odds.data arrays where the first two keys are label and value in that exact order.",
    "expressions": [
      ".odds.data |= map(if keys_unsorted[0:2] - [\"label\",\"value\"] == [] then empty else . end)",
      ".odds.data |= map(select(keys_unsorted[0:2] != [\"label\",\"value\"]))"
    ],
    "identifier": 64545318
  },
  {
    "context": [
      "curl https://ip-ranges.amazonaws.com/ip-ranges.json |\r\n  jq -r '.prefixes[] | select(.service==\"CLOUDFRONT\") | \"set_real_ip_from \\(.ip_prefix);\"' > set_real_ip_from.inc",
      "Output of the command:\r\n\r\n    set_real_ip_from 34.216.51.0/25;\r\n    set_real_ip_from 34.223.12.224/27;\r\n    set_real_ip_from 34.223.80.192/26;\r\n    set_real_ip_from 34.226.14.0/24;\r\n    set_real_ip_from 35.158.136.0/24;\r\n    set_real_ip_from 35.162.63.192/26;\r\n    set_real_ip_from 35.167.191.128/26;\r\n    set_real_ip_from 44.227.178.0/24;\r\n    set_real_ip_from 44.234.108.128/25;\r\n    set_real_ip_from 44.234.90.252/30;\r\n    set_real_ip_from 52.15.127.128/26;"
    ],
    "utterance": "Produce lines in the format 'set_real_ip_from <ip_prefix>;' for each entry with service equal to CLOUDFRONT.",
    "expressions": [
      ".prefixes[] | select(.service==\"CLOUDFRONT\") | \"set_real_ip_from \\(.ip_prefix);\""
    ],
    "data": [
      {
        "input": {
          "prefixes": [
            {
              "ip_prefix": "34.216.51.0/25",
              "service": "CLOUDFRONT"
            },
            {
              "ip_prefix": "203.0.113.0/24",
              "service": "AMAZON"
            },
            {
              "ip_prefix": "35.158.136.0/24",
              "service": "CLOUDFRONT"
            }
          ]
        },
        "output": [
          "set_real_ip_from 34.216.51.0/25;",
          "set_real_ip_from 35.158.136.0/24;"
        ]
      }
    ],
    "identifier": 64070856
  },
  {
    "context": [
      "Only print object if `value` is different of the previous object.",
      "reduce .[] as $x (null;\n    if . == null then [$x]\n    elif .[-1].value == $x.value then .\n    else . + [$x] end)",
      "[ foreach .[] as $x ({};\n    if .prev == $x.value then .emit = null\n    else {prev: $x.value, emit: $x}\n    end;\n    select(.emit).emit ) ]"
    ],
    "utterance": "Return objects where 'value' is different from the previous object's 'value', including the first object.",
    "expressions": [
      "reduce .[] as $x (null; if . == null then [$x] elif .[-1].value == $x.value then . else . + [$x] end)",
      "[ foreach .[] as $x ({}; if .prev == $x.value then .emit = null else {prev: $x.value, emit: $x} end; select(.emit).emit ) ]"
    ],
    "data": [
      {
        "input": [
          {
            "date": "10-03-20",
            "value": 3
          },
          {
            "date": "11-03-20",
            "value": 3
          },
          {
            "date": "12-03-20",
            "value": 3
          },
          {
            "date": "13-03-20",
            "value": 8
          },
          {
            "date": "14-03-20",
            "value": 8
          },
          {
            "date": "15-03-20",
            "value": 5
          }
        ],
        "output": [
          {
            "date": "10-03-20",
            "value": 3
          },
          {
            "date": "13-03-20",
            "value": 8
          },
          {
            "date": "15-03-20",
            "value": 5
          }
        ]
      }
    ],
    "identifier": 64180906
  },
  {
    "context": [
      "I want to define `;` as a delimiter for export to `csv` file in the following command ... [fields] | @csv",
      "You might be able to get away with using `join(\";\")`, but it would almost certainly be better to use `gsub(\";\";\"\\\\;\")` on strings first, but it depends on how you want to handle semicolons in JSON strings.",
      "Depending on your requirements or expectations, you might also want to consider using `@tsv` and then postprocessing the tabs, e.g. using\n    sed $'s/\\t/;/g'\n\nor \n\n    tr '\\t' ';'"
    ],
    "utterance": "Export selected fields using a semicolon as the delimiter instead of comma.",
    "expressions": [
      "[.user.screen_name, .user.followers_count, .retweeted_status.user.screen_name, .full_text, .display_text_range[1], .created_at, .id, .in_reply_to_user_id, .in_reply_to_status_id, .user.location, .place.name, .user.verified, .retweet_count, .favorite_count, (.entities.media[].type // null), (.entities.hashtags[].text // null)] | map(tostring | gsub(\";\";\"\\\\;\")) | join(\";\")"
    ],
    "identifier": 64510755
  },
  {
    "context": [
      "resultId=$(jq '.results[].result_id' $response)",
      "The shell variable `$response` holds a JSON value, not a filename, ergo:",
      "resultId=$(jq '.results[].result_id' <<< \"$response\")"
    ],
    "utterance": "Extract the value of 'result_id' for each object in the 'results' array from the variable holding the response.",
    "expressions": [
      ".results[].result_id"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "result_id": "1234",
              "public_id": "abc-123-xyz",
              "location": 1
            }
          ],
          "triggered_check_ids": [
            "abc-123-xyz"
          ],
          "locations": [
            {
              "is_active": true,
              "region": "Somewhere",
              "display_name": "A1",
              "id": 1,
              "name": "A1"
            },
            {
              "is_active": true,
              "region": "Somewhere else",
              "display_name": "B2",
              "id": 2,
              "name": "B2"
            }
          ]
        },
        "output": "1234"
      }
    ],
    "identifier": 64033996
  },
  {
    "context": [
      "The last column is just the substring of `text` starting from `begin+1` to `end` (suppose the string in `text` is indexed starting from 1.",
      "I don't know how to extract this info using just `jq` as it involves taking a parent sibling element and the substring of another parent sibling element. Could anybody show me how to extract the output in this format?",
      "Assuming the first column of the desired output is the \"sourceid\", we can adapt your solution as follows:",
      " | [$id, .begin, .end, $text[.begin : .end] ]"
    ],
    "utterance": "Extract all drugs with their sourceid, span begin, span end, and the exact substring from text indexed from begin to end (both inclusive, 1-based) for each occurrence where obj==\"drug\".",
    "expressions": [
      ".[]\n| .sourceid as $id\n| .text as $text\n| .denotations[]\n| select(.obj==\"drug\")\n| .span\n| [$id, .begin, .end, $text[.begin : .end] ]\n| @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "project": "BERN",
            "sourcedb": "PubMed",
            "sourceid": "32818866",
            "text": "Identification of two bitter components in Zanthoxylum bungeanum Maxim. and exploration of their bitter taste mechanism through receptor hTAS2R14. Bitterness is an inherent organoleptic characteristic affecting the flavor of Zanthoxylum bungeanum Maxim. In this study, the vital bitter components of Z. bungeanum were concentrated through solvent extraction, sensory analysis, silica gel chromatography, and thin-layer chromatographic techniques and subsequently identified by UPLC-Q-TOF-MS. Two components with the highest bitterness intensities (BIs), such as 7-methoxycoumarin and 8-prenylkaempferol were selected. The bitter taste perceived thresholds of 7-methoxycoumarin and 8-prenylkaempferol were 0.062 mmol/L and 0.022 mmol/L, respectively. Moreover, the correlation between the contents of the two bitter components and the BIs of Z. bungeanum were proved. The results of siRNA and flow cytometry showed that 7-methoxycoumarin and 8-prenylkaempferol could activate the bitter receptor hTAS2R14. The results concluded that 7-methoxycoumarin and 8-prenylkaempferol contribute to the bitter taste of Z. bungeanum.",
            "denotations": [
              {
                "id": [
                  "MESH:D058428",
                  "BERN:315272203"
                ],
                "span": {
                  "begin": 377,
                  "end": 387
                },
                "obj": "drug"
              },
              {
                "id": [
                  "CHEBI:5679",
                  "BERN:4597103"
                ],
                "span": {
                  "begin": 562,
                  "end": 579
                },
                "obj": "drug"
              },
              {
                "id": [
                  "MESH:C532177",
                  "BERN:280529003"
                ],
                "span": {
                  "begin": 584,
                  "end": 602
                },
                "obj": "drug"
              },
              {
                "id": [
                  "CHEBI:5679",
                  "BERN:4597103"
                ],
                "span": {
                  "begin": 659,
                  "end": 676
                },
                "obj": "drug"
              },
              {
                "id": [
                  "MESH:C532177",
                  "BERN:280529003"
                ],
                "span": {
                  "begin": 681,
                  "end": 699
                },
                "obj": "drug"
              },
              {
                "id": [
                  "CHEBI:5679",
                  "BERN:4597103"
                ],
                "span": {
                  "begin": 919,
                  "end": 936
                },
                "obj": "drug"
              },
              {
                "id": [
                  "MESH:C532177",
                  "BERN:280529003"
                ],
                "span": {
                  "begin": 941,
                  "end": 959
                },
                "obj": "drug"
              },
              {
                "id": [
                  "CHEBI:5679",
                  "BERN:4597103"
                ],
                "span": {
                  "begin": 1032,
                  "end": 1049
                },
                "obj": "drug"
              },
              {
                "id": [
                  "MESH:C532177",
                  "BERN:280529003"
                ],
                "span": {
                  "begin": 1054,
                  "end": 1072
                },
                "obj": "drug"
              }
            ]
          }
        ],
        "output": [
          "32818866\t377\t387\tsilica gel",
          "32818866\t562\t579\t7-methoxycoumarin",
          "32818866\t584\t602\t8-prenylkaempferol",
          "32818866\t659\t676\t7-methoxycoumarin",
          "32818866\t681\t699\t8-prenylkaempferol",
          "32818866\t919\t936\t7-methoxycoumarin",
          "32818866\t941\t959\t8-prenylkaempferol",
          "32818866\t1032\t1049\t7-methoxycoumarin",
          "32818866\t1054\t1072\t8-prenylkaempferol"
        ]
      }
    ],
    "identifier": 64582030
  },
  {
    "context": [
      "Here is an example of JSON which results an empty array from the jq call:",
      "Here is JSON with populated content returning a non-empty array from jq call:",
      "readarray -t URL_names <<<\"$(echo \"$URL_list_json\" | jq -r '.[].Body.monitors[].name')\"",
      "If you want to check if the array is empty, check that in jq.",
      "jq --exit-status '.[].Body.monitors[].name' and just check the exit status."
    ],
    "utterance": "Determine whether any monitors[].name exist under Body for each top-level object; if no names are present, indicate empty result.",
    "expressions": [
      "jq --exit-status '.[].Body.monitors[].name'"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Region": "dc1",
              "Tenant": "tenant1",
              "Stage": "test"
            },
            "Body": {
              "monitors": []
            }
          }
        ]
      },
      {
        "input": [
          {
            "Header": {
              "Region": "dc2",
              "Tenant": "tenant2",
              "Stage": "qa"
            },
            "Body": {
              "monitors": [
                {
                  "enabled": true,
                  "entityId": "TEST-674BA97E74FC74AA",
                  "name": "production.example.com"
                },
                {
                  "enabled": false,
                  "entityId": "TEST-3E2D23438A973D1E",
                  "name": "test.example.com"
                }
              ]
            }
          }
        ],
        "output": [
          "production.example.com",
          "test.example.com"
        ]
      }
    ],
    "identifier": 64092857
  },
  {
    "context": [
      "I'm trying to parse the instance id, state, launch time and name using jq from the following partial output:",
      "But when I try to display the instance name as well the command fails:",
      "[ .InstanceId, \n  .State.Name,\n  .LaunchTime, \n  (.Tags[] | select(.Key==\"Name\").Value) ] \n| @tsv"
    ],
    "utterance": "Extract the instance id, state, launch time, and the value of the tag with Key==\"Name\" for each instance.",
    "expressions": [
      "[ .InstanceId, .State.Name, .LaunchTime, (.Tags[] | select(.Key==\"Name\").Value) ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "AmiLaunchIndex": 0,
          "ImageId": "ami-07c1483ef8c3dfece",
          "InstanceId": "i-0309XXXXXf6d500c",
          "InstanceType": "m5.2xlarge",
          "KeyName": "k8s-prod-ap-southeast-1",
          "LaunchTime": "2019-01-27T12:23:55+00:00",
          "Monitoring": {
            "State": "enabled"
          },
          "Placement": {
            "AvailabilityZone": "ap-southeast-1c",
            "GroupName": "",
            "Tenancy": "default"
          },
          "PrivateDnsName": "ip-X-X-X-X.ap-southeast-1.compute.internal",
          "PrivateIpAddress": "X.X.X.X",
          "ProductCodes": [],
          "PublicDnsName": "",
          "State": {
            "Code": 16,
            "Name": "running"
          },
          "SourceDestCheck": true,
          "Tags": [
            {
              "Key": "Environment",
              "Value": "dev"
            },
            {
              "Key": "Project",
              "Value": "someproject"
            },
            {
              "Key": "Name",
              "Value": "k8s-prod-ap-southeast-1-mongodb"
            },
            {
              "Key": "aws:autoscaling:groupName",
              "Value": "k8s-prod-ap-southeast-1-mongodb-moved-marmoset-20190127122348196400000006"
            },
            {
              "Key": "extra_tag1",
              "Value": "extra_value1"
            },
            {
              "Key": "extra_tag2",
              "Value": "extra_value2"
            }
          ]
        },
        "output": "i-0309XXXXXf6d500c\trunning\t2019-01-27T12:23:55+00:00\tk8s-prod-ap-southeast-1-mongodb"
      }
    ],
    "identifier": 64014481
  },
  {
    "context": [
      "\"I would like to create files with the filename as `key` (e.g: files like `client_decrypted.key` & passphrase) with the contents of the files as the `value` of the corresponding key.\"",
      "\"jq -j '.data | to_entries[] | (.key, \"\\u0000\", .value, \"\\u0000\")' json\""
    ],
    "utterance": "Extract all key-value pairs from the data field and output each key followed by a null byte and its value followed by a null byte, for use in file creation.",
    "expressions": [
      ".data | to_entries[] | (.key, \"\\u0000\", .value, \"\\u0000\")",
      "-j '.data | to_entries[] | (.key, \"\\u0000\", .value, \"\\u0000\")'"
    ],
    "data": [
      {
        "input": {
          "request_id": "016-ae81e5737add",
          "renewable": false,
          "data": {
            "client_decrypted.key": "-----BEGIN KEY-----sdjijhgisdTRjkRD05\n-----END KEY-----",
            "passphrase": "password"
          }
        }
      }
    ],
    "identifier": 64203739
  },
  {
    "context": [
      "filter.jq \r\n&quot;.security = {hideVersionStringsWhenNotLogged: true}&quot;",
      "So the contents of your `filter.jq` file could look like this:",
      ".security = {hideVersionStringsWhenNotLogged: true}"
    ],
    "utterance": "Set the security field to an object with hideVersionStringsWhenNotLogged set to true at the root of the data.",
    "expressions": [
      ".security = {hideVersionStringsWhenNotLogged: true}"
    ],
    "identifier": 64546963
  },
  {
    "context": [
      "You can do the whole thing in jq if you want.",
      "begin_date=\"2020-10-28T10:00:00Z\"",
      "end_date=\"2020-11-10T10:00:00Z\"",
      "curl -s \"http://worldtimeapi.org/api/timezone/Asia/Jerusalem\" | \\\njq --arg bd $begin_date --arg ed $end_date '.unixtime \n   | if . >= ($bd | fromdate) and . <= ($ed | fromdate) \n     then \"between 10 days range dates\"\n     else \"not between 10 days range dates\"\n     end'",
      "`fromdate` converts the beginning and end dates into the number of seconds since the Unix epoch (1970-01-01T00:00:00Z). We can compare those numbers with the value of .unixtime.",
      "I altered the beginning and end dates to a format that jq could easily recognize."
    ],
    "utterance": "Determine if the current UTC unixtime from the API falls between 2020-10-28T10:00:00Z and 2020-11-10T10:00:00Z, outputting a message for inside or outside the range.",
    "expressions": [
      ".unixtime | if . >= ($bd | fromdate) and . <= ($ed | fromdate) then \"between 10 days range dates\" else \"not between 10 days range dates\" end"
    ],
    "data": [
      {
        "input": {
          "unixtime": 1604000000
        },
        "output": "between 10 days range dates"
      },
      {
        "input": {
          "unixtime": 1602000000
        },
        "output": "not between 10 days range dates"
      }
    ],
    "identifier": 64590034
  },
  {
    "context": [
      "How do I merge the list of snapshots from all files into one? I tried jq with merge, but nothing seems to work ",
      "jq -n '{Snapshots: [inputs.Snapshots] | add}' out.*.json",
      "Note that the -n option is necessary here."
    ],
    "utterance": "Combine all snapshots across multiple files into a single Snapshots list.",
    "expressions": [
      "jq -n '{Snapshots: [inputs.Snapshots] | add}' out.*.json"
    ],
    "data": [
      {
        "input": [
          {
            "Snapshots": [
              {
                "SnapshotId": "snap-0001",
                "Description": "foo"
              },
              {
                "SnapshotId": "snap-0002",
                "Description": "bar"
              }
            ]
          },
          {
            "Snapshots": [
              {
                "SnapshotId": "snap-0003",
                "Description": "baz"
              }
            ]
          }
        ],
        "output": {
          "Snapshots": [
            {
              "SnapshotId": "snap-0001",
              "Description": "foo"
            },
            {
              "SnapshotId": "snap-0002",
              "Description": "bar"
            },
            {
              "SnapshotId": "snap-0003",
              "Description": "baz"
            }
          ]
        }
      }
    ],
    "identifier": 64081670
  },
  {
    "context": [
      "I need to retrieve the S value from ID and N value from no and put them into a query as parameters..",
      "$ ID=$(cat data.json | jq .Item.ID.S -r)",
      "$ no=$(cat data.json | jq .Item.no.N -r)",
      "we could write:",
      "< data.json jq --arg ID \"$ID\" --arg no \"$no\" -cr '\n  .Item\n  | .ID.S as $v1\n  | .no.N as $v2\n  | $v1, $v2, {($v1): {\"S\": $ID}, ($v2): {\"N\": $no}}\n'"
    ],
    "utterance": "Extract the value associated with .Item.ID.S and the value associated with .Item.no.N as separate values to use as parameters in a shell command.",
    "expressions": [
      ".Item.ID.S",
      ".Item.no.N",
      "jq -r '.Item.ID.S'",
      "jq -r '.Item.no.N'"
    ],
    "data": [
      {
        "input": {
          "Item": {
            "ID": {
              "S": "4869949"
            },
            "no": {
              "N": "2"
            }
          }
        },
        "output": [
          "4869949",
          "2"
        ]
      }
    ],
    "identifier": 64149031
  },
  {
    "context": [
      "I want to create a new file that includes everything from `file1.json`, but append it to include the relevent Count field based on the County field.",
      "# create map from county to count\n  ( $file2 | obj(\"County\";.Count) ) as $count\n\n# add .properties.Count to each feature\n| .features |= map( .properties.Count = $count[.properties.NAME] )",
      "If you need to convert that to a string you can include a call to `tostring`.  e.g.\n.features |= map( .properties.Count = ( $count[.properties.NAME] | tostring ) )",
      "or you could perform the conversion when the lookup table is created, e.g.\n  ( $file2 | obj(\"County\"; .Count | tostring ) ) as $count"
    ],
    "utterance": "For each Feature in the features array, add a Count property to its properties object, assigning the matching value from the array where County equals the feature's NAME.",
    "expressions": [
      "def obj(k;f): reduce .[] as $o ({}; .[$o[k]] = ($o | f));\n($file2 | obj(\"County\";.Count)) as $count | .features |= map(.properties.Count = $count[.properties.NAME])",
      "def obj(k;f): reduce .[] as $o ({}; .[$o[k]] = ($o | f));\n($file2 | obj(\"County\";.Count|tostring)) as $count | .features |= map(.properties.Count = $count[.properties.NAME])",
      "def obj(k;f): reduce .[] as $o ({}; .[$o[k]] = ($o | f));\n($file2 | obj(\"County\";.Count)) as $count | .features |= map(.properties.Count = ($count[.properties.NAME] | tostring))"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "GEO_ID": "0500000US06001",
                "STATE": "06",
                "COUNTY": "001",
                "NAME": "Alameda",
                "LSAD": "County",
                "CENSUSAREA": 739.017
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -122.30936,
                      37.77615
                    ],
                    [
                      -122.317215,
                      37.778527
                    ]
                  ]
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "GEO_ID": "0500000US06001",
                "STATE": "06",
                "COUNTY": "001",
                "NAME": "Alameda",
                "LSAD": "County",
                "CENSUSAREA": 739.017,
                "Count": 25
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -122.30936,
                      37.77615
                    ],
                    [
                      -122.317215,
                      37.778527
                    ]
                  ]
                ]
              }
            }
          ]
        }
      },
      {
        "input": [
          {
            "County": "Alameda",
            "Count": 25
          },
          {
            "County": "Amador",
            "Count": 1
          }
        ]
      }
    ],
    "identifier": 64469597
  },
  {
    "context": [
      "I'm trying to filter an array of objects by their `name` property, and then select the first element that passed the filter.",
      "With the following `jq` filter `.deployments[] | select(.name == \"nrn-v2-mst-aptd-gcms-lcz-sty-c1\")  | .url` executed at https://jqplay.org/ I get a \"list\" of urls.",
      "But, I don't understand how I extract the first element of this, it's not an array and even if I try to convert it into an array with `.deployments[] | select(.name == \"nrn-v2-mst-aptd-gcms-lcz-sty-c1\")  | [.url] | .[0]` I still get the same result.",
      "Solution: \n\n`first(.deployments[] | select(.name == \"nrn-v2-mst-aptd-gcms-lcz-sty-c1\")  | .url)`",
      "That \u201clist\u201d is actually a *stream* of JSON values, so you could simply enclose your jq expression in `first(   )` to get the first value."
    ],
    "utterance": "Select the first object's url value from the deployments array where name equals \"nrn-v2-mst-aptd-gcms-lcz-sty-c1\".",
    "expressions": [
      "first(.deployments[] | select(.name == \"nrn-v2-mst-aptd-gcms-lcz-sty-c1\") | .url)"
    ],
    "data": [
      {
        "input": {
          "deployments": [
            {
              "uid": "dpl_95kYvsWHaq3yAuJJ6uAaWXQY287R",
              "name": "nrn-v2-mst-aptd-gcms-lcz-sty-c1",
              "url": "nrn-v2-mst-aptd-gcms-lcz-sty-c1-n9ru06e1q.vercel.app"
            },
            {
              "uid": "dpl_Fwk5UXLJFU1miLnSfoUM91gnqSNK",
              "name": "nrn-v2-mst-aptd-gcms-lcz-sty-c2",
              "url": "nrn-v2-mst-aptd-gcms-lcz-sty-c2-hpbca7bei.vercel.app"
            },
            {
              "uid": "dpl_5U9vDaGKWBkSJF1H1EYMzreWeYvu",
              "name": "nrn-v2-mst-aptd-gcms-lcz-sty-c1",
              "url": "nrn-v2-mst-aptd-gcms-lcz-sty-c1-16g58d4zd.vercel.app"
            }
          ]
        },
        "output": "nrn-v2-mst-aptd-gcms-lcz-sty-c1-n9ru06e1q.vercel.app"
      }
    ],
    "identifier": 64402825
  },
  {
    "context": [
      "need to replace `tbd-` with `premium-` in task's value if and only if made is `german` and task's value starts with `tbd-`",
      "walk( if type==\"object\" and .task and (.task|startswith(\"tbd-\")) and\n         any(.[]; type==\"object\" and has(\"german\"))\n      then .task|=sub(\"tbd-\"; \"premium-\")\n      else . end )",
      "walk( if type==\"object\" and .task and (.task|startswith(\"tbd-\")) and any(.[]; type==\"object\" and has(\"german\")) then .task|=sub(\"tbd-\"; \"premium-\") else . end )"
    ],
    "utterance": "Replace the prefix 'tbd-' with 'premium-' in any task value if the object contains a 'german' property and the task value starts with 'tbd-'.",
    "expressions": [
      "walk( if type==\"object\" and .task and (.task|startswith(\"tbd-\")) and any(.[]; type==\"object\" and has(\"german\")) then .task|=sub(\"tbd-\"; \"premium-\") else . end )",
      "def walk(f): . as $in | if type == \"object\" then reduce keys[] as $key ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f elif type == \"array\" then map( walk(f) ) | f else f end; walk( if type==\"object\" and .task and (.task|startswith(\"tbd-\")) and any(.[]; type==\"object\" and has(\"german\")) then .task|=sub(\"tbd-\"; \"premium-\") else . end )"
    ],
    "data": [
      {
        "input": {
          "vehicle": {
            "maintenance": [
              {
                "parts": "wheel",
                "size": [
                  "one",
                  "two"
                ]
              },
              {
                "task": "tbd-service-oil",
                "car": {
                  "german": {
                    "audi": [
                      "Synthetic"
                    ]
                  }
                },
                "some": [
                  "other"
                ]
              },
              {
                "task": "service-oil",
                "honda": {
                  "japan": {
                    "oil": [
                      "regular"
                    ]
                  }
                }
              }
            ],
            "repair": [
              {
                "parts": "wheel",
                "size": [
                  "one",
                  "two"
                ]
              },
              {
                "task": "tbd-engine-repair",
                "car": {
                  "german": {
                    "engine": [
                      "6-cyl"
                    ]
                  }
                }
              },
              {
                "task": "engine-repair",
                "car": {
                  "german": {
                    "engine": [
                      "4-cyl"
                    ]
                  }
                }
              }
            ]
          }
        },
        "output": {
          "vehicle": {
            "maintenance": [
              {
                "parts": "wheel",
                "size": [
                  "one",
                  "two"
                ]
              },
              {
                "task": "premium-service-oil",
                "car": {
                  "german": {
                    "audi": [
                      "Synthetic"
                    ]
                  }
                },
                "some": [
                  "other"
                ]
              },
              {
                "task": "service-oil",
                "honda": {
                  "japan": {
                    "oil": [
                      "regular"
                    ]
                  }
                }
              }
            ],
            "repair": [
              {
                "parts": "wheel",
                "size": [
                  "one",
                  "two"
                ]
              },
              {
                "task": "premium-engine-repair",
                "car": {
                  "german": {
                    "engine": [
                      "6-cyl"
                    ]
                  }
                }
              },
              {
                "task": "engine-repair",
                "car": {
                  "german": {
                    "engine": [
                      "4-cyl"
                    ]
                  }
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 64144681
  },
  {
    "context": [
      "Sort an array of objects within an array by most recent timestamp, and then sort the outer array by each array's first object's timestamp, using `jq`.",
      "jq '.[] |= sort_by(.created_at) | sort_by(.[].created_at)'"
    ],
    "utterance": "Sort each inner array of objects by their 'created_at' field ascending, then sort the outer array by the earliest 'created_at' value in each inner array.",
    "expressions": [
      ".[] |= sort_by(.created_at) | sort_by(.[].created_at)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "created_at": "2020-09-26T14:48:46.000Z",
              "conversation_id": "1309867515456237571",
              "id": "1309867515456237571",
              "text": "example1"
            }
          ],
          [
            {
              "created_at": "2020-09-26T14:48:47.000Z",
              "conversation_id": "1309867518455156736",
              "id": "1309867518455156736",
              "text": "example2"
            },
            {
              "created_at": "2020-09-26T14:48:47.000Z",
              "conversation_id": "1309867518455156736",
              "id": "1309867517846810625",
              "text": "example3"
            },
            {
              "created_at": "2020-09-26T14:48:46.000Z",
              "conversation_id": "1309867518455156736",
              "id": "1309867516659937284",
              "text": "example4"
            }
          ],
          [
            {
              "created_at": "2020-09-26T14:48:48.000Z",
              "conversation_id": "1309867524473999364",
              "id": "1309867524473999364",
              "text": "example5"
            },
            {
              "created_at": "2020-09-26T14:48:47.000Z",
              "conversation_id": "1309867524473999364",
              "id": "1309867520468291586",
              "text": "example6"
            },
            {
              "created_at": "2020-09-26T14:48:47.000Z",
              "conversation_id": "1309867524473999364",
              "id": "1309867520153845760",
              "text": "example7"
            }
          ],
          [
            {
              "created_at": "2020-09-26T14:48:48.000Z",
              "conversation_id": "1309867524750749705",
              "id": "1309867524750749705",
              "text": "example8"
            }
          ]
        ]
      }
    ],
    "identifier": 64080087
  },
  {
    "context": [
      "How can I write the array to a json file?",
      "The json file should contain the following:",
      "{\r\n  \"testkey\": \"testvalue\",\r\n  \"testkey1\": \"testvalue1\",\r\n  \"testkey2\": \"testvalue2\"\r\n}",
      "jq -n '\r\n    $ARGS.positional|\r\n    . as $a|\r\n    (length/2) as $l|\r\n    [range($l)|{key:$a[.],value:$a[.+$l]}]|\r\n    from_entries' --args \"${!myarray[@]}\" \"${myarray[@]}\"",
      "for key in \"${!myarray[@]}\"; do \r\n    printf \"%s\\0%s\\0\" \"$key\" \"${myarray[$key]}\"\r\ndone | \r\njq -sR '\r\n    split(\"\\u0000\")|\r\n    . as $elements|\r\n    [range(length/2)|{key:$elements[2*.],value:$elements[2*.+1]}]|\r\n    from_entries'"
    ],
    "utterance": "Convert a shell associative array to a file where each key-value pair appears as an object property.",
    "expressions": [
      "jq -n '\n    $ARGS.positional|\n    . as $a|\n    (length/2) as $l|\n    [range($l)|{key:$a[.],value:$a[.+$l]}]|\n    from_entries' --args \"${!myarray[@]}\" \"${myarray[@]}\"",
      "for key in \"${!myarray[@]}\"; do \n    printf \"%s\\0%s\\0\" \"$key\" \"${myarray[$key]}\"\ndone | \njq -sR '\n    split(\"\\u0000\")|\n    . as $elements|\n    [range(length/2)|{key:$elements[2*.],value:$elements[2*.+1]}]|\n    from_entries'"
    ],
    "data": [
      {
        "input": {
          "myarray": {
            "testkey": "testvalue",
            "testkey1": "testvalue1",
            "testkey2": "testvalue2"
          }
        },
        "output": {
          "testkey": "testvalue",
          "testkey1": "testvalue1",
          "testkey2": "testvalue2"
        }
      }
    ],
    "identifier": 64594378
  },
  {
    "context": [
      "I have this JSON : ...",
      "And I would like to display something like this :\r\n\r\n    {\r\n      \"resourceName\": \"user_1\",\r\n      \"etag\": \"etag_value_1\",\r\n      \"value\": \"email_1\"\r\n    }",
      "I'm playing with something like this but does not work :\r\n\r\n    jq '.connections[].emailAddresses[] | {.resourceName, .etag, .value}' test.json",
      "Your path expression is wrong, the fields `resourceName` and `etag` are present in the top level path inside array of `connections`, and the `value` field is inside the `emailAddresses` array.",
      "Since you are forming an object, wrap the fields over `{..}`",
      ".connections[] | { resourceName, etag } + ( .emailAddresses[] | { value } )"
    ],
    "utterance": "Select resourceName and etag from each connection, and value from each of its emailAddresses, producing one object per email address with all three fields.",
    "expressions": [
      ".connections[] | { resourceName, etag } + ( .emailAddresses[] | { value } )"
    ],
    "data": [
      {
        "input": {
          "connections": [
            {
              "resourceName": "user_1",
              "etag": "etag_value_1",
              "emailAddresses": [
                {
                  "metadata": {
                    "primary": true,
                    "source": {
                      "type": "CONTACT",
                      "id": "id_1"
                    }
                  },
                  "value": "email_1",
                  "type": "home"
                }
              ]
            },
            {
              "resourceName": "user_2",
              "etag": "etag_value_2",
              "emailAddresses": [
                {
                  "metadata": {
                    "primary": true,
                    "source": {
                      "type": "CONTACT",
                      "id": "id_2"
                    }
                  },
                  "value": "email_2",
                  "type": "home"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "resourceName": "user_1",
            "etag": "etag_value_1",
            "value": "email_1"
          },
          {
            "resourceName": "user_2",
            "etag": "etag_value_2",
            "value": "email_2"
          }
        ]
      }
    ],
    "identifier": 64141379
  },
  {
    "context": [
      "I am trying to extract the value for something|something key in my below JSON but getting a compile error",
      "The filter `.properties | .something|something` is giving me below error when I try it in [Jqplay.org][1].",
      "You need to surround `something|something` with quotes in order to escape the pipe character:",
      ".properties.\"something|something\""
    ],
    "utterance": "Extract the value of the 'something|something' key under properties.",
    "expressions": [
      ".properties[\"something|something\"]",
      ".properties.\"something|something\""
    ],
    "data": [
      {
        "input": {
          "properties": {
            "Anything": "ABCD",
            "something|something": "unknown"
          }
        },
        "output": "unknown"
      }
    ],
    "identifier": 64093421
  },
  {
    "context": [
      "jq often has `|` (pipe) characters and, that could potentially let users run non-jq commands. e.g.:",
      "`jq . | rm file.txt`",
      "How do I safely let users run this?",
      "this question isn't about piping commands together. It is about how to safely execute a jq command that has pipes in it.",
      "You can use io.Pipe() which basically creates a synchronous in-memory pipe and it can be used to connect code expecting an io.Reader with code expecting an io.Writer.",
      "c1 := exec.Command(\"cat\", \"/home/fruits.json\")",
      "c2 := exec.Command(\"jq\", \".fruits[0:2]\")",
      "c1.Stdout = w",
      "c2.Stdin = r"
    ],
    "utterance": "Allow users to run a filter with the | operator safely without allowing arbitrary shell commands, extracting the first two elements from the fruits array.",
    "expressions": [
      ".fruits[0:2]"
    ],
    "data": [
      {
        "input": {
          "fruits": [
            "apples",
            "oranges",
            "pears"
          ]
        },
        "output": [
          "apples",
          "oranges"
        ]
      }
    ],
    "identifier": 64300498
  },
  {
    "context": [
      "I have a JSON file with two arrays. I'd like to combine the arrays into a single array of objects, each of which contains an element from each of the original arrays.",
      "Desired output:\n[\n  { \"en\":\"E1\", \"fr\":\"F1\"},\n  { \"en\":\"E2\", \"fr\":\"F2\"},\n  { \"en\":\"E3\", \"fr\":\"F3\"},\n  { \"en\":\"E4\", \"fr\":\"F4\"}\n]",
      "I used range() to iterate over the elements of the arrays:\n\n    jq '[range(.en|length) as $i | {en: .en[$i], fr: .fr[$i]}]' file.json",
      "You could also use `transpose` to \"zip\" the arrays together:\n\n    [[.en,.fr] | transpose[] | {en:.[0], fr:.[1]} ]",
      "Here's a solution that will work with arbitrarily many keys and that does not require knowledge of the key names beforehand:\n```\ndef objectify($keys):\n  [$keys, .] | transpose | map({(.[0]): .[1]}) | add;\n\nkeys_unsorted as $keys\n| [[.[]] | transpose[] | objectify($keys)]\n```"
    ],
    "utterance": "Combine two arrays with keys 'en' and 'fr' into an array of objects where each object pairs the i-th elements from both arrays under their respective keys.",
    "expressions": [
      "[range(.en|length) as $i | {en: .en[$i], fr: .fr[$i]}]",
      "[[.en,.fr] | transpose[] | {en:.[0], fr:.[1]} ]",
      "def objectify($keys):\n  [$keys, .] | transpose | map({(.[0]): .[1]}) | add;\n\nkeys_unsorted as $keys\n| [[.[]] | transpose[] | objectify($keys)]"
    ],
    "data": [
      {
        "input": {
          "en": [
            "E1",
            "E2",
            "E3",
            "E4"
          ],
          "fr": [
            "F1",
            "F2",
            "F3",
            "F4"
          ]
        },
        "output": [
          {
            "en": "E1",
            "fr": "F1"
          },
          {
            "en": "E2",
            "fr": "F2"
          },
          {
            "en": "E3",
            "fr": "F3"
          },
          {
            "en": "E4",
            "fr": "F4"
          }
        ]
      }
    ],
    "identifier": 64210344
  },
  {
    "context": [
      "What I want to do is extract the urls nested in the constraint.value fields for the always_use_https actions.",
      "The goal is to extract the values and return them as a json array.",
      "jq '[                                       \n        [\n                [\n                        [\n                                .[] | .[] | select(.actions[].id | contains(\"always_use_https\"))\n                        ] | .[].targets[] | select(.target | contains(\"url\"))\n                ] | .[] | .constraint | select(.operator | contains(\"matches\"))\n        ] | .[].value \n]'",
      "jq '.[\"example.org\"]\n    | map(select( any(.actions[]; .id == \"always_use_https\"))\n          | .targets[]\n          | select(.target == \"url\")\n          | .constraint.value )\n' cloudfare.json"
    ],
    "utterance": "Extract the values from constraint.value where an action has id equal to always_use_https, and return them as an array.",
    "expressions": [
      ".[\"example.org\"] | map(select(any(.actions[]; .id == \"always_use_https\")) | .targets[] | select(.target == \"url\") | .constraint.value)"
    ],
    "data": [
      {
        "input": {
          "example.org": [
            {
              "id": "341",
              "targets": [
                {
                  "target": "url",
                  "constraint": {
                    "operator": "matches",
                    "value": "http://ng.example.org/*"
                  }
                }
              ],
              "actions": [
                {
                  "id": "always_use_https"
                }
              ],
              "priority": 12,
              "status": "active",
              "created_on": "2017-11-29T18:07:36.000000Z",
              "modified_on": "2020-09-02T16:09:03.000000Z"
            },
            {
              "id": "406",
              "targets": [
                {
                  "target": "url",
                  "constraint": {
                    "operator": "matches",
                    "value": "http://nz.example.org/*"
                  }
                }
              ],
              "actions": [
                {
                  "id": "always_use_https"
                }
              ],
              "priority": 9,
              "status": "active",
              "created_on": "2017-11-29T18:07:55.000000Z",
              "modified_on": "2020-09-02T16:09:03.000000Z"
            },
            {
              "id": "427",
              "targets": [
                {
                  "target": "url",
                  "constraint": {
                    "operator": "matches",
                    "value": "nz.example.org/*"
                  }
                }
              ],
              "actions": [
                {
                  "id": "ssl",
                  "value": "flexible"
                }
              ],
              "priority": 8,
              "status": "active",
              "created_on": "2017-11-29T18:08:00.000000Z",
              "modified_on": "2020-09-02T16:09:03.000000Z"
            }
          ]
        },
        "output": [
          "http://ng.example.org/*",
          "http://nz.example.org/*"
        ]
      }
    ],
    "identifier": 64056168
  },
  {
    "context": [
      "The problem is that I don\u2019t want the nodes in V2 that don\u2019t exist in V1 to appear in the result.",
      "$a | .Parameters | keys_unsorted as $whitelist \n | $b | .Parameters | with_entries( select(.key | IN($whitelist[])) ) as $update\n | $a | .Parameters += $update",
      "input.Parameters as $dict\n   | input\n   | .Parameters |= reduce keys_unsorted[] as $k (.;\n       if ($dict|has($k)) then .[$k] = $dict[$k] else . end)",
      ".Parameters |= (. + commonKeys($dict))"
    ],
    "utterance": "Override the values of an object's nested keys with values from another object, but only for keys that already exist in the first object; exclude keys that exist only in the second object.",
    "expressions": [
      "$a | .Parameters | keys_unsorted as $whitelist | $b | .Parameters | with_entries( select(.key | IN($whitelist[])) ) as $update | $a | .Parameters += $update",
      "input.Parameters as $dict | input | .Parameters |= reduce keys_unsorted[] as $k (.; if ($dict|has($k)) then .[$k] = $dict[$k] else . end)",
      "def commonKeys($o2): keys_unsorted as $k1 | ($o2|keys_unsorted) as $k2 | [($k1 - ($k1-$k2))[] | {(.): $o2[.]}] | add; input.Parameters as $dict | input | .Parameters |= (. + commonKeys($dict))"
    ],
    "data": [
      {
        "input": [
          {
            "Parameters": {
              "a": "value-of-a",
              "b": "value-of-b"
            }
          },
          {
            "Parameters": {
              "a": "new-value-of-a",
              "c": "value-of-c"
            }
          }
        ],
        "output": {
          "Parameters": {
            "a": "new-value-of-a",
            "b": "value-of-b"
          }
        }
      }
    ],
    "identifier": 64052172
  },
  {
    "context": [
      "Is it possible to display something like this: (using jq)\n\nauthor=tomek\ntitle=helloworld\ntest=sampletextonetwothree",
      "cat response.json | jq -r 'to_entries | map([.key, .value]) | .[] | join(\"=\")'",
      "jq 'to_entries[] | \"\\(.key)=\\(.value)\"'",
      "jq -r 'to_entries[] | .key + \"=\" + .value'"
    ],
    "utterance": "List all key-value pairs as lines in the format key=value for every field in the object.",
    "expressions": [
      "to_entries[] | \"\\(.key)=\\(.value)\"",
      "to_entries[] | .key + \"=\" + .value",
      "to_entries | map([.key, .value]) | .[] | join(\"=\")"
    ],
    "data": [
      {
        "input": {
          "author": "tomek",
          "title": "helloworld",
          "test": "sampletextonetwothree"
        },
        "output": [
          "author=tomek",
          "title=helloworld",
          "test=sampletextonetwothree"
        ]
      }
    ],
    "identifier": 64140869
  },
  {
    "context": [
      "I have json file with multiple object Id's and I need a query that excludes different ids based on naming conventions. These are essentially OR's.",
      "cat file.json | jq '.interface[] | select(.description | contains (\"VLL\") | not )'",
      ".interface[]\n| select(.description | test (\"VLL|2002089|otherstuff\" ) | not )",
      "[\"VLL\",\"2002089\",\"otherstuff\"] as $blacklist\n| .interface[]\n| select(.description | IN($blacklist[]) | not)"
    ],
    "utterance": "Exclude objects whose description field contains any of the substrings VLL, 2002089, or otherstuff.",
    "expressions": [
      ".interface[] | select(.description | test(\"VLL|2002089|otherstuff\") | not)",
      "[\"VLL\",\"2002089\",\"otherstuff\"] as $blacklist | .interface[] | select(.description | IN($blacklist[]) | not)"
    ],
    "identifier": 64001535
  },
  {
    "context": [
      "I want to keep the whole array but add/update the first element having the result like\n[{\"keyA\": \"value\", \"newkey\": \"newvalue\"}, {\"keyA\": \"otherValue\"}...]",
      "How do I get the full array input set and with the first element updated?",
      "You need to use an [update operator](https://stedolan.github.io/jq/manual/#Arithmeticupdate-assignment:+=,-=,*=,/=,%=,//=) there to retain the original structure and contents. For example:\n\n.[0] += { newkey: \"newvalue\" }\n"
    ],
    "utterance": "Update the first element of an array by adding or setting a newkey with value newvalue, while keeping the rest of the array unchanged.",
    "expressions": [
      ".[0] += { newkey: \"newvalue\" }"
    ],
    "data": [
      {
        "input": [
          {
            "keyA": "value"
          },
          {
            "keyA": "otherValue"
          }
        ],
        "output": [
          {
            "keyA": "value",
            "newkey": "newvalue"
          },
          {
            "keyA": "otherValue"
          }
        ]
      }
    ],
    "identifier": 64510180
  },
  {
    "context": [
      "I return a few json values from an API feed using this command:",
      ".[] | {id: .id, content: .content, assignee: .assignee.name}",
      "I'm trying to replace commas within the command, and not even sure what terminology to search for.",
      "Ideally I'd use something like this:",
      "jq -cr  '.[ ] | {id: .id, content: *** BEGIN DO SOMETHING .content END DO SOMETHING***, assignee: .assignee.name}'",
      "Found my answer elsewhere:",
      "jq -cr  '.[] | {id: .id, content: .content | sub(\",\"; \"\"), assignee: .assignee.name} '",
      "Yes you can use `gsub/2`.",
      ". | gsub(\",\";\"\")"
    ],
    "utterance": "Replace all commas in the content field with an empty string when selecting id, content, and assignee name from each object in the array.",
    "expressions": [
      ".[] | {id: .id, content: .content | sub(\",\"; \"\"), assignee: .assignee.name}",
      ".[] | {id: .id, content: .content | gsub(\",\"; \"\"), assignee: .assignee.name}"
    ],
    "identifier": 64215674
  },
  {
    "context": [
      "my output should replace default value only if key is refreshInterval",
      "jq '.\"refreshInterval\".\"default\"=40000' plugin.json",
      "The `jq` command you've posted [should work just fine](https://jqplay.org/s/TJpYM4bu41), but it doesn't update the file, it just outputs the updated result.",
      "jq '.refreshInterval.default = 40000' plugin.json > jq_output"
    ],
    "utterance": "Replace the value of the default property to 40000 only for the object whose key is refreshInterval.",
    "expressions": [
      ".refreshInterval.default = 40000"
    ],
    "data": [
      {
        "input": {
          "doubleClickDiff": {
            "type": "boolean",
            "title": "Show diff on double click",
            "description": "If true, doubling clicking a file in the list of changed files will open a diff.",
            "default": false
          },
          "historyCount": {
            "type": "integer",
            "title": "History count",
            "description": "Number of (most recent) commits shown in the history log",
            "default": 25
          },
          "refreshInterval": {
            "type": "integer",
            "title": "Refresh interval",
            "description": "Number of milliseconds between polling the file system for changes.",
            "default": 10000
          },
          "simpleStaging": {
            "type": "boolean",
            "title": "Simple staging flag",
            "description": "If true, use a simplified concept of staging. Only files with changes are shown (instead of showing staged/changed/untracked), and all files with changes will be automatically staged",
            "default": false
          }
        },
        "output": {
          "doubleClickDiff": {
            "type": "boolean",
            "title": "Show diff on double click",
            "description": "If true, doubling clicking a file in the list of changed files will open a diff.",
            "default": false
          },
          "historyCount": {
            "type": "integer",
            "title": "History count",
            "description": "Number of (most recent) commits shown in the history log",
            "default": 25
          },
          "refreshInterval": {
            "type": "integer",
            "title": "Refresh interval",
            "description": "Number of milliseconds between polling the file system for changes.",
            "default": 40000
          },
          "simpleStaging": {
            "type": "boolean",
            "title": "Simple staging flag",
            "description": "If true, use a simplified concept of staging. Only files with changes are shown (instead of showing staged/changed/untracked), and all files with changes will be automatically staged",
            "default": false
          }
        }
      }
    ],
    "identifier": 63993045
  },
  {
    "context": [
      "I am trying to out all the data from my json file that matches the value \"data10=true\" it does that but only grabs the names, how can i make it so it will output everything in my json file with anything that matches the \"data10=true\"?",
      "jq 'to_entries | map(select(.value.data10==\"true\")) | from_entries' data.json",
      "input ***data.json***,\nwith **false** value:\n{\n  \"FOO\": {\n    \"data10\": \"false\",\n    \"name\": \"Donald\",\n    \"location\": \"Stockholm\"\n  },\n  \"BAR\": {\n    \"data10\": \"true\",\n    \"name\": \"Walt\",\n    \"location\": \"Stockholm\"\n  },\n  \"BAZ\": {\n    \"data10\": \"true\",\n    \"name\": \"Jack\",\n    \"location\": \"Whereever\"\n  }\n}",
      "output:\n{\n  \"BAR\": {\n    \"data10\": \"true\",\n    \"name\": \"Walt\",\n    \"location\": \"Stockholm\"\n  },\n  \"BAZ\": {\n    \"data10\": \"true\",\n    \"name\": \"Jack\",\n    \"location\": \"Whereever\"\n  }\n}"
    ],
    "utterance": "Return all objects whose data10 property equals \"true\", including all their keys and values.",
    "expressions": [
      "to_entries | map(select(.value.data10==\"true\")) | from_entries"
    ],
    "data": [
      {
        "input": {
          "FOO": {
            "data10": "false",
            "name": "Donald",
            "location": "Stockholm"
          },
          "BAR": {
            "data10": "true",
            "name": "Walt",
            "location": "Stockholm"
          },
          "BAZ": {
            "data10": "true",
            "name": "Jack",
            "location": "Whereever"
          }
        },
        "output": {
          "BAR": {
            "data10": "true",
            "name": "Walt",
            "location": "Stockholm"
          },
          "BAZ": {
            "data10": "true",
            "name": "Jack",
            "location": "Whereever"
          }
        }
      }
    ],
    "identifier": 64229569
  },
  {
    "context": [
      "legendary list-installed --json | jq '.[].title' | head -n 1 | sed s/\"\\\"\"/\"\"/g | wc -w",
      "The expected output should be something like this:\n<button onclick=app name e.g. Coley> The Escapist 2 </button>",
      "legendary list-installed --json | jq '.[].title'",
      "++ legendary list-installed --json",
      "++ jq 'map(if .title == \"{}\" then .app_name elif .title == \"_\" then \"_\" else \"_\" end)'"
    ],
    "utterance": "Select all top-level objects and return the value of the title field for each.",
    "expressions": [
      ".[].title"
    ],
    "identifier": 64410325
  },
  {
    "context": [
      "I want to convert the above output in a more \"human\" readable form without omitting any of the returned info. I tried using the --output table option for AWS CLI but it is including a lot of spaces in between the columns and rows.",
      "I tried using jq to convert it into a table or .tsv of some sort using map, but with no luck as I am a total beginner in JQ.",
      "If someone has any ideas on how to approach this - any help would be appreciated.",
      "The following produces a table with nested subtables in accorance with my understanding of the basic requirements.",
      "json2tree | @tsv"
    ],
    "utterance": "Format the findings as a tabular or TSV output, including all information, for easier human reading.",
    "expressions": [
      "json2tree | @tsv"
    ],
    "data": [
      {
        "input": {
          "imageScanFindings": {
            "findings": [
              {
                "name": "CVE-2018-12886",
                "description": "stack_protect_prologue in cfgexpand.c and stack_protect_epilogue in function.c in GNU Compiler Collection (GCC) 4.1 through 8 (under certain circumstances) generate instruction sequences when targeting ARM targets that spill the address of the stack protector guard, which allows an attacker to bypass the protection of -fstack-protector, -fstack-protector-all, -fstack-protector-strong, and -fstack-protector-explicit against stack overflow by controlling what the stack canary is compared against.",
                "uri": "https://security-tracker.debian.org/tracker/CVE-2018-12886",
                "severity": "MEDIUM",
                "attributes": [
                  {
                    "key": "package_version",
                    "value": "8.3.0-6"
                  },
                  {
                    "key": "package_name",
                    "value": "gcc-8"
                  },
                  {
                    "key": "CVSS2_VECTOR",
                    "value": "AV:N/AC:M/Au:N/C:P/I:P/A:P"
                  },
                  {
                    "key": "CVSS2_SCORE",
                    "value": "6.8"
                  }
                ]
              },
              {
                "name": "CVE-2020-1751",
                "description": "An out-of-bounds write vulnerability was found in glibc before 2.31 when handling signal trampolines on PowerPC. Specifically, the backtrace function did not properly check the array bounds when storing the frame address, resulting in a denial of service or potential code execution. The highest threat from this vulnerability is to system availability.",
                "uri": "https://security-tracker.debian.org/tracker/CVE-2020-1751",
                "severity": "MEDIUM",
                "attributes": [
                  {
                    "key": "package_version",
                    "value": "2.28-10"
                  },
                  {
                    "key": "package_name",
                    "value": "glibc"
                  },
                  {
                    "key": "CVSS2_VECTOR",
                    "value": "AV:L/AC:M/Au:N/C:P/I:P/A:C"
                  },
                  {
                    "key": "CVSS2_SCORE",
                    "value": "5.9"
                  }
                ]
              }
            ],
            "imageScanCompletedAt": "2020-10-23T00:03:10+05:30",
            "vulnerabilitySourceUpdatedAt": "2020-10-22T16:21:44+05:30",
            "findingSeverityCounts": {
              "MEDIUM": 14,
              "INFORMATIONAL": 72,
              "LOW": 18,
              "UNDEFINED": 3
            }
          },
          "registryId": "12345678911",
          "repositoryName": "name-of-repo",
          "imageId": {
            "imageDigest": "sha256:1213412412412451241414214141412412",
            "imageTag": "latest"
          },
          "imageScanStatus": {
            "status": "COMPLETE",
            "description": "The scan was completed successfully."
          }
        }
      }
    ],
    "identifier": 64495891
  },
  {
    "context": [
      "watch 'curl localhost:8000/something | jq'",
      "which just returns \"(23) Failed writing body\" which is from `jq`. What does `jq` want here?",
      "This did it:\n\n    watch 'curl localhost:8000/something | jq .' "
    ],
    "utterance": "View all fields of the status response while using watch.",
    "expressions": [
      "jq ."
    ],
    "identifier": 64565122
  },
  {
    "context": [
      "I need to be able to pick the latest tagged image in a ECR repository which does not have the tag latest.",
      "The list may contain `latest` as one of the entries. I want to skip that entry and pick the first imageTag here which is not latest.",
      "aws ecr describe-images --repository-name <repo-name> --region us-east-1 --output text --query 'sort_by(imageDetails,& imagePushedAt)[*].imageTags[*]'",
      "The `imageTag` output here is \n\n    ajohn-feature-123\n    bgates-feature-345",
      "The list may contain `latest` as one of the entries. I want to skip that entry and pick the first imageTag here which is not latest."
    ],
    "utterance": "Return the most recently pushed image tag that is not 'latest'.",
    "expressions": [
      "sort_by(.imageDetails; .imagePushedAt) | reverse | map(.imageTags[] | select(. != \"latest\")) | .[0]"
    ],
    "data": [
      {
        "input": {
          "imageDetails": [
            {
              "imageDigest": "sha256:abc",
              "imageTags": [
                "latest"
              ],
              "imagePushedAt": 1700000000
            },
            {
              "imageDigest": "sha256:def",
              "imageTags": [
                "ajohn-feature-123"
              ],
              "imagePushedAt": 1700000100
            },
            {
              "imageDigest": "sha256:ghi",
              "imageTags": [
                "bgates-feature-345"
              ],
              "imagePushedAt": 1700000150
            }
          ]
        },
        "output": "bgates-feature-345"
      }
    ],
    "identifier": 64475175
  },
  {
    "context": [
      "I would like to print out only the files that are of `fileType` == `video` in the `files` array such that I end up with output that looks like so:\n\n```\n1234, \"http://.../b.mp4\"\n4321, \"http://.../d.mp4\"\n```",
      "The following pipeline makes the solution fairly self-explanatory, assuming one understands the basic syntax and the -r command-line option:\n```\n< input.json jq -r '\n  .[]\n  | .code as $code\n  | .files[]\n  | select(.fileType == \"video\")\n  | \"\\($code), \\\"\\(.url)\\\"\"\n'\n```\n"
    ],
    "utterance": "For each object, output the code and the url of each file with fileType equal to video, formatted as code, \"url\".",
    "expressions": [
      ".[] | .code as $code | .files[] | select(.fileType == \"video\") | \"\u0000($code), \\\"\u0000(.url)\\\"\""
    ],
    "data": [
      {
        "input": [
          {
            "code": "1234",
            "files": [
              {
                "fileType": "pdf",
                "url": "http://.../a.pdf"
              },
              {
                "fileType": "video",
                "url": "http://.../b.mp4"
              }
            ]
          },
          {
            "code": "4321",
            "files": [
              {
                "fileType": "pdf",
                "url": "http://.../c.pdf"
              },
              {
                "fileType": "video",
                "url": "http://.../d.mp4"
              }
            ]
          },
          {
            "code": "9999",
            "files": [
              {
                "fileType": "pdf",
                "url": "http://.../e.pdf"
              }
            ]
          }
        ],
        "output": [
          "1234, \"http://.../b.mp4\"",
          "4321, \"http://.../d.mp4\""
        ]
      }
    ],
    "identifier": 64289911
  },
  {
    "context": [
      "I also tried `| jq -r '.ChangeInfo.Id'` but the `,` is still being appended to `ID`",
      "ID=$(aws route53 change-resource-record-sets ... --query 'ChangeInfo.Id' --output text)"
    ],
    "utterance": "Extract the value of the ChangeInfo.Id field from the command output without any trailing comma or quotes.",
    "expressions": [
      ".ChangeInfo.Id",
      ".ChangeInfo.Id | rtrimstr(\",\")"
    ],
    "data": [
      {
        "input": {
          "ChangeInfo": {
            "Id": "/change/XXX,",
            "Status": "PENDING"
          }
        },
        "output": "/change/XXX"
      }
    ],
    "identifier": 64387238
  },
  {
    "context": [
      "What I want to get an object which contains: id, fullName, emaila, team and role. I can do it but only when user belongs to one team. If user belongs to more than one team - I can't handle it.",
      "My goal is:\n\n{\n  \"id\": \"user1\",\n  \"fullName\": \"User One\",\n  \"email\": \"user.one@my.mail.com\",\n  \"team\": \"Team_A,\n  \"role\": \"TEAM_MEMBER\"\n},\n{\n  \"id\": \"user1\",\n  \"fullName\": \"User One\",\n  \"email\": \"user.one@my.mail.com\",\n  \"team\": \"Team_B\",\n  \"role\": \"TEAM_ADMIN\"\n},\n{\n  \"id\": \"user2\",\n  \"fullName\": \"User Two\",\n  \"email\": \"user.two@my.mail.com\",\n  \"team\": \"Team_B\",\n  \"role\": \"TEAM_ADMIN\"\n}\n",
      "Here's another more concise solution, assuming there will only be one \"user info\" per id.\n\n```sh\n# group by id\ngroup_by(.id) | map(\n    # for each group, partition by \"type\"\n    group_by(.fullName)\n\n      # create combinations of all the info and team objects and merge them\n      | combinations | add\n)\n```",
      "[group_by(.id)[]\n | [map(select(has(\"team\")|not)), map(select(has(\"team\")))]\n | combinations\n | add]"
    ],
    "utterance": "Produce a list where for each user-team assignment, each object includes that user's 'id', 'fullName', 'email', corresponding 'team', and 'role'.",
    "expressions": [
      "group_by(.id) | map(\n    group_by(.fullName)\n        | combinations | add\n)",
      "[group_by(.id)[]\n | [map(select(has(\"team\")|not)), map(select(has(\"team\")))]\n | combinations\n | add]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "user1",
            "fullName": "User One",
            "email": "user.one@my.mail.com"
          },
          {
            "id": "user2",
            "fullName": "User Two",
            "email": "user.two@my.mail.com"
          },
          {
            "id": "user1",
            "team": "Team_A",
            "role": "TEAM_MEMBER"
          },
          {
            "id": "user1",
            "team": "Team_B",
            "role": "TEAM_ADMIN"
          },
          {
            "id": "user2",
            "team": "Team_B",
            "role": "TEAM_ADMIN"
          }
        ],
        "output": [
          {
            "id": "user1",
            "fullName": "User One",
            "email": "user.one@my.mail.com",
            "team": "Team_A",
            "role": "TEAM_MEMBER"
          },
          {
            "id": "user1",
            "fullName": "User One",
            "email": "user.one@my.mail.com",
            "team": "Team_B",
            "role": "TEAM_ADMIN"
          },
          {
            "id": "user2",
            "fullName": "User Two",
            "email": "user.two@my.mail.com",
            "team": "Team_B",
            "role": "TEAM_ADMIN"
          }
        ]
      }
    ],
    "identifier": 64114407
  }
]