[
  {
    "context": [
      "input:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;title&quot;: &quot;Hello&quot;\r\n      }\r\n    ]\r\n\r\noutput:\r\n\r\n    {&quot;name&quot;: &quot;John&quot;,&quot;title&quot;: &quot;Hello&quot;}",
      "$ jq -c first <<<'[ { \"name\": \"John\", \"title\": \"Hello\" } ]'\r\n    {\"name\":\"John\",\"title\":\"Hello\"}"
    ],
    "utterance": "Extract the first object from an array where the first object has name \"John\" and title \"Hello\".",
    "expressions": [
      "first"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "title": "Hello"
          }
        ],
        "output": {
          "name": "John",
          "title": "Hello"
        }
      }
    ],
    "identifier": 62143216
  },
  {
    "context": [
      "If I want to use a shell script to change the parameter of `X_serial` by the original number +1 which is 77 in this example.",
      "Use [tag:jq] instead, for example:",
      "`$ jq '.LINE.X_serial |= \"\\(tonumber + 1)\"' 123.json`",
      "This simply updates `.LINE.X_serial` by converting its value to a number, increasing the result by one, and converting it back to a string."
    ],
    "utterance": "Increment the value of LINE.X_serial by 1 and update it as a string",
    "expressions": [
      ".LINE.X_serial |= \"\\(tonumber + 1)\""
    ],
    "data": [
      {
        "input": {
          "LINE": {
            "A_serial": "1234",
            "B_serial": "2345",
            "C_serial": "3456",
            "X_serial": "76"
          }
        },
        "output": {
          "LINE": {
            "A_serial": "1234",
            "B_serial": "2345",
            "C_serial": "3456",
            "X_serial": "77"
          }
        }
      }
    ],
    "identifier": 62144640
  },
  {
    "context": [
      "By default `jq` provides a function `input_filename` which prints the filename being processed currently.",
      "jq ' { filename: input_filename, content: . } ' **/*.json",
      "To have a comma between the object entries, use the `-n` flag with `inputs` and put the entire result in an array `[..]`",
      "jq -n '[inputs | { filename: input_filename, content: . }]' **/*.json"
    ],
    "utterance": "Produce an array of objects, each containing the filename and its corresponding parsed content, for all files matching **/*.json in the directory tree.",
    "expressions": [
      "jq '{ filename: input_filename, content: . }' **/*.json",
      "jq -n '[inputs | { filename: input_filename, content: . }]' **/*.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": 123
          },
          {
            "b": 234
          },
          {
            "c": 456
          }
        ],
        "output": [
          {
            "filename": "a.json",
            "content": {
              "a": 123
            }
          },
          {
            "filename": "b.json",
            "content": {
              "b": 234
            }
          },
          {
            "filename": "foo/bar/base/c c.json",
            "content": {
              "c": 456
            }
          }
        ]
      }
    ],
    "identifier": 62156585
  },
  {
    "context": [
      "how to I replace all occurrences of `\"value\": 1234.56` with `\"value\": {\"$numberDecimal\":\"1234.56\"}`; that is, wrap the numbers.",
      "The following jq program will convert numbers to JSON objects of the form `{\"$numberDecimal\": <STRING>}`:",
      "walk(if type == \"number\" then {\"$numberDecimal\": tostring} else . end)"
    ],
    "utterance": "Wrap every number value in the structure as {\"$numberDecimal\": <string version of the number>}.",
    "expressions": [
      "walk(if type == \"number\" then {\"$numberDecimal\": tostring} else . end)"
    ],
    "data": [
      {
        "input": {
          "data": {
            "slice": [
              {
                "source": {
                  "id": "foo"
                },
                "value": 1.0
              },
              {
                "source": {
                  "id": "bar"
                },
                "value": 2.0
              }
            ]
          }
        },
        "output": {
          "data": {
            "slice": [
              {
                "source": {
                  "id": "foo"
                },
                "value": {
                  "$numberDecimal": "1"
                }
              },
              {
                "source": {
                  "id": "bar"
                },
                "value": {
                  "$numberDecimal": "2"
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 62164324
  },
  {
    "context": [
      "I always know the node **name** but not the **\"id\"**.",
      "\"What I really need to happen is if .name==\"node2\" then it gives me generatednodeid2\"",
      "In this situation, the \"to_entries\" family of filters is helpful, e.g.:",
      ".nodes | to_entries[] | select(.value.name == \"node2\") | .key"
    ],
    "utterance": "Find the key in the 'nodes' object whose 'name' value is 'node2'.",
    "expressions": [
      ".nodes | to_entries[] | select(.value.name == \"node2\") | .key"
    ],
    "data": [
      {
        "input": {
          "cluster_name": "cluster1",
          "nodes": {
            "generatednodeid1": {
              "name": "node01"
            },
            "generatednodeid2": {
              "name": "node2"
            }
          }
        },
        "output": "generatednodeid2"
      }
    ],
    "identifier": 62162599
  },
  {
    "context": [
      "I would like to use jq to turn this into a single array of objects based on the value of \"last\".  The desired output would be something like this:",
      "[{\"last\": \"Doe\"},{\"last\": \"Smith\"}]",
      "where only ***unique*** values of \"last\" that is a child of \"b\" are included.  In my case I don't care about any of the other fields.",
      "```\n[.. | select( (.b?|type) == \"array\")\n | .b[] | select(.last?).last ]\n| unique\n| map({last: .})\n```"
    ],
    "utterance": "Extract all unique 'last' values from objects inside any 'b' array and output them as objects with only the 'last' key.",
    "expressions": [
      "[.. | select( (.b?|type) == \"array\") | .b[] | select(.last?).last ] | unique | map({last: .})"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "last": "other",
              "b": [
                {
                  "first": "John",
                  "last": "Doe"
                }
              ]
            },
            {
              "last": "other",
              "b": [
                {
                  "first": "Jane",
                  "last": "Doe"
                }
              ]
            },
            {
              "last": "other",
              "b": [
                {
                  "first": "John",
                  "last": "Smith"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "last": "Doe"
          },
          {
            "last": "Smith"
          }
        ]
      }
    ],
    "identifier": 62161569
  },
  {
    "context": [
      "I can do `cat stripe-invoices-list.json | jq -C '. | {invoice_id: .data[].id,}'` and it returns:",
      "I try to add more data to the output but it then creates redundant and even incorrect output:",
      "`cat stripe-invoices-list.json | jq -C '. | {invoice_id: .data[].id, client: .data[].customer_name,}'`",
      "you're expanding `data` twice in the same object constructor, and it leads to a [combinatorial explosion](https://en.wikipedia.org/wiki/Combinatorial_explosion#Computing). Below is the correct way of doing it.",
      "```\n.data[] | {invoice_id: .id, client: .customer_name}\n```"
    ],
    "utterance": "Display for each invoice its id and customer_name fields as an object.",
    "expressions": [
      ".data[] | {invoice_id: .id, client: .customer_name}"
    ],
    "identifier": 62198965
  },
  {
    "context": [
      "but I want to add in every object - another one:\r\n```\r\n   {\r\n      \"thisMustBeInEveryarray\": \"thisone\"\r\n   }\r\n```\r\nBut like:\r\n[\r\n   {\r\n      \"name\":\"blablabla1\",\r\n      \"something\": \"blablabla\"\r\n      \"something2\": \"blablabla\"\r\n      \"thisMustBeInEveryarray\": \"thisone\"\r\n   },   \r\n   {\r\n      \"name\":\"blablabla2\",\r\n      \"something\": \"blablabla\"\r\n      \"something2\": \"blablabla\"\r\n      \"thisMustBeInEveryarray\": \"thisone\"\r\n   },   \r\n   {\r\n      \"name\":\"blablabla3\",\r\n      \"something\": \"blablabla\"\r\n      \"something2\": \"blablabla\"\r\n      \"thisMustBeInEveryarray\": \"thisone\"\r\n   }\r\n]",
      "Specify `mustbeinevery.json` as the first input so that you can refer to others by `inputs` keyword, and add them inside an array constructor.",
      "jq '[inputs+. ]' mustbeinevery.json firstone.json secondone.json thirdone.json"
    ],
    "utterance": "Add the object {\"thisMustBeInEveryarray\": \"thisone\"} to each of several other objects and output the results as an array.",
    "expressions": [
      "[inputs+. ]"
    ],
    "data": [
      {
        "input": [
          {
            "thisMustBeInEveryarray": "thisone"
          },
          {
            "name": "blablabla1",
            "something": "blablabla",
            "something2": "blablabla"
          },
          {
            "name": "blablabla2",
            "something": "blablabla",
            "something2": "blablabla"
          },
          {
            "name": "blablabla3",
            "something": "blablabla",
            "something2": "blablabla"
          }
        ],
        "output": [
          {
            "name": "blablabla1",
            "something": "blablabla",
            "something2": "blablabla",
            "thisMustBeInEveryarray": "thisone"
          },
          {
            "name": "blablabla2",
            "something": "blablabla",
            "something2": "blablabla",
            "thisMustBeInEveryarray": "thisone"
          },
          {
            "name": "blablabla3",
            "something": "blablabla",
            "something2": "blablabla",
            "thisMustBeInEveryarray": "thisone"
          }
        ]
      }
    ],
    "identifier": 62166196
  },
  {
    "context": [
      "I want to select all the entries where `publish=true` and create a simplified JSON array of objects like this:\n[\n  {\n    \"name\": \"x\"\n    \"groupName\": \"tom\"\n  },\n  {\n    \"name\": \"x\"\n    \"groupName\": \"joe\"\n  },\n  {\n    \"name\": \"y\"\n    \"groupName\": \"joe\"\n  }  \n]\n",
      "jq '.[]|map(\n      .name as $n\n      | .group[]\n      | select(.publish==true)\n      | {name:$n,groupname:.name}\n    )' file.json",
      "[inputs[][]\n | .name as $group\n | .group[]\n | select(.publish == true)\n | {name, groupName: $group}\n]",
      ".a | map({name, groupname: (.group[] | select(.publish) .name)})"
    ],
    "utterance": "Produce a flat array of objects containing the parent name and group name for each group entry with publish equal to true.",
    "expressions": [
      ".a | map(.name as $n | .group[] | select(.publish==true) | {name:$n,groupName:.name})",
      ".a | map(.name as $n | .group[] | select(.publish==true) | {name:$n,groupname:.name})",
      ".a | map({name, groupname: (.group[] | select(.publish) .name)})"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "name": "x",
              "group": [
                {
                  "name": "tom",
                  "publish": true
                },
                {
                  "name": "joe",
                  "publish": true
                }
              ]
            },
            {
              "name": "y",
              "group": [
                {
                  "name": "tom",
                  "publish": false
                },
                {
                  "name": "joe",
                  "publish": true
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "x",
            "groupName": "tom"
          },
          {
            "name": "x",
            "groupName": "joe"
          },
          {
            "name": "y",
            "groupName": "joe"
          }
        ]
      }
    ],
    "identifier": 62181671
  },
  {
    "context": [
      "I am using jq tools to merge 2 json files but there are some duplicate keys, and I would like for the duplicate keys to sum their values.",
      "Here are the files:",
      "file1:\n{\n  \"total\": {\n    \"seconds\": 1490\n  },\n  \"days\": {\n    \"2020-05-20\": {\n      \"seconds\": 1400\n    },\n    \"2020-05-19\": {\n      \"seconds\": 30\n    },\n    \"2020-05-18\": {\n      \"seconds\": 60\n    }\n  }\n}",
      "file2:\n{\n  \"total\": {\n    \"seconds\": 295\n  },\n  \"days\": {\n    \"2020-05-22\": {\n      \"seconds\": 120\n    },\n    \"2020-05-21\": {\n      \"seconds\": 80\n    },\n    \"2020-05-20\": {\n      \"seconds\": 95\n    }\n  }\n}",
      "Expected output:\n{\n  \"total\": {\n    \"seconds\": 1785\n  },\n  \"days\": {\n    \"2020-05-22\": {\n      \"seconds\": 120\n    },\n    \"2020-05-21\": {\n      \"seconds\": 80\n    },\n    \"2020-05-20\": {\n      \"seconds\": 1495\n    },\n    \"2020-05-19\": {\n      \"seconds\": 30\n    },\n    \"2020-05-18\": {\n      \"seconds\": 60\n    }\n  }\n}",
      "Below program works fine for your samples, but it won't work if the objects in your actual inputs have other keys with non-number values.\n```\njq '. as $in |\nreduce paths(numbers) as $p (input;\n  setpath($p; getpath($p) + ($in | getpath($p))\n)' file1 file2\n```",
      "jq -s '\n    reduce (paths(numbers) as $p | [$p[1:], getpath($p)]) as $i \n        ({}; setpath($i[0]; getpath($i[0]) + $i[1]))' file1 file2\n\nThis only considers leaf nodes which are numbers and produces a merged object with all numbers at similar paths summed up. It works for any number of files."
    ],
    "utterance": "Merge two files with overlapping keys and sum all numbers at matching paths, so that duplicate keys have their numeric values added together.",
    "expressions": [
      ". as $in |\nreduce paths(numbers) as $p (input; setpath($p; getpath($p) + ($in | getpath($p))))",
      "-s 'reduce (paths(numbers) as $p | [$p[1:], getpath($p)]) as $i ({}; setpath($i[0]; getpath($i[0]) + $i[1]))'"
    ],
    "data": [
      {
        "input": [
          {
            "total": {
              "seconds": 1490
            },
            "days": {
              "2020-05-20": {
                "seconds": 1400
              },
              "2020-05-19": {
                "seconds": 30
              },
              "2020-05-18": {
                "seconds": 60
              }
            }
          },
          {
            "total": {
              "seconds": 295
            },
            "days": {
              "2020-05-22": {
                "seconds": 120
              },
              "2020-05-21": {
                "seconds": 80
              },
              "2020-05-20": {
                "seconds": 95
              }
            }
          }
        ],
        "output": {
          "total": {
            "seconds": 1785
          },
          "days": {
            "2020-05-22": {
              "seconds": 120
            },
            "2020-05-21": {
              "seconds": 80
            },
            "2020-05-20": {
              "seconds": 1495
            },
            "2020-05-19": {
              "seconds": 30
            },
            "2020-05-18": {
              "seconds": 60
            }
          }
        }
      }
    ],
    "identifier": 62149662
  },
  {
    "context": [
      "What I expect is\n\n```\n863260\n42499\n```",
      "since `releases` is an array you need to do this:\n\n`curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent \"FooBarApp/3.0\" | jq .releases[].id`\n\nnotice the `[]` after `releases`\n",
      "`curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent \"FooBarApp/3.0\" | jq .releases[].id`"
    ],
    "utterance": "Extract the id values from each object in the releases array.",
    "expressions": [
      ".releases[].id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 863260,
            "status": "Accepted",
            "type": "release",
            "format": "12\", Single",
            "label": "EMI America",
            "title": "Get Up And Jump / Baby Appeal",
            "resource_url": "https://api.discogs.com/releases/863260",
            "role": "Main",
            "artist": "The Red Hot Chili Peppers*",
            "year": 1984,
            "thumb": "",
            "stats": {
              "community": {
                "in_wantlist": 138,
                "in_collection": 198
              }
            }
          },
          {
            "id": 42499,
            "title": "The Red Hot Chili Peppers",
            "type": "master",
            "main_release": 687880,
            "artist": "The Red Hot Chili Peppers*",
            "role": "Main",
            "resource_url": "https://api.discogs.com/masters/42499",
            "year": 1984,
            "thumb": "",
            "stats": {
              "community": {
                "in_wantlist": 1209,
                "in_collection": 995
              }
            }
          }
        ],
        "output": [
          863260,
          42499
        ]
      }
    ],
    "identifier": 62199772
  },
  {
    "context": [
      "I would like to transform:",
      "{\n  \"articles/guide-1/article-1.html\": {\n    \"href\": \"articles/guide-1/article-1.html\",\n    \"title\": \"Article 1\",\n    \"keywords\": \"keyword-a\"\n  },\n  \"articles/guide-2/article-1.html\": {\n    \"href\": \"articles/guide-2/article-1.html\",\n    \"title\": \"Article 1\",\n    \"keywords\": \"keyword-b\"\n  },\n  \"articles/guide-3/article-1.html\": {\n    \"href\": \"articles/guide-3/article-1.html\",\n    \"title\": \"Article 1\",\n    \"keywords\": \"keyword-c\"\n  }\n}",
      "into href,title:",
      "articles/guide-1/article-1.html,Article 1",
      "articles/guide-2/article-1.html,Article 1",
      "articles/guide-3/article-1.html,Article 1",
      ".[] works fine with string interpolation.",
      "$ jq -r '.[] | \"\\(.href),\\(.title)\"' file",
      "articles/guide-1/article-1.html,Article 1",
      "articles/guide-2/article-1.html,Article 1",
      "articles/guide-3/article-1.html,Article 1"
    ],
    "utterance": "Extract href and title fields from each object and output as lines in the format href,title.",
    "expressions": [
      ".[] | \"\\(.href),\\(.title)\""
    ],
    "data": [
      {
        "input": {
          "articles/guide-1/article-1.html": {
            "href": "articles/guide-1/article-1.html",
            "title": "Article 1",
            "keywords": "keyword-a"
          },
          "articles/guide-2/article-1.html": {
            "href": "articles/guide-2/article-1.html",
            "title": "Article 1",
            "keywords": "keyword-b"
          },
          "articles/guide-3/article-1.html": {
            "href": "articles/guide-3/article-1.html",
            "title": "Article 1",
            "keywords": "keyword-c"
          }
        },
        "output": [
          "articles/guide-1/article-1.html,Article 1",
          "articles/guide-2/article-1.html,Article 1",
          "articles/guide-3/article-1.html,Article 1"
        ]
      }
    ],
    "identifier": 62200045
  },
  {
    "context": [
      "jq --arg VAR \"$VAR\" '.+{VAR:$VAR}' my.json > my.tmp.json && mv my.tmp.json my.json",
      "config_add() {\n    local VAR=\"$1\"\n    local VALUE=\"$2\"\n    jq --arg VAR \"$VAR\" --arg VALUE \"$VALUE\" '.+{($VAR): $VALUE}' > my.json.tmp && my.json.tmp my.json \n}",
      "export x=xyzzy\njq -n --arg a x '{($a): $ENV[$a]}'\n{\n  \"x\": \"xyzzy\"\n}"
    ],
    "utterance": "Add a new key and value, where both are provided by shell variables, to a file.",
    "expressions": [
      "jq --arg VAR \"$VAR\" --arg VALUE \"$VALUE\" '.+{($VAR): $VALUE}' my.json",
      "jq -n --arg a x '{($a): $ENV[$a]}'"
    ],
    "identifier": 62215514
  },
  {
    "context": [
      "result = $(curl -s -X GET \"https://openexchangerates.org/api/latest.json?app_id=SOME_KEY\" | jq '.rates.GBP')",
      "result=$(curl -s -X GET \"https://openexchangerates.org/api/latest.json?app_id=SOME_KEY\" | jq '.rates.GBP')"
    ],
    "utterance": "Extract the value of the GBP field from the rates object.",
    "expressions": [
      ".rates.GBP"
    ],
    "identifier": 62200741
  },
  {
    "identifier": 62238735
  },
  {
    "context": [
      "My goal is to do a call with jq applied to return the following, given the example above (again lines and spaces added for readability, but only need to return valid JSON blob):",
      "To summarise, I am trying to automatically generate templated values that match the \"schema\" JSON shown above.",
      "So just to clarify, the values for \"name\" (including their surrounding double-quotes) are concatenated with either:",
      "- :1234567890 ...when the \"type\" for that object is \"int\"",
      "- \":xxxxxxxxxx\" ...when the \"type\" for that object is \"string\"",
      "- ...and when type is \"array\" or \"record\" the appropriate enclosures are added {} or [] with the nested content inside.",
      "- if its an array of records, generate TWO records for the output",
      "def sampleData:",
      "  takeFirstTypeFromArray |",
      "  if .type == \"int\" then",
      "    1234567890",
      "  elif .type == \"string\" then",
      "    \"xxxxxxxxxx\"",
      "  elif .type == \"array\" then   # generate two entries for any test array",
      "    [(.items | sampleData), (.items | sampleData)]",
      "  elif .type == \"record\" then",
      "    (.fields | map({(.name): sampleData}) | add)",
      "  elif (.type | type) == \"array\" then",
      "    (.type[] | sampleData)",
      "  elif (.type | type) == \"object\" then",
      "    (.type | sampleData)",
      "  else",
      "    [\"UNKNOWN\", .]",
      "  end;",
      "map({(.name): sampleData}) | add"
    ],
    "utterance": "Generate an example data object conforming to the provided schema, substituting integer fields with 1234567890, string fields with \"xxxxxxxxxx\", creating arrays with two default objects, and recursively handling nested arrays and records.",
    "expressions": [
      "def takeFirstTypeFromArray:\n  if (.type | type) == \"array\" then\n    .type = .type[0]\n  else\n    .\n  end;\n\ndef sampleData:\n  takeFirstTypeFromArray |\n  if .type == \"int\" then\n    1234567890\n  elif .type == \"string\" then\n    \"xxxxxxxxxx\"\n  elif .type == \"array\" then\n    [(.items | sampleData), (.items | sampleData)]\n  elif .type == \"record\" then\n    (.fields | map({(.name): sampleData}) | add)\n  elif (.type | type) == \"array\" then\n    (.type[] | sampleData)\n  elif (.type | type) == \"object\" then\n    (.type | sampleData)\n  else\n    [\"UNKNOWN\", .]\n  end;\n\nmap({(.name): sampleData}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "id",
            "type": "int"
          },
          {
            "name": "agents",
            "type": {
              "type": "array",
              "items": {
                "name": "carSalesAgents",
                "type": "record",
                "fields": [
                  {
                    "name": "agentName",
                    "type": [
                      "string",
                      "null"
                    ],
                    "default": null
                  },
                  {
                    "name": "agentEmail",
                    "type": [
                      "string",
                      "null"
                    ],
                    "default": null
                  },
                  {
                    "name": "agentPhones",
                    "type": {
                      "type": "array",
                      "items": {
                        "name": "SalesAgentPhone",
                        "type": "record",
                        "fields": [
                          {
                            "name": "phoneNumber",
                            "type": "string"
                          }
                        ]
                      }
                    },
                    "default": []
                  }
                ]
              }
            },
            "default": []
          },
          {
            "name": "description",
            "type": "string"
          }
        ],
        "output": {
          "id": 1234567890,
          "agents": [
            {
              "agentName": "xxxxxxxxxx",
              "agentEmail": "xxxxxxxxxx",
              "agentPhones": [
                {
                  "phoneNumber": "xxxxxxxxxx"
                },
                {
                  "phoneNumber": "xxxxxxxxxx"
                }
              ]
            },
            {
              "agentName": "xxxxxxxxxx",
              "agentEmail": "xxxxxxxxxx",
              "agentPhones": [
                {
                  "phoneNumber": "xxxxxxxxxx"
                },
                {
                  "phoneNumber": "xxxxxxxxxx"
                }
              ]
            }
          ],
          "description": "xxxxxxxxxx"
        }
      }
    ],
    "identifier": 62171545
  },
  {
    "context": [
      "Is it possible to somehow set the -R option within a jq script?",
      "No.",
      "jq -Rs '. as $in\n  | try fromjson \n    catch ($in | splits(\"\\n\") | split(\",\") | select(length>0))'",
      "< inputfile jq -n --rawfile raw inputfile '\n  def handleCSV: $raw | splits(\"\\n\") | split(\",\") | select(length>0);\n  try inputs catch handleCSV\n'"
    ],
    "utterance": "Process either CSV or JSON input using a script that automatically detects and handles the input type, without needing to pass -R as a command-line option.",
    "expressions": [
      ". as $in | try fromjson catch ($in | splits(\"\\n\") | split(\",\") | select(length>0))",
      "def handleCSV: $raw | splits(\"\\n\") | split(\",\") | select(length>0); try inputs catch handleCSV"
    ],
    "identifier": 62216552
  },
  {
    "context": [
      "echo '{\"foo\": \"0\"}' | jq 'select(.foo == \"0\")'",
      "'{\"foo\": \"0\"}\n{\"foo\": \"1\"}' | jq -c 'select(.foo == \\\"0\\\")'",
      "{ \"foo\": \"0\" }",
      "{ \"foo\": \"0\" }\n{ \"foo\": \"1\" }"
    ],
    "utterance": "Select all objects where the key foo has the string value 0",
    "expressions": [
      "select(.foo == \"0\")",
      "select(.foo == \\\"0\\\")"
    ],
    "data": [
      {
        "input": {
          "foo": "0"
        },
        "output": {
          "foo": "0"
        }
      },
      {
        "input": [
          {
            "foo": "0"
          },
          {
            "foo": "1"
          }
        ],
        "output": {
          "foo": "0"
        }
      }
    ],
    "identifier": 62238882
  },
  {
    "context": [
      "With JQ, i query the value of the \"track\" key from the selected track, and save it to the \"mediaFormat\" variable.",
      "mediaFormat=$(mediainfo \"$1\" --Output=JSON | jq \".media.track[$2].Format\");",
      "Maybe the only thing you miss is using the `--raw-output` option of `jq` like so:",
      "mediaFormat=$(mediainfo \"$1\" --Output=JSON | jq --raw-output \".media.track[$2].Format\");",
      "Whenever you use `jq` to access some `string` values, it will be best to use the `--raw-output` option because it get's rid of the enclosing quotes."
    ],
    "utterance": "Extract the value of the Format key from the specified track in the media object, returning it as an unquoted string.",
    "expressions": [
      ".media.track[$2].Format",
      ".media.track[1].Format"
    ],
    "data": [
      {
        "input": {
          "media": {
            "track": [
              {
                "TrackType": "General",
                "Format": "MPEG-4"
              },
              {
                "TrackType": "Video",
                "Format": "AVC"
              }
            ]
          }
        },
        "output": "AVC"
      }
    ],
    "identifier": 62248524
  },
  {
    "context": [
      "We are now looking for a `jq` filter to get all dicts where `value` and `default` are not equal.",
      "Iterate over the dicts by `.[]`, select only those that have the value different to the default:",
      "jq '.[] | select (.value != .default)' file.json"
    ],
    "utterance": "Select all objects from the list where the value of 'value' is not equal to the value of 'default'.",
    "expressions": [
      ".[] | select (.value != .default)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "value": "value1",
            "default": "value1"
          },
          {
            "name": "bar",
            "value": "blafasel",
            "default": "value2"
          }
        ],
        "output": {
          "name": "bar",
          "value": "blafasel",
          "default": "value2"
        }
      }
    ],
    "identifier": 62262761
  },
  {
    "context": [
      "My goal is though to produce one file with the content:\r\n\r\n    {\"index\":{\"_index\":\"items1\",\"_id\":8021096}}\r\n    {source1...}\r\n    {\"index\":{\"_index\":\"items1\",\"_id\":8021446}}\r\n    {source2...}\r\n    {\"index\":{\"_index\":\"items1\",\"_id\":8023950}}\r\n    ...",
      "How could I combine the jq commands above to one single command producing one file?",
      "`,` is your friend:",
      "```\r\n.hits.hits[]._source\r\n| (., {\"index\" : { \"_index\" : \"items1\", \"_id\" : .item_id  } })\r\n\r\n```"
    ],
    "utterance": "For each hit, emit an index object using the item's item_id, immediately followed by the source object, each on its own line.",
    "expressions": [
      ".hits.hits[]._source | ({\"index\" : { \"_index\" : \"items1\", \"_id\" : .item_id } }, .)"
    ],
    "data": [
      {
        "input": {
          "hits": {
            "hits": [
              {
                "_source": {
                  "item_id": 8021096,
                  "foo": "bar1"
                }
              },
              {
                "_source": {
                  "item_id": 8021446,
                  "foo": "bar2"
                }
              },
              {
                "_source": {
                  "item_id": 8023950,
                  "foo": "bar3"
                }
              }
            ]
          }
        },
        "output": [
          {
            "index": {
              "_index": "items1",
              "_id": 8021096
            }
          },
          {
            "item_id": 8021096,
            "foo": "bar1"
          },
          {
            "index": {
              "_index": "items1",
              "_id": 8021446
            }
          },
          {
            "item_id": 8021446,
            "foo": "bar2"
          },
          {
            "index": {
              "_index": "items1",
              "_id": 8023950
            }
          },
          {
            "item_id": 8023950,
            "foo": "bar3"
          }
        ]
      }
    ],
    "identifier": 62259688
  },
  {
    "identifier": 62282739
  },
  {
    "context": [
      "I would like to filter the Cloudwatch output so that it only displays CPUUtilization threshold not equals to 70, 60 and 40.",
      "jq '.MetricAlarms[]|select(.MetricName == \"CPUUtilization\")|select(.Threshold != 70)|select(.Threshold != 60)|select(.Threshold != 40)' alarms.json",
      ".MetricAlarms[] \n| select( .MetricName == \"CPUUtilization\" and (.Threshold |  IN(40,60,70) | not ) )"
    ],
    "utterance": "Filter elements where MetricName is CPUUtilization and Threshold is not equal to 70, 60, or 40.",
    "expressions": [
      ".MetricAlarms[]|select(.MetricName == \"CPUUtilization\")|select(.Threshold != 70)|select(.Threshold != 60)|select(.Threshold != 40)",
      ".MetricAlarms[] | select(.MetricName == \"CPUUtilization\" and (.Threshold | IN(40,60,70) | not))"
    ],
    "identifier": 62280426
  },
  {
    "context": [
      "I have a json string in the following format:\r\n\r\n    json='{\"x\": [{\"y\":\"yyy1\", \"z\":\"zzz1 zzz1\"}, {\"y\":\"yyy2\", \"z\":\"zzz2 zzz2\"}]}''",
      "I'm trying to get an array var of all \"y\" and separate array of \"z\" with jq like\r\n\r\n    y_arr=$(echo \"${json}\" | jq '.x | [] | .y') # => outputs 2 array elements \r\n    y_arr=$(echo \"${json}\" | jq '.x | [] | .z') # => outputs 4 array elements due to space",
      "Assuming your bash has `readarray` (aka `mapfile`) and that having the bash array values be valid JSON is acceptable, you could write:\r\n```\r\nreadarray z_array < <(echo \"${json}\" | jq -c '.x[] | .z') \r\n```",
      "If all the .z values are JSON strings, then provided these strings do not have embedded newline characters, and that you want the bash array values to be \"raw\" strings (as opposed to JSON strings), you could add the -r option to the invocation of jq."
    ],
    "utterance": "Extract all values of the property z from each object in the x array as an array, preserving spaces within the values.",
    "expressions": [
      ".x[].z",
      ".x | map(.z)"
    ],
    "data": [
      {
        "input": {
          "x": [
            {
              "y": "yyy1",
              "z": "zzz1 zzz1"
            },
            {
              "y": "yyy2",
              "z": "zzz2 zzz2"
            }
          ]
        },
        "output": [
          "zzz1 zzz1",
          "zzz2 zzz2"
        ]
      }
    ],
    "identifier": 62263081
  },
  {
    "context": [
      "Testing at jqplay.org, this .[1] | [.timeEnded, .lifecycleState] | flatten gets me the result I need.",
      "Trying to embed that in bash, I am trying to do something like:",
      "status=$(curl -X GET <URL> | jq -r -c '[.timeEnded, .lifecycleState] | flatten' | awk -F, '{print $2}' | sed 's/\"//g')",
      "With no escaping the pipes within the jq, I get",
      "[.timeEnded,: command not found",
      "I tried to escape those pipes as jq -r -c '[.timeEnded, .lifecycleState] \\| flatten' but that gets me a jq syntax error:"
    ],
    "utterance": "Extract the .timeEnded and .lifecycleState fields from the second element of an array, then flatten the result.",
    "expressions": [
      ".[1] | [.timeEnded, .lifecycleState] | flatten"
    ],
    "identifier": 62291556
  },
  {
    "context": [
      "Ideally I'd like to update `host.properties.name.lastrun` and `host.properties.name.value` at the same time.",
      "jq --arg hpnl foo --arg hpnv bar '.host.properties.name.lastrun = $hpnl | .host.properties.name.value = $hpnv' file",
      "In JQ you can pipe the result of an assignment to another. E.g:",
      "jq --arg host_name_value   \"$host_name_value\"   \\\n   --arg host_name_lastrun \"$host_name_lastrun\" '\n.host.properties.name |= (\n  .value   = $host_name_value   |\n  .lastrun = $host_name_lastrun\n)' data/firemotd-data-host.json"
    ],
    "utterance": "Update host.properties.name.lastrun and host.properties.name.value simultaneously to given values.",
    "expressions": [
      ".host.properties.name.lastrun = $hpnl | .host.properties.name.value = $hpnv",
      ".host.properties.name |= (.value = $host_name_value | .lastrun = $host_name_lastrun)"
    ],
    "data": [
      {
        "input": {
          "host": {
            "properties": {
              "name": {
                "generated": "@logon",
                "value": "${host.name}",
                "lastrun": "2020-06-09 20:48:00,357",
                "type": "keyword"
              }
            }
          }
        },
        "output": {
          "host": {
            "properties": {
              "name": {
                "generated": "@logon",
                "value": "bar",
                "lastrun": "foo",
                "type": "keyword"
              }
            }
          }
        }
      }
    ],
    "identifier": 62289911
  },
  {
    "context": [
      "I would like to reformat this to make the values of `.name` into a key with a fixed value like this:",
      "{\n\"deploy_products\": \"all\",\n\"errands\": {\n    \"product_1_guid\": {\n      \"run_pre_delete\": {\n        \"broker-deregistrar\": true,\n        \"delete-all-service-instances\": true,\n        \"deregister-broker\": true\n      }\n    }\n  },\n  \"ignore_warnings\": true\n}",
      "the list of errands may only be \"delete-apps\", or even nothing at all.",
      "in the above example I need `.xxx`, `.yyy` and `.zzz` to come from the original JSON.",
      "Generate the name-true pairs within an array constructor so that you can easily merge them with `add` and place the result wherever it belongs.",
      "{\n  deploy_products: \"all\",\n  errands: {\n    product_1_guid: {\n      run_pre_delete: [\n        { (.errands[].name): true }\n      ] | add\n    }\n  },\n  ignore_warnings: true\n}"
    ],
    "utterance": "Transform an object containing an array of objects with a 'name' property into a nested object where each 'name' becomes a key with value true under 'run_pre_delete', along with additional fixed keys.",
    "expressions": [
      "{\n  deploy_products: \"all\",\n  errands: {\n    product_1_guid: {\n      run_pre_delete: [\n        { (.errands[].name): true }\n      ] | add\n    }\n  },\n  ignore_warnings: true\n}"
    ],
    "data": [
      {
        "input": {
          "errands": [
            {
              "name": "broker-deregistrar",
              "label": "Deregister and Purge Instances",
              "impact_warning": null,
              "pre_delete": true
            },
            {
              "name": "delete-all-service-instances",
              "label": "Delete All Service Instances",
              "impact_warning": null,
              "pre_delete": true
            },
            {
              "name": "deregister-broker",
              "label": "Deregister On-Demand Service Broker",
              "impact_warning": null,
              "pre_delete": true
            }
          ]
        },
        "output": {
          "deploy_products": "all",
          "errands": {
            "product_1_guid": {
              "run_pre_delete": {
                "broker-deregistrar": true,
                "delete-all-service-instances": true,
                "deregister-broker": true
              }
            }
          },
          "ignore_warnings": true
        }
      }
    ],
    "identifier": 62289276
  },
  {
    "context": [
      "I want search this string `tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854` in that structure",
      "I&#39;d like to get the index of vout, in this case 1. is it possible with jq?",
      "A simple and reasonably efficient jq program that finds all such indices is as follows:",
      "With the given input, this in fact yields 1, which is in accordance with the problem description",
      "I guess you want the `n` of the element of `vout` that contains the given address in its addresses list. That can be achieved with",
      "jq '.vout[]\n    | select(.scriptPubKey.addresses[] == \"tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854\")\n    | .n\n   ' file.json"
    ],
    "utterance": "Find the index of the vout entry whose scriptPubKey.addresses array contains the value 'tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854'.",
    "expressions": [
      ".vout | range(0;length) as $i | if any(.[$i]|..; . == \"tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854\") then $i else empty end",
      ".vout[] | select(.scriptPubKey.addresses[] == \"tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854\") | .n"
    ],
    "data": [
      {
        "input": {
          "txid": "67bc5194442dc350312a7c0a5fc7ef912c31bf00b23349b4c3afdf177c91fb2f",
          "hash": "8392ded0647e4166eda342cee409c7d0e1e3ffab24de41866d2e6a7bd0a245b3",
          "version": 2,
          "size": 245,
          "vsize": 164,
          "weight": 653,
          "locktime": 1764124,
          "vin": [
            {
              "txid": "69eed058cbd18b3bf133c8341582adcd76a4d837590d3ae8fa0ffee1d597a8c3",
              "vout": 0,
              "scriptSig": {
                "asm": "0014759fc698313da549948940508df6db93a319096e",
                "hex": "160014759fc698313da549948940508df6db93a319096e"
              },
              "txinwitness": [
                "3044022014a8eb758063c52bc970d42013e653f5d3fb3c190b55f7cfa72680280cc5138602202a873b5cad4299b2f52d8cccb4dcfa66fa6ec256d533788f54440d4cdad7dd6501",
                "02ec8ba22da03ed1870fe4b9f9071067a6a1fda6f582c5c858644e44bd401bfc0a"
              ],
              "sequence": 4294967294
            }
          ],
          "vout": [
            {
              "value": 0.37841708,
              "n": 0,
              "scriptPubKey": {
                "asm": "0 686bc8ce41505642c96f3eb99919fff63f4c0f11",
                "hex": "0014686bc8ce41505642c96f3eb99919fff63f4c0f11",
                "reqSigs": 1,
                "type": "witness_v0_keyhash",
                "addresses": [
                  "tb1qdp4u3njp2pty9jt086uejx0l7cl5crc3x3phwd"
                ]
              }
            },
            {
              "value": 0.00022,
              "n": 1,
              "scriptPubKey": {
                "asm": "0 0b173480108e035f92b1f52dbf4e90474f7b36dc",
                "hex": "00140b173480108e035f92b1f52dbf4e90474f7b36dc",
                "reqSigs": 1,
                "type": "witness_v0_keyhash",
                "addresses": [
                  "tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854"
                ]
              }
            }
          ],
          "hex": "02000000000101c3a897d5e1fe0ffae83a0d5937d8a476cdad821534c833f13b8bd1cb58d0ee690000000017160014759fc698313da549948940508df6db93a319096efeffffff022c6b410200000000160014686bc8ce41505642c96f3eb99919fff63f4c0f11f0550000000000001600140b173480108e035f92b1f52dbf4e90474f7b36dc02473044022014a8eb758063c52bc970d42013e653f5d3fb3c190b55f7cfa72680280cc5138602202a873b5cad4299b2f52d8cccb4dcfa66fa6ec256d533788f54440d4cdad7dd65012102ec8ba22da03ed1870fe4b9f9071067a6a1fda6f582c5c858644e44bd401bfc0a1ceb1a00",
          "blockhash": "000000009acb8b4f06a97beb23b3d9aeb3df71052dabec94465933b564c27f50",
          "confirmations": 2,
          "time": 1591687001,
          "blocktime": 1591687001
        },
        "output": 1
      }
    ],
    "identifier": 62277191
  },
  {
    "context": [
      "I have N numbers of arrays of objects with the same identifying key within objects, and I'd love to merge those with `jq`.",
      "**From**\n[\n  {\n    \"google.com\": {\n      \"http\": {\n        \"dest_url\": \"http://stackoverflow.com\"\n      }\n    }\n  },\n  {\n    \"google.com\": {\n      \"https\": {\n        \"dest_url\": \"https://github.com\"\n      }\n    }\n  },\n  {\n    \"test.com\": {\n      \"https\": {\n        \"dest_url\": \"https://wikipedia.com\"\n      }\n    }\n  }\n]",
      "**To**\n{\n  \"google.com\": {\n    \"http\": {\n      \"dest_url\": \"http://stackoverflow.com\"\n    },\n    \"https\": {\n      \"dest_url\": \"https://github.com\"\n    }\n  },\n  \"test.com\": {\n    \"https\": {\n      \"dest_url\": \"https://wikipedia.com\"\n    }\n  }\n}",
      "You can use the `group_by()` of the keyname after doing `to_entries()` and form the final JSON from the grouped result",
      "map(to_entries[])\n| group_by(.key)[] \n| { (.[0].key) : map(.value)|add }",
      "A shorter alternative using `reduce` and recursive merging by `*` operator:",
      "reduce .[] as $p ({}; . * $p)"
    ],
    "utterance": "Combine an array of objects by merging all objects with the same top-level key so their sub-keys are merged into a single object per key.",
    "expressions": [
      "reduce .[] as $p ({}; . * $p)",
      "map(to_entries[])\n| group_by(.key)[]\n| { (.[0].key) : map(.value)|add }"
    ],
    "data": [
      {
        "input": [
          {
            "google.com": {
              "http": {
                "dest_url": "http://stackoverflow.com"
              }
            }
          },
          {
            "google.com": {
              "https": {
                "dest_url": "https://github.com"
              }
            }
          },
          {
            "test.com": {
              "https": {
                "dest_url": "https://wikipedia.com"
              }
            }
          }
        ],
        "output": {
          "google.com": {
            "http": {
              "dest_url": "http://stackoverflow.com"
            },
            "https": {
              "dest_url": "https://github.com"
            }
          },
          "test.com": {
            "https": {
              "dest_url": "https://wikipedia.com"
            }
          }
        }
      }
    ],
    "identifier": 62297983
  },
  {
    "context": [
      "Output json needs to be like below where in `$AUTH` and `$REG` are env variables.",
      "Grab `AUTH` and `REG` environment variables from `$ENV` preset variable and create fields using them, then add the resulting object to the first member of the input.",
      ".abc |= {auth_url: env.AUTH, region_name: env.REG, endpoint_type: \"PRIVATE\"} + .",
      "jq --arg AUTH \"$AUTH\" --arg REG \"$REG\" '\n   .abc |= {auth_url: $AUTH, region_name: $REG, endpoint_type: \"PRIVATE\"} + .\n' sample.json"
    ],
    "utterance": "Add the fields auth_url (from AUTH environment variable), region_name (from REG environment variable), and endpoint_type (with value PRIVATE) to the abc object at the top level.",
    "expressions": [
      "first(.[]) |= ( $ENV | {\n    auth_url:      .AUTH,\n    region_name:   .REG,\n    endpoint_type: \"PRIVATE\"\n  }\n) + .",
      ".abc |= {auth_url: env.AUTH, region_name: env.REG, endpoint_type: \"PRIVATE\"} + .",
      ".abc |= {auth_url: $AUTH, region_name: $REG, endpoint_type: \"PRIVATE\"} + ."
    ],
    "data": [
      {
        "input": {
          "abc": {
            "admin": {
              "username": "admin",
              "password": "pa55word",
              "tenant_name": "t1"
            },
            "users": [
              {
                "username": "n1",
                "password": "password",
                "user_domain_name": "Default",
                "project_name": "p1",
                "project_domain_name": "Default"
              },
              {
                "username": "n2",
                "password": "password",
                "user_domain_name": "Default",
                "project_name": "p2",
                "project_domain_name": "Default"
              }
            ]
          }
        },
        "output": {
          "abc": {
            "auth_url": "$AUTH",
            "region_name": "$REG",
            "endpoint_type": "PRIVATE",
            "admin": {
              "username": "admin",
              "password": "pa55word",
              "tenant_name": "t1"
            },
            "users": [
              {
                "username": "n1",
                "password": "password",
                "user_domain_name": "Default",
                "project_name": "p1",
                "project_domain_name": "Default"
              },
              {
                "username": "n2",
                "password": "password",
                "user_domain_name": "Default",
                "project_name": "p2",
                "project_domain_name": "Default"
              }
            ]
          }
        }
      }
    ],
    "identifier": 62326410
  },
  {
    "context": [
      "Input JSON",
      "{\n\"key\": {\n    \"type\": [\n      \"object\",\n      {\n        \"A\": \"string\",\n        \"B\": \"string\"\n      }\n    ],\n    \"value\": {\n      \"A\": \"value of A\",\n      \"B\": \"value of B\"\n    }\n  }\n}",
      "Expected Output:",
      "{\n    \"A\": {\n        \"value\": \"value of A\"\n    },\n    \"B\": {\n        \"value\": \"value of B\"\n    }\n}",
      "the following jq program produces the required output",
      ".key.value | map_values({value: .})"
    ],
    "utterance": "Transform an object containing a key with a value mapping (\"A\": \"value of A\", \"B\": \"value of B\") into an object where each key has a nested object with a key 'value' holding the original value.",
    "expressions": [
      ".key.value | map_values({value: .})"
    ],
    "data": [
      {
        "input": {
          "key": {
            "type": [
              "object",
              {
                "A": "string",
                "B": "string"
              }
            ],
            "value": {
              "A": "value of A",
              "B": "value of B"
            }
          }
        },
        "output": {
          "A": {
            "value": "value of A"
          },
          "B": {
            "value": "value of B"
          }
        }
      }
    ],
    "identifier": 62332389
  },
  {
    "context": [
      "How do I merge all the json outputs from if and elif into single json using jq.",
      "You could pipe into `jq -s .`:",
      "for .... ; do ... ; done | jq -s ."
    ],
    "utterance": "Combine multiple objects produced in a loop into an array.",
    "expressions": [
      "jq -s ."
    ],
    "identifier": 62342787
  },
  {
    "context": [
      "I would like the result to be one line of data per array element where each line should include some fields from the array element and some fields from the identifying information.",
      "I would like to get an output like this:",
      "\"SYSTEM.DEF.SVRCONN\",\"Svrconn\",\"127.0.0.1\",\"SampleApp\",\"MQJM\",\"09010005\",\"11:07:18\",\"Get\",102,\"SYSTEM.DEFAULT.LOCAL.QUEUE\",2033",
      "Using your approach, the following is a solution:",
      ".eventData\n| ({channelName, channelType, connectionName, applName, remoteProduct, remoteVersion}\n   + ( .activityTrace[]\n       | { operationTime, operationId, qmgrOpDuration, objectName, v: .reasonCode.value}))\n| [.[]]\n| @csv",
      "A slightly more efficient approach",
      ".eventData\n| [.channelName, .channelType, .connectionName, .applName, .remoteProduct, .remoteVersion]\n  + ( .activityTrace[]\n      | [.operationTime, .operationId, .qmgrOpDuration, .objectName, .reasonCode.value] )\n| @csv",
      ".eventData\n| [.channelName, .channelType, .connectionName, .applName, .remoteProduct, .remoteVersion] as $x\n| ( .activityTrace[] \n    | [.operationTime]\n      + $x\n      + [.operationId, .qmgrOpDuration, .objectName, .reasonCode.value] )\n| @csv"
    ],
    "utterance": "Produce one line per activityTrace element including channelName, channelType, connectionName, applName, remoteProduct, remoteVersion, operationTime, operationId, qmgrOpDuration, objectName, and reasonCode.value in a specific column order.",
    "expressions": [
      ".eventData | ({channelName, channelType, connectionName, applName, remoteProduct, remoteVersion} + (.activityTrace[] | {operationTime, operationId, qmgrOpDuration, objectName, v: .reasonCode.value})) | [.[]] | @csv",
      ".eventData | [.channelName, .channelType, .connectionName, .applName, .remoteProduct, .remoteVersion] as $x | (.activityTrace[] | [.operationTime] + $x + [.operationId, .qmgrOpDuration, .objectName, .reasonCode.value]) | @csv"
    ],
    "data": [
      {
        "input": {
          "eventCreation": {
            "timeStamp": "2020-06-06T15:07:20Z",
            "epoch": 1591456040
          },
          "eventData": {
            "applName": "SampleApp",
            "channelName": "SYSTEM.DEF.SVRCONN",
            "connectionName": "127.0.0.1",
            "channelType": "Svrconn",
            "remoteProduct": "MQJM",
            "remoteVersion": "09010005",
            "activityTrace": [
              {
                "operationId": "Get",
                "operationTime": "11:07:18",
                "qmgrOpDuration": 102,
                "reasonCode": {
                  "name": "No Msg Available",
                  "value": 2033
                },
                "objectName": "SYSTEM.DEFAULT.LOCAL.QUEUE"
              },
              {
                "operationId": "Cb",
                "operationTime": "11:07:18",
                "qmgrOpDuration": 10,
                "reasonCode": {
                  "name": "None",
                  "value": 0
                },
                "objectName": "SYSTEM.DEFAULT.LOCAL.QUEUE"
              },
              {
                "operationId": "Cb",
                "operationTime": "11:07:18",
                "qmgrOpDuration": 12,
                "reasonCode": {
                  "name": "None",
                  "value": 0
                },
                "objectName": "SYSTEM.DEFAULT.LOCAL.QUEUE"
              }
            ]
          }
        },
        "output": [
          "\"SYSTEM.DEF.SVRCONN\",\"Svrconn\",\"127.0.0.1\",\"SampleApp\",\"MQJM\",\"09010005\",\"11:07:18\",\"Get\",102,\"SYSTEM.DEFAULT.LOCAL.QUEUE\",2033",
          "\"SYSTEM.DEF.SVRCONN\",\"Svrconn\",\"127.0.0.1\",\"SampleApp\",\"MQJM\",\"09010005\",\"11:07:18\",\"Cb\",10,\"SYSTEM.DEFAULT.LOCAL.QUEUE\",0",
          "\"SYSTEM.DEF.SVRCONN\",\"Svrconn\",\"127.0.0.1\",\"SampleApp\",\"MQJM\",\"09010005\",\"11:07:18\",\"Cb\",12,\"SYSTEM.DEFAULT.LOCAL.QUEUE\",0"
        ]
      }
    ],
    "identifier": 62239580
  },
  {
    "context": [
      "Given an original JSON file.\r\n\r\n```JSON\r\n{\r\n  \"version\": \"base\",\r\n  \"myValue\": \"to be changed\",\r\n  \"channelId\": 0\r\n}\r\n```\r\n\r\nWe want to run a command to update some variables in it, so that after we run:\r\n\r\n```Bash\r\nCHANNEL_ID=1701 MY_VALUE=\"new value\" ./test.sh\r\n```\r\n\r\nThe JSON should look like this:\r\n\r\n```JSON\r\n{\r\n  \"version\": \"base\",\r\n  \"myValue\": \"new value\",\r\n  \"channelId\": 1701\r\n}\r\n```",
      "jq --arg key \"$1\" --arg value \"$2\" '.[$key] = $value'",
      "CHANNEL_ID=1701 MY_VALUE=\"new value\" \\\r\n     jq '{\"version\": \"base\", myValue: env.MY_VALUE, channelId: env.CHANNEL_ID}' build/config.json"
    ],
    "utterance": "Update the values of myValue and channelId to those provided in environment variables, correctly handling cases where the value contains whitespace.",
    "expressions": [
      "jq --arg key \"$1\" --arg value \"$2\" '.[$key] = $value'",
      "jq '{\"version\": \"base\", myValue: env.MY_VALUE, channelId: env.CHANNEL_ID}' build/config.json"
    ],
    "data": [
      {
        "input": {
          "version": "base",
          "myValue": "to be changed",
          "channelId": 0
        },
        "output": {
          "version": "base",
          "myValue": "new value",
          "channelId": 1701
        }
      }
    ],
    "identifier": 62346892
  },
  {
    "context": [
      "Given:\r\n\r\n```ft=json\r\n{\r\n  \"field1\": {\r\n\t\"key1\": 11,\r\n\t\"key2\": 10\r\n  },\r\n  \"field2\": {\r\n\t\"key1\": 11,\r\n\t\"key2\": 10\r\n  }\r\n}\r\n```",
      "Desired output\r\n\r\n```ft=json\r\n[\r\n   {\"name\": \"field1\", \"key1\": 11, \"key2\": 10},\r\n   {\"name\": \"field2\", \"key1\": 11, \"key2\": 10}\r\n]\r\n```",
      "Generate an object in `{ \"name\": <key> }` form for each key, and merge that with the key's value.",
      "```\nto_entries | map({name: .key} + .value)\n```",
      "```\n[keys_unsorted[] as $k | {name: $k} + .[$k]]\n```",
      "Something like below. Get the list of keys in the JSON using `keys[]` and add the new field `name` by indexing key on each object.",
      "jq '[ keys[] as $k | { name: $k } + .[$k] ]'"
    ],
    "utterance": "For each top-level key in an object, create an array of objects containing all key-value pairs from the subobject and add a field 'name' with the original key as its value.",
    "expressions": [
      "to_entries | map({name: .key} + .value)",
      "[keys_unsorted[] as $k | {name: $k} + .[$k]]",
      "[keys[] as $k | {name: $k} + .[$k]]"
    ],
    "data": [
      {
        "input": {
          "field1": {
            "key1": 11,
            "key2": 10
          },
          "field2": {
            "key1": 11,
            "key2": 10
          }
        },
        "output": [
          {
            "name": "field1",
            "key1": 11,
            "key2": 10
          },
          {
            "name": "field2",
            "key1": 11,
            "key2": 10
          }
        ]
      }
    ],
    "identifier": 62343182
  },
  {
    "context": [
      "I need to get the entire object(s) in json array returned by `list-action-executions` command from aws cli, where the attributes satisfy the condition below",
      "\"stageName\": \"DeployStage\",",
      "\"actionName\": \"PromoteToProdApprovalGate\",",
      "The right filter would be to filter on the array",
      ".actionExecutionDetails[] | select(.stageName == \"DeployStage\" and .actionName == \"PromoteToProdApprovalGate\")",
      "Or if you want the original array updated with the filtered result, do this",
      ".actionExecutionDetails |= map(select(.stageName == \"DeployStage\" and .actionName == \"PromoteToProdApprovalGate\"))"
    ],
    "utterance": "Return all objects from the actionExecutionDetails array where stageName is DeployStage and actionName is PromoteToProdApprovalGate.",
    "expressions": [
      ".actionExecutionDetails[] | select(.stageName == \"DeployStage\" and .actionName == \"PromoteToProdApprovalGate\")",
      ".actionExecutionDetails |= map(select(.stageName == \"DeployStage\" and .actionName == \"PromoteToProdApprovalGate\"))"
    ],
    "data": [
      {
        "input": {
          "actionExecutionDetails": [
            {
              "pipelineExecutionId": "pipeline-exec-id-1",
              "actionExecutionId": "action-exec-id-1",
              "pipelineVersion": 2,
              "stageName": "DeployStage",
              "actionName": "PromoteToProdApprovalGate",
              "startTime": "2020-06-01T22:11:53-04:00",
              "lastUpdateTime": "2020-06-01T22:11:53-04:00",
              "status": "InProgress",
              "input": {
                "actionTypeId": {
                  "category": "Approval",
                  "owner": "AWS",
                  "provider": "Manual",
                  "version": "1"
                },
                "configuration": {
                  "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
                  "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
                  "NotificationArn": "arn:aws:sns:us-east-1:"
                },
                "resolvedConfiguration": {
                  "CustomData": "Deploy Service to Prod Approval Required for CommitID=bb-commit-id-1",
                  "ExternalEntityLink": "url/bb-commit-id",
                  "NotificationArn": "arn:aws:sns:us-east-1:"
                },
                "region": "us-east-1",
                "inputArtifacts": []
              },
              "output": {
                "outputArtifacts": [],
                "outputVariables": {}
              }
            },
            {
              "pipelineExecutionId": "pipeline-exec-id-2",
              "actionExecutionId": "action-exec-id-2",
              "pipelineVersion": 2,
              "stageName": "DeployStage",
              "actionName": "ImageEnvironmentTag",
              "startTime": "2020-06-01T22:09:45.833000-04:00",
              "lastUpdateTime": "2020-06-01T22:11:52.689000-04:00",
              "status": "Succeeded",
              "input": {
                "actionTypeId": {
                  "category": "Build",
                  "owner": "AWS",
                  "provider": "CodeBuild",
                  "version": "1"
                },
                "configuration": {
                  "EnvironmentVariables": "[\n  { \"name\": \"LAST_ENV\", \"value\": \"qa\" },\n  { \"name\": \"BB_COMMIT_ID\", \"value\": \"#{SourceBuildVariables.BB_COMMIT_ID}\" }\n]\n",
                  "ProjectName": "project-name-environement-tag"
                },
                "resolvedConfiguration": {
                  "EnvironmentVariables": "[\n  { \"name\": \"LAST_ENV\", \"value\": \"qa\" },\n  { \"name\": \"BB_COMMIT_ID\", \"value\": \"bb-commit-id-1\" }\n]\n",
                  "ProjectName": "projectName"
                },
                "region": "us-east-1",
                "inputArtifacts": [
                  {
                    "name": "PipelineArtifacts",
                    "s3location": {
                      "bucket": "bucket",
                      "key": "key"
                    }
                  }
                ]
              },
              "output": {
                "outputArtifacts": [],
                "executionResult": {
                  "externalExecutionId": "externalExecutionId",
                  "externalExecutionUrl": "https://console.aws.amazon.com/codebuild/home?region=us-east-1#/builds/"
                },
                "outputVariables": {}
              }
            }
          ]
        },
        "output": [
          {
            "pipelineExecutionId": "pipeline-exec-id-1",
            "actionExecutionId": "action-exec-id-1",
            "pipelineVersion": 2,
            "stageName": "DeployStage",
            "actionName": "PromoteToProdApprovalGate",
            "startTime": "2020-06-01T22:11:53-04:00",
            "lastUpdateTime": "2020-06-01T22:11:53-04:00",
            "status": "InProgress",
            "input": {
              "actionTypeId": {
                "category": "Approval",
                "owner": "AWS",
                "provider": "Manual",
                "version": "1"
              },
              "configuration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
                "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "resolvedConfiguration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=bb-commit-id-1",
                "ExternalEntityLink": "url/bb-commit-id",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "region": "us-east-1",
              "inputArtifacts": []
            },
            "output": {
              "outputArtifacts": [],
              "outputVariables": {}
            }
          }
        ]
      }
    ],
    "identifier": 62235507
  },
  {
    "context": [
      "I'm trying to convert data from a file called AllPrintings.json that looks like:\n\n{\n  \"10E\": {...},\n  \"BFZ\": {...}\n}\n\nInto: \n\n{\n  {\n    \"name\": \"Abundance\",\n    \"price\": 1.4,\n    \"uuid\": \"1669af17-d287-5094-b005-4b143441442f\",\n    \"set\": \"10E\"\n  }, ...\n}\n",
      "I'm able to get everything except the set by running \ncat AllPrintings.json | jq '[.[] | .cards | .[] |  {uuid: .uuid, name: .name, price: .prices.paper | .[]? }]'",
      "You were close. The missing part is `to_entries`, which converts an object into `{key, value}` pairs:\n\nto_entries | map(.key as $set | .value.cards[] | {uuid, name, price: .prices.paper | .[]?, set: $set })"
    ],
    "utterance": "Produce an array of objects for all cards, each with fields: uuid, name, price (first value from .prices.paper), and set (the top-level key from which the card came).",
    "expressions": [
      "to_entries | map(.key as $set | .value.cards[] | {uuid, name, price: .prices.paper | .[]?, set: $set })"
    ],
    "data": [
      {
        "input": {
          "10E": {
            "cards": [
              {
                "name": "Abundance",
                "prices": {
                  "paper": {
                    "2020-06-11": 1.4
                  },
                  "paperFoil": {
                    "2020-06-11": 31.12
                  }
                },
                "uuid": "1669af17-d287-5094-b005-4b143441442f"
              },
              {
                "name": "Academy Researchers",
                "prices": {
                  "paper": {
                    "2020-06-11": 0.36
                  },
                  "paperFoil": {
                    "2020-06-11": 1.22
                  }
                },
                "uuid": "047d5499-a21c-5f5c-9679-1599fcaf9815"
              }
            ]
          },
          "BFZ": {
            "cards": [
              {
                "name": "Adverse Conditions",
                "prices": {
                  "paper": {
                    "2020-06-11": 0.23
                  },
                  "paperFoil": {
                    "2020-06-11": 1.86
                  }
                },
                "uuid": "1669af17-d287-5094-b005-4b143441123"
              },
              {
                "name": "Akoum Firebird",
                "prices": {
                  "paper": {
                    "2020-06-11": 0.51
                  },
                  "paperFoil": {
                    "2020-06-11": 3.85
                  }
                },
                "uuid": "047d5499-a21c-5f5c-9679-1599fcafad567"
              }
            ]
          }
        },
        "output": [
          {
            "name": "Abundance",
            "price": 1.4,
            "uuid": "1669af17-d287-5094-b005-4b143441442f",
            "set": "10E"
          },
          {
            "name": "Academy Researchers",
            "price": 0.36,
            "uuid": "047d5499-a21c-5f5c-9679-1599fcaf9815",
            "set": "10E"
          },
          {
            "name": "Adverse Conditions",
            "price": 0.23,
            "uuid": "1669af17-d287-5094-b005-4b143441123",
            "set": "BFZ"
          },
          {
            "name": "Akoum Firebird",
            "price": 0.51,
            "uuid": "047d5499-a21c-5f5c-9679-1599fcafad567",
            "set": "BFZ"
          }
        ]
      }
    ],
    "identifier": 62346791
  },
  {
    "context": [
      "I want to reduce this to unique SSIDs with the highest signal.",
      "# jq '.AP | sort_by(.Signal) | reverse | unique_by(.SSID)' aps.json",
      "This seemed to do the trick.",
      "# jq '.AP | sort_by(.SSID,-.Signal)| unique_by(.SSID)' aps.json",
      "[",
      "  {",
      "    \"SSID\": \"Bart\",",
      "    \"Signal\": -20",
      "  },",
      "  {",
      "    \"SSID\": \"Homer\",",
      "    \"Signal\": -90",
      "  },",
      "  {",
      "    \"SSID\": \"Lisa\",",
      "    \"Signal\": -19",
      "  }",
      "]",
      "[.AP | group_by(.SSID) | .[] | max_by(.Signal)]"
    ],
    "utterance": "Select, for each SSID, the access point entry with the highest signal value.",
    "expressions": [
      ".AP | sort_by(.SSID,-.Signal) | unique_by(.SSID)",
      "[.AP | group_by(.SSID) | .[] | max_by(.Signal)]",
      "[reduce .AP[] as $ap ({}; .[$ap.SSID] |= (. // []) + [$ap]) | to_entries[] | max_by(.value[].Signal).value[-1]]"
    ],
    "data": [
      {
        "input": {
          "AP": [
            {
              "SSID": "Bart",
              "Signal": -20
            },
            {
              "SSID": "Lisa",
              "Signal": -19
            },
            {
              "SSID": "Homer",
              "Signal": -91
            },
            {
              "SSID": "Homer",
              "Signal": -92
            },
            {
              "SSID": "Lisa",
              "Signal": -92
            },
            {
              "SSID": "Lisa",
              "Signal": -21
            },
            {
              "SSID": "Homer",
              "Signal": -90
            },
            {
              "SSID": "Bart",
              "Signal": -21
            },
            {
              "SSID": "Bart",
              "Signal": -22
            }
          ]
        },
        "output": [
          {
            "SSID": "Bart",
            "Signal": -20
          },
          {
            "SSID": "Homer",
            "Signal": -90
          },
          {
            "SSID": "Lisa",
            "Signal": -19
          }
        ]
      }
    ],
    "identifier": 62349549
  },
  {
    "context": [
      "I have the following json from curl.",
      "I would like to print it out in a table format like:\r\n```\r\nCritical: 35\r\nError: 31\r\n```",
      "Put `.rows` and `.data` into an array, and feed that to `transpose` filter to pair each *row* with its corresponding *data*. Then for each pair, generate strings of name-datum pairs by means of string interpolation. E.g.:",
      "[.rows, .data] | transpose[] | \"\\(.[0].name): \\(.[1][])\""
    ],
    "utterance": "Print each name from the 'rows' array followed by its corresponding value from the 'data' array, formatted as 'name: value' for each pair.",
    "expressions": [
      "[.rows, .data] | transpose[] | \"\\(.[0].name): \\(.[1][])\""
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "id": 1,
              "name": "Critical"
            },
            {
              "id": 2,
              "name": "Error"
            }
          ],
          "data": [
            [
              35
            ],
            [
              31
            ]
          ]
        },
        "output": [
          "Critical: 35",
          "Error: 31"
        ]
      }
    ],
    "identifier": 62405357
  },
  {
    "context": [
      "I want to leverage the **match(regex) or capture(regex)** function and also get the individual output match objects for the matches, which in the above case would be **#YOLO** that caused the regex to be matched.",
      "It would be more efficient to eliminate the call to `test`:",
      "```\n.posts[].com\n| match(\"#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+\")\n| .string\n```",
      "Simply wrap the REGEX in a named-capture structure of the form `(?<x>REGEX).x`.  For example:",
      "```\n.posts[].com\n| capture(\"(?<x>#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+)\")\n| .x\n```"
    ],
    "utterance": "Extract the matched hashtag starting with '#' and not followed by 'p', a digit, 'q', or '_' in the 'com' attribute of each post, returning only the matched hashtag string such as '#YOLO'.",
    "expressions": [
      ".posts[].com | match(\"#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+\") | .string",
      ".posts[].com | capture(\"(?<x>#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+)\") | .x"
    ],
    "data": [
      {
        "input": {
          "posts": [
            {
              "archived_on": 3241233,
              "replies": 132,
              "com": "Life is good , and I don't want to take anything away from it . Literally #YOLO"
            },
            {
              "archived_on": 456343423,
              "replies": 150,
              "com": "The premier league is returning and I am very excited for it "
            }
          ]
        },
        "output": [
          "#YOLO"
        ]
      }
    ],
    "identifier": 62364354
  },
  {
    "context": [
      "And I would like to map this into this type of object format, promoting a field to be the new 'key' and return an object with that field as the key to an array of the original data without that key: (Almost like grouping the data by a particular field)",
      "Group by `.NodeName`, and index each group with that value in an object. Then remove `NodeName` field from all members.",
      "group_by(.NodeName)\n| INDEX(.[]; .[0].NodeName)\n| del(.[][].NodeName)"
    ],
    "utterance": "Group array elements by their NodeName field, using NodeName as each key in an object whose value is the array of original objects with NodeName removed.",
    "expressions": [
      "group_by(.NodeName)\n| INDEX(.[]; .[0].NodeName)\n| del(.[][].NodeName)"
    ],
    "data": [
      {
        "input": [
          {
            "NodeName": "node1",
            "VolumeName": "vol1",
            "Size": "50.0T",
            "Used": "18.6T",
            "Free": "31.4T",
            "Fragmentation": "31%",
            "Capacity": "37%",
            "Health": "ONLINE"
          },
          {
            "NodeName": "node1",
            "VolumeName": "vol2",
            "Size": "796G",
            "Used": "28.5M",
            "Free": "796G",
            "Fragmentation": "0%",
            "Capacity": "0%",
            "Health": "ONLINE"
          }
        ],
        "output": {
          "node1": [
            {
              "VolumeName": "vol1",
              "Size": "50.0T",
              "Used": "18.6T",
              "Free": "31.4T",
              "Fragmentation": "31%",
              "Capacity": "37%",
              "Health": "ONLINE"
            },
            {
              "VolumeName": "vol2",
              "Size": "796G",
              "Used": "28.5M",
              "Free": "796G",
              "Fragmentation": "0%",
              "Capacity": "0%",
              "Health": "ONLINE"
            }
          ]
        }
      }
    ],
    "identifier": 62401644
  },
  {
    "context": [
      "What I expected is:\r\n\r\n    12\r\n    rachel.howell@reqres.in\r\n    Rachel\r\n    Howell\r\n    https://s3.amazonaws.com/uifaces/faces/twitter/hebertialmeida/128.jpg",
      "With [tag:jq], it&#39;d be:\r\n```\r\njq -r &#39;.[]&#39; file\r\n```"
    ],
    "utterance": "Output only the values from all keys in the top-level object, one per line, without brackets or quotes.",
    "expressions": [
      "jq -r '.[]' file"
    ],
    "data": [
      {
        "input": {
          "id": 12,
          "email": "rachel.howell@reqres.in",
          "first_name": "Rachel",
          "last_name": "Howell",
          "avatar": "https://s3.amazonaws.com/uifaces/faces/twitter/hebertialmeida/128.jpg"
        },
        "output": [
          12,
          "rachel.howell@reqres.in",
          "Rachel",
          "Howell",
          "https://s3.amazonaws.com/uifaces/faces/twitter/hebertialmeida/128.jpg"
        ]
      }
    ],
    "identifier": 62423488
  },
  {
    "context": [
      "Join locations by a comma, and put the result into an array with other fields. Then join again by a comma followed by a space to get the desired output format. E.g.:",
      "```\n.data[].event | [\n  .num,\n  .hostname,\n  .ip,\n (.locations | join(\",\")) ?\n] | join(\", \")\n```",
      "At its core, you want to build an array consisting of the values you want:",
      "$ jq '.data[].event | [.num, .hostame, .ip, .locations]' tmp.json",
      "First, let's turn the list of locations into a single string:",
      "$ jq '.data[].event | [.num, .hostame, .ip, (.locations|join(\",\"))]' tmp.json",
      "Next, let's join those strings into a \", \"-separated string.",
      "$ jq '.data[].event | [.num, .hostame, .ip, (.locations|join(\",\"))] | join(\", \")' tmp.json",
      "Finally, you can use the -r flag to output raw text rather than a JSON string value.",
      "$ jq -r '.data[].event | [.num, .hostame, .ip, (.locations|join(\",\"))] | join(\", \")' tmp.json"
    ],
    "utterance": "Output num, hostname, ip, and locations (joined by a comma) for each event entry, formatted as a comma-separated string.",
    "expressions": [
      ".data[].event | [.num, .hostname, .ip, (.locations | join(\",\"))] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "time": 20201606,
              "event": {
                "ip": "127.0.1",
                "hostname": "srv1",
                "locations": [
                  "UK",
                  "site1"
                ],
                "num": 1
              }
            },
            {
              "time": 202016034,
              "event": {
                "ip": "127.0.2",
                "hostname": "srv2",
                "locations": [
                  "UK",
                  "site2"
                ],
                "num": 3
              }
            }
          ]
        },
        "output": [
          "1, srv1, 127.0.1, UK,site1",
          "3, srv2, 127.0.2, UK,site2"
        ]
      }
    ],
    "identifier": 62411990
  },
  {
    "context": [
      "Is there any way I can make my jq parser running despite this numeric literal error? Maybe, ignoring it and carry on with the next line?",
      "to recover from an error, you can use the idiom illustrated by the following:",
      "With a program like this, you would normally invoke jq with the -n command-line argument.",
      "def myfilter:\n  . as $parent \n  | .text\n  | match(\"#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+\") as $result\n  | {\"time\":$parent.timestamp_ms,\"string\":$result.string} ;\n\ndef process:\n  try (inputs | myfilter) \n  catch (\"error at line \\(input_line_number)\", process);\n\nprocess"
    ],
    "utterance": "Continue processing all input lines, skipping any that cause errors and returning output for valid lines only.",
    "expressions": [
      "def myfilter:\n  . as $parent \n  | .text\n  | match(\"#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+\") as $result\n  | {\"time\":$parent.timestamp_ms,\"string\":$result.string} ;\n\ndef process:\n  try (inputs | myfilter) \n  catch (\"error at line \\(input_line_number)\", process);\n\nprocess"
    ],
    "identifier": 62418421
  },
  {
    "context": [
      "How can I express a case insensitive simple key reference in jq?",
      "Is there a way to express the `.key` filter such that it'll catch `\"key\"` or `\"kEy\"` ?",
      "Given `i` flag, the `test` builtin matches case-insensitively, you can use it in conjunction with `to_entries`. E.g.:",
      "to_entries[] | select(.key | test(\"key\"; \"i\")) .value",
      "One way would be to convert all keys to lower-case as a default format and extract the key name of your choice",
      "with_entries( .key |= ascii_downcase ).key"
    ],
    "utterance": "Retrieve the value associated with a key named 'key', regardless of the key's letter casing.",
    "expressions": [
      "to_entries[] | select(.key | test(\"key\"; \"i\")) .value",
      "with_entries(.key |= ascii_downcase).key"
    ],
    "data": [
      {
        "input": {
          "kEy": "value"
        },
        "output": "value"
      },
      {
        "input": {
          "key": "value"
        },
        "output": "value"
      }
    ],
    "identifier": 62433986
  },
  {
    "context": [
      "Expected output:\r\n\r\n    {\"version\":\"1.0\",\"author\":\"user1\"}\r\n    \r\n    {\"version\":\"1.0\",\"author\":\"user2\",\"timestamp\":\"2019-02-05\"}\r\n    \r\n    {\"version\":\"1.0\",\"author\":\"user3\",\"price\":\"10.0\"}\r\n",
      "jq -c '.[] | .metadata' data1.json",
      "$ jq -c '.[] | .metadata' data1.json\r\n{\"version\":\"1.0\",\"author\":\"user1\"}\r\n{\"version\":\"1.0\",\"author\":\"user2\",\"timestamp\":\"2019-02-05\"}\r\n{\"version\":\"1.0\",\"author\":\"user3\",\"price\":\"10.0\"}\r\n"
    ],
    "utterance": "Print each top-level object's metadata as a compact object on its own output line.",
    "expressions": [
      ".[] | .metadata",
      "-c '.[] | .metadata'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "metadata": {
              "version": "1.0",
              "author": "user1"
            }
          },
          {
            "id": "2",
            "metadata": {
              "version": "1.0",
              "author": "user2",
              "timestamp": "2019-02-05"
            }
          },
          {
            "id": "3",
            "metadata": {
              "version": "1.0",
              "author": "user3",
              "price": "10.0"
            }
          }
        ],
        "output": [
          {
            "version": "1.0",
            "author": "user1"
          },
          {
            "version": "1.0",
            "author": "user2",
            "timestamp": "2019-02-05"
          },
          {
            "version": "1.0",
            "author": "user3",
            "price": "10.0"
          }
        ]
      }
    ],
    "identifier": 62421111
  },
  {
    "context": [
      "Of the returned objects, how can I select the object that has latest value for `lastUpdateTime` attribute",
      "You can use `max_by` and provide a path expression,  using which you can sort the array of objects.",
      ".actionExecutionDetails | max_by(.startTime)",
      ".actionExecutionDetails | sort_by(.startTime) | last"
    ],
    "utterance": "Select the object from the array with the latest value for the lastUpdateTime attribute.",
    "expressions": [
      "max_by(.lastUpdateTime)",
      "sort_by(.lastUpdateTime) | last"
    ],
    "data": [
      {
        "input": [
          {
            "pipelineExecutionId": "",
            "actionExecutionId": "",
            "pipelineVersion": 2,
            "stageName": "DeployStage",
            "actionName": "PromoteToProdApprovalGate",
            "startTime": "2020-06-01T22:11:53-04:00",
            "lastUpdateTime": "2020-06-01T22:11:53-04:00",
            "status": "InProgress",
            "input": {
              "actionTypeId": {
                "category": "Approval",
                "owner": "AWS",
                "provider": "Manual",
                "version": "1"
              },
              "configuration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
                "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "resolvedConfiguration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=xxx1",
                "ExternalEntityLink": "http://",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "region": "us-east-1",
              "inputArtifacts": []
            },
            "output": {
              "outputArtifacts": [],
              "outputVariables": {}
            }
          },
          {
            "pipelineExecutionId": "",
            "actionExecutionId": "",
            "pipelineVersion": 1,
            "stageName": "DeployStage",
            "actionName": "PromoteToProdApprovalGate",
            "startTime": "2020-03-31T23:29:14.479000-04:00",
            "lastUpdateTime": "2020-04-03T19:04:51.646000-04:00",
            "status": "Succeeded",
            "input": {
              "actionTypeId": {
                "category": "Approval",
                "owner": "AWS",
                "provider": "Manual",
                "version": "1"
              },
              "configuration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
                "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "resolvedConfiguration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=xxx2",
                "ExternalEntityLink": "http://",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "region": "us-east-1",
              "inputArtifacts": []
            },
            "output": {
              "outputArtifacts": [],
              "executionResult": {
                "externalExecutionId": "",
                "externalExecutionSummary": "Approved by arn:aws:sts:"
              },
              "outputVariables": {}
            }
          },
          {
            "pipelineExecutionId": "",
            "actionExecutionId": "",
            "pipelineVersion": 1,
            "stageName": "DeployStage",
            "actionName": "PromoteToProdApprovalGate",
            "startTime": "2020-03-18T21:10:25.541000-04:00",
            "lastUpdateTime": "2020-03-25T21:10:25.965000-04:00",
            "status": "Failed",
            "input": {
              "actionTypeId": {
                "category": "Approval",
                "owner": "AWS",
                "provider": "Manual",
                "version": "1"
              },
              "configuration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
                "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
                "NotificationArn": "arn:aws:sns:us-east-1"
              },
              "resolvedConfiguration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=xxx3",
                "ExternalEntityLink": "http://",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "region": "us-east-1",
              "inputArtifacts": []
            },
            "output": {
              "outputArtifacts": [],
              "executionResult": {
                "externalExecutionId": ""
              },
              "outputVariables": {}
            }
          },
          {
            "pipelineExecutionId": "",
            "actionExecutionId": "",
            "pipelineVersion": 1,
            "stageName": "DeployStage",
            "actionName": "PromoteToProdApprovalGate",
            "startTime": "2020-03-09T19:23:43.637000-04:00",
            "lastUpdateTime": "2020-03-10T14:48:30.069000-04:00",
            "status": "Failed",
            "input": {
              "actionTypeId": {
                "category": "Approval",
                "owner": "AWS",
                "provider": "Manual",
                "version": "1"
              },
              "configuration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
                "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
                "NotificationArn": "arn:aws:sns:us-east-1"
              },
              "resolvedConfiguration": {
                "CustomData": "Deploy Service to Prod Approval Required for CommitID=xxx4",
                "ExternalEntityLink": "http://",
                "NotificationArn": "arn:aws:sns:us-east-1:"
              },
              "region": "us-east-1",
              "inputArtifacts": []
            },
            "output": {
              "outputArtifacts": [],
              "executionResult": {
                "externalExecutionId": "",
                "externalExecutionSummary": ""
              },
              "outputVariables": {}
            }
          }
        ],
        "output": {
          "pipelineExecutionId": "",
          "actionExecutionId": "",
          "pipelineVersion": 2,
          "stageName": "DeployStage",
          "actionName": "PromoteToProdApprovalGate",
          "startTime": "2020-06-01T22:11:53-04:00",
          "lastUpdateTime": "2020-06-01T22:11:53-04:00",
          "status": "InProgress",
          "input": {
            "actionTypeId": {
              "category": "Approval",
              "owner": "AWS",
              "provider": "Manual",
              "version": "1"
            },
            "configuration": {
              "CustomData": "Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}",
              "ExternalEntityLink": "#{SourceBuildVariables.BB_URL}",
              "NotificationArn": "arn:aws:sns:us-east-1:"
            },
            "resolvedConfiguration": {
              "CustomData": "Deploy Service to Prod Approval Required for CommitID=xxx1",
              "ExternalEntityLink": "http://",
              "NotificationArn": "arn:aws:sns:us-east-1:"
            },
            "region": "us-east-1",
            "inputArtifacts": []
          },
          "output": {
            "outputArtifacts": [],
            "outputVariables": {}
          }
        }
      }
    ],
    "identifier": 62236276
  },
  {
    "context": [
      "I would like to export it (and any file of this type with a larger date range) into the following CSV format using ``jq`` (note the reordering of the fields):",
      "with the conditions that any value associated with a \"state\" attribute (which always exists) different from {A,R,O,W,K} or a \"validated\" attribute (which can be missing) different from 2 is set to the default value -9999.",
      "def adjust:\n  if (.state | test(\"^[AROWK]$\") | not) or .validated != 2 \n  then .value = -9999 \n  else . \n  end;",
      "[\"WDR001\", \"WVR001\", \"WSR001\", \"TLR001\", \"THR001\", \"DTR001\", \"PPR001\", \"RHR001\", \"DDM003\", \"WVM003\", \"FFM003\", \"RHM003\", \"RAIN12\"] as $keys\n| [.data[] | .id as $id | .base[] | . + {id: $id}]\n| group_by(.date)[]\n| map(adjust)\n| .[0].date as $date\n| ( INDEX(.[]; .id ) | map_values({value}) )\n| [ $date, ($keys[] as $k | .[$k].value)]\n| @csv",
      "If you want semi-colon separated values without the quotation marks around the date, you could use `join(;)` instead of `@csv`.",
      "[\"WDR001\", \"WVR001\", \"WSR001\", \"TLR001\", \"THR001\", \"DTR001\", \"PPR001\", \"RHR001\", \"DDM003\", \"WVM003\", \"FFM003\", \"RHM003\", \"RAIN12\"] as $keys\n| [.data[] | .base[] + {id}]\n| group_by(.date)[]\n| map(adjust)\n| .[0].date as $date\n| ( INDEX(.[]; .id ) | map_values({value}) )\n| [ $date, (.[$keys[]]|.value)]\n| @csv"
    ],
    "utterance": "Export a dataset so each row lists a specific date and measurement values in a custom column order, substituting -9999 for any value where 'state' is not one of A, R, O, W, K or 'validated' is not 2.",
    "expressions": [
      "def adjust:\n  if (.state | test(\"^[AROWK]$\") | not) or .validated != 2 \n  then .value = -9999 \n  else . \n  end;\n\n[\"WDR001\", \"WVR001\", \"WSR001\", \"TLR001\", \"THR001\", \"DTR001\", \"PPR001\", \"RHR001\", \"DDM003\", \"WVM003\", \"FFM003\", \"RHM003\", \"RAIN12\"] as $keys\n| [.data[] | .id as $id | .base[] | . + {id: $id}]\n| group_by(.date)[]\n| map(adjust)\n| .[0].date as $date\n| ( INDEX(.[]; .id ) | map_values({value}) )\n| [ $date, ($keys[] as $k | .[$k].value)]\n| @csv",
      "[\"WDR001\", \"WVR001\", \"WSR001\", \"TLR001\", \"THR001\", \"DTR001\", \"PPR001\", \"RHR001\", \"DDM003\", \"WVM003\", \"FFM003\", \"RHM003\", \"RAIN12\"] as $keys\n| [.data[] | .base[] + {id}]\n| group_by(.date)[]\n| map(adjust)\n| .[0].date as $date\n| ( INDEX(.[]; .id ) | map_values({value}) )\n| [ $date, (.[$keys[]]|.value)]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "DDM003",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 335.2,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 330.1,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "DTR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 0.2,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 0.1,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "FFM003",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 2.62,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 3.15,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "RAIN12",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 15.0,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 16.0,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "RHM003",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 85.41,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 85.35,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "WVM003",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 2.56,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 3.08,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "TLR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 14.28,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 14.36,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "THR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 14.07,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 14.23,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "PPR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 999.2,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 998.9,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "RHR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 80.5,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 80.0,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "WDR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 317.71,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 320.31,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "WVR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 2.75,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 2.33,
                  "state": "A",
                  "validated": 2
                }
              ]
            },
            {
              "id": "WSR001",
              "base": [
                {
                  "date": "2020-06-04T00:30:00Z",
                  "value": 2.91,
                  "state": "A",
                  "validated": 2
                },
                {
                  "date": "2020-06-04T01:00:00Z",
                  "value": 2.44,
                  "state": "A",
                  "validated": 2
                }
              ]
            }
          ]
        },
        "output": [
          "\"2020-06-04T00:30:00Z\",317.71,2.75,2.91,14.28,14.07,0.2,999.2,80.5,335.2,2.56,2.62,85.41,15",
          "\"2020-06-04T01:00:00Z\",320.31,2.33,2.44,14.36,14.23,0.1,998.9,80,330.1,3.08,3.15,85.35,16"
        ]
      }
    ],
    "identifier": 62197903
  },
  {
    "context": [
      "In other words, print the `.id.`, `.name`, and iterate over addresses array and print `.id`, `.ipValue.ipStr` and `.hostName`??",
      ".objects[] | .id, .name, (.adresses[] | .id, .ipValue.ipStr, .hostName)",
      "jq -r '.objects[]\n  | [.id, .name] + (.addresses[] | [.id, .ipValue.ipStr, .hostName])\n  | @csv'"
    ],
    "utterance": "For each object, print its id and name, then for each address in its addresses array, print the address id, ipValue.ipStr, and hostName.",
    "expressions": [
      ".objects[] | .id, .name, (.addresses[] | .id, .ipValue.ipStr, .hostName)",
      ".objects[] | [.id, .name] + (.addresses[] | [.id, .ipValue.ipStr, .hostName])"
    ],
    "identifier": 62462000
  },
  {
    "context": [
      "I have a json file and I&#39;m looking to lowercase PART of a value - I can jq the value and lower case the string but how do I ensure this new lowercase value gets added back into the whole file?",
      "jq &#39;.[].Id&#39; file.json | awk &#39;{print tolower($0)}&#39;",
      "the above only lower cases the ID value&#39;s but now I also need to write those back into their correct spots.",
      "Use the [update operator](https://stedolan.github.io/jq/manual/#Update-assignment:|=) with [`ascii_downcase`](https://stedolan.github.io/jq/manual/#ascii_downcase,ascii_upcase) builtin.",
      "jq &#39;.[].Id |= ascii_downcase&#39; file"
    ],
    "utterance": "Lowercase the Id field for every object in the top-level array and update the objects in place.",
    "expressions": [
      ".[].Id |= ascii_downcase"
    ],
    "identifier": 62454640
  },
  {
    "context": [
      "I want to update the NAME and Value in it using the below variables..",
      "It's generally safer, and therefore often better, to use a JSON-aware tool rather than `sed` when editing JSON.",
      "jq --arg name \"$name\" --arg newvalue \"$newvalue\" '\n  .Changes[0].ResourceRecordSet |= \n    (.NAME=$name\n   | .ResourceRecords[0].Value = $newvalue)' <<< \"$rssample\""
    ],
    "utterance": "Update the NAME and first ResourceRecords[0].Value fields to specific values provided as variables.",
    "expressions": [
      ".Changes[0].ResourceRecordSet |= (.NAME=$name | .ResourceRecords[0].Value = $newvalue)",
      "walk(if type == \"object\" then if has(\"NAME\") then .NAME=$name else . end | if has(\"Value\") then .Value = $newvalue else . end else . end)"
    ],
    "data": [
      {
        "input": {
          "Changes": [
            {
              "Action": "UPSERT",
              "ResourceRecordSet": {
                "ResourceRecords": [
                  {
                    "Value": ""
                  }
                ],
                "Type": "TXT",
                "NAME": "",
                "TTL": 300
              }
            }
          ]
        },
        "output": {
          "Changes": [
            {
              "Action": "UPSERT",
              "ResourceRecordSet": {
                "ResourceRecords": [
                  {
                    "Value": "heritage=external-dns,external-dns/owner=us-east-1:sandbox-newtestowner,external-dns/resource=ingress/monitoring/prometheus-operator-alertmanager"
                  }
                ],
                "Type": "TXT",
                "NAME": "testname",
                "TTL": 300
              }
            }
          ]
        }
      }
    ],
    "identifier": 62440381
  },
  {
    "context": [
      "$ jq --argjson cves \"$(cat my-scan-result.json)\" --argjson fqin=\"FQIN\" '.+={$fqin: $cves}' output.json",
      "The phrase `--argjson fqin=\"FQIN\"` is incorrect.  Please see the jq manual for details.  Suffice it to say here that you could achieve the desired effect by writing `--arg fqin \"$FQIN\"`.",
      "The jq expression `{$fqin: $cves}` is incorrect.  When a key name is specified using a variable, the variable must be enclosed in parentheses: `{($fqin): $cves}`.",
      "FQIN=\"example.com/foo/bar:7.0.\" jq -n --argjson cves \"$(cat my-scan-result.json)\" '.+={(env.FQIN): $cves}'"
    ],
    "utterance": "Add an object where the key is the value of a shell variable FQIN and the value is an array read from a file, appending this to an existing file.",
    "expressions": [
      "--arg fqin \"$FQIN\" --argjson cves \"$(cat my-scan-result.json)\" '.+={( $fqin ): $cves}'",
      "FQIN=\"example.com/foo/bar:7.0.\" jq -n --argjson cves \"$(cat my-scan-result.json)\" '.+={(env.FQIN): $cves}'"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "example.com/foo/bar:7.0.3": [
            {
              "cvePK": "CVE-2020-11656",
              "summary": "In SQLite through 3.31.1, the ALTER TABLE implementation has a use-after-free, as demonstrated by an ORDER BY clause that belongs to a compound SELECT statement.",
              "cvss": 7.5,
              "notes": ""
            },
            {
              "cvePK": "CVE-2019-19646",
              "summary": "pragma.c in SQLite through 3.30.1 mishandles NOT NULL in an integrity_check PRAGMA command in certain cases of generated columns.",
              "cvss": 7.5,
              "notes": ""
            }
          ]
        }
      }
    ],
    "identifier": 62442694
  },
  {
    "context": [
      "But I am expecting it to print as `\\\\052.apiconsumer.alpha.sandbox.test.net.`, which is , as it is \"Name\" from the json object..",
      "If you want to see the JSON string, then invoke jq without the -r option.",
      "If you want to invoke jq with the -r option and want to see two backslashes, you will have to encode them as four backslashes in your JSON."
    ],
    "utterance": "Display the value of the Name field with all escape sequences and quotes as in the original representation.",
    "expressions": [
      ".Name"
    ],
    "data": [
      {
        "input": {
          "ResourceRecords": [
            {
              "Value": "heritage=external-dns,external-dns/owner=us-east-1:sandbox,external-dns/resource=service/api"
            }
          ],
          "Type": "TXT",
          "Name": "\\\\052.apiconsumer.alpha.sandbox.test.net.",
          "TTL": 300
        },
        "output": "\"\\\\052.apiconsumer.alpha.sandbox.test.net.\""
      }
    ],
    "identifier": 62463251
  },
  {
    "context": [
      "I just need the value from *\"ItemsQueued\"* to be stored in another variable. Please note that all items occur twice in this string and I need both item values.",
      "$ jq '.[].ItemsQueued' file",
      "0",
      "0"
    ],
    "utterance": "Extract all values associated with the key ItemsQueued from each object in the top-level array.",
    "expressions": [
      ".[].ItemsQueued"
    ],
    "data": [
      {
        "input": [
          {
            "Description": "blablabla",
            "RemoteServerID": "982734298437234",
            "DisplayClass": 101,
            "ActiveWorkers": 0,
            "TotalWorkers": 1,
            "State": 13,
            "ItemsQueued": 0,
            "BytesQueued": 0,
            "LastWorkerSubmitTime": 1592553946,
            "CurrentTime": 1592554151,
            "ItemsReplicated": 456,
            "BytesReplicated": 188588980
          },
          {
            "Description": "blablabla",
            "RemoteServerID": "982734298437234",
            "DisplayClass": 100,
            "ActiveWorkers": 0,
            "TotalWorkers": 6,
            "State": 13,
            "ItemsQueued": 0,
            "BytesQueued": 0,
            "LastWorkerSubmitTime": 1592553615,
            "CurrentTime": 1592554151,
            "ItemsReplicated": 403459,
            "BytesReplicated": 1061944812437
          }
        ],
        "output": [
          0,
          0
        ]
      }
    ],
    "identifier": 62467225
  },
  {
    "context": [
      "Is there any way to disregard those non-array attributes with `jq`?",
      "jq '.categories[][][][] | arrays[]' services.json",
      "jq '.categories[][][][][]?' services.json",
      ".. | strings",
      ".. | strings | select(contains(\".\"))"
    ],
    "utterance": "Extract all strings representing blacklisted hosts from the 'categories' section, skipping non-array attributes and ignoring values like 'true'.",
    "expressions": [
      ".categories[][][][] | arrays[]",
      ".categories[][][][][]?",
      ".. | strings | select(contains(\".\"))"
    ],
    "data": [
      {
        "input": {
          "categories": {
            "Cryptomining": [
              {
                "a.js": {
                  "http://zymerget.bid": [
                    "alflying.date",
                    "alflying.win",
                    "zymerget.faith"
                  ],
                  "performance": "true"
                }
              },
              {
                "CashBeet": {
                  "http://cashbeet.com": [
                    "cashbeet.com",
                    "serv1swork.com"
                  ]
                }
              }
            ]
          }
        },
        "output": [
          "alflying.date",
          "alflying.win",
          "zymerget.faith",
          "cashbeet.com",
          "serv1swork.com"
        ]
      }
    ],
    "identifier": 62493191
  },
  {
    "context": [
      "I have the following JSON that I want to convert to CSV. It is an array of arrays, which contains an object and an array of objects.",
      "The desired is the following:\r\nA,192.1,0,2020-06-12T16:52:10.000Z\r\nA,175.2,0,2020-06-12T16:53:50.000Z\r\nB,176,0,2020-06-12T16:53:25.000Z\r\nB,122.8,0,2020-06-12T16:53:30.000Z\r\nB,122.01,0,2020-06-12T16:55:35.000Z",
      ".[][] | [.name] + (.DATA[] | [.V,.Q,.T]) | @csv",
      "My output is generating the product of `name` and `DATA`, which is not what I need."
    ],
    "utterance": "Produce one CSV row per DATA entry, each containing the parent object's name followed by V, Q, and T values from the DATA entry.",
    "expressions": [
      ".[][] | [.name] + (.DATA[] | [.V,.Q,.T]) | @csv"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "A",
              "DATA": [
                {
                  "V": 192.1,
                  "Q": 0,
                  "T": "2020-06-12T16:52:10.000Z"
                },
                {
                  "V": 175.2,
                  "Q": 0,
                  "T": "2020-06-12T16:53:50.000Z"
                }
              ]
            },
            {
              "name": "B",
              "DATA": [
                {
                  "V": 176,
                  "Q": 0,
                  "T": "2020-06-12T16:53:25.000Z"
                },
                {
                  "V": 122.8,
                  "Q": 0,
                  "T": "2020-06-12T16:53:30.000Z"
                },
                {
                  "V": 122.01,
                  "Q": 0,
                  "T": "2020-06-12T16:55:35.000Z"
                }
              ]
            }
          ]
        ],
        "output": [
          "A,192.1,0,2020-06-12T16:52:10.000Z",
          "A,175.2,0,2020-06-12T16:53:50.000Z",
          "B,176,0,2020-06-12T16:53:25.000Z",
          "B,122.8,0,2020-06-12T16:53:30.000Z",
          "B,122.01,0,2020-06-12T16:55:35.000Z"
        ]
      }
    ],
    "identifier": 62463747
  },
  {
    "context": [
      "I need to replace the \",\" inside Godaddy, and it fails:",
      "jq -r '.transaction_details[]|[.payer_info.payer_name.alternate_full_name|=sub(\",\";\"-\")]' transactions.tx",
      "How do I replace a string with another inside a single member?",
      "You need add some parenthesis :",
      "jq -r '.transaction_details[]|\n      [ .payer_info.payer_name.alternate_full_name | (.|=sub(\",\";\"-\") )\n      ] '",
      "jq -r 'walk(if type == \"string\" then gsub(\",\"; \"-\") else . end)'"
    ],
    "utterance": "Replace commas with dashes in the payer's alternate_full_name field within transaction_details.",
    "expressions": [
      ".transaction_details[] | [ .payer_info.payer_name.alternate_full_name | (.|=sub(\",\";\"-\")) ]",
      "walk(if type == \"string\" then gsub(\",\"; \"-\") else . end)"
    ],
    "identifier": 62505860
  },
  {
    "context": [
      "I wish to add to the \"properties\" section another price, namely the median home price per county. So I have a second json file with data like this:",
      ", where I want all the categories of the 2nd json to be appended to the \"properties\" section as a separate category.",
      "The \"id\" and the \"Full County Number\" in the first and second json files match up exactly. However, the \"Full County Number\" lacks the \"0500000US\" prefix before each county. How might I merge these 2 json files to get the third json with the additional property?",
      "First, a dictionary ($dict) is constructed, and then this dictionary is used to update the first file.",
      "def lpad:\n  tostring | if length < 5 then (\"00000\" + .) | .[-5:] else . end;\n\n\n(input\n | map( with_entries(if .key == \"Full County Number\" \n                     then .key = \"id\" | .value |= \"0500000US\" + lpad \n                     else .\n                     end ) )\n   | INDEX(.[]; .id) ) as $dict\n| inputs\n| .objects.us_counties_20m.geometries |= \n      map( .id as $id \n           | (.properties += $dict[$id]) )"
    ],
    "utterance": "Merge county-level data from a list based on a numeric county code into each corresponding county's properties entry, using a key that requires adding a prefix and left-padding the code to match the ID format.",
    "expressions": [
      "def lpad:\n  tostring | if length < 5 then (\"00000\" + .) | .[-5:] else . end;\n\n(input\n | map( with_entries(if .key == \"Full County Number\" \n                     then .key = \"id\" | .value |= \"0500000US\" + lpad \n                     else .\n                     end ) )\n   | INDEX(.[]; .id) ) as $dict\n| inputs\n| .objects.us_counties_20m.geometries |= \n      map( .id as $id \n           | (.properties += $dict[$id]) )"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Full County Number": 56045,
              "Price-RangeQ42019": "$150,000-$350,000",
              "Geography": "Weston County,  Wyoming",
              "Latitude (generated)": 43.8403,
              "Longitude (generated)": -104.5684,
              "Q42019 Price": "$178,218"
            },
            {
              "Full County Number": 56043,
              "Price-RangeQ42019": "$150,000-$350,000",
              "Geography": "Washakie County,  Wyoming",
              "Latitude (generated)": 43.8356,
              "Longitude (generated)": -107.6602,
              "Q42019 Price": "$170,665"
            }
          ],
          {
            "type": "Topology",
            "transform": {
              "scale": [
                0.035896170617061705,
                0.005347309530953095
              ],
              "translate": [
                -179.14734,
                17.884813
              ]
            },
            "objects": {
              "us_counties_20m": {
                "type": "GeometryCollection",
                "geometries": [
                  {
                    "type": "Polygon",
                    "arcs": [
                      [
                        0,
                        1,
                        2,
                        3,
                        4
                      ]
                    ],
                    "id": "0500000US56043",
                    "properties": {
                      "PRICE": 48863
                    }
                  },
                  {
                    "type": "Polygon",
                    "arcs": [
                      [
                        5,
                        6,
                        7,
                        8,
                        9,
                        10
                      ]
                    ],
                    "id": "0500000US56045",
                    "properties": {
                      "PRICE": 41940
                    }
                  }
                ]
              }
            }
          }
        ],
        "output": {
          "type": "Topology",
          "transform": {
            "scale": [
              0.035896170617061705,
              0.005347309530953095
            ],
            "translate": [
              -179.14734,
              17.884813
            ]
          },
          "objects": {
            "us_counties_20m": {
              "type": "GeometryCollection",
              "geometries": [
                {
                  "type": "Polygon",
                  "arcs": [
                    [
                      0,
                      1,
                      2,
                      3,
                      4
                    ]
                  ],
                  "id": "0500000US56043",
                  "properties": {
                    "PRICE": 48863,
                    "Price-RangeQ42019": "$150,000-$350,000",
                    "Geography": "Washakie County,  Wyoming",
                    "Latitude (generated)": 43.8356,
                    "Longitude (generated)": -107.6602,
                    "Q42019 Price": "$170,665"
                  }
                },
                {
                  "type": "Polygon",
                  "arcs": [
                    [
                      5,
                      6,
                      7,
                      8,
                      9,
                      10
                    ]
                  ],
                  "id": "0500000US56045",
                  "properties": {
                    "PRICE": 41940,
                    "Price-RangeQ42019": "$150,000-$350,000",
                    "Geography": "Weston County,  Wyoming",
                    "Latitude (generated)": 43.8403,
                    "Longitude (generated)": -104.5684,
                    "Q42019 Price": "$178,218"
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 62434205
  },
  {
    "context": [
      "I want to create JSON output *with jq* that looks like this:\r\n\r\n    {\r\n      \"records\": [\r\n        {\r\n          \"id\": \"1234\",\r\n          \"song\": \"Yesterday\",\r\n          \"artist\": \"The Beatles\"\r\n        }\r\n      ]\r\n    }",
      "jq --null-input               \\\r\n   --arg id 1234              \\\r\n   --arg song Yesterday       \\\r\n   --arg artist \"The Beatles\" \\\r\n'.records[0] = {$id, $song, $artist}'",
      "jq-1.6` you can use the $ARGS.positional attribute to construct your JSON from scratch\r\n\r\n    jq -n '\r\n      $ARGS.positional | { \r\n        records: [ \r\n          { \r\n            id:     .[0], \r\n            song:   .[1], \r\n            artist: .[2]   \r\n          }\r\n        ] \r\n      }' --args 1234 Yesterday \"The Beatles\"",
      "Another, cleaner, approach based on the answer of @Inian could be\r\n\r\n    jq -n \\\r\n       --arg id 1234\r\n       --arg song Yesterday\r\n       --arg artist \"The Beatles\"\r\n       '{records: [{id:$id, song:$song, artist:$artist}]}'",
      "jq  --null-input\\\r\n    --argjson id     1234\\\r\n    --arg     song   Yesterday\\\r\n    --arg     artist \"The Beatles\"\\\r\n    '{ \"records\" : [{ $id, $song, $artist }] }'"
    ],
    "utterance": "Create an object with a top-level key 'records' containing an array with one object where id is 1234, song is 'Yesterday', and artist is 'The Beatles'.",
    "expressions": [
      "jq --null-input --arg id 1234 --arg song Yesterday --arg artist \"The Beatles\" '.records[0] = {$id, $song, $artist}'",
      "jq -n --arg id 1234 --arg song Yesterday --arg artist \"The Beatles\" '{records: [{id:$id, song:$song, artist:$artist}]}'",
      "jq --null-input --argjson id 1234 --arg song Yesterday --arg artist \"The Beatles\" '{ \"records\" : [{ $id, $song, $artist }] }'",
      "jq -n '$ARGS.positional | {records: [{id: .[0], song: .[1], artist: .[2]}]}' --args 1234 Yesterday \"The Beatles\""
    ],
    "data": [
      {
        "input": {},
        "output": {
          "records": [
            {
              "id": "1234",
              "song": "Yesterday",
              "artist": "The Beatles"
            }
          ]
        }
      }
    ],
    "identifier": 62468117
  },
  {
    "context": [
      "And I want any of these options:",
      "Option 1:\n{\n  \"DomainName\": \"test\",\n  \"Endpoint\": \"test.com\",\n  \"ElasticsearchClusterConfig\": {\n    \"InstanceType\": \"t2.medium.elasticsearch\",\n    \"InstanceCount\": 2,\n  }\n}",
      "Option 2:\n{\n  \"DomainName\": \"test\",\n  \"Endpoint\": \"test.com\",\n  \"InstanceType\": \"t2.medium.elasticsearch\",\n  \"InstanceCount\": 2,\n}",
      "I achieved Option 2 using:\njq '.DomainStatus | {DomainName, Endpoint, InstanceType: .ElasticsearchClusterConfig.InstanceType, InstanceCount: .ElasticsearchClusterConfig.InstanceCount}'",
      "BUT the problem is that **I don't want to write redundant code**.",
      "It want something like this: `.ElasticsearchClusterConfig | {InstanceType, InstanceCount}` inside the **jq** command I wrote before.",
      "You don't have to repeat any code. You can instruct `jq` to keep only the fields you want. The `|=`, assignment update operator modifies the object to its left, by recreating it with fields on its right. In our case, only update the ones you need.",
      ".DomainStatus | { \n    DomainName, \n    Endpoint, \n    ElasticsearchClusterConfig: (\n       .ElasticsearchClusterConfig | { \n           InstanceType, \n           InstanceCount \n       }\n    )\n}",
      "or option 2, if you don't want to type out the names explicitly, use a placeholder like",
      ".DomainStatus | .ElasticsearchClusterConfig as $ec | { \n    DomainName, \n    Endpoint, \n    InstanceType:  $ec.InstanceType, \n    InstanceCount: $ec.InstanceCount\n}"
    ],
    "utterance": "Extract the DomainName and Endpoint from DomainStatus, and for ElasticsearchClusterConfig, keep only InstanceType and InstanceCount.",
    "expressions": [
      ".DomainStatus | { DomainName, Endpoint, ElasticsearchClusterConfig: ( .ElasticsearchClusterConfig | { InstanceType, InstanceCount } ) }"
    ],
    "data": [
      {
        "input": {
          "DomainStatus": {
            "DomainId": "12345",
            "DomainName": "test",
            "ARN": "arn:aws:es:eu-west-1:12345:domain/test",
            "Created": true,
            "Deleted": false,
            "Endpoint": "test.com",
            "Processing": false,
            "UpgradeProcessing": false,
            "ElasticsearchVersion": "5.3",
            "ElasticsearchClusterConfig": {
              "InstanceType": "t2.medium.elasticsearch",
              "InstanceCount": 2,
              "DedicatedMasterEnabled": false,
              "ZoneAwarenessEnabled": true,
              "ZoneAwarenessConfig": {
                "AvailabilityZoneCount": 2
              }
            },
            "EBSOptions": {
              "EBSEnabled": true,
              "VolumeType": "gp2",
              "VolumeSize": 30
            }
          }
        },
        "output": {
          "DomainName": "test",
          "Endpoint": "test.com",
          "ElasticsearchClusterConfig": {
            "InstanceType": "t2.medium.elasticsearch",
            "InstanceCount": 2
          }
        }
      }
    ],
    "identifier": 62467840
  },
  {
    "context": [
      "I want to add a key-value pair to a JSON using jq, but it also needs to add the parent if that doesn&#39;t exists.",
      "The key **'base_parameters'** might not exist.",
      "If it&#39;s certain that the key `base_parameters` is either nonexistent or has an object value, simply assigning a value to `.base_parameters.app_name` will just work.",
      ".notebook_task.base_parameters.app_name = \"testapp\""
    ],
    "utterance": "Add the key 'app_name' with the value 'testapp' under 'base_parameters' inside 'notebook_task', creating 'base_parameters' if it does not exist.",
    "expressions": [
      ".notebook_task.base_parameters.app_name = \"testapp\""
    ],
    "data": [
      {
        "input": {
          "notebook_task": {
            "notebook_path": "/Applications/dbtest/addcol",
            "base_parameters": {}
          }
        },
        "output": {
          "notebook_task": {
            "notebook_path": "/Applications/dbtest/addcol",
            "base_parameters": {
              "app_name": "testapp"
            }
          }
        }
      },
      {
        "input": {
          "notebook_task": {
            "notebook_path": "/Applications/dbtest/addcol"
          }
        },
        "output": {
          "notebook_task": {
            "notebook_path": "/Applications/dbtest/addcol",
            "base_parameters": {
              "app_name": "testapp"
            }
          }
        }
      }
    ],
    "identifier": 62514985
  },
  {
    "context": [
      "but I can't seem to get to the `Name` value in `Tags` thats not nested. I've done it this way but its still nested:",
      "`aws ec2 describe-instances | jq '.Reservations[] | {type: .Instances[].InstanceType, name: .Instances[].Tags[] | select (.Key == \"Name\")}''`",
      "Expand `Instances` once to avoid a combinatorial explosion. To apply a filter to the result(s) of `select`, simply write the filter next to it.",
      "`.Reservations[].Instances[] | {InstanceType, name: .Tags[] | select(.Key == \"Name\") .Value}`"
    ],
    "utterance": "Extract each instance's InstanceType and the Value from the tag where Key is \"Name\" as a flat object.",
    "expressions": [
      ".Reservations[].Instances[] | {InstanceType, name: .Tags[] | select(.Key == \"Name\") .Value}"
    ],
    "identifier": 62519154
  },
  {
    "context": [
      "but instead of \".name\"\r\nwant to print \".items[].metadata.name\"",
      "```\r\n.items[] as $i\r\n| spec.volumes[].configMap|select(.name==\"webdata\")\r\n| $i\r\n| .metadata.name\r\n```"
    ],
    "utterance": "For each pod, if any of its volumes' configMap has name equal to \"webdata\", print the pod's metadata.name.",
    "expressions": [
      ".items[] as $i | select(.spec.volumes[].configMap? // {} | .name == \"webdata\") | .metadata.name"
    ],
    "identifier": 62537153
  },
  {
    "context": [
      "I need to change the availableMemory setting to an integer so it looks like this:",
      "I know that there is a `|tonumber` available but cannot seem to figure out the syntax to get it working when setting a property.",
      "To achieve the desired effect using the `MEMSET=... jq ...` style, one could write:",
      ".memoryConfiguration.availableMemory=(env.MEMSET|tonumber)",
      "To pass in an integer value as a JSON number, use --argjson rather than --arg:",
      "jq --argjson MyMemSetting \"$SETMEM\" '.memoryConfiguration.availableMemory=$MyMemSetting' my_json_file.json"
    ],
    "utterance": "Set the property memoryConfiguration.availableMemory to an integer value from a shell variable, ensuring the property is a number and not a string.",
    "expressions": [
      ".memoryConfiguration.availableMemory = (env.MEMSET | tonumber)",
      ".memoryConfiguration.availableMemory = $MyMemSetting"
    ],
    "data": [
      {
        "input": {
          "memoryConfiguration": {
            "optimizeMemorySettingsOnSave": true,
            "availableMemory": "30167040",
            "sharedBuffers": 209715,
            "workMem": 4194,
            "effectiveCacheSize": 786432,
            "maintenanceWorkMem": 65536
          }
        },
        "output": {
          "memoryConfiguration": {
            "optimizeMemorySettingsOnSave": true,
            "availableMemory": 30167040,
            "sharedBuffers": 209715,
            "workMem": 4194,
            "effectiveCacheSize": 786432,
            "maintenanceWorkMem": 65536
          }
        }
      }
    ],
    "identifier": 62515926
  },
  {
    "context": [
      "I need to select only elements `somekey` where `id` isn\u2019t a substring of `somekey`",
      "Here is what I have tried that comes closest to a success:\r\n\r\n    jq .[] | select(.somekey|contains(.id)|not)",
      "`jq 'map(select(.id as $id | .somekey | contains($id) | not))'`"
    ],
    "utterance": "Select all objects where the value of id does not appear as a substring in the value of somekey.",
    "expressions": [
      "map(select(.id as $id | .somekey | contains($id) | not))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "abcd",
            "somekey": "abcdrestofchain"
          },
          {
            "id": "efgh",
            "somekey": "mnoprestofchain"
          },
          {
            "id": "ijkl",
            "somekey": "xyzrestofchain"
          }
        ],
        "output": [
          {
            "id": "efgh",
            "somekey": "mnoprestofchain"
          },
          {
            "id": "ijkl",
            "somekey": "xyzrestofchain"
          }
        ]
      }
    ],
    "identifier": 62579312
  },
  {
    "context": [
      "I actually have 2 arrays in bash that contains string values.",
      "I would like to create a json with 2 attributes, something like that if possible",
      "{ \"results\":[ { \"nom\":\"Kevin\", \"status\":\"OK\" }, { \"nom\":\"Paul\", \"status\":\"Danger\" } ] }",
      "paste <(printf \"%s\\n\" \"${Array1[@]}\") <(printf \"%s\\n\" \"${Array2[@]}\") | jq -nRc '{ results: [inputs] | map(split(\"\\t\") | { nom: .[0], status: .[1] }) }'",
      "produces {\"results\":[{\"nom\":\"Kevin\",\"status\":\"OK\"},{\"nom\":\"Paul\",\"status\":\"DANGER\"}]}",
      "It uses `paste` to generate pairs of corresponding array elements, separated by tabs, one pair per line, and then uses `jq` to create the JSON output from that."
    ],
    "utterance": "Pair elements of two arrays as objects with 'nom' and 'status' keys and output as a results array.",
    "expressions": [
      "{ results: [inputs] | map(split(\"\\t\") | { nom: .[0], status: .[1] }) }"
    ],
    "data": [
      {
        "input": [
          [
            "Kevin",
            "Paul"
          ],
          [
            "OK",
            "DANGER"
          ]
        ],
        "output": {
          "results": [
            {
              "nom": "Kevin",
              "status": "OK"
            },
            {
              "nom": "Paul",
              "status": "DANGER"
            }
          ]
        }
      }
    ],
    "identifier": 62534710
  },
  {
    "context": [
      "I have a json file that looks like this: ... \"components\": [], ... \"timetracking\": {} ... I'd like to remove the empty arrays like timetracking and components.",
      "if you want to remove the keys that have values equal to [] or {}, then you could use `walk` like so:",
      "walk(if type == \"object\" \n     then with_entries(if .value == {} or .value == [] then empty else . end) \n     else . end)",
      "This can also be written more compactly as:",
      "walk(if type == \"object\" then with_entries(select(.value | (. != {} and . != []))) else . end)"
    ],
    "utterance": "Remove all key-value pairs from objects where the value is an empty object or empty array.",
    "expressions": [
      "walk(if type == \"object\" then with_entries(if .value == {} or .value == [] then empty else . end) else . end)",
      "walk(if type == \"object\" then with_entries(select(.value | (. != {} and . != []))) else . end)"
    ],
    "data": [
      {
        "input": [
          [
            [
              [
                {
                  "expand": "renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations",
                  "id": "10000",
                  "self": "https://test.atlassian.net/rest/api/latest/issue/10000",
                  "key": "AGILE-1",
                  "components": [],
                  "timetracking": {}
                }
              ]
            ]
          ]
        ],
        "output": [
          [
            [
              [
                {
                  "expand": "renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations",
                  "id": "10000",
                  "self": "https://test.atlassian.net/rest/api/latest/issue/10000",
                  "key": "AGILE-1"
                }
              ]
            ]
          ]
        ]
      }
    ],
    "identifier": 62564201
  },
  {
    "context": [
      "I need to get instance id and volumed id in same line as given below.",
      "```\nExpected output\n\"i-f5ada1f18 vol-66a8adas2a2d\"\n\"i-bb064fda12140 vol-52951f1dss9\"\n\"i-3e1059sc5asd vol-0da2ds122846\"\n```",
      ".Reservations[].Instances[] | .InstanceId, .BlockDeviceMappings[].Ebs.VolumeId",
      "You can try below command with `AWK` and `sed`"
    ],
    "utterance": "Return each stopped or shutting-down EC2 instance's instance id and its attached volume id together on the same line, space-separated.",
    "expressions": [
      ".Reservations[].Instances[] | .BlockDeviceMappings[] | \"\u007f{.InstanceId} \u007f{.Ebs.VolumeId}\""
    ],
    "identifier": 62592374
  },
  {
    "context": [
      "but i need all key with out space and uppercase with {#JSON_KEY} plus CONSECUTIVE_FAILURES value and IS_DELETED value with \" \"  :",
      "all key with out space and uppercase with {#JSON_KEY}",
      "- CONSECUTIVE_FAILURES value and IS_DELETED value with \" \"",
      "- see only item with CONSECUTIVE_FAILURES > 0 in one single array",
      "something like this:",
      "One sigle array with all errrors.",
      "map(with_entries( .key |= ( gsub( \" \"; \"_\")\n                            | ascii_upcase \n                            | \"{#\\(.)}\" )\n                  | .value |= tostring))"
    ],
    "utterance": "Return a single array of all objects from both 'repsFrom' and 'repsTo' where CONSECUTIVE_FAILURES is greater than 0, with all keys transformed to uppercase, spaces replaced by underscores, each key wrapped in {#...}, and all values converted to strings.",
    "expressions": [
      "[.repsFrom[], .repsTo[]]\n| map(select(.\"consecutive failures\" > 0)\n       | with_entries(\n           .key |= (gsub(\" \"; \"_\") | ascii_upcase | \"{#\" + . + \"}\")\n           | .value |= tostring\n         )\n     )"
    ],
    "data": [
      {
        "input": {
          "dsa": {
            "options": 1,
            "objectGUID": "373f09c9-43ab-489b-9bed-c5357fbe37df",
            "invocationId": "e0e99a5d-9162-4c96-93e1-939976bee141"
          },
          "repsFrom": [
            {
              "NC dn": "DC=company,DC=org",
              "DSA objectGUID": "df9e8712-98c5-42e4-a020-2e5218404e51",
              "last attempt time": "Thu Jun 11 14:27:42 2020 CEST",
              "last attempt message": "was successful",
              "consecutive failures": 1,
              "last success": "Thu Jun 11 14:27:42 2020 CEST",
              "NTDS DN": "CN=NTDS Settings,CN=STEN0002-R2,CN=Servers,CN=TENGIZ,CN=Sites,CN=Configuration,DC=company,DC=org",
              "is deleted": false,
              "DSA": "TENGIZ\\STEN0002-R2"
            },
            {
              "NC dn": "DC=company,DC=org",
              "DSA objectGUID": "d5d168fd-5fc3-4afc-9acc-32c7f10d14a2",
              "last attempt time": "Thu Jun 11 14:27:43 2020 CEST",
              "last attempt message": "was successful",
              "consecutive failures": 1,
              "last success": "Thu Jun 11 14:27:43 2020 CEST",
              "NTDS DN": "CN=NTDS Settings,CN=SCGPN0002-R2,CN=Servers,CN=POINTE-NOIRE,CN=Sites,CN=Configuration,DC=company,DC=org",
              "is deleted": false,
              "DSA": "POINTE-NOIRE\\SCGPN0002-R2"
            }
          ],
          "repsTo": [
            {
              "NC dn": "DC=company,DC=org",
              "DSA objectGUID": "86f053eb-36d7-41e4-b944-7bcd9fcb8aaa",
              "last attempt time": "NTTIME(0)",
              "last attempt message": "was successful",
              "consecutive failures": 1,
              "last success": "NTTIME(0)",
              "NTDS DN": "CN=NTDS Settings,CN=SMX0840002-R4,CN=Servers,CN=MX084,CN=Sites,CN=Configuration,DC=company,DC=org",
              "is deleted": false,
              "DSA": "MX084\\SMX0840002-R4"
            },
            {
              "NC dn": "DC=company,DC=org",
              "DSA objectGUID": "6e98ac67-389b-488a-ae3e-abf36d38ba73",
              "last attempt time": "NTTIME(0)",
              "last attempt message": "was successful",
              "consecutive failures": 0,
              "last success": "NTTIME(0)",
              "NTDS DN": "CN=NTDS Settings,CN=SCZ0002,CN=Servers,CN=CZ003,CN=Sites,CN=Configuration,DC=company,DC=org",
              "is deleted": false,
              "DSA": "CZ003\\SCZ0002"
            }
          ],
          "NTDSConnections": [
            {
              "name": "dc6118e7-eca5-4c2c-8248-2e762104e95a",
              "remote DN": "CN=NTDS Settings,CN=SPRLIMA0002-R2,CN=Servers,CN=PR-LIMA,CN=Sites,CN=Configuration,DC=company,DC=org",
              "options": 1,
              "enabled": true,
              "dns name": "sprlima0002-r2.company.org",
              "replicates NC": []
            },
            {
              "name": "9aa7d28f-5b08-42fe-960a-073c8ebfa4fb",
              "remote DN": "CN=NTDS Settings,CN=SMX0840002-R4,CN=Servers,CN=MX084,CN=Sites,CN=Configuration,DC=company,DC=org",
              "options": 1,
              "enabled": true,
              "dns name": "smx0840002-r4.company.org",
              "replicates NC": []
            }
          ]
        },
        "output": [
          {
            "{#NC_DN}": "DC=company,DC=org",
            "{#DSA_OBJECTGUID}": "df9e8712-98c5-42e4-a020-2e5218404e51",
            "{#LAST_ATTEMPT_TIME}": "Thu Jun 11 14:27:42 2020 CEST",
            "{#LAST_ATTEMPT_MESSAGE}": "was successful",
            "{#CONSECUTIVE_FAILURES}": "1",
            "{#LAST_SUCCESS}": "Thu Jun 11 14:27:42 2020 CEST",
            "{#NTDS_DN}": "CN=NTDS Settings,CN=STEN0002-R2,CN=Servers,CN=TENGIZ,CN=Sites,CN=Configuration,DC=company,DC=org",
            "{#IS_DELETED}": "false",
            "{#DSA}": "TENGIZ\\STEN0002-R2"
          },
          {
            "{#NC_DN}": "DC=company,DC=org",
            "{#DSA_OBJECTGUID}": "d5d168fd-5fc3-4afc-9acc-32c7f10d14a2",
            "{#LAST_ATTEMPT_TIME}": "Thu Jun 11 14:27:43 2020 CEST",
            "{#LAST_ATTEMPT_MESSAGE}": "was successful",
            "{#CONSECUTIVE_FAILURES}": "1",
            "{#LAST_SUCCESS}": "Thu Jun 11 14:27:43 2020 CEST",
            "{#NTDS_DN}": "CN=NTDS Settings,CN=SCGPN0002-R2,CN=Servers,CN=POINTE-NOIRE,CN=Sites,CN=Configuration,DC=company,DC=org",
            "{#IS_DELETED}": "false",
            "{#DSA}": "POINTE-NOIRE\\SCGPN0002-R2"
          },
          {
            "{#NC_DN}": "DC=company,DC=org",
            "{#DSA_OBJECTGUID}": "86f053eb-36d7-41e4-b944-7bcd9fcb8aaa",
            "{#LAST_ATTEMPT_TIME}": "NTTIME(0)",
            "{#LAST_ATTEMPT_MESSAGE}": "was successful",
            "{#CONSECUTIVE_FAILURES}": "1",
            "{#LAST_SUCCESS}": "NTTIME(0)",
            "{#NTDS_DN}": "CN=NTDS Settings,CN=SMX0840002-R4,CN=Servers,CN=MX084,CN=Sites,CN=Configuration,DC=company,DC=org",
            "{#IS_DELETED}": "false",
            "{#DSA}": "MX084\\SMX0840002-R4"
          }
        ]
      }
    ],
    "identifier": 62312365
  },
  {
    "context": [
      "I have this JSON file:",
      "[{\"ParameterKey\": \"EC2KeyPair\", \"ParameterValue\": \"$YOUR_EC2_KEY_PAIR\"}, ... ]",
      "And I want to turn it into this:",
      "'EC2KeyPair=$YOUR_EC2_KEY_PAIR SSHLocation=$YOUR_SSH_LOCATION DjangoEnvVarDebug=$YOUR_DJANGO_ENV_VAR_DEBUG DjangoEnvVarSecretKey=$YOUR_DJANGO_ENV_VAR_SECRET_KEY DjangoEnvVarDBName=$YOUR_DJANGO_ENV_VAR_DB_NAME DjangoEnvVarDBUser=$YOUR_DJANGO_ENV_VAR_DB_USER DjangoEnvVarDBPassword=$YOUR_DJANGO_ENV_VAR_DB_PASSWORD DjangoEnvVarDBHost=$YOUR_DJANGO_ENV_VAR_DB_HOST'",
      "But I'm not sure how to join the strings together. I was looking at reduce but I think it only works on lists, and streams of strings aren't lists.",
      "it can easily be achieved using the -r command-line option together with the filter:",
      "map(\"\\(.ParameterKey)=\\(.ParameterValue)\") | \"'\" + join(\" \") + \"'\""
    ],
    "utterance": "Convert an array of objects containing ParameterKey and ParameterValue fields into a space-separated string of key=value pairs, enclosed in single quotes.",
    "expressions": [
      "map(\"\\(.ParameterKey)=\\(.ParameterValue)\") | \"'\" + join(\" \") + \"'\""
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "EC2KeyPair",
            "ParameterValue": "$YOUR_EC2_KEY_PAIR"
          },
          {
            "ParameterKey": "SSHLocation",
            "ParameterValue": "$YOUR_SSH_LOCATION"
          },
          {
            "ParameterKey": "DjangoEnvVarDebug",
            "ParameterValue": "$YOUR_DJANGO_ENV_VAR_DEBUG"
          },
          {
            "ParameterKey": "DjangoEnvVarSecretKey",
            "ParameterValue": "$YOUR_DJANGO_ENV_VAR_SECRET_KEY"
          },
          {
            "ParameterKey": "DjangoEnvVarDBName",
            "ParameterValue": "$YOUR_DJANGO_ENV_VAR_DB_NAME"
          },
          {
            "ParameterKey": "DjangoEnvVarDBUser",
            "ParameterValue": "$YOUR_DJANGO_ENV_VAR_DB_USER"
          },
          {
            "ParameterKey": "DjangoEnvVarDBPassword",
            "ParameterValue": "$YOUR_DJANGO_ENV_VAR_DB_PASSWORD"
          },
          {
            "ParameterKey": "DjangoEnvVarDBHost",
            "ParameterValue": "$YOUR_DJANGO_ENV_VAR_DB_HOST"
          }
        ],
        "output": "'EC2KeyPair=$YOUR_EC2_KEY_PAIR SSHLocation=$YOUR_SSH_LOCATION DjangoEnvVarDebug=$YOUR_DJANGO_ENV_VAR_DEBUG DjangoEnvVarSecretKey=$YOUR_DJANGO_ENV_VAR_SECRET_KEY DjangoEnvVarDBName=$YOUR_DJANGO_ENV_VAR_DB_NAME DjangoEnvVarDBUser=$YOUR_DJANGO_ENV_VAR_DB_USER DjangoEnvVarDBPassword=$YOUR_DJANGO_ENV_VAR_DB_PASSWORD DjangoEnvVarDBHost=$YOUR_DJANGO_ENV_VAR_DB_HOST'"
      }
    ],
    "identifier": 62559544
  },
  {
    "context": [
      "I am trying to get the number of records with a count of 1.",
      "Use `jq 'map(select(.count==1))|length' in.json`.",
      "Here\u2019s one efficient solution ... the solution is simply:\n\n    count(.[] | select(.count==1))"
    ],
    "utterance": "Count the number of objects in the array where count equals 1.",
    "expressions": [
      "map(select(.count==1)) | length",
      "count(.[] | select(.count==1))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 0,
            "count": 1
          },
          {
            "id": 1,
            "count": 1
          },
          {
            "id": 2,
            "count": 0
          }
        ],
        "output": 2
      }
    ],
    "identifier": 62618271
  },
  {
    "context": [
      "I need to have XEJLuJyxLDE after \"id\": only , pretty long list and I'm very new to linux and jq.",
      "My command now is which doesn't work ```curl -s 'https://www.googleapis.com/youtube/v3/videos?chart=mostPopular&locale=RU&maxResults=50&key=MY_API_HERE'  --header 'Accept: application/json' | jq \".id\"```",
      "You can use:\r\n\r\n    jq '.items[].id'\r\n\r\nto retrieve all `id`s."
    ],
    "utterance": "Extract all values of the 'id' field from the list under 'items'.",
    "expressions": [
      ".items[].id"
    ],
    "data": [
      {
        "input": {
          "kind": "youtube#videoListResponse",
          "etag": "peo7sRMHdYZRkNABiJLj7xYZ0yo",
          "items": [
            {
              "kind": "youtube#video",
              "etag": "DrIQh9Tabqk3iak4yonUCzJ3sTk",
              "id": "XEJLuJyxLDE"
            },
            {
              "kind": "youtube#video",
              "etag": "1pZQ8jDaavX6KnOyiFrHQQiZtHo",
              "id": "jO0luDEHesc"
            },
            {
              "kind": "youtube#video",
              "etag": "EJZ20jnqkqp7uTg5krUSK1SQE5s",
              "id": "ixl31324UxE"
            }
          ]
        },
        "output": [
          "XEJLuJyxLDE",
          "jO0luDEHesc",
          "ixl31324UxE"
        ]
      }
    ],
    "identifier": 62595453
  },
  {
    "context": [
      "The only command I have found which successfully merges all input files into one output array is:\r\n\r\n```shell\r\njq --slurp '[0] + .[1]' file1.json file2.json\r\n```",
      "I'm writing a shell script which is expected to merge a variable set of files into a single JSON array as an output. My script will execute something like:\r\n\r\n```shell\r\nfind . -type f -iname '*.json' | xargs jq 'FILTER'\r\n```\r\n\r\nThis should invoke `jq` like `jq 'FILTER' file1.json file2.json ...`.",
      "Is there a feature that I'm missing that will take all input files and first merge them into one contiguous list of objects without having to rewrite the filter to something like `.[0] + .[1] + .[2] ...`?",
      "jq --slurp 'map(.[])' 1.json 2.json 3.json",
      "jq --slurp 'flatten' 1.json 2.json 3.json",
      "if your version of jq supports `inputs`, you could write:\r\n\r\n    jq -n '[inputs[]]' 1.json 2.json 3.json # etc",
      "Otherwise, you could simply write:\r\n\r\n    jq -s add 1.json 2.json 3.json # etc"
    ],
    "utterance": "Combine the contents of multiple files where each file contains an array of objects into a single array containing all objects from all files.",
    "expressions": [
      "map(.[])",
      "flatten",
      "[inputs[]]",
      "add"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 1
            }
          ],
          [
            {
              "id": 2
            }
          ],
          [
            {
              "id": 3
            }
          ]
        ],
        "output": [
          {
            "id": 1
          },
          {
            "id": 2
          },
          {
            "id": 3
          }
        ]
      }
    ],
    "identifier": 62603453
  },
  {
    "context": [
      "I would like to parse the file to convert the epoch into human readable date format.",
      "I also presume the value has to be divided by 1000 to get the milliseconds away but dont see how to get both working.",
      "With JQ, convert each timestamp to a number, divide the result by 1000 to get a value that date manipulation builtins could understand, and feed it to `strflocaltime` to get a human-readable date string.",
      "$ jq '[].Date |= (tonumber / 1000 | strflocaltime(\"%c %Z\"))' file"
    ],
    "utterance": "Replace each string timestamp value in the Date field, given in milliseconds since epoch, with a formatted human-readable date string including time and timezone offset.",
    "expressions": [
      ".[].Date |= (tonumber / 1000 | strflocaltime(\"%c %Z\"))"
    ],
    "data": [
      {
        "input": [
          {
            "Date": "1555095683495",
            "read": "1"
          },
          {
            "Date": "1555578329532",
            "read": "1"
          }
        ],
        "output": [
          {
            "Date": "Fri Apr 12 22:01:23 2019 +03",
            "read": "1"
          },
          {
            "Date": "Thu Apr 18 12:05:29 2019 +03",
            "read": "1"
          }
        ]
      }
    ],
    "identifier": 62633272
  },
  {
    "context": [
      "You could use jq to emit the top-level items in the array, one per line, as follows:\r\n\r\n    jq -c '.[]' file.json\r\n",
      "If you want to split it say 10,000 records per file."
    ],
    "utterance": "Emit each top-level array item as a compact line, so records are newline-delimited.",
    "expressions": [
      "jq -c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 683156,
            "overall_rating": 5.0,
            "hotel_id": 220216,
            "hotel_name": "Beacon Hill Hotel",
            "title": "\u201cgreat hotel, great location\u201d",
            "text": "The rooms here are not palatial",
            "author_id": "C0F"
          },
          {
            "id": 692745,
            "overall_rating": 5.0,
            "hotel_id": 113317,
            "hotel_name": "Casablanca Hotel Times Square",
            "title": "\u201cabsolutely delightful\u201d",
            "text": "I travelled from Spain...",
            "author_id": "8C1"
          }
        ],
        "output": [
          "{\"id\":683156,\"overall_rating\":5.0,\"hotel_id\":220216,\"hotel_name\":\"Beacon Hill Hotel\",\"title\":\"\u201cgreat hotel, great location\u201d\",\"text\":\"The rooms here are not palatial\",\"author_id\":\"C0F\"}",
          "{\"id\":692745,\"overall_rating\":5.0,\"hotel_id\":113317,\"hotel_name\":\"Casablanca Hotel Times Square\",\"title\":\"\u201cabsolutely delightful\u201d\",\"text\":\"I travelled from Spain...\",\"author_id\":\"8C1\"}"
        ]
      }
    ],
    "identifier": 62611438
  },
  {
    "context": [
      "jq -n --arg x \"bar\" '{foo: $x}'",
      "Or use string interpolation:\n\njq -n --arg x \"bar\" '{foo: \"\\($x)\"}'",
      "jq -n --arg x 123 '{\"foo\": $x}' > foo.json",
      "jq -n  '{\"foo\": \"'\"$(SOME_VAR)'\"\"}' > foo.json"
    ],
    "utterance": "Produce an object with a property 'foo' whose value is taken from a variable passed into the command, such as 'bar', '123', or the value of SOME_VAR",
    "expressions": [
      "jq -n --arg x \"bar\" '{foo: $x}'",
      "jq -n --arg x \"bar\" '{foo: \"\\($x)\"}'",
      "jq -n --arg x 123 '{\"foo\": $x}'",
      "jq -n  '{\"foo\": \"'\"$(SOME_VAR)'\"\"}'"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "foo": "bar"
        }
      },
      {
        "input": {},
        "output": {
          "foo": "123"
        }
      },
      {
        "input": {},
        "output": {
          "foo": "my-var"
        }
      }
    ],
    "identifier": 62645974
  },
  {
    "context": [
      "I am trying to get rid of the starting digits.",
      "Can anyone help me with a simple solution to remove all digits that each line begins with, without it affecting the rest of the line?",
      "With JQ that'd be way easier. E.g.:",
      "jq 'map(sub(\"^\\\\d+\";\"\"))'"
    ],
    "utterance": "Remove all starting digits from each string element in an array, regardless of whether there is one or more digits at the start.",
    "expressions": [
      "map(sub(\"^\\d+\";\"\"))"
    ],
    "data": [
      {
        "input": [
          "0local>aggr.tasks.max = 128",
          "1local>aggr.tasks.max = 128",
          "2local->aggi.tasks.max = 128",
          "3local>aggr.fetch.max.wait.ms = 150",
          "4local>aggr.fetch.max.wait.ms = 150",
          "5local->aggr.fetch.max.wait.ms = 150",
          "6local->aggr.fetch.min.bytes = 10485760",
          "7local>aggr-fetch.min.bytes = 10485760",
          "8local>aggr-fetch.min.bytes = 10485760",
          "9local->aggr.fetch.max.bytes = 52428800",
          "10local->aggr.fetch.max.bytes = 52428800",
          "11local->aggr.fetch.max.bytes = 52428800",
          "12local->aggr.max.request.size = 10485760",
          "13local->aggr-max.request.size = 10485760",
          "14local->aggr-max.request.size = 10485760"
        ],
        "output": [
          "local>aggr.tasks.max = 128",
          "local>aggr.tasks.max = 128",
          "local->aggi.tasks.max = 128",
          "local>aggr.fetch.max.wait.ms = 150",
          "local>aggr.fetch.max.wait.ms = 150",
          "local->aggr.fetch.max.wait.ms = 150",
          "local->aggr.fetch.min.bytes = 10485760",
          "local>aggr-fetch.min.bytes = 10485760",
          "local>aggr-fetch.min.bytes = 10485760",
          "local->aggr.fetch.max.bytes = 52428800",
          "local->aggr.fetch.max.bytes = 52428800",
          "local->aggr.fetch.max.bytes = 52428800",
          "local->aggr.max.request.size = 10485760",
          "local->aggr-max.request.size = 10485760",
          "local->aggr-max.request.size = 10485760"
        ]
      }
    ],
    "identifier": 62619312
  },
  {
    "context": [
      "export media_content=$(jq '[env.schedules][\"media_content\"]' json_file.json)",
      "If I run the script, it displays:",
      "environment variable: \"1\"",
      "What I get: null",
      "If I hardcode the variable:",
      "export schedules=\"1\"",
      "The problem no longer occurs",
      "But the result from this also generates additional \"s:",
      "export schedules=$(echo $zone | jq '.schedules')",
      "If you print it now you will see additional \"s:",
      "echo $schedules # \"1\"",
      "So just remove the \"s from the value:",
      "schedules=$( echo $schedules | sed s/\\\"//g )"
    ],
    "utterance": "Select the value of the media_content field for the object whose key matches the environment variable schedules with the value 1.",
    "expressions": [
      ".[env.schedules][\"media_content\"]"
    ],
    "data": [
      {
        "input": {
          "1": {
            "media_content": "test3.xspf"
          },
          "2": {
            "media_content": "test3.xspf"
          }
        },
        "output": "test3.xspf"
      }
    ],
    "identifier": 62651799
  },
  {
    "context": [
      "How I can extract the version number? `v<number>` can contain the only version tag. I need to get a number and increment version for the set to var.",
      "If output of `sort_by(imageDetails,& imagePushedAt)[*]` is empty JSON arr instead ... Set `2` ... No one repo `sort_by(imageDetails,& imagePushedAt)[*]` return `[]` set `1`.",
      "As a result, I try to get var `VERSION` with next version for an update or `1` if the repo is empty.",
      "You could use the `select()` function on the `imageTags` array and get only the tag starting with `v` and increment it.",
      "jq '( .[].imageTags[] | select(startswith(\"v\")) | ltrimstr(\"v\") | tonumber | .+1 ) // 1'"
    ],
    "utterance": "Get the highest numeric tag starting with 'v' from the imageTags arrays, increment it by 1, or set to 1 if no such tag exists.",
    "expressions": [
      "( .[].imageTags[] | select(startswith(\"v\")) | ltrimstr(\"v\") | tonumber | .+1 ) // 1"
    ],
    "data": [
      {
        "input": [
          {
            "imageTags": [
              "v1",
              "sometag"
            ]
          }
        ],
        "output": 2
      },
      {
        "input": [],
        "output": 1
      }
    ],
    "identifier": 62656417
  },
  {
    "context": [
      "How can I modify the script to take only the highest version number when multiple tags exist?",
      "Note that we're generating a list from each `imageTags` entry and finding the `max` entry in that list before incrementing it."
    ],
    "utterance": "For each object, output one more than the highest numeric value found among tags starting with 'v' in its imageTags array.",
    "expressions": [
      "(\n  .[].imageTags\n  | [\n      .[]\n      | select(startswith(\"v\"))\n      | ltrimstr(\"v\")\n      | tonumber\n    ]\n  | max\n  | .+1\n) // 1"
    ],
    "data": [
      {
        "input": [
          {
            "imageTags": [
              "v4",
              "v3"
            ]
          },
          {
            "imageTags": [
              "v1",
              "v2"
            ]
          }
        ],
        "output": [
          5,
          3
        ]
      }
    ],
    "identifier": 62666546
  },
  {
    "context": [
      "BUT, I only want to see the first outgoing message followed by the first incoming message followed by the next outgoing message followed by the next incoming message, etc. (If I sent three messages in a row, I want do delete/ignore the second and third message and only look at the first one. If I received eight messages in a row before I responded, I want to only see the first of those messages and delete/skip/forward past the following seven.",
      "I&#39;d use [`foreach`](https://stedolan.github.io/jq/manual/v1.6/#foreach) for that as the task basically requires a state machine that extracts some values from the current input whenever the state changes.\n```\nforeach .[] as {$type, $sent_at} (\n  {};\n  {prev: .curr, curr: $type};\n  if .curr != .prev\n  then $type, $sent_at\n  else empty end\n)\n```"
    ],
    "utterance": "Return only the first message each time the message direction changes between 'incoming' and 'outgoing', outputting its type and sent_at values.",
    "expressions": [
      "foreach .[] as {$type, $sent_at} (\n  {};\n  {prev: .curr, curr: $type};\n  if .curr != .prev\n  then $type, $sent_at\n  else empty end\n)"
    ],
    "identifier": 62679922
  },
  {
    "context": [
      "and I want to show a duration of hours:minutes instead of \"start\" and \"end\" times.",
      "Could jq write the output like\n[\n  {\n    \"time\": \"0:50:03\",\n    \"tags\": [\n      \"WPP\",\n      \"WPP review tasks, splashify popup\",\n      \"clients\",\n      \"work\"\n    ],\n    \"annotation\": \"update rules, fix drush errors, create base wpp-splash module.\"\n  }\n]\nor something similar.",
      "def duration($finish; $start):\n  def twodigits: \"00\" + tostring | .[-2:];\n  [$finish, $start]\n  | map(strptime(\"%Y%m%dT%H%M%SZ\") | mktime) # seconds\n  | .[0] - .[1]\n  | (. % 60 | twodigits) as $s\n  | (((. / 60) % 60) | twodigits)  as $m\n  | (./3600 | floor) as $h\n  | \"\\($h):\\($m):\\($s)\" ;",
      "The solution is now simply:\n\n    map( {time: duration(.end;.start)} + del(.start,.end) )"
    ],
    "utterance": "Replace \"start\" and \"end\" fields with a computed duration in hours:minutes:seconds format.",
    "expressions": [
      "def duration($finish; $start):\n  def twodigits: \"00\" + tostring | .[-2:];\n  [$finish, $start]\n  | map(strptime(\"%Y%m%dT%H%M%SZ\") | mktime)\n  | .[0] - .[1]\n  | (. % 60 | twodigits) as $s\n  | (((. / 60) % 60) | twodigits)  as $m\n  | (./3600 | floor) as $h\n  | \"\\($h):\\($m):\\($s)\" ;\n\nmap( {time: duration(.end;.start)} + del(.start,.end) )"
    ],
    "data": [
      {
        "input": [
          {
            "start": "20200629T202456Z",
            "end": "20200629T211459Z",
            "tags": [
              "WPP",
              "WPP review tasks, splashify popup",
              "clients",
              "work"
            ],
            "annotation": "update rules, fix drush errors, create base wpp-splash module."
          },
          {
            "start": "20200629T223000Z",
            "end": "20200629T224641Z",
            "tags": [
              "WPP",
              "WPP review tasks, splashify popup",
              "clients",
              "work"
            ]
          }
        ],
        "output": [
          {
            "time": "0:50:03",
            "tags": [
              "WPP",
              "WPP review tasks, splashify popup",
              "clients",
              "work"
            ],
            "annotation": "update rules, fix drush errors, create base wpp-splash module."
          },
          {
            "time": "0:16:41",
            "tags": [
              "WPP",
              "WPP review tasks, splashify popup",
              "clients",
              "work"
            ]
          }
        ]
      }
    ],
    "identifier": 62665537
  },
  {
    "context": [
      "\"But I want to select only a few I tried giving in braces of to_entries[] but it didn't work.\"",
      "\"Expected output:\\n\\nServer1 - UP\\n\\nSplunk -UP\\n\\nPlatfora - UP\"",
      "\"select(.key == (\\\"server1\\\", \\\"Splunk\\\", \\\"Platfora\\\"))\""
    ],
    "utterance": "Select and output only the entries with keys 'server1', 'Splunk', or 'Platfora', showing their names and status.",
    "expressions": [
      ".components | to_entries[] | select(.key == (\"server1\", \"Splunk\", \"Platfora\")) | \"\\(.key)- \\(.value.status)\""
    ],
    "data": [
      {
        "input": {
          "components": {
            "Server2": {
              "status": "UP"
            },
            "server1": {
              "status": "UP"
            },
            "Splunk": {
              "status": "UP"
            },
            "Datameer": {
              "status": "UP"
            },
            "Platfora": {
              "status": "UP"
            },
            "diskSpace": {
              "status": "Good"
            }
          }
        },
        "output": [
          "server1- UP",
          "Splunk- UP",
          "Platfora- UP"
        ]
      }
    ],
    "identifier": 62684606
  },
  {
    "context": [
      "I would like to retrieve the Name, ID of the OutputTransportList and ID of the WebPoints via jq.",
      "Till now I can retrieve the Name, ID and all WebPoints, but my intension is to retrive only the ID of the WebPoints.",
      "jq '.OutputTransportList[]| [.Name,.ID,.PackagingInfo.WebList,.WebPoints.ID]'",
      "Try using this expression with your actual json and see if it works:",
      ".OutputTransportList[].PackagingInfo.WebList[].WebPoints[].ID",
      "with your sample json, it outputs:",
      "\"{c9d63dec-3d11-6f98-bcab-25db01ced512}\""
    ],
    "utterance": "Extract Name and ID from OutputTransportList and the ID of each WebPoint.",
    "expressions": [
      "[.OutputTransportList[] | {Name, ID, WebPointIDs: (.PackagingInfo.WebList[].WebPoints[].ID)}]",
      ".OutputTransportList[] | [.Name, .ID, (.PackagingInfo.WebList[].WebPoints[].ID)]"
    ],
    "data": [
      {
        "input": {
          "Name_id": "New",
          "Active": true,
          "OutputTransportList": [
            {
              "ID": "{724BCC39-D287-4047-88E3-5E300F37BB37}",
              "Name": "TEST HD",
              "OutputServiceList": [
                {
                  "ID": "{12E6CE83-8DCD-469D-A6EA-D4A4AAC9A3F1}",
                  "Name": "TEST HD",
                  "Enable": true
                }
              ],
              "MWProfileList": [],
              "PackagingInfo": {
                "PackagingProfileList": [],
                "WebList": [
                  {
                    "WebPoints": [
                      {
                        "ID": "{c9d63dec-3d11-6f98-bcab-25db01ced512}",
                        "RedundancyMode": "ACTIVE_ACTIVE",
                        "PrimaryPointTemplateReference": "{74128CCE-1E50-43F5-BAB5-7E6E63541CA7}",
                        "ResourceName": ""
                      }
                    ]
                  }
                ]
              },
              "TransportInfo": {
                "Protocol": "IP"
              }
            }
          ],
          "PoolList": []
        },
        "output": [
          {
            "Name": "TEST HD",
            "ID": "{724BCC39-D287-4047-88E3-5E300F37BB37}",
            "WebPointIDs": "{c9d63dec-3d11-6f98-bcab-25db01ced512}"
          }
        ]
      }
    ],
    "identifier": 62674328
  },
  {
    "context": [
      "We would like to parse the above tail logs into a human-readable format where we are only interested in time and msg.",
      "so the expected output is:\r\n\r\n    2020-07-02T11:15:09.21+0530 (unlock) Attempting to release lock snapshot-app-mash-0",
      "It would seem that the input is a valid JSON string, and therefore that invoking jq with the -r option and a filter such as the following should do the trick:\r\n```\r\ncapture(\"^ *(?<date>[^ ]+) [^ ]+ [^ ]+ (?<json>.*)\")\r\n| \"\\(.date) \\(.json|fromjson|.msg)\"\r\n```"
    ],
    "utterance": "Extract the date and msg fields from log lines that begin with a timestamp and contain an embedded object, then output them in the format '<timestamp> <msg>'.",
    "expressions": [
      "capture(\"^ *(?<date>[^ ]+) [^ ]+ [^ ]+ (?<json>.*)\") | \"\\(.date) \\(.json|fromjson|.msg)\""
    ],
    "data": [
      {
        "input": "   2020-07-02T11:15:09.21+0530 [APP/PROC/WEB/1] OUT { \"written_at\":\"2020-07-02T05:45:09.210Z\",\"msg\":\"(unlock) Attempting to release lock snapshot-app-mash-0\" }",
        "output": "2020-07-02T11:15:09.21+0530 (unlock) Attempting to release lock snapshot-app-mash-0"
      }
    ],
    "identifier": 62691308
  },
  {
    "context": [
      "What I want is:\n\n    a=\"apple\"\n    b=\"banana\"\n    c=5\n    d=[\"this\", \"is\", \"an\", \"array\"]\n    e=false\n\nNote that only strings in the input JSON have quotes in the output.",
      "By using `jq -r 'to_entries[] | \"\\(.key)=\\\"\\(.value)\\\"\"'` I could generate an output like\n\na=\"apple\"\nb=\"banana\"\nc=\"5\"\nd=\"[\"this\", \"is\", \"an\", \"array\"]\"\ne=\"false\"\n\nSo my question is:\n\n1. Is using jq the right way to approach this problem? Or should I use regex?\n2. If jq is the correct direction, how do I fix what I've come up with?",
      "You can test whether .value is a string or not using `type` ([manual entry](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions)).",
      "jq -r 'to_entries[]\n          | \"\\(.key) = \\( .value \n                          | if type == \"string\"\n                            then \"\\\"\\(.)\\\"\"\n                            else . \n                            end\n                        )\"'"
    ],
    "utterance": "Output key=value pairs, quoting only string values and leaving numbers, arrays, and booleans unquoted.",
    "expressions": [
      "to_entries[] | \"\\(.key)=\\( .value | if type == \"string\" then \"\\\"\\(.)\\\"\" else . end )\""
    ],
    "data": [
      {
        "input": {
          "a": "apple",
          "b": "banana",
          "c": 5,
          "d": [
            "this",
            "is",
            "an",
            "array"
          ],
          "e": false
        },
        "output": [
          "a=\"apple\"",
          "b=\"banana\"",
          "c=5",
          "d=[\"this\", \"is\", \"an\", \"array\"]",
          "e=false"
        ]
      }
    ],
    "identifier": 62685750
  },
  {
    "context": [
      "I want to display specific data for all returned AMIs and include tags `when they exist`, otherwise, a blank `tags` key is fine.",
      "What I can't figure out is how to (optionally) include the data contained in the Tags[] array.",
      "the command below works `for anything that has tags`, but I get a `jq: error (at <stdin>:451): Cannot iterate over null (null)` error whenever it hits a result that doesn't contain any tags.",
      "you can try\n\n```\naws ec2 describe-images --owners self | jq '.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags?)}'\n```"
    ],
    "utterance": "Extract amiName, imageId, creationDate, and description for each AMI, including a tag field as an object derived from Tags when present, or a blank tag object if Tags is not present.",
    "expressions": [
      ".Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags // [] | from_entries)}"
    ],
    "data": [
      {
        "input": {
          "Images": [
            {
              "Name": "os42testclusterXXXXXXXXX",
              "ImageId": "ami-XXXXXXXXXXX",
              "CreationDate": "2020-02-18T21:52:27.000Z",
              "Description": "OpenShift 4 42XXXXXXXXXX",
              "Tags": [
                {
                  "Key": "kubernetes.io/cluster/os42testclusterXXXXXXXX",
                  "Value": "owned"
                },
                {
                  "Key": "Name",
                  "Value": "os42testclusterXXXXXXXXX"
                },
                {
                  "Key": "sourceAMI",
                  "Value": "ami-XXXXXXXXXXXX"
                },
                {
                  "Key": "sourceRegion",
                  "Value": "us-west-2"
                }
              ]
            },
            {
              "Name": "StudentMicroK8s",
              "ImageId": "ami-XXXXXXXXXXX",
              "CreationDate": "2020-02-10T18:21:12.000Z",
              "Description": "Base Image for K8s",
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "StudentMicroK8sImage"
                }
              ]
            },
            {
              "Name": "BOSH-XXXXXXXXXXX",
              "ImageId": "ami-XXXXXXXXXX",
              "CreationDate": "2018-08-31T04:07:36.000Z",
              "Description": "bosh-aws-xen-hvm-ubuntu-trusty-go_agent 3586.40",
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "bosh-aws-xen-hvm-ubuntu-trusty-go_agent 3586.40"
                }
              ]
            },
            {
              "Name": "Untagged",
              "ImageId": "ami-NOTAG",
              "CreationDate": "2019-10-01T00:00:00.000Z",
              "Description": "image without tags"
            }
          ]
        },
        "output": [
          {
            "amiName": "os42testclusterXXXXXXXXX",
            "imageId": "ami-XXXXXXXXXXX",
            "creationDate": "2020-02-18T21:52:27.000Z",
            "description": "OpenShift 4 42XXXXXXXXXX",
            "tag": {
              "kubernetes.io/cluster/os42testclusterXXXXXXXX": "owned",
              "Name": "os42testclusterXXXXXXXXX",
              "sourceAMI": "ami-XXXXXXXXXXXX",
              "sourceRegion": "us-west-2"
            }
          },
          {
            "amiName": "StudentMicroK8s",
            "imageId": "ami-XXXXXXXXXXX",
            "creationDate": "2020-02-10T18:21:12.000Z",
            "description": "Base Image for K8s",
            "tag": {
              "Name": "StudentMicroK8sImage"
            }
          },
          {
            "amiName": "BOSH-XXXXXXXXXXX",
            "imageId": "ami-XXXXXXXXXX",
            "creationDate": "2018-08-31T04:07:36.000Z",
            "description": "bosh-aws-xen-hvm-ubuntu-trusty-go_agent 3586.40",
            "tag": {
              "Name": "bosh-aws-xen-hvm-ubuntu-trusty-go_agent 3586.40"
            }
          },
          {
            "amiName": "Untagged",
            "imageId": "ami-NOTAG",
            "creationDate": "2019-10-01T00:00:00.000Z",
            "description": "image without tags",
            "tag": {}
          }
        ]
      }
    ],
    "identifier": 62668317
  },
  {
    "context": [
      "I want to output the .messages object as csv, followed by the \"end1\" value.",
      "How can I add .end1?",
      "the filter\n( .messages[] | [.error_message, .num_media, .status] | @csv ), .end1\ngenerates\n\",\\\"1\\\",\\\"received\\\"\"\n\",\\\"2\\\",\\\"received\\\"\"\n\"end page 1\""
    ],
    "utterance": "Output each entry in messages as CSV, then output the value of end1 immediately after.",
    "expressions": [
      "( .messages[] | [.error_message, .num_media, .status] | @csv ), .end1"
    ],
    "data": [
      {
        "input": {
          "end": 9,
          "previous_page_uri": null,
          "messages": [
            {
              "error_message": null,
              "num_media": "1",
              "status": "received"
            },
            {
              "error_message": null,
              "num_media": "2",
              "status": "received"
            }
          ],
          "end1": "end page 1",
          "end2": "end page 2"
        },
        "output": [
          "\",\\\"1\\\",\\\"received\\\"\"",
          "\",\\\"2\\\",\\\"received\\\"\"",
          "\"end page 1\""
        ]
      }
    ],
    "identifier": 62705580
  },
  {
    "context": [
      "I have multiple files of JSON-ish text that I need to merge:",
      "I would like to get back\n{\n  \"City1\":\n  {\n    \"Coords\":\n    [\n      [10,20,30],\n      [11,21,31],\n      [13,23,33]\n    ]\n  },\n  \"City2\":\n  {\n    \"Coords\":\n    [\n      [12,22,32]\n    ]\n  },\n  \"City3\":\n  {\n    \"Coords\":\n    [\n      [14,24,34],\n      [15,25,35]\n    ]\n  }\n}",
      "jq -s 'map(to_entries)|flatten|group_by(.key)|\n        map( { (.[0].key): { \"Coords\": (reduce .[].value.Coords as $i ([]; . + $i))}} )'"
    ],
    "utterance": "Merge multiple objects containing city keys with nested coordinate lists so that each city's coordinates are concatenated in the result.",
    "expressions": [
      "jq -s 'map(to_entries)|flatten|group_by(.key)|map( { (.[0].key): { \"Coords\": (reduce .[].value.Coords as $i ([]; . + $i))}} )|add'"
    ],
    "data": [
      {
        "input": [
          {
            "City1": {
              "Coords": [
                [
                  10,
                  20,
                  30
                ],
                [
                  11,
                  21,
                  31
                ]
              ]
            },
            "City2": {
              "Coords": [
                [
                  12,
                  22,
                  32
                ]
              ]
            }
          },
          {
            "City1": {
              "Coords": [
                [
                  13,
                  23,
                  33
                ]
              ]
            },
            "City3": {
              "Coords": [
                [
                  14,
                  24,
                  34
                ],
                [
                  15,
                  25,
                  35
                ]
              ]
            }
          }
        ],
        "output": {
          "City1": {
            "Coords": [
              [
                10,
                20,
                30
              ],
              [
                11,
                21,
                31
              ],
              [
                13,
                23,
                33
              ]
            ]
          },
          "City2": {
            "Coords": [
              [
                12,
                22,
                32
              ]
            ]
          },
          "City3": {
            "Coords": [
              [
                14,
                24,
                34
              ],
              [
                15,
                25,
                35
              ]
            ]
          }
        }
      }
    ],
    "identifier": 62704574
  },
  {
    "context": [
      "I need to convert string like\n\"{\n  \\\"entity\\\":{\n    \\\"id\\\":\\\"7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\\\", ... }\"",
      "to string where no quotes for keys:\n\"{\n  entity:{\n    id:\\\"7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\\\", ... }\"",
      "To delete the quotation marks around the keys, the following may suffice.\ntr -d '\\n' < escaped.json |\n  jq fromjson |\n  sed '/^ *\".*\": /{s/\"//; s/\": /: /;}'"
    ],
    "utterance": "Convert a string containing escaped key-quoted syntax to one where keys are unquoted but values retain their quotes.",
    "expressions": [
      "jq 'fromjson | walk(if type == \"array\" or type == \"object\" then . else null end)' <<< $(cat escaped.json) | sed '/\"/{s/\"//g; s/: null.*//;}'",
      "tr -d '\\n' < escaped.json | jq fromjson | sed '/^ *\".*\": /{s/\"//; s/\": /: /;}'"
    ],
    "data": [
      {
        "input": "\"{\\n  \\\"entity\\\":{\\n    \\\"id\\\":\\\"7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\\\",\\n    \\\"type\\\":\\\"Products\\\",\\n    \\\"status\\\":\\\"pending\\\",\\n    \\\"services\\\":[{\\n      \\\"id\\\":\\\"1e05737e-754b-4d19-b872-5a0135d99cf4\\\",\\n      \\\"type\\\":\\\"Services\\\",\\n      \\\"status\\\":\\\"active\\\"\\n    },{\\n      \\\"id\\\":\\\"2238fe75-3d1a-4768-8464-be7d48037215\\\",\\n      \\\"type\\\":\\\"Services\\\",\\n      \\\"status\\\":\\\"active\\\"\\n    }]\\n  }\\n}\"",
        "output": "{\n  entity: {\n    id: \"7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\",\n    type: \"Products\",\n    status: \"pending\",\n    services: [\n      {\n        id: \"1e05737e-754b-4d19-b872-5a0135d99cf4\",\n        type: \"Services\",\n        status: \"active\"\n      },\n      {\n        id: \"2238fe75-3d1a-4768-8464-be7d48037215\",\n        type: \"Services\",\n        status: \"active\"\n      }\n    ]\n  }\n}"
      }
    ],
    "identifier": 62634257
  },
  {
    "context": [
      "Now, the key \"123456\" is dynamic, and I actually need it to form the url for the cURL command. Because of this, the string \"123456\" is stored as a variable called $PAGE_ID.",
      "How can I use jq to access the value corresponding to this key?",
      "data | jq -c --arg pid \"$PAGE_ID\" '.[$pid]'",
      "data | jq --arg pid \"$PAGE_ID\" '.[$pid].extract'",
      "$ jq --arg pageid \"$PAGE_ID\" 'to_entries[] | select(.key==$pageid) | .value' <<<'{\"123456\": {\"extract\": \"this is the bit I am looking for\"}}'",
      "jq \".\\\"$PAGE_ID\\\"\" <<< '{\"123456\": {\"extract\": \"this is the bit I am looking for\"}}'"
    ],
    "utterance": "Retrieve the value or a subfield for a key that is a numeric string and whose name is stored in a shell variable.",
    "expressions": [
      "jq --arg pid \"$PAGE_ID\" '.[$pid]'",
      "jq --arg pid \"$PAGE_ID\" '.[$pid].extract'",
      "jq --arg pageid \"$PAGE_ID\" 'to_entries[] | select(.key==$pageid) | .value'",
      "jq \".\\\"$PAGE_ID\\\"\""
    ],
    "data": [
      {
        "input": {
          "123456": {
            "extract": "this is the bit I am looking for"
          }
        },
        "output": {
          "extract": "this is the bit I am looking for"
        }
      },
      {
        "input": {
          "123456": {
            "extract": "this is the bit I am looking for"
          }
        },
        "output": "this is the bit I am looking for"
      }
    ],
    "identifier": 62738086
  },
  {
    "context": [
      "The data contains time strings of the format \"2020-07-04T18:14:12Z\".",
      "$ echo '\"2020-07-04T18:14:12Z\"' | jq 'fromdate | strflocaltime(\"%H:%M\")'",
      "\"20:14\"       // I suppose this is the same issue as above with mktime",
      "As a temporary workaround, we can get the offset introduced by `mktime` with: `jq -n 'now | gmtime | mktime - (now | trunc)'`. Subtracting this offset from any occurrence of `fromdate` will then reliably yield UTC timestamps.",
      "Subtracting this offset from any occurrence of `fromdate` will then reliably yield UTC timestamps."
    ],
    "utterance": "Parse an ISO8601 time string in GMT and output the local time with a format of HH:MM, ensuring the correct handling of time zones and daylight saving time",
    "expressions": [
      ". | fromdate - (now | gmtime | mktime - (now | trunc)) | strflocaltime(\"%H:%M\")"
    ],
    "data": [
      {
        "input": "2020-07-04T18:14:12Z",
        "output": "\"19:14\""
      }
    ],
    "identifier": 62733112
  },
  {
    "context": [
      "I have  a stream of JSON entities. Here is one of them called 'info':",
      "I want to extract keys from nested json, so it looks like this:",
      "for which the following filter will produce the desired results:",
      "if . then with_entries(.key |= \"info_\" + .) else . end"
    ],
    "utterance": "For each object, rename all its keys to have the prefix 'info_', but leave nulls unchanged.",
    "expressions": [
      "if . then with_entries(.key |= \"info_\" + .) else . end"
    ],
    "data": [
      {
        "input": [
          null,
          null,
          {
            "id": "qwefhu214o",
            "number": "2346",
            "date": "28.01.2019"
          },
          null,
          null,
          {
            "id": "esg324lif",
            "number": "1378",
            "date": "29.05.2019"
          },
          {
            "id": "gwrs853sdf",
            "number": "4487",
            "date": "20.12.2019"
          }
        ],
        "output": [
          null,
          null,
          {
            "info_id": "qwefhu214o",
            "info_number": "2346",
            "info_date": "28.01.2019"
          },
          null,
          null,
          {
            "info_id": "esg324lif",
            "info_number": "1378",
            "info_date": "29.05.2019"
          },
          {
            "info_id": "gwrs853sdf",
            "info_number": "4487",
            "info_date": "20.12.2019"
          }
        ]
      }
    ],
    "identifier": 62747608
  },
  {
    "context": [
      "I'd like to produce a JSON object that contains the value of the `Name` tag, along with the subnet ID, if the name matches some string (e.g. testing).",
      "What is the best way of capturing the value of the `Name` tag (we happen to know there is only one instance of it, and if there wasn't, it would be fine to do something like 1. picking the first instance, 2. picking the last instance, or 3. erroring).",
      "aws ec2 describe-subnets | jq '\n.Subnets[]\n| select(\n    .Tags[]?\n    | select(.Key == \"Name\")\n    | .Value\n    | test(\"testing\"))\n| . as $obj\n| .Tags[]\n| select(.Key == \"Name\")\n| .Value as $name\n| {\"Name\": $name, \"SubnetId\": $obj.SubnetId}'",
      "Try \n\n    jq  '.Subnets[]|\n        { \"Name\": ( .Tags|from_entries| .Name), \"SubnetID\": .SubnetID} |\n        select(.Name | test(\"testing\"))'"
    ],
    "utterance": "Return an object with the Name tag value and SubnetId of each subnet where the Name matches 'testing'.",
    "expressions": [
      ".Subnets[]\n| select(\n    .Tags[]?\n    | select(.Key == \"Name\")\n    | .Value\n    | test(\"testing\"))\n| . as $obj\n| .Tags[]\n| select(.Key == \"Name\")\n| .Value as $name\n| {\"Name\": $name, \"SubnetId\": $obj.SubnetId}",
      ".Subnets[] |\n  { \"Name\": (.Tags | from_entries | .Name), \"SubnetID\": .SubnetID } |\n  select(.Name | test(\"testing\"))"
    ],
    "data": [
      {
        "input": {
          "Subnets": [
            {
              "AvailabilityZone": "us-west-2b",
              "AvailabilityZoneId": "usw2-az2",
              "AvailableIpAddressCount": 8187,
              "CidrBlock": "10.0.96.0/19",
              "DefaultForAz": false,
              "MapPublicIpOnLaunch": false,
              "State": "available",
              "SubnetId": "subnet-02000000000000000",
              "VpcId": "vpc-06ba0000000000000",
              "OwnerId": "350000000000",
              "AssignIpv6AddressOnCreation": false,
              "Ipv6CidrBlockAssociationSet": [],
              "Tags": [
                {
                  "Key": "aws:cloudformation:logical-id",
                  "Value": "PrivateSubnet02"
                },
                {
                  "Key": "aws:cloudformation:stack-name",
                  "Value": "dev"
                },
                {
                  "Key": "Name",
                  "Value": "testing-vpc-stack-Subnet02"
                }
              ],
              "SubnetArn": "arn:aws:ec2:us-west-2:350000000000:subnet/subnet-02000000000000000"
            }
          ]
        },
        "output": {
          "Name": "testing-vpc-stack-Subnet02",
          "SubnetId": "subnet-02000000000000000"
        }
      }
    ],
    "identifier": 62724716
  },
  {
    "context": [
      "Any idea how I can remove the quotes around the 2 text values that get put into the `ListElement` part?",
      "jq -n --raw-input --raw-output '\n    def stripQuotes: capture(\"^\\\"(?<content>.*)\\\"$\").content // .;\n\n    [inputs | split(\",\") | map(stripQuotes) |\n     {\n         \"ListElementCode\": .[0],\n         \"ListElement\": \"\\(.[1]) \\(.[2])\"\n     }]\n' <in.csv >out.json",
      "jq -n --raw-input --raw-output '[inputs | split(\",\") | { \"ListElementCode\": .[0], \"ListElement\": \"\\(.[1]|fromjson) \\(.[2]|fromjson)\" } ]' input.csv "
    ],
    "utterance": "Combine the first and second quoted fields from each line into a new field without surrounding quotes, keeping the first field unchanged.",
    "expressions": [
      "jq -n --raw-input --raw-output '\n    def stripQuotes: capture(\"^\\\"(?<content>.*)\\\"$\").content // .;\n\n    [inputs | split(\",\") | map(stripQuotes) |\n     {\n         \"ListElementCode\": .[0],\n         \"ListElement\": \"\\(.[1]) \\(.[2])\"\n     }]\n' <in.csv >out.json",
      "jq -n --raw-input --raw-output '[inputs | split(\",\") | { \"ListElementCode\": .[0], \"ListElement\": \"\\(.[1]|fromjson) \\(.[2]|fromjson)\" } ]' input.csv "
    ],
    "data": [
      {
        "input": [
          "1,\"SC1\",\"Leeds\"",
          "2,\"SC2\",\"Barnsley\""
        ],
        "output": [
          {
            "ListElementCode": "1",
            "ListElement": "SC1 Leeds"
          },
          {
            "ListElementCode": "2",
            "ListElement": "SC2 Barnsley"
          }
        ]
      }
    ],
    "identifier": 62756705
  },
  {
    "context": [
      "I am working with a dataset of dns records like `{\"timestamp\":\"1592145252\",\"name\":\"0.127.9.109.rev.sfr.net\",\"type\":\"a\",\"value\":\"109.9.127.0\"}`",
      "I cannot figure out how to 1) strip the subdomain details out of the name field. in this example i just want `sfr.net` 2) print the name backwards, eg: `0.127.9.109.rev.sfr.net` would become `ten.rfs.ver.901.9.721.0` my end goal is to print lines like this: `0.127.9.109.rev.sfr.net,ten.rfs.ver.901.9.721.0,a,sfr.net`",
      "split(\"\") | reverse | join(\"\")",
      ".name | [ . , (split(\"\") | reverse | join(\"\")), (split(\".rev.\")[1]) ] | join(\",\")",
      "jq -r '\n   .type as $type\n   | .name\n   | \"\\(.),\\(explode|reverse|implode),\\($type),\"\n     + capture(\"(?<subdomain>[^.]+[.][^.]+)$\").subdomain'"
    ],
    "utterance": "Produce a comma-separated line containing the original name, the name reversed, the type, and the last two labels of the name field (e.g., 'sfr.net').",
    "expressions": [
      ".name | [ ., (split(\"\") | reverse | join(\"\")), .type, (capture(\"(?<subdomain>[^.]+[.][^.]+)$\").subdomain) ] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "timestamp": "1592145252",
          "name": "0.127.9.109.rev.sfr.net",
          "type": "a",
          "value": "109.9.127.0"
        },
        "output": "0.127.9.109.rev.sfr.net,ten.rfs.ver.901.9.721.0,a,sfr.net"
      }
    ],
    "identifier": 62767461
  },
  {
    "context": [
      "I have this JSON:\r\n\r\n    {\r\n      \r\n      &quot;values&quot;: [      \r\n        {\r\n          &quot;type&quot;: &quot;any&quot;,\r\n          &quot;value&quot;: &quot;email1,email2,email3&quot;,\r\n          &quot;key&quot;: &quot;emails&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;any&quot;,\r\n          &quot;value&quot;: &quot;id1,id2,id3&quot;,\r\n          &quot;key&quot;: &quot;ids&quot;\r\n        }\r\n      ]\r\n    }",
      "And I would like to have it as:\r\n\r\n    [\r\n       {\r\n          &quot;email&quot;:&quot;email1&quot;,\r\n          &quot;id&quot;:&quot;id1&quot;\r\n       },\r\n       {\r\n          &quot;email&quot;:&quot;email2&quot;,\r\n          &quot;id&quot;:&quot;id2&quot;\r\n       },\r\n       {\r\n          &quot;email&quot;:&quot;email3&quot;,\r\n          &quot;id&quot;:&quot;id3&quot;\r\n       }\r\n    ]",
      "If *emails* and *ids* are fixed at the top of the array `values`, and are always in the same order, you can use this program:\r\n```\r\n.values | [\r\n  (.[0].value / &quot;,&quot;), # emails\r\n  (.[1].value / &quot;,&quot;)  # ids\r\n] | transpose | map({email: .[0], id: .[1]})\r\n```",
      "Otherwise, as the objects in `values` have `key`-`value` pairs, you can resort to `from_entries`:\r\n```\r\n.values | from_entries | [\r\n  (.emails / &quot;,&quot;),\r\n  (.ids / &quot;,&quot;)\r\n] | transpose | map({email: .[0], id: .[1]})\r\n```"
    ],
    "utterance": "Transform an object with 'values' containing 'emails' and 'ids' as comma-separated strings into an array of objects, each with 'email' and 'id' paired by position.",
    "expressions": [
      ".values | [\n  (.[0].value / \",\"), # emails\n  (.[1].value / \",\")  # ids\n] | transpose | map({email: .[0], id: .[1]})",
      ".values | from_entries | [\n  (.emails / \",\"),\n  (.ids / \",\")\n] | transpose | map({email: .[0], id: .[1]})"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "type": "any",
              "value": "email1,email2,email3",
              "key": "emails"
            },
            {
              "type": "any",
              "value": "id1,id2,id3",
              "key": "ids"
            }
          ]
        },
        "output": [
          {
            "email": "email1",
            "id": "id1"
          },
          {
            "email": "email2",
            "id": "id2"
          },
          {
            "email": "email3",
            "id": "id3"
          }
        ]
      }
    ],
    "identifier": 62752976
  },
  {
    "context": [
      "jq '.text.message=\"<p style=text-align: left; font-size: 14px><font color=\\\"#1a1a1a\\\"><b>Test</b></font> </p>\"'",
      "echo '{\"text\": {\"message\": \"some message here\"}}' | jq '.text.message=\"<p style=text-align: left; font-size: 14px><font color=\\\"#1a1a1a\\\"><b>Test</b></font> </p>\"'",
      "html='<![CDATA[ <p style=\"text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;\"><font color=\"#1a1a1a\"><b>test</b></font> - <font color=\"#4d4d4d\">Hello </font></p> <p style=\"text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;\"><font color=\"#1a1a1a\"><b>test</b></font> - <font color=\"#4d4d4d\">Hi </font></p> ]]>'",
      "# pass the shell variable into jq with the --arg option:",
      "echo '{\"text\": {\"message\": \"some message here\"}}' | jq --arg msg \"$html\" '.text.message = $msg'",
      "$ jq -n '.text.message=\"<p style=text-align: left; font-size: 14px><font color=\\\"#1a1a1a\\\"><b>Test</b></font> </p>\"'",
      "jq -R '. as $in | ({} | .text.message=$in)' <<< \"$data\"",
      "jq -R '{text: {message: .}}'  <<< \"$data\"",
      "jq -n --arg data \"$data\" '.text.message=.'"
    ],
    "utterance": "Set the value of the message field to a complex HTML string, ensuring the HTML content is preserved as-is",
    "expressions": [
      ".text.message=\"<p style=text-align: left; font-size: 14px><font color=\\\"#1a1a1a\\\"><b>Test</b></font> </p>\"",
      ".text.message = $msg",
      ".text.message = .",
      "{text: {message: .}}",
      ". as $in | ({} | .text.message=$in)"
    ],
    "data": [
      {
        "input": {
          "text": {
            "message": "some message here"
          }
        },
        "output": {
          "text": {
            "message": "<p style=text-align: left; font-size: 14px><font color=\"#1a1a1a\"><b>Test</b></font> </p>"
          }
        }
      },
      {
        "input": null,
        "output": {
          "text": {
            "message": "<p style=text-align: left; font-size: 14px><font color=\"#1a1a1a\"><b>Test</b></font> </p>"
          }
        }
      },
      {
        "input": null,
        "output": {
          "text": {
            "message": "<![CDATA[ <p style=\"text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;\"><font color=\"#1a1a1a\"><b>test</b></font> - <font color=\"#4d4d4d\">Hello </font></p> <p style=\"text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;\"><font color=\"#1a1a1a\"><b>test</b></font> - <font color=\"#4d4d4d\">Hi </font></p> ]]>"
          }
        }
      }
    ],
    "identifier": 62758770
  },
  {
    "context": [
      "in `Users` there is `Name` key and in `Country` also i have `Name` key. I need to preprocess the json file to differentiate the keys. My expected result is below.",
      "Tag name should be appended to the attribute name.",
      "As originally posted, neither the illustrative input nor the corresponding output is valid JSON, but the following has been tested using JSON based on the shown input:\n```\n.Data |= (  (.User    |= map(with_entries(.key |= (\"User_\" + .))))\n          | (.Country |= map(with_entries(.key |= (\"Country_\" + .)))) )\n```",
      "Of course, the above may need tweaking depending on the actual requirements, and can be generalized in various ways, e.g. as shown below.\n\n## A generalization\n\n```\n.Data |= with_entries( (.key + \"_\") as $newkey\n                       | .value |= map(with_entries(.key |= ($newkey + .))))\n```",
      "Here is an approach using jq [Streaming](https://stedolan.github.io/jq/manual/#Streaming)\n```\nfromstream(tostream | .[0] |= if length < 4 then . else .[3]=\"\\(.[1])_\\(.[3])\" end)\n```"
    ],
    "utterance": "Rename all nested object keys within top-level groups by prefixing them with the group name and an underscore",
    "expressions": [
      ".Data |= ( (.User |= map(with_entries(.key |= (\"User_\" + .)))) | (.Country |= map(with_entries(.key |= (\"Country_\" + .)))) )",
      ".Data |= with_entries( (.key + \"_\") as $newkey | .value |= map(with_entries(.key |= ($newkey + .))))",
      "fromstream(tostream | .[0] |= if length < 4 then . else .[3]=\"\\(.[1])_\\(.[3])\" end)"
    ],
    "data": [
      {
        "input": {
          "Data": {
            "User": [
              {
                "Name": "Solomon",
                "Age": 20
              },
              {
                "Name": "Absolom",
                "Age": 30
              }
            ],
            "Country": [
              {
                "Name": "US",
                "Resident": "Permanent"
              },
              {
                "Name": "UK",
                "Resident": "Temporary"
              }
            ]
          }
        },
        "output": {
          "Data": {
            "User": [
              {
                "User_Name": "Solomon",
                "User_Age": 20
              },
              {
                "User_Name": "Absolom",
                "User_Age": 30
              }
            ],
            "Country": [
              {
                "Country_Name": "US",
                "Country_Resident": "Permanent"
              },
              {
                "Country_Name": "UK",
                "Country_Resident": "Temporary"
              }
            ]
          }
        }
      }
    ],
    "identifier": 62796948
  },
  {
    "context": [
      "How can I transform the data to the below. Which is, to identify the domains in the format of `site.SLD.TLD` present and then remove the duplication of them. (Not including the subdomains, protocols or paths as illustrated below.)",
      "One solution was offered which does a regex match to extract the last two strings separated by . and call the unique function on that & works up to a point but doesn\u2019t cover `site.SLD.TLD` that has 2 parts. Like `google.co.uk`  would return only `co.uk` with this jq for example:",
      "`jq '.domains |= (map(capture(\"(?<x>[[:alpha:]]+).(?<z>[[:alpha:]]+)(.?)$\") | join(\".\")) | unique)'`",
      "It may be useful to illustrate an approach to the problem that passes the (revised) test presented in the Q.  This approach could easily be extended in any one of a number of ways:",
      "def extract:\n  sub(\"^[^:]*://\";\"\")\n  | sub(\"/.*$\";\"\")\n  | split(\".\")\n  | (if (.[-1]|length) == 2 and (.[-2]|length) <= 3\n     then -3 else -2 end) as $ix\n  | .[$ix : ]\n  | join(\".\") ;",
      "{name, domain: (.domains | map(extract) | unique)}",
      "Output\n{\n  \"name\": \"Visma Public\",\n  \"domain\": [\n    \"visma.com\",\n    \"vismaonline.com\",\n    \"workbox.co.uk\",\n    \"workbox.dk\"\n  ]\n}"
    ],
    "utterance": "Extract the registered domain (site.SLD.TLD) for each entry in the domains array, ignoring protocols, subdomains, and paths, and provide a unique, sorted list of these domains.",
    "expressions": [
      "def extract: sub(\"^[^:]*://\";\"\") | sub(\"/.*$\";\"\") | split(\".\") | (if (.[-1]|length) == 2 and (.[-2]|length) <= 3 then -3 else -2 end) as $ix | .[$ix:] | join(\".\"); {name, domains: (.domains | map(extract) | unique)}"
    ],
    "data": [
      {
        "input": {
          "name": "Visma Public",
          "domains": [
            "accountsettings.connect.identity.stagaws.visma.com",
            "admin.stage.vismaonline.com",
            "api.home.stag.visma.com",
            "api.workbox.dk",
            "app.workbox.dk",
            "app.workbox.co.uk",
            "authz.workbox.dk",
            "connect.identity.stagaws.visma.com",
            "eaccounting.stage.vismaonline.com",
            "eaccountingprinting.stage.vismaonline.com",
            "http://myservices-api.stage.vismaonline.com/",
            "identity.stage.vismaonline.com",
            "myservices.stage.vismaonline.com"
          ]
        },
        "output": {
          "name": "Visma Public",
          "domains": [
            "visma.com",
            "vismaonline.com",
            "workbox.co.uk",
            "workbox.dk"
          ]
        }
      }
    ],
    "identifier": 62777634
  }
]