[
  {
    "context": [
      "All i want to do is copy these objects to another file under a single array using the jq command.",
      "If you wanted simply to append the objects in File_1.json to an existing array in (say) output.json, you could write:",
      "jq  '. + [inputs]' output.json File_1.json",
      "This presupposes output.json contains exactly one array (or the JSON value `null`).  So to start, you could initialize output.json by running:",
      "echo null > output.json"
    ],
    "utterance": "Append objects from one file to an existing file so that all objects are collected in a single array, updating the target each time.",
    "expressions": [
      ". + [inputs]"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "1",
            "Name": "Kiran",
            "Age": "12"
          },
          {
            "Id": "2",
            "Name": "Dileep",
            "Age": "22"
          }
        ],
        "output": [
          {
            "Id": "1",
            "Name": "Kiran",
            "Age": "12"
          },
          {
            "Id": "2",
            "Name": "Dileep",
            "Age": "22"
          }
        ]
      }
    ],
    "identifier": 59801518
  },
  {
    "context": [
      "I know that `key` has a unique value. I need to get it\u2019s grand-parent\u2019s sibling key value (the value of `gp_sibling` key).",
      "If you want to get it only if there is the `key` element with it's value, you could try this:\n\n    jq 'select(.\"grand-parent\"?.parent?[]?.key==\"known_value\")|.gp_sibling' <file>",
      "paths(.key? == \"known_value\") as $p\n| getpath($p[0:-4])\n| .[]\n| select(type==\"string\")"
    ],
    "utterance": "Return the value of the root-level key 'gp_sibling' only when the nested object contains an element with key equal to 'known_value'.",
    "expressions": [
      "select(.\"grand-parent\"?.parent?[]?.key==\"known_value\") | .gp_sibling",
      "paths(.key? == \"known_value\") as $p | getpath($p[0:-4]) | .[] | select(type==\"string\")"
    ],
    "data": [
      {
        "input": {
          "gp_sibling": "desired_value",
          "grand-parent": {
            "parent": [
              {
                "key": "known_value",
                "sibling": "asdf"
              }
            ]
          }
        },
        "output": "desired_value"
      }
    ],
    "identifier": 59813234
  },
  {
    "context": [
      "I would like to convert the following JSON into a csv format using jq.",
      "The output should look like the following. I'm struggeling with the nested object as value of the address key.",
      "For brevity, the following assumes that all the .address objects have the keys in the right order:",
      "def headers: \"number,firstName,lastName,gender,age,streetAddress,city,state,postalCode\";",
      "headers,",
      "(to_entries[]",
      " | [.key,",
      "    (.value ",
      "     | (.firstName, .lastName, .gender, .age, .address[])) ]",
      " | join(\",\") )"
    ],
    "utterance": "Convert nested input to CSV with columns number, firstName, lastName, gender, age, streetAddress, city, state, postalCode, flattening address values.",
    "expressions": [
      "def headers: \"number,firstName,lastName,gender,age,streetAddress,city,state,postalCode\";\nheaders,\n(to_entries[]\n | [.key,\n    (.value \n     | (.firstName, .lastName, .gender, .age, .address[])) ]\n | join(\",\") )"
    ],
    "data": [
      {
        "input": {
          "one": {
            "firstName": "John",
            "lastName": "Smith",
            "gender": "man",
            "age": 32,
            "address": {
              "streetAddress": "21 2nd Street",
              "city": "New York",
              "state": "NY",
              "postalCode": "10021"
            }
          },
          "two": {
            "firstName": "Johnny",
            "lastName": "Smithy",
            "gender": "man",
            "age": 33,
            "address": {
              "streetAddress": "22 2nd Street",
              "city": "New York",
              "state": "NY",
              "postalCode": "10021"
            }
          }
        },
        "output": "number,firstName,lastName,gender,age,streetAddress,city,state,postalCode\none,John,Smith,man,32,21 2nd Street,New York,NY,10021\ntwo,Johnny,Smithy,man,33,22 2nd Street,New York,NY,10021"
      }
    ],
    "identifier": 59820910
  },
  {
    "context": [
      "I want to sort the values based on title. i.e. expected output",
      "To produce the output as shown in the Q:",
      ".values | sort_by(.title)[]"
    ],
    "utterance": "Output each object in the 'values' array individually, sorted by the 'title' field in ascending order.",
    "expressions": [
      ".values | sort_by(.title)[]"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "title": "B",
              "url": "https://B"
            },
            {
              "title": "A",
              "url": "https://A"
            }
          ]
        },
        "output": {
          "title": "A",
          "url": "https://A"
        }
      },
      {
        "input": {
          "values": [
            {
              "title": "B",
              "url": "https://B"
            },
            {
              "title": "A",
              "url": "https://A"
            }
          ]
        },
        "output": {
          "title": "B",
          "url": "https://B"
        }
      }
    ],
    "identifier": 59849700
  },
  {
    "context": [
      "I use jq using the answer in the previous thread to generate a JSON string like this:\r\n\r\njq -Rn '[inputs | {(.): env[.]}] | add' ./tmp.txt\r\n# GENERATES { \"ENV_VAR_A\": \"a val\", \"ENV_VAR_B\": \"a val\", \"ENV_VAR_C\": \"a val\"}",
      "With a bit modified `jq` command that produces single line output, you can just do:\r\n\r\nsed -i 's/{{SOME_PATTERN}}/'\"$(jq -nRc '[inputs | {(.): env[.]}] | add' /etc/nginx/conf.d/env)\"'/ somefile",
      "If your jq has the --rawfile option, there should be no need to juggle jq and sed:\r\n\r\n< somefile jq -R --rawfile text tmp.txt '\r\n  ($text\r\n   | split(\"\\n\")\r\n   | map(select(length>0)\r\n   | {(.): env[.]}) | add) as $json\r\n  | sub(\"{{SOME_PATTERN}}\"; $json|tostring)'"
    ],
    "utterance": "Generate an object mapping each variable name (one per line) from a file to its corresponding environment variable value and replace the marker {{SOME_PATTERN}} in a text file with this object.",
    "expressions": [
      "[inputs | {(.): env[.]}] | add",
      "[inputs | {(.): env[.]}] | add",
      "($text\n   | split(\"\\n\")\n   | map(select(length>0)\n   | {(.): env[.]}) | add) as $json\n  | sub(\"{{SOME_PATTERN}}\"; $json|tostring)"
    ],
    "data": [
      {
        "input": {
          "env": {
            "ENV_VAR_A": "a val",
            "ENV_VAR_B": "b val",
            "ENV_VAR_C": "c val"
          },
          "tmp.txt": "ENV_VAR_A\nENV_VAR_B\nENV_VAR_C\n",
          "somefile": "My object: {{SOME_PATTERN}}"
        },
        "output": "My object: {\"ENV_VAR_A\":\"a val\",\"ENV_VAR_B\":\"b val\",\"ENV_VAR_C\":\"c val\"}"
      }
    ],
    "identifier": 59791136
  },
  {
    "context": [
      "I want to replace in the item \"favbox-min-height\", in the key: value \"default\": 300 for \"default\": 400",
      ".[\"favbox-min-height\"] |= (.default = 400)"
    ],
    "utterance": "Replace the value of 'default' with 400 in the 'favbox-min-height' object.",
    "expressions": [
      ".[\"favbox-min-height\"] |= (.default = 400)"
    ],
    "data": [
      {
        "input": {
          "layout": {
            "menu-layout": {
              "type": "section",
              "title": "Layout and content",
              "keys": [
                "show-category-icons",
                "favbox-show",
                "favbox-min-height",
                "show-places"
              ]
            },
            "menu-behave": {
              "type": "section",
              "keys": [
                "enable-autoscroll",
                "search-filesystem"
              ]
            }
          },
          "favbox-min-height": {
            "type": "spinbutton",
            "default": 300
          }
        },
        "output": {
          "layout": {
            "menu-layout": {
              "type": "section",
              "title": "Layout and content",
              "keys": [
                "show-category-icons",
                "favbox-show",
                "favbox-min-height",
                "show-places"
              ]
            },
            "menu-behave": {
              "type": "section",
              "keys": [
                "enable-autoscroll",
                "search-filesystem"
              ]
            }
          },
          "favbox-min-height": {
            "type": "spinbutton",
            "default": 400
          }
        }
      }
    ],
    "identifier": 59851383
  },
  {
    "context": [
      "I have the following input json:\r\n\r\n    {\"id\": 100, \"a\": [{\"t\" : 1,\"c\" : 2 }, {\"t\": 2, \"c\" : 3 }] }\r\n    {\"id\": 200, \"a\": [{\"t\": 2, \"c\" : 3 }] }\r\n    {\"id\": 300, \"a\": [{\"t\": 1, \"c\" : 3 }] }",
      "And I expect the following CSV output:\r\n\r\n    id,t1,t2\r\n    100,2,3\r\n    200,,3\r\n    300,3,",
      "jq -r '[\"id\",\"t1\",\"t2\"],[.id, (.a[] | select(.t==1)).c//null, (.a[] | select(.t==2)).c//null ]|@csv'",
      "In short, you produce a direct object containing the values from your input, then add it to a \"default\" object to fill in the missing keys.",
      "Here's a simple solution that does not assume anything about the ordering of the items in the .a array, and easily generalizes to arbitrarily many .t values:\r\n\r\n# Convert an array of {t, c} to a dictionary:\r\ndef tod: map({(.t|tostring): .c}) | add;\r\n\r\n[\"id\", \"t1\", \"t2\"],   # header\r\n(inputs \r\n | (.a | tod) as $dict\r\n | [.id, (range(1;3) as $i | $dict[$i|tostring]) ])\r\n| @csv"
    ],
    "utterance": "Output a CSV table with columns id, t1, and t2, where t1 and t2 correspond to the c values for t=1 and t=2 within the a array, leaving fields blank when a value is missing.",
    "expressions": [
      "[\"id\",\"t1\",\"t2\"],[.id, (.a[] | select(.t==1)).c//null, (.a[] | select(.t==2)).c//null ]|@csv",
      "def tod: map({(.t|tostring): .c}) | add;\n[\"id\", \"t1\", \"t2\"], (inputs | (.a | tod) as $dict | [.id, (range(1;3) as $i | $dict[$i|tostring]) ]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": 100,
            "a": [
              {
                "t": 1,
                "c": 2
              },
              {
                "t": 2,
                "c": 3
              }
            ]
          },
          {
            "id": 200,
            "a": [
              {
                "t": 2,
                "c": 3
              }
            ]
          },
          {
            "id": 300,
            "a": [
              {
                "t": 1,
                "c": 3
              }
            ]
          }
        ],
        "output": "id,t1,t2\n100,2,3\n200,,3\n300,3,"
      }
    ],
    "identifier": 59824452
  },
  {
    "context": [
      "Given a JSON structure such as below, I want to test for the existence of the `sys/` top-level key.",
      "You just need to use the `has` attribute which returns a boolean value depending on the presence of the key mentioned",
      "jq 'has(\"sys/\")'",
      "So using this on your given JSON\n\n    jq -e 'has(\"sys/\")' json > /dev/null\n    echo $?\n    0",
      "but for a non-existent key `sys1`, it emits\n\n    jq -e 'has(\"sys1/\")' json > /dev/null\n    echo $?\n    1"
    ],
    "utterance": "Test if the top-level key 'sys/' exists.",
    "expressions": [
      "has(\"sys/\")"
    ],
    "data": [
      {
        "input": {
          "abc/": {
            "uuid": "fd"
          },
          "sys/": {
            "uuid": "id2"
          }
        },
        "output": true
      },
      {
        "input": {
          "abc/": {
            "uuid": "fd"
          }
        },
        "output": false
      }
    ],
    "identifier": 59861501
  },
  {
    "context": [
      "I need only a particular key field from all this overwhelming information.",
      "Let us assume that I need `web_url`,",
      "The problem here is there are multiple key field with \"web_url\".",
      "How do only get the `web_url` field I am after?",
      "You have 4 `web_url` in your JSON.",
      ".[] | .web_url",
      ".[] | .merged_by.web_url",
      ".[] | .author.web_url",
      ".[] | .assignee.web_url",
      "If the question is essentially how to find the needle in the haystack, the answer is: use `paths`; more specifically, in your case:",
      "jq -c 'paths(. == \"https://gitlaboo.tests.com/demo/frog/merge_requests/1\")\n             | select(.[-1] == \"web_url\")\n' file.json",
      "The output gives the path as a JSON array:\n\n    [0,\"web_url\"]\n",
      "This can be used directly in jq (using `getpath/1`), or as the basis for a direct query:\n\n    .[0].web_url"
    ],
    "utterance": "Extract all web_url fields, including nested ones such as those in merged_by, author, and assignee, from an array of objects.",
    "expressions": [
      ".[] | .web_url",
      ".[] | .merged_by.web_url",
      ".[] | .author.web_url",
      ".[] | .assignee.web_url"
    ],
    "data": [
      {
        "input": [
          {
            "id": 196,
            "iid": 1,
            "project_id": 233,
            "title": "DEV to Master",
            "description": "",
            "state": "merged",
            "created_at": "2019-12-04T14:14:35.424-06:00",
            "updated_at": "2019-12-04T14:14:47.310-06:00",
            "merged_by": {
              "id": 122,
              "name": "Sengoku",
              "username": "sengk",
              "state": "active",
              "avatar_url": "https://secure.gravatar.com/avatar/7cvffgfgfgfgf9eb1348d0ba7795a076?s=80\\u0026d=identicon",
              "web_url": "https://gitlaboo.tests.com/sengk"
            },
            "merged_at": "2019-12-04T14:14:47.468-06:00",
            "closed_by": null,
            "closed_at": null,
            "target_branch": "master",
            "source_branch": "DEV",
            "upvotes": 0,
            "downvotes": 0,
            "author": {
              "id": 122,
              "name": "Sengoku",
              "username": "sengk",
              "state": "active",
              "avatar_url": "https://secure.gravatar.com/avatar/7fgdfdgdfgdvfg9eb1348d0ba7795a076?s=80\\u0026d=identicon",
              "web_url": "https://gitlaboo.tests.com/sengk"
            },
            "assignee": {
              "id": 122,
              "name": "Sengoku",
              "username": "sengk",
              "state": "active",
              "avatar_url": "https://secure.gravatar.com/avatar/7afsdfdvdfvfde24f89eb1348d0ba7795a076?s=80\\u0026d=identicon",
              "web_url": "https://gitlaboo.tests.com/sengk"
            },
            "source_project_id": 233,
            "target_project_id": 233,
            "labels": [],
            "work_in_progress": false,
            "milestone": null,
            "merge_when_pipeline_succeeds": false,
            "merge_status": "can_be_merged",
            "sha": "6318e51ea8czfdfsdvdfvdfbc02988ba62c71e5774107e",
            "merge_commit_sha": "6dc5vdfvdfgdfg5bf14e97dea949b8584c0c68d6",
            "user_notes_count": 0,
            "discussion_locked": null,
            "should_remove_source_branch": null,
            "force_remove_source_branch": false,
            "web_url": "https://gitlaboo.tests.com/demo/frog/merge_requests/1",
            "time_stats": {
              "time_estimate": 0,
              "total_time_spent": 0,
              "human_time_estimate": null,
              "human_total_time_spent": null
            },
            "squash": false
          }
        ],
        "output": [
          "https://gitlaboo.tests.com/demo/frog/merge_requests/1",
          "https://gitlaboo.tests.com/sengk",
          "https://gitlaboo.tests.com/sengk",
          "https://gitlaboo.tests.com/sengk"
        ]
      }
    ],
    "identifier": 59791160
  },
  {
    "context": [
      "jq -r --arg swagger \"$swagger\" '.apiDefinition = $swagger' <<<\"$json\"",
      "--argfile swagger swagger.json",
      "jq -n --slurpfile swagger swagger.json '{\"apiDefintion\": $swagger[0]}'",
      "--slurpfile puts the contents of swagger.json into the variable $swagger, as an array.",
      "$swagger[0] is used to only include the first item of the slurped array."
    ],
    "utterance": "Set the value of the apiDefinition key to the contents of the swagger.json file, avoiding argument list too long errors.",
    "expressions": [
      "jq '.apiDefinition = input' sample.json < swagger.json",
      "jq --slurpfile swagger swagger.json '.apiDefinition = $swagger[0]' sample.json",
      "jq --argfile swagger swagger.json '.apiDefinition = $swagger' sample.json"
    ],
    "data": [
      {
        "input": {
          "name": "",
          "description": "",
          "context": "",
          "version": "",
          "provider": "cbs",
          "apiDefinition": "",
          "wsdlUri": null,
          "responseCaching": "Disabled",
          "cacheTimeout": 300,
          "destinationStatsEnabled": false,
          "isDefaultVersion": true,
          "transport": [
            "http",
            "https"
          ],
          "tags": [
            "PROVIDER_",
            "MIFE"
          ],
          "tiers": [
            "Unlimited",
            "Default",
            "Silver",
            "Subscription",
            "Gold",
            "Premium",
            "Bronze"
          ],
          "maxTps": {
            "sandbox": 5000,
            "production": 1000
          },
          "visibility": "PUBLIC",
          "visibleRoles": [],
          "endpointConfig": "",
          "endpointSecurity": {
            "username": "user",
            "type": "basic",
            "password": "pass"
          },
          "gatewayEnvironments": "Production and Sandbox",
          "sequences": [],
          "subscriptionAvailability": null,
          "subscriptionAvailableTenants": [],
          "businessInformation": {
            "businessOwnerEmail": "BUSINESSOWNEREMAIL_",
            "technicalOwnerEmail": "TECHNICALOWNEREMAIL_",
            "technicalOwner": "TECHNICALOWNER_",
            "businessOwner": "BUSINESSOWNER_"
          },
          "corsConfiguration": {
            "accessControlAllowOrigins": [
              "*"
            ],
            "accessControlAllowHeaders": [
              "authorization",
              "Access-Control-Allow-Origin",
              "Content-Type",
              "SOAPAction"
            ],
            "accessControlAllowMethods": [
              "GET",
              "PUT",
              "POST",
              "DELETE",
              "PATCH",
              "OPTIONS"
            ],
            "accessControlAllowCredentials": false,
            "corsConfigurationEnabled": false
          }
        }
      }
    ],
    "identifier": 59854249
  },
  {
    "context": [
      "I would like to add an entry \"zeiterfassungAktiviert\" : true just after the key gueltigBis (or alternatively before the key inhaltsverzeichnis)",
      "For the first part, it helps to have a helper function:\n\ndef insertkv($afterkey; $key; $value):\n  def insertafter($ix; $x): .[0:1+$ix] + [$x] + .[1+$ix:];\n\n  to_entries\n  | insertafter( map(.key) | index($afterkey);  {$key, $value})\n  | from_entries;"
    ],
    "utterance": "Insert a key-value pair with key \"zeiterfassungAktiviert\" and value true immediately after the key \"gueltigBis\" in the top-level object",
    "expressions": [
      "def insertkv($afterkey; $key; $value):\n  def insertafter($ix; $x): .[0:1+$ix] + [$x] + .[1+$ix:];\n  to_entries\n  | insertafter( map(.key) | index($afterkey); {$key, $value})\n  | from_entries;\n\ninsertkv(\"gueltigBis\"; \"zeiterfassungAktiviert\"; true)"
    ],
    "data": [
      {
        "input": {
          "fachbereich": "qp",
          "produktTyp": "PRODUKT_ANFRAGE_V1",
          "name": "Produkt Anfrage",
          "kurzName": "anfrage",
          "gueltigAb": "2019-01-01T00:00:00.000",
          "gueltigBis": "2022-12-31T00:00:00.000",
          "inhaltsverzeichnis": {
            "versandumfang": "auftragsverwaltung/versandumfang",
            "dokumentenerzeugung": "dokumentenerzeugung"
          }
        },
        "output": {
          "fachbereich": "qp",
          "produktTyp": "PRODUKT_ANFRAGE_V1",
          "name": "Produkt Anfrage",
          "kurzName": "anfrage",
          "gueltigAb": "2019-01-01T00:00:00.000",
          "gueltigBis": "2022-12-31T00:00:00.000",
          "zeiterfassungAktiviert": true,
          "inhaltsverzeichnis": {
            "versandumfang": "auftragsverwaltung/versandumfang",
            "dokumentenerzeugung": "dokumentenerzeugung"
          }
        }
      }
    ],
    "identifier": 59864629
  },
  {
    "context": [
      "I am trying to print it out in the following format:",
      "123, 456, teststring",
      "123, 789, teststring2",
      "How can I make the element on the outside of the array print for every set of elements that are printed from within the array?",
      "jq -r '[].item1 as $data | $data.array1[] | [ $data.item2 , .item3 , .item4 ] | @csv' json",
      "jq -r '[].item1 as $data | $data.array1[] | [ ($data.item2|tostring) , (.item3|tostring) , .item4 ]|join(\", \")'"
    ],
    "utterance": "For each element of array1, produce a line with the value of item2, item3, and item4, formatted as comma-separated values.",
    "expressions": [
      ".[].item1 as $data | $data.array1[] | [ $data.item2 , .item3 , .item4 ] | @csv",
      ".[].item1 as $data | $data.array1[] | [ ($data.item2|tostring) , (.item3|tostring) , .item4 ]|join(\", \")"
    ],
    "data": [
      {
        "input": [
          {
            "item1": {
              "item2": 123,
              "array1": [
                {
                  "item3": 456,
                  "item4": "teststring"
                },
                {
                  "item3": 789,
                  "item4": "teststring2"
                }
              ]
            }
          }
        ],
        "output": [
          "123,456,\"teststring\"",
          "123,789,\"teststring2\""
        ]
      }
    ],
    "identifier": 59879489
  },
  {
    "context": [
      "I have a piped command as follows that looks at the sealed status of Hashicorp Vault:\n\n`vault status -format json -address=\"https://127.0.0.1:8200\" -tls-skip-verify | jq -r '.sealed'`",
      "So therefore I need to invert the output from `jq`, i.e `sealed=false => true and sealed=true=>false`.",
      "jq supports the boolean operations [and/or/not](https://stedolan.github.io/jq/manual/v1.6/#and/or/not). `not` is a builtin function and needs to be called as a filter:\n\n    jq -r '.sealed | not'"
    ],
    "utterance": "Invert the value of the sealed field so that true becomes false and false becomes true.",
    "expressions": [
      ".sealed | not"
    ],
    "data": [
      {
        "input": {
          "sealed": true
        },
        "output": false
      },
      {
        "input": {
          "sealed": false
        },
        "output": true
      }
    ],
    "identifier": 59913511
  },
  {
    "context": [
      "I am trying change the `name` and `version` on the object of a given `@type`, with the following input",
      "I found many examples for changing a single value, and I can successfully do this by chaining multiple `select` statements together.",
      "But I was hoping I could condense this so I only have perform the `select` once to change both values.",
      "if .[\"@type\"] == \"Project\" then .name = \"newname\" | .version  = \"newversion\" else . end",
      "map( (select(.[\"@type\"] == \"Project\") | .name = \"newname\" | .version  = \"newversion\" ) // .)",
      "map(select(.[\"@type\"] == \"Project\") * {name: \"newname\", version: \"newversion\"} // .)"
    ],
    "utterance": "Set both the name and version fields to new values in all objects where @type equals Project.",
    "expressions": [
      "[ .[] | if .[\"@type\"] == \"Project\" then .name = \"newname\" | .version = \"newversion\" else . end ]",
      "map((select(.[\"@type\"] == \"Project\") | .name = \"newname\" | .version = \"newversion\") // .)",
      "(.[] | select([\"@type\"] == \"Project\")) |= (.name = \"newname\" | .version = \"newversion\")",
      "map(select(.[\"@type\"] == \"Project\") * {name: \"newname\", version: \"newversion\"} // .)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "oldname",
            "version": "oldversion",
            "@type": "Project"
          },
          {
            "name": "bomname",
            "version": "bomversion",
            "@type": "BOM"
          },
          {
            "name": "componentname",
            "version": "componentversion",
            "@type": "Component"
          }
        ],
        "output": [
          {
            "name": "newname",
            "version": "newversion",
            "@type": "Project"
          },
          {
            "name": "bomname",
            "version": "bomversion",
            "@type": "BOM"
          },
          {
            "name": "componentname",
            "version": "componentversion",
            "@type": "Component"
          }
        ]
      }
    ],
    "identifier": 59904094
  },
  {
    "context": [
      "In a JSON file I need to replace encrypted values with their clear text values as an initialization process using the command line tool `jq`.",
      "These \"$crypto\" objects can be anywhere in the JSON structure.",
      "I need that document to look like this: ... \"unknownKey8\": \"clearTextValue\"",
      "The following performs the replacement described in the text.",
      "jq --arg cleartext \"clearTextValue\" -f decrypt.jq sample.json",
      "walk(if type == \"object\" then decrypt($cleartext) else . end)"
    ],
    "utterance": "Replace every object whose value is a {$crypto: ...} object anywhere in the structure with the string \"clearTextValue\".",
    "expressions": [
      "def decrypt($value):\n  with_entries(if .value|type == \"object\"\n    then with_entries(if .value | (type == \"object\" and has(\"$crypto\"))\n      then .value = $value else . end)\n    else . end) ;\nwalk(if type == \"object\" then decrypt($cleartext) else . end)"
    ],
    "data": [
      {
        "input": {
          "unknownKey1": {
            "unknownKey2": {
              "name": "JWT_SESSION",
              "properties": {
                "maxTokenLifeMinutes": 120,
                "tokenIdleTimeMinutes": 30
              }
            },
            "unknownKey3": [
              {
                "unknownKey4": "STATIC_USER",
                "unknownKey5": {
                  "unknownKey6": "internal/user",
                  "unknownKey7": "anonymous",
                  "unknownKey8": {
                    "$crypto": {
                      "type": "x-simple-encryption",
                      "value": {
                        "cipher": "AES/CBC/PKCS5Padding",
                        "stableId": "someId",
                        "salt": "4J5ckE6+JaS8TLqAN4073g==",
                        "data": "vBeHAPJXLl+X/8Enp9vxMA==",
                        "keySize": 16,
                        "purpose": "someDescription",
                        "iv": "N2xCe5RiJibHv9hLY+OduA==",
                        "mac": "VoOo1BKptwfqIJeSOb/qGA=="
                      }
                    }
                  }
                },
                "enabled": true
              }
            ]
          }
        },
        "output": {
          "unknownKey1": {
            "unknownKey2": {
              "name": "JWT_SESSION",
              "properties": {
                "maxTokenLifeMinutes": 120,
                "tokenIdleTimeMinutes": 30
              }
            },
            "unknownKey3": [
              {
                "unknownKey4": "STATIC_USER",
                "unknownKey5": {
                  "unknownKey6": "internal/user",
                  "unknownKey7": "anonymous",
                  "unknownKey8": "clearTextValue"
                },
                "enabled": true
              }
            ]
          }
        }
      }
    ],
    "identifier": 59913277
  },
  {
    "context": [
      "I want to convert the Below JSON to Map. but its coming as a list.",
      "Expected format:\r\n\r\n    {\r\n      \"1\": \"/profile/api/v3/service/40/technical\",\r\n      \"2\": \"/profile/api/v3/service/40/technical\"\r\n    }",
      "But i am getting :::\r\n\r\n    [\r\n      {\r\n        \"1\": \"/profile/api/v3/service/40/technical\"\r\n      },\r\n      {\r\n        \"2\": \"/profile/api/v3/service/40/technical\"\r\n      }\r\n    ]",
      "JQ Query:::\r\n\r\n    ._embedded.items | map({(.order| tostring ) : .technical._links.self.href} )",
      "Simply tack on `| add` to the end of your jq program."
    ],
    "utterance": "Create an object mapping each item's order value to the corresponding technical._links.self.href.",
    "expressions": [
      "._embedded.items | map({ (.order|tostring) : .technical._links.self.href }) | add"
    ],
    "data": [
      {
        "input": {
          "_embedded": {
            "items": [
              {
                "order": 1,
                "technical": {
                  "id": 1,
                  "_links": {
                    "self": {
                      "href": "/profile/api/v3/service/40/technical"
                    }
                  }
                }
              },
              {
                "order": 2,
                "technical": {
                  "id": 1,
                  "_links": {
                    "self": {
                      "href": "/profile/api/v3/service/40/technical"
                    }
                  }
                }
              }
            ]
          }
        },
        "output": {
          "1": "/profile/api/v3/service/40/technical",
          "2": "/profile/api/v3/service/40/technical"
        }
      }
    ],
    "identifier": 59915712
  },
  {
    "context": [
      "input = [\"123\", \"456\"]",
      "expected output = array=123,456",
      "echo '[\"123\", \"456\"]' | jq -r '\"array=\" + join(\",\")'",
      "jq --raw-output '\"array=\\(join(\",\"))\"'"
    ],
    "utterance": "Produce a string in the form array=123,456 from an array of strings [\"123\", \"456\"]",
    "expressions": [
      "\"array=\" + join(\",\")",
      "\"array=\\(join(\",\"))\""
    ],
    "data": [
      {
        "input": [
          "123",
          "456"
        ],
        "output": "array=123,456"
      }
    ],
    "identifier": 59936373
  },
  {
    "context": [
      "I need to be able to query for a specific user in the \"User\" attribute and insert a new password for resubmission back to the api.",
      "Where a match for a specific user is found, return the entire structure with only that user's new password inserted. In the example, querying for user1 would return the entire PROFILE1 and PROFILE2, but not PROFILE3 as it doesn't contain user1 credentials.",
      "jq --arg newPwd \"newPassword\" \\\n   'walk(if type == \"object\" and .User == \"user1\" then .password |= $newPwd else . end)  \n      | map_values(select(.. | select(type == \"object\") and .User == \"user1\"))'",
      "with_entries(select( .value\n    | any(paths(. == \"user1\");\n          .[-1] == \"User\" )))\n| walk( if type == \"object\" and .User == \"user1\" and has(\"Password\")\n        then .Password = \"newpassword\"\n\t    else .end)"
    ],
    "utterance": "Select all top-level profiles that contain a User attribute of value \"user1\" (at any nested level), and update the password for user1 to a new value while returning only those matching profiles.",
    "expressions": [
      "with_entries(select( .value\n    | any(paths(. == \"user1\");\n          .[-1] == \"User\" )))\n| walk( if type == \"object\" and .User == \"user1\" and has(\"Password\")\n        then .Password = \"newpassword\"\n        else .end)",
      "walk(if type == \"object\" and .User == \"user1\" then .Password = \"derp\" else . end)\n| map_values(select(.. | select(type == \"object\") and .User == \"user1\"))"
    ],
    "data": [
      {
        "input": {
          "PROFILE1": {
            "Type": "ConnectionProfile:FileTransfer:DualEndPoint",
            "WorkloadAutomationUsers": [
              "*"
            ],
            "VerifyBytes": true,
            "TargetAgent": "sqlrptvmjhbpr01",
            "TargetCTM": "Production",
            "Endpoint:Src:Local_0": {
              "Type": "Endpoint:Src:Local",
              "User": "user1",
              "Port": "0",
              "OsType": "Windows",
              "HostName": "Local",
              "Password": "*****",
              "HomeDirectory": "/user1homedir"
            },
            "Endpoint:Dest:SFTP_1": {
              "Type": "Endpoint:Dest:SFTP",
              "User": "user2",
              "HostName": "server2",
              "Password": "*****",
              "HomeDirectory": "/user2homedir"
            }
          },
          "PROFILE2": {
            "Type": "ConnectionProfile:FileTransfer:Local",
            "WorkloadAutomationUsers": [
              "*"
            ],
            "VerifyBytes": true,
            "User": "user1",
            "VerifyDestination": true,
            "OsType": "Windows",
            "HostName": "Local",
            "Password": "*****",
            "TargetAgent": "server1",
            "TargetCTM": "Production"
          },
          "PROFILE3": {
            "Type": "ConnectionProfile:FileTransfer:Local",
            "WorkloadAutomationUsers": [
              "*"
            ],
            "VerifyBytes": true,
            "User": "user3",
            "OsType": "Windows",
            "HostName": "Local",
            "Password": "*****",
            "HomeDirectory": "/user3hoemdir",
            "TargetAgent": "server2",
            "TargetCTM": "Production"
          }
        },
        "output": {
          "PROFILE1": {
            "Type": "ConnectionProfile:FileTransfer:DualEndPoint",
            "WorkloadAutomationUsers": [
              "*"
            ],
            "VerifyBytes": true,
            "TargetAgent": "sqlrptvmjhbpr01",
            "TargetCTM": "Production",
            "Endpoint:Src:Local_0": {
              "Type": "Endpoint:Src:Local",
              "User": "user1",
              "Port": "0",
              "OsType": "Windows",
              "HostName": "Local",
              "Password": "newpassword",
              "HomeDirectory": "/user1homedir"
            },
            "Endpoint:Dest:SFTP_1": {
              "Type": "Endpoint:Dest:SFTP",
              "User": "user2",
              "HostName": "server2",
              "Password": "*****",
              "HomeDirectory": "/user2homedir"
            }
          },
          "PROFILE2": {
            "Type": "ConnectionProfile:FileTransfer:Local",
            "WorkloadAutomationUsers": [
              "*"
            ],
            "VerifyBytes": true,
            "User": "user1",
            "VerifyDestination": true,
            "OsType": "Windows",
            "HostName": "Local",
            "Password": "newpassword",
            "TargetAgent": "server1",
            "TargetCTM": "Production"
          }
        }
      }
    ],
    "identifier": 59823154
  },
  {
    "context": [
      "Am trying to add a json array with just one array element to a json. And it has to be added only if it does not already exist.",
      "Just use an explicit `if` condition that checks for the attribute `schemes` in the root level of the JSON structure",
      "jq --argjson argval \"$schem\" 'if has(\"schemes\")|not then .+= { schemes: $argval } else . end' json",
      "You can even go one level further and check even if `schemes` is present and if it does _not_ contain the value you expect, then make the overwrite.",
      "jq --argjson argval \"$schem\" 'if ( (has(\"schemes\")|not) or .schemes != $argval) then (.schemes: $argval) else . end'"
    ],
    "utterance": "Add the property schemes with value [\"https\"] only if it does not already exist as a property.",
    "expressions": [
      "if has(\"schemes\")|not then .+= { schemes: $argval } else . end",
      "if ( (has(\"schemes\")|not) or .schemes != $argval) then (.schemes: $argval) else . end"
    ],
    "data": [
      {
        "input": {
          "lorem": "2.0",
          "ipsum": {
            "key1": "value1",
            "key2": "value2"
          },
          "schemes": [
            "https"
          ],
          "dorum": "value3"
        },
        "output": {
          "lorem": "2.0",
          "ipsum": {
            "key1": "value1",
            "key2": "value2"
          },
          "schemes": [
            "https"
          ],
          "dorum": "value3"
        }
      },
      {
        "input": {
          "lorem": "2.0",
          "ipsum": {
            "key1": "value1",
            "key2": "value2"
          },
          "dorum": "value3"
        },
        "output": {
          "lorem": "2.0",
          "ipsum": {
            "key1": "value1",
            "key2": "value2"
          },
          "dorum": "value3",
          "schemes": [
            "https"
          ]
        }
      }
    ],
    "identifier": 59946450
  },
  {
    "context": [
      "#ruby\n\n`curl -m 10 -s -H '[...]' \"https://example_with_json_file.com\" | jq -r .remote | group_by(.name) | map({ (.[0].name): map(.id) }) | \"\\(.[])\" | grep '3\\|4\\|11' > file.txt`",
      "How can i pipe this output into a txt file\n```\n{\"cast-3\":[3212,3213]}\n{\"cast-4\":[4211]}\n{\"home-11\":[3212]}\n```",
      "bar = `curl -m 10 -s -H '[...]' \"https://example_with_json_file.com\" | jq -r .remote | group_by(.name) | map({ (.[0].name): map(.id) }) | \"\\(.[])\" | grep '3\\|4\\|11'`"
    ],
    "utterance": "Group the remote objects by name, map each name to a list of id values, and select groups whose name contains '3', '4', or '11'.",
    "expressions": [
      ".remote | group_by(.name) | map({ (.[0].name): map(.id) }) | .[] | select((keys[0] | test(\"3|4|11\")))"
    ],
    "data": [
      {
        "input": {
          "remote": [
            {
              "name": "cast-1",
              "id": 1212
            },
            {
              "name": "cast-1",
              "id": 1214
            },
            {
              "name": "home-11",
              "id": 3212
            },
            {
              "name": "cast-3",
              "id": 3212
            },
            {
              "name": "cast-3",
              "id": 3213
            },
            {
              "name": "cast-4",
              "id": 4211
            }
          ]
        },
        "output": [
          {
            "cast-3": [
              3212,
              3213
            ]
          },
          {
            "cast-4": [
              4211
            ]
          },
          {
            "home-11": [
              3212
            ]
          }
        ]
      }
    ],
    "identifier": 59951545
  },
  {
    "context": [
      "i need to fetch the value of the key \"toModify\" in data section. And also wanted to modify the key(toModify) value with another value Ex: hello1234567 to xyz. How can we do that using jq.",
      "$ jq '.items[0].data.cData |= (from_entries | .toModify = \"xyz\" | to_entries)' tmp.json",
      "{\n  \"items\": [\n    {\n      \"source\": {\n        \"id\": \"12334\"\n      },\n      \"data\": {\n        \"name\": \"test\",\n        \"value\": \"test\",\n        \"cData\": [\n          {\n            \"key\": \"keOne\",\n            \"value\": \"hello\"\n          },\n          {\n            \"key\": \"toModify\",\n            \"value\": \"xyz\"\n          }\n        ]\n      }\n    }\n  ]\n}",
      ".items[].data.cData\n  |= map(if .key == \"toModify\" then .key = \"MODIFIED\" else . end)"
    ],
    "utterance": "Replace the value associated with key 'toModify' inside the cData array with 'xyz'.",
    "expressions": [
      ".items[].data.cData |= (map(if .key == \"toModify\" then .value = \"xyz\" else . end))",
      ".items[0].data.cData |= (from_entries | .toModify = \"xyz\" | to_entries)"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "source": {
                "id": "12334"
              },
              "data": {
                "name": "test",
                "value": "test",
                "cData": [
                  {
                    "key": "keOne",
                    "value": "hello"
                  },
                  {
                    "key": "toModify",
                    "value": "hello1234567"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "items": [
            {
              "source": {
                "id": "12334"
              },
              "data": {
                "name": "test",
                "value": "test",
                "cData": [
                  {
                    "key": "keOne",
                    "value": "hello"
                  },
                  {
                    "key": "toModify",
                    "value": "xyz"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 59952122
  },
  {
    "context": [
      "Trying to pull value for @odata.id from redfish.txt file below.",
      "cat redfish.txt | jq .Systems",
      "{\r\n  \"@odata.id\": \"/redfish/v1/Systems\"\r\n}",
      "You could simply use the filter:\r\n\r\n    .Systems[\"@odata.id\"]",
      "what you need is ...\r\n\r\n    jq '.Systems.\"@odata.id\"'\r\n\r\nBecause you DON'T have an array, you have have normal key that just needs proper quoting ..."
    ],
    "utterance": "Retrieve the value associated with the @odata.id key inside the Systems property.",
    "expressions": [
      ".Systems[\"@odata.id\"]",
      ".Systems.\"@odata.id\""
    ],
    "data": [
      {
        "input": {
          "@odata.context": "/redfish/v1/$metadata#ServiceRoot.ServiceRoot",
          "@odata.id": "/redfish/v1",
          "@odata.type": "#ServiceRoot.v1_2_0.ServiceRoot",
          "AccountService": {
            "@odata.id": "/redfish/v1/Managers/iDRAC.Embedded.1/AccountService"
          },
          "Chassis": {
            "@odata.id": "/redfish/v1/Chassis"
          },
          "Description": "Root Service",
          "EventService": {
            "@odata.id": "/redfish/v1/EventService"
          },
          "Id": "RootService",
          "JsonSchemas": {
            "@odata.id": "/redfish/v1/JSONSchemas"
          },
          "Links": {
            "Sessions": {
              "@odata.id": "/redfish/v1/Sessions"
            }
          },
          "Managers": {
            "@odata.id": "/redfish/v1/Managers"
          },
          "Name": "Root Service",
          "Oem": {
            "Dell": {
              "@odata.type": "#DellServiceRoot.v1_0_0.ServiceRootSummary",
              "IsBranded": 0,
              "ManagerMACAddress": "d0:96:69:51:d4:70",
              "ServiceTag": "XXXX"
            }
          },
          "RedfishVersion": "1.2.0",
          "Registries": {
            "@odata.id": "/redfish/v1/Registries"
          },
          "SessionService": {
            "@odata.id": "/redfish/v1/SessionService"
          },
          "Systems": {
            "@odata.id": "/redfish/v1/Systems"
          },
          "Tasks": {
            "@odata.id": "/redfish/v1/TaskService"
          },
          "UpdateService": {
            "@odata.id": "/redfish/v1/UpdateService"
          }
        },
        "output": "/redfish/v1/Systems"
      }
    ],
    "identifier": 59959364
  },
  {
    "context": [
      "I have output and I want to prefix it with a url.",
      "output\n\"node1\"\t\"testing\"\n\"node2\"\tnull",
      "expected output\n\"node1\"\t\"https://jira.test.com/testing\"\n\"node2\"\t\"https://jira.test.com/null\"",
      "Looks to me like you want:\n\n```\njq -r '.items[] | [.metadata.name, \"https://jira.test.com/\\(.metadata.labels[\"test.com/cordon-reason\"])\" ] | @tsv'\n```"
    ],
    "utterance": "For each item, output the metadata.name and the string 'https://jira.test.com/' followed by the value of metadata.labels[\"test.com/cordon-reason\"] as tab-separated values.",
    "expressions": [
      ".items[] | [.metadata.name, \"https://jira.test.com/\\(.metadata.labels[\"test.com/cordon-reason\"])\" ] | @tsv",
      ".items[] | [.metadata.name, \"https://jira.test.com/\\(.metadata.labels[\"team.com/cordon-reason\"])\" ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "node1",
                "labels": {
                  "team.com/cordon-reason": "testing"
                }
              }
            },
            {
              "metadata": {
                "name": "node2",
                "labels": {
                  "team.com/cordon-reason": null
                }
              }
            }
          ]
        },
        "output": "node1\thttps://jira.test.com/testing\nnode2\thttps://jira.test.com/null"
      }
    ],
    "identifier": 59960188
  },
  {
    "context": [
      "How can i make sure empty value gets when Key is missing ?.",
      "I want output something like below which adds empty value if deviceName is missing.",
      "In `jq` you can use the alternate operator `//` that can be used to return default values. E.g.  `.foo // 1` will evaluate to `1` if there's no `.foo` element in the input",
      "Using that and appending an empty string \"\" if the key is not present, you can do",
      "jq -r '[.id // \"\", .deviceName // \"\", .total // \"\", .master // \"\"] | @csv'",
      "You can take the first object as a reference for a full record, like",
      "keys_unsorted as $k | (., inputs) | [.[$k[]]] | @csv"
    ],
    "utterance": "Output rows with empty string when deviceName field is missing, ensuring columns remain aligned when converting to CSV.",
    "expressions": [
      "[.id // \"\", .deviceName // \"\", .total // \"\", .master // \"\"] | @csv",
      "keys_unsorted as $k | (., inputs) | [.[$k[]]] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": "ABC",
            "deviceName": "",
            "total": 100,
            "master": 20
          },
          {
            "id": "ABC",
            "total": 100,
            "master": 20
          }
        ],
        "output": "\"ABC\",\"\",100,20\n\"ABC\",\"\",100,20"
      }
    ],
    "identifier": 59960742
  },
  {
    "context": [
      "But if I run with the incorrect case, eg.\n\n$ jq -r '. | select(.value==\"Myemail@domain.com\") .id' sample.json\n\n...I do not get a result.",
      "You don't really need regexp for this.\n\nselect(.value | ascii_downcase == \"myemail@domain.com\") .id",
      "But if you insist on it, below is how you perform a case-insensitive match using `test/2`.\n\nselect(.value | test(\"MyEmail@domain.com\"; \"i\")) .id"
    ],
    "utterance": "Find the id where the value field matches MyEmail@domain.com regardless of case",
    "expressions": [
      "select(.value | ascii_downcase == \"myemail@domain.com\") .id",
      "select(.value | test(\"MyEmail@domain.com\"; \"i\")) .id"
    ],
    "data": [
      {
        "input": [
          {
            "created_at": "2020-01-17T12:54:02Z",
            "primary": true,
            "verified": true,
            "deliverable_state": "deliverable",
            "undeliverable_count": 0,
            "updated_at": "2020-01-17T12:54:03Z",
            "url": "http://www.website.com",
            "id": 376062709553,
            "user_id": 374002305374,
            "type": "email",
            "value": "test-1234567@domain.com"
          },
          {
            "created_at": "2019-02-07T20:49:41Z",
            "primary": false,
            "verified": true,
            "deliverable_state": "deliverable",
            "undeliverable_count": 0,
            "updated_at": "2019-02-07T20:49:41Z",
            "url": "http://www.website.com",
            "id": 366235941554,
            "user_id": 374002305374,
            "type": "email",
            "value": "MyEmail@domain.com"
          }
        ],
        "output": 366235941554
      }
    ],
    "identifier": 59969841
  },
  {
    "context": [
      "I am trying to merge an arbitrary number of files, containing identical schema's, but different data into a single file.",
      "The following outputs the correct information (no duplicates) regardless of file order",
      "jq -s 'reduce .[] as $dot ({}; .logs.logs_collected.files.collect_list += $dot.logs.logs_collected.files.collect_list)' web.json wazuh-agent.json suricata.json",
      "you need to use `add` but the way it was invoked was incorrect. ... it should have been [.[].logs.logs_collected.files.collect_list] | add",
      "[.[].logs.logs_collected.files.collect_list] | add | unique",
      "As for the duplication of first elements, it is because you were using the append operation `+=` instead of the assignment `=`.",
      "So putting it together will work as expected irrespective of the order of files.",
      "jq -s '.[0].logs.logs_collected.files.collect_list = ([.[].logs.logs_collected.files.collect_list]|add|unique)|.[0]'"
    ],
    "utterance": "Merge multiple files to produce one output containing all objects under logs.logs_collected.files.collect_list, combined without duplicates, regardless of input file order.",
    "expressions": [
      "jq -s 'reduce .[] as $dot ({}; .logs.logs_collected.files.collect_list += $dot.logs.logs_collected.files.collect_list)' web.json wazuh-agent.json suricata.json",
      "jq -s '.[0].logs.logs_collected.files.collect_list = ([.[].logs.logs_collected.files.collect_list]|add|unique)|.[0]' web.json suricata.json wazuh-agent.json",
      "[.[].logs.logs_collected.files.collect_list] | add | unique"
    ],
    "data": [
      {
        "input": [
          {
            "logs": {
              "logs_collected": {
                "files": {
                  "collect_list": [
                    {
                      "file_name": "/var/log/suricata/eve-ips.json",
                      "log_group_name": "{{grains.environment_full}}SuricataIPS",
                      "log_stream_name": "{{grains.id}}",
                      "timezone": "UTC",
                      "timestamp_format": "%Y-%m-%dT%H:%M:%S.%f+0000"
                    }
                  ]
                }
              }
            }
          },
          {
            "logs": {
              "logs_collected": {
                "files": {
                  "collect_list": [
                    {
                      "file_name": "/var/log/company/company-json.log",
                      "log_group_name": "{{grains.environment_full}}Play",
                      "log_stream_name": "{{grains.id}}",
                      "timezone": "UTC",
                      "timestamp_format": "%Y-%m-%dT%H:%M:%S.%fZ"
                    },
                    {
                      "file_name": "/var/log/company/company-notifications.log",
                      "log_group_name": "{{grains.environment_full}}Notifications",
                      "log_stream_name": "{{grains.id}}",
                      "timezone": "UTC",
                      "timestamp_format": "%Y-%m-%dT%H:%M:%S.%fZ"
                    }
                  ]
                }
              }
            }
          },
          {
            "logs": {
              "logs_collected": {
                "files": {
                  "collect_list": [
                    {
                      "file_name": "/var/ossec/logs/alerts/alerts.json",
                      "log_group_name": "{{grains.environment_full}}OSSEC",
                      "log_stream_name": "{{grains.id}}",
                      "timezone": "UTC",
                      "timestamp_format": "%Y-%m-%d %H:%M:%S"
                    }
                  ]
                }
              }
            }
          }
        ],
        "output": {
          "logs": {
            "logs_collected": {
              "files": {
                "collect_list": [
                  {
                    "file_name": "/var/log/company/company-json.log",
                    "log_group_name": "{{grains.environment_full}}Play",
                    "log_stream_name": "{{grains.id}}",
                    "timezone": "UTC",
                    "timestamp_format": "%Y-%m-%dT%H:%M:%S.%fZ"
                  },
                  {
                    "file_name": "/var/log/company/company-notifications.log",
                    "log_group_name": "{{grains.environment_full}}Notifications",
                    "log_stream_name": "{{grains.id}}",
                    "timezone": "UTC",
                    "timestamp_format": "%Y-%m-%dT%H:%M:%S.%fZ"
                  },
                  {
                    "file_name": "/var/log/suricata/eve-ips.json",
                    "log_group_name": "{{grains.environment_full}}SuricataIPS",
                    "log_stream_name": "{{grains.id}}",
                    "timezone": "UTC",
                    "timestamp_format": "%Y-%m-%dT%H:%M:%S.%f+0000"
                  },
                  {
                    "file_name": "/var/ossec/logs/alerts/alerts.json",
                    "log_group_name": "{{grains.environment_full}}OSSEC",
                    "log_stream_name": "{{grains.id}}",
                    "timezone": "UTC",
                    "timestamp_format": "%Y-%m-%d %H:%M:%S"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 59884137
  },
  {
    "context": [
      "I essentially have to filter results based on year and store the resultant json file.",
      "The output I'm looking to get is\n```\n[\n{\n      \"query\": \"#India_since_2019\",\n      \"username\": \"user_1\",\n      \"ID\": \"123455\",\n      \"tweet\": \"This is the tweet\",\n      \"datetime\": \"2019-04-05\"\n    },\n    {\n      \"query\": \"#India_since_2019\",\n      \"username\": \"user_1\",\n      \"ID\": \"123455\",\n      \"tweet\": \"This is the tweet\",\n      \"datetime\": \"2019-04-05\"\n    }\n]\n```",
      "One of the major advantages of jq is that it is stream-oriented, so there should be no need to convert your stream of JSON entities to an array of those entities, unless that is the goal.",
      "In other words, it might be advisable to perform all the processing in jq rather than converting the stream to a single, unmanageably large JSON entity for some tool that cannot deal with a stream."
    ],
    "utterance": "Combine all objects in a stream into a JSON array for output.",
    "expressions": [
      "[inputs]"
    ],
    "data": [
      {
        "input": [
          {
            "query": "#India_since_2019",
            "username": "user_1",
            "ID": "123455",
            "tweet": "This is the tweet",
            "datetime": "2019-04-05"
          },
          {
            "query": "#India_since_2019",
            "username": "user_1",
            "ID": "123455",
            "tweet": "This is the tweet",
            "datetime": "2019-04-05"
          }
        ],
        "output": [
          {
            "query": "#India_since_2019",
            "username": "user_1",
            "ID": "123455",
            "tweet": "This is the tweet",
            "datetime": "2019-04-05"
          },
          {
            "query": "#India_since_2019",
            "username": "user_1",
            "ID": "123455",
            "tweet": "This is the tweet",
            "datetime": "2019-04-05"
          }
        ]
      }
    ],
    "identifier": 59962659
  },
  {
    "context": [
      "export REGIONS=\"region1,region2\"",
      "export KMS_KEYS=\"key1,key2\"",
      "I'm stuck on how to use my REGIONS variable content as the keys and KMS_KEYS variable as the values.",
      "Split `$regions` and `$kmskeys` by commas into two separate arrays, transpose them to pair each region with corresponding kms key and make objects out of them, then add them together to form a single object.",
      ".builders[].region_kms_key_ids = (\n    [ $regions/\",\", $kmskeys/\",\" ] | transpose | map({(.[0]):.[1]}) | add\n)"
    ],
    "utterance": "Assign to each builder a region_kms_key_ids object where each region (from REGIONS) is a key mapped to the corresponding kms key (from KMS_KEYS), pairing them by order.",
    "expressions": [
      ".builders[].region_kms_key_ids = ([ $regions/\",\", $kmskeys/\",\" ] | transpose | map({ (.[0]): .[1] }) | add)"
    ],
    "data": [
      {
        "input": {
          "builders": [
            {
              "name": "aws"
            }
          ]
        },
        "output": {
          "builders": [
            {
              "name": "aws",
              "region_kms_key_ids": {
                "region1": "key1",
                "region2": "key2"
              }
            }
          ]
        }
      }
    ],
    "identifier": 59985760
  },
  {
    "context": [
      "My goal is to have only one column title row in the table instead of one for each entry, and of course to display the data instead of the error.",
      "A fixed version might look like:",
      "jq -rn '[\"NAME\",\"NODE\",\"SOURCE IP\",\"SOURCE PORT\",\"DESTINATION IP\",\"DESTINATION PORT\",\"GATEWAY IP\",\"GATEWAY PORT\"] as $fields | (  $fields,                        # emit the list as a header  ($fields | map(length*\"-\")),    # print separators below each header  (inputs | .[] | [.name, .node, .s_ip, .s_port, .d_ip, .d_port, .pif_ip, .pif_port]) ) | @tsv' <<<\"$s\" # where s is a string with your JSON content.",
      "...which emits as output, for your input (without any reformatting to align the tabs):",
      "NAME\tNODE\tSOURCE IP\tSOURCE PORT\tDESTINATION IP\tDESTINATION PORT\tGATEWAY IP\tGATEWAY PORT",
      "----\t----\t---------\t-----------\t--------------\t----------------\t----------\t------------",
      "mike1\tc04\t10.244.7.235\t38558\t129.12.34.567\t22\t129.23.45.678\t11019",
      "fhlb-test\tc04\t10.244.7.20\t49846\t129.98.76.543\t22\t129.87.65.432\t23698",
      "The immediate bug was the inclusion of `.[]` in `(.[], map(length*\"-\"))` -- the first part of that is pointless, and does nothing but insert your map contents (which isn't valid in TSV content, not being a list) into the data stream."
    ],
    "utterance": "Produce a table with a single header row and columns for name, node, s_ip, s_port, d_ip, d_port, pif_ip, and pif_port, using the values from each 'host' object.",
    "expressions": [
      "[\"NAME\",\"NODE\",\"SOURCE IP\",\"SOURCE PORT\",\"DESTINATION IP\",\"DESTINATION PORT\",\"GATEWAY IP\",\"GATEWAY PORT\"] as $fields | (  $fields,  ($fields | map(length*\"-\")),  (inputs | .host | [.name, .node, .s_ip, .s_port, .d_ip, .d_port, .pif_ip, .pif_port]) ) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "host": {
              "name": "mike1",
              "node": "c04",
              "s_ip": "10.244.7.235",
              "s_port": "38558",
              "d_ip": "129.12.34.567",
              "d_port": "22",
              "pif_ip": "129.23.45.678",
              "pif_port": "11019"
            }
          },
          {
            "host": {
              "name": "fhlb-test",
              "node": "c04",
              "s_ip": "10.244.7.20",
              "s_port": "49846",
              "d_ip": "129.98.76.543",
              "d_port": "22",
              "pif_ip": "129.87.65.432",
              "pif_port": "23698"
            }
          }
        ],
        "output": "NAME\tNODE\tSOURCE IP\tSOURCE PORT\tDESTINATION IP\tDESTINATION PORT\tGATEWAY IP\tGATEWAY PORT\n----\t----\t---------\t-----------\t--------------\t----------------\t----------\t------------\nmike1\tc04\t10.244.7.235\t38558\t129.12.34.567\t22\t129.23.45.678\t11019\nfhlb-test\tc04\t10.244.7.20\t49846\t129.98.76.543\t22\t129.87.65.432\t23698"
      }
    ],
    "identifier": 59973594
  },
  {
    "context": [
      "Regarding the key \"apple-cider\" -- since it has a special character (\"-\"), you cannot use the abbreviated syntax.  Whichever version of jq you have, you can use the unabbreviated form: `.[\"apple-cider\"]`; you might also be able to use the form:\n\n    .\"apple-cider\"\n",
      "it worked with this command\n\n    jq -r '.lambda.\"apple-cider\"[].type' test.json "
    ],
    "utterance": "Extract the type property from all items under the apple-cider key inside the lambda object.",
    "expressions": [
      ".lambda.[\"apple-cider\"][].type",
      ".lambda.\"apple-cider\"[].type"
    ],
    "data": [
      {
        "input": {
          "lambda": {
            "apple": [
              {
                "type": "fruit",
                "color": "red",
                "shape": "round",
                "cron": "0/10 * * * ? *"
              }
            ],
            "orange": [
              {
                "type": "fruit",
                "color": "orange",
                "shape": "round",
                "cron": "0/15 * * * ? *"
              }
            ],
            "apple-cider": [
              {
                "type": "juice",
                "color": "pink",
                "shape": "none",
                "cron": "0/30 * * * ? *"
              }
            ]
          }
        },
        "output": [
          "juice"
        ]
      }
    ],
    "identifier": 59995900
  },
  {
    "context": [
      "I need to perform a conversion where every object (`httpReq`, `params`, `userAgent`, `userKeyDetails`) need to be converted as array of objects, with `key` and `value` properties. Every key is not mandatory, a single json may NOT have all given keys.",
      "It works, but it's failing on rows where one of the given key is missing, with following error:",
      "So I need a selector which works handling the possibility of a key to be missing, can this be obtained directly with a jq selector?",
      "Now we just need to update `f` so that it doesn't fail if the requested key doesn't exist. To do that, we can replace `.` with `select(has(key))`.",
      "def f(key):\n    select(has(key))[key] |= to_entries\n;\nf(\"userAgent\") | f(\"userKeyDetails\") | f(\"params\") | f(\"httpReq\")"
    ],
    "utterance": "Convert each of the fields 'httpReq', 'params', 'userAgent', and 'userKeyDetails' to arrays of objects with 'key' and 'value' properties, but only for those that exist in the data; do nothing if the field is missing.",
    "expressions": [
      "def f(key): select(has(key))[key] |= to_entries; f(\"userAgent\") | f(\"userKeyDetails\") | f(\"params\") | f(\"httpReq\")"
    ],
    "data": [
      {
        "input": {
          "callID": "xxxxxxxxxxxxxx",
          "authType": "xxxxxxxxxxxxxx",
          "timestamp": "xxxxxxxxxxxxxx",
          "errCode": "0",
          "errMessage": "xxxxxxxxxxxxxx",
          "endpoint": "xxxxxxxxxxxxxx",
          "userKey": "xxxxxxxxxxxxxx",
          "httpReq": {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          },
          "ip": "xxxxxxxxxxxxxx",
          "params": {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          },
          "uid": "xxxxxxxxxxxxxx",
          "apikey": "xxxxxxxxxxxxxx",
          "userAgent": {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          },
          "userKeyDetails": {
            "name": "xxxxxxxxxxxxxx"
          }
        },
        "output": {
          "callID": "xxxxxxxxxxxxxx",
          "authType": "xxxxxxxxxxxxxx",
          "timestamp": "xxxxxxxxxxxxxx",
          "errCode": "0",
          "errMessage": "xxxxxxxxxxxxxx",
          "endpoint": "xxxxxxxxxxxxxx",
          "userKey": "xxxxxxxxxxxxxx",
          "httpReq": [
            {
              "key": "key1",
              "value": "value1"
            },
            {
              "key": "key2",
              "value": "value2"
            },
            {
              "key": "key3",
              "value": "value3"
            }
          ],
          "ip": "xxxxxxxxxxxxxx",
          "params": [
            {
              "key": "key1",
              "value": "value1"
            },
            {
              "key": "key2",
              "value": "value2"
            },
            {
              "key": "key3",
              "value": "value3"
            }
          ],
          "uid": "xxxxxxxxxxxxxx",
          "apikey": "xxxxxxxxxxxxxx",
          "userAgent": [
            {
              "key": "key1",
              "value": "value1"
            },
            {
              "key": "key2",
              "value": "value2"
            },
            {
              "key": "key3",
              "value": "value3"
            }
          ],
          "userKeyDetails": [
            {
              "key": "name",
              "value": "xxxxxxxxxxxxxx"
            }
          ]
        }
      }
    ],
    "identifier": 59974811
  },
  {
    "context": [
      "The data in the above file (say data.json) has to filtered and the candles data has to be saved in csv file (say output.csv). I am unable to get .data.candles data in a csv file.",
      "Output expected is:\r\n    \r\n    2015-12-28T09:15:00+0530,1386.4,1388.0,1381.05,1385.1,788\r\n    2015-12-28T09:16:00+0530,1385.1,1389.1,1383.85,1385.5,609\r\n    ...",
      "One way:\r\n\r\n    $ jq -r '.data.candles[] | @csv' data.json",
      "It just sends all the elements of the candles array to the `@csv` output formatter, one at a time, and prints out the raw results instead of treating each output line as a JSON string (The `-r` option)."
    ],
    "utterance": "Extract each array inside the candles field and write each as a line in CSV format, with values comma-separated and strings quoted as needed.",
    "expressions": [
      ".data.candles[] | @csv"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": {
            "candles": [
              [
                "2015-12-28T09:15:00+0530",
                1386.4,
                1388,
                1381.05,
                1385.1,
                788
              ],
              [
                "2015-12-28T09:16:00+0530",
                1385.1,
                1389.1,
                1383.85,
                1385.5,
                609
              ],
              [
                "2015-12-28T09:17:00+0530",
                1385.5,
                1387,
                1385.5,
                1385.7,
                212
              ],
              [
                "2015-12-28T09:18:00+0530",
                1387,
                1387.95,
                1385.3,
                1387.95,
                1208
              ],
              [
                "2015-12-28T09:19:00+0530",
                1387,
                1387.55,
                1385.6,
                1386.25,
                716
              ],
              [
                "2015-12-28T09:20:00+0530",
                1386.95,
                1389.95,
                1386.95,
                1389,
                727
              ],
              [
                "2015-12-28T09:21:00+0530",
                1389,
                1392.95,
                1389,
                1392.95,
                291
              ],
              [
                "2015-12-28T09:22:00+0530",
                1392.95,
                1393,
                1392,
                1392.95,
                180
              ],
              [
                "2015-12-28T09:23:00+0530",
                1392.95,
                1393,
                1392,
                1392.15,
                1869
              ],
              [
                "2016-01-01T13:22:00+0530",
                1386.4,
                1388,
                1381.05,
                1385.1,
                788
              ],
              [
                "2016-01-01T13:23:00+0530",
                1385.1,
                1389.1,
                1383.85,
                1385.5,
                613
              ],
              [
                "2016-01-01T13:24:00+0530",
                1385.5,
                1387,
                1385.5,
                1385.7,
                212
              ],
              [
                "2016-01-01T13:25:00+0530",
                1387,
                1387.95,
                1385.3,
                1387.95,
                1208
              ],
              [
                "2016-01-01T13:26:00+0530",
                1387,
                1387.55,
                1385.6,
                1386.25,
                716
              ],
              [
                "2016-01-01T13:27:00+0530",
                1386.95,
                1389.95,
                1386.95,
                1389,
                727
              ],
              [
                "2016-01-01T13:28:00+0530",
                1389,
                1392.95,
                1389,
                1392.95,
                291
              ],
              [
                "2016-01-01T13:29:00+0530",
                1392.95,
                1393,
                1392,
                1392.95,
                180
              ],
              [
                "2016-01-01T13:30:00+0530",
                1392.95,
                1393,
                1392,
                1392.15,
                1869
              ]
            ]
          }
        },
        "output": [
          "\"2015-12-28T09:15:00+0530\",1386.4,1388,1381.05,1385.1,788",
          "\"2015-12-28T09:16:00+0530\",1385.1,1389.1,1383.85,1385.5,609",
          "\"2015-12-28T09:17:00+0530\",1385.5,1387,1385.5,1385.7,212",
          "\"2015-12-28T09:18:00+0530\",1387,1387.95,1385.3,1387.95,1208",
          "\"2015-12-28T09:19:00+0530\",1387,1387.55,1385.6,1386.25,716",
          "\"2015-12-28T09:20:00+0530\",1386.95,1389.95,1386.95,1389,727",
          "\"2015-12-28T09:21:00+0530\",1389,1392.95,1389,1392.95,291",
          "\"2015-12-28T09:22:00+0530\",1392.95,1393,1392,1392.95,180",
          "\"2015-12-28T09:23:00+0530\",1392.95,1393,1392,1392.15,1869",
          "\"2016-01-01T13:22:00+0530\",1386.4,1388,1381.05,1385.1,788",
          "\"2016-01-01T13:23:00+0530\",1385.1,1389.1,1383.85,1385.5,613",
          "\"2016-01-01T13:24:00+0530\",1385.5,1387,1385.5,1385.7,212",
          "\"2016-01-01T13:25:00+0530\",1387,1387.95,1385.3,1387.95,1208",
          "\"2016-01-01T13:26:00+0530\",1387,1387.55,1385.6,1386.25,716",
          "\"2016-01-01T13:27:00+0530\",1386.95,1389.95,1386.95,1389,727",
          "\"2016-01-01T13:28:00+0530\",1389,1392.95,1389,1392.95,291",
          "\"2016-01-01T13:29:00+0530\",1392.95,1393,1392,1392.95,180",
          "\"2016-01-01T13:30:00+0530\",1392.95,1393,1392,1392.15,1869"
        ]
      }
    ],
    "identifier": 59806699
  },
  {
    "context": [
      "I want to create valid json using jq in bash.",
      "each time when bash script will execute \"Add new element to existing JSON array\" and if file is empty create new file.",
      "json should be created first time like ...",
      "and when I next time execute the bash script element should be added into the array like ...",
      "\"date \", \"service data\" , \"service info\" fields in my json which are missing in my current one",
      "You just want to add new object to your input. jq doesn't do in-place file editing, so you'll have to write to a temporary file and replace your original after the fact.",
      "jq --arg transactionId \"$TRANSACTION_ID_METRIC\" \\",
      "   --arg name \"$REALPBPODDEFNAME\" \\",
      "   --arg lintruntime \"$Cloudlintruntime\" \\",
      "   --arg status \"$EXITCODE\" \\",
      "   --arg buildtime \"$totaltime\" \\",
      "   '.ServiceData.ServiceInfo += [ {transactionID: $transactionId, name: $name, lintruntime: $lintruntime, status: $status, buildtime: $buildtime} ]' \\",
      "    Test.json > tmp.json &&",
      " mv tmp.json Test.json"
    ],
    "utterance": "Add a new object with specified fields and values to the ServiceData.ServiceInfo array, ensuring that date, ServiceData, and ServiceInfo fields exist, creating them if missing.",
    "expressions": [
      ".ServiceData.ServiceInfo += [{transactionID: $transactionId, name: $name, lintruntime: $lintruntime, status: $status, buildtime: $buildtime}]"
    ],
    "data": [
      {
        "input": {
          "ServiceData": {
            "date": "30/1/2020",
            "ServiceInfo": [
              {
                "transcationId": "20200129T130718Z",
                "name": "MyService",
                "lintruntime": "178",
                "status": "0",
                "buildtime": "3298"
              }
            ]
          }
        },
        "output": {
          "ServiceData": {
            "date": "30/1/2020",
            "ServiceInfo": [
              {
                "transcationId": "20200129T130718Z",
                "name": "MyService",
                "lintruntime": "178",
                "status": "0",
                "buildtime": "3298"
              },
              {
                "transactionID": "$transactionId",
                "name": "$name",
                "lintruntime": "$lintruntime",
                "status": "$status",
                "buildtime": "$buildtime"
              }
            ]
          }
        }
      }
    ],
    "identifier": 59986903
  },
  {
    "context": [
      "I have the following json ... [ { \"name\":\"bucket1\" }, { \"name\":\"bucket1\" } ] ... I want to convert it to { \"buckets\":[ { \"name\":\"bucket1\" }, { \"name\":\"bucket1\" } ] }",
      "**The solution is the following:** {\"buckets\":.}",
      "**In the Command line:** jq '{\"buckets\":.}'"
    ],
    "utterance": "Wrap the array in an object with a key named \"buckets\".",
    "expressions": [
      "{\"buckets\":.}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "bucket1"
          },
          {
            "name": "bucket1"
          }
        ],
        "output": {
          "buckets": [
            {
              "name": "bucket1"
            },
            {
              "name": "bucket1"
            }
          ]
        }
      }
    ],
    "identifier": 60045218
  },
  {
    "context": [
      "echo $(credentials) | jq .username",
      "jq: error (at <stdin>:1): Cannot index string with string \"username\"",
      "I was able to finally resolve this by doing something that feels a little hacky.",
      "credentials=$(python test.py | jq -r .)",
      "You could also use `fromjson`, e.g.:",
      "echo '\"{\\\"username\\\": \\\"test\\\", \\\"password\\\": \\\"test\\\"}\"' | jq 'fromjson'",
      "echo $(credentials) | jq .username",
      "echo $(credentials) | jq fromjson | jq .username"
    ],
    "utterance": "Extract the username value where the input is a stringified object containing username and password fields",
    "expressions": [
      "fromjson | .username",
      ". | fromjson | .username"
    ],
    "data": [
      {
        "input": "\"{\\\"username\\\": \\\"test\\\", \\\"password\\\": \\\"test\\\"}\"",
        "output": "test"
      }
    ],
    "identifier": 60022403
  },
  {
    "context": [
      "Here\u2019s the json document",
      "[{\"name\": \"bucket1\",\"clusterName\":\"cluster1\"}, {\"name\": \"bucket2\",\"clusterName\":\"cluster1\"}, {\"name\": \"bucket3\",\"clusterName\":\"cluster2\"}, {\"name\": \"bucket4\",\"clusterName\":\"cluster2\"}]",
      "And I want to convert it to",
      "[{\"clusterName\": \"cluster1\", buckets:[{\"name\": \"bucket1\"}, {\"name\": \"bucket2\"}]}, {\"clusterName\": \"cluster2\", buckets:[{\"name\": \"bucket3\"}, {\"name\": \"bucket4\"}]}]",
      "cat doc.json | jq '[group_by(.clusterName)[] | { clusterName: .[0].clusterName, \"buckets\": [.[] | { name: .name } ]}]'",
      "group_by(.clusterName)\n| map( {clusterName: .[0].clusterName,\n        buckets: map( {name} ) } )"
    ],
    "utterance": "Group objects by clusterName and for each group, output an object with the clusterName and an array of bucket objects, each containing only the name.",
    "expressions": [
      "[group_by(.clusterName)[] | { clusterName: .[0].clusterName, buckets: [.[] | { name: .name }] }]",
      "group_by(.clusterName) | map({ clusterName: .[0].clusterName, buckets: map({ name }) })"
    ],
    "data": [
      {
        "input": [
          {
            "name": "bucket1",
            "clusterName": "cluster1"
          },
          {
            "name": "bucket2",
            "clusterName": "cluster1"
          },
          {
            "name": "bucket3",
            "clusterName": "cluster2"
          },
          {
            "name": "bucket4",
            "clusterName": "cluster2"
          }
        ],
        "output": [
          {
            "clusterName": "cluster1",
            "buckets": [
              {
                "name": "bucket1"
              },
              {
                "name": "bucket2"
              }
            ]
          },
          {
            "clusterName": "cluster2",
            "buckets": [
              {
                "name": "bucket3"
              },
              {
                "name": "bucket4"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60011507
  },
  {
    "context": [
      "I'm trying to locate the last date to keep in this output looking back 3 days (in the example list below this should be the date of 2020-01-24):",
      "yaml2json hassio.txt | jq 'map(.date) | sort | reverse[-2] | .[0:10]'",
      "< hassio.txt jq -nR '\n  [inputs | select(test(\"^- date\")) | sub(\".*date: \";\"\") | fromjson]\n  | sort | reverse[-2] | sub(\"\\\\..*\";\"\")'\n\"2020-01-24T03:00:01\""
    ],
    "utterance": "Find the third most recent date value in a list of backup records.",
    "expressions": [
      "jq 'map(.date) | sort | reverse[-2] | .[0:10]'",
      "jq -nR '[inputs | select(test(\"^- date\")) | sub(\".*date: \";\"\") | fromjson] | sort | reverse[-2] | sub(\"\\\\..*\";\"\")'"
    ],
    "data": [
      {
        "input": [
          {
            "date": "2019-12-10T03:00:01.313293+00:00",
            "name": "Automated backup 2019-12-10 04:00",
            "protected": false,
            "slug": "a0d3f958",
            "type": "full"
          },
          {
            "date": "2020-02-03T16:25:55.265219+00:00",
            "name": "Automated backup 2020-02-03 17:25",
            "protected": false,
            "slug": "acb7907b",
            "type": "full"
          },
          {
            "date": "2020-02-03T15:00:11.584836+00:00",
            "name": "Automated backup 2020-02-03 16:00",
            "protected": false,
            "slug": "6284d707",
            "type": "full"
          },
          {
            "date": "2020-01-24T03:00:01.169351+00:00",
            "name": "Automated backup 2020-01-24 04:00",
            "protected": false,
            "slug": "53d10566",
            "type": "full"
          }
        ],
        "output": "2020-01-24T03:00:01.169351+00:00"
      }
    ],
    "identifier": 60045283
  },
  {
    "context": [
      "I want to save two key values .id and .status into bash array.",
      "My array is 3 elements long echo ${#array[@]} returns 3 but I want it to be 2 elements long.",
      "Thus, to work-around that you\u2019d need to set IFS to the delimiter which is unique enough for your JSON data - for the sake of the example, let it be comma (assuming your JSON is in curl.json for brevity):",
      "array=($(<curl.json jq -r '[.id, .status] | @csv'))",
      "echo ${#array[@]}\n2",
      "echo ${array[1]}\n\"In Queue\""
    ],
    "utterance": "Extract the values of the id and status fields so they can be assigned as two elements in a bash array, preserving spaces in the status value.",
    "expressions": [
      "[.id, .status] | @csv"
    ],
    "data": [
      {
        "input": {
          "id": 6442,
          "name": "Execute Workflow",
          "description": "Plan: data",
          "status": "In Queue",
          "start_date": 0,
          "end_date": 0,
          "job_type": "Execute Workflow",
          "created_by_name": null,
          "creation_date": 1580762385615,
          "creation_date_str": "02/03/2020 09:39:45 PM",
          "last_updated_date": 1580762385615,
          "last_updated_date_str": "02/03/2020 09:39:45 PM",
          "last_updated_by_name": null,
          "schedule_on": 0,
          "paused_at_step": 0,
          "percent_complete": 0,
          "job_action_type": null,
          "child_job_id": -1
        },
        "output": "\"6442\",\"In Queue\""
      }
    ],
    "identifier": 60052195
  },
  {
    "context": [
      "I want to achieve this configuration building a block with \"logConfiguration\" and \"logDriver\"",
      "As you can see on point #2.A above, the config \"logDriver\" is written few times, and when the task definition is created within AWS fargate no logs are available in CloudWatch, because it is not picking the \"logDriver\" configuration, yes there is a log group in CloudWatch, but neither stdout nor stderr is captured from the container because \"logDriver\" is not being correctly introduced in the json task.",
      "You can accomplish the task with just one invocation of jq, and without using the shell's support for string interpolation, which is error-prone.  For example:",
      "    jq --arg group my_grup --arg region eu-west-2 --arg prefix ecsx '\n      .containerDefinitions[0].logConfiguration.options\n        = {\"awslogs-group\": $group,\n           \"awslog-region\": $region,\n           \"awslogs-stream-prefix\": $prefix}' input.json",
      "You can add .logDriver similarly (in the one invocation of jq)."
    ],
    "utterance": "Set the logConfiguration block including logDriver and options keys on the first object of containerDefinitions with specific awslogs-group, awslogs-region, and awslogs-stream-prefix values.",
    "expressions": [
      "jq --arg group my_grup --arg region eu-west-2 --arg prefix ecsx '(.containerDefinitions[0].logConfiguration) = {logDriver: \"awslogs\", options: {\"awslogs-group\": $group, \"awslogs-region\": $region, \"awslogs-stream-prefix\": $prefix}}' input.json"
    ],
    "data": [
      {
        "input": {
          "family": "",
          "networkMode": "awsvpc",
          "executionRoleArn": "arn:aws:iam::XXXXXXXXX:role/ecsTaskExecutionRole",
          "containerDefinitions": [
            {
              "name": "",
              "image": ":",
              "portMappings": [
                {
                  "containerPort": 3091,
                  "hostPort": 3091,
                  "protocol": "tcp"
                }
              ],
              "essential": true
            }
          ],
          "requiresCompatibilities": [
            "FARGATE"
          ],
          "cpu": "256",
          "memory": "512"
        },
        "output": {
          "family": "",
          "networkMode": "awsvpc",
          "executionRoleArn": "arn:aws:iam::XXXXXXXXX:role/ecsTaskExecutionRole",
          "containerDefinitions": [
            {
              "name": "",
              "image": ":",
              "portMappings": [
                {
                  "containerPort": 3091,
                  "hostPort": 3091,
                  "protocol": "tcp"
                }
              ],
              "essential": true,
              "logConfiguration": {
                "logDriver": "awslogs",
                "options": {
                  "awslogs-group": "my_grup",
                  "awslogs-region": "eu-west-2",
                  "awslogs-stream-prefix": "ecsx"
                }
              }
            }
          ],
          "requiresCompatibilities": [
            "FARGATE"
          ],
          "cpu": "256",
          "memory": "512"
        }
      }
    ],
    "identifier": 60025451
  },
  {
    "context": [
      "I have `input.txt` which can be simplified down to this:\n\n    [\n      {\n        \"foo1\": \"bar1\",\n        \"baz1\": \"fizz1\"\n      },\n      {\n        \"foo2\": \"bar2\",\n        \"baz2\": \"fizz2\"\n      }\n    ]",
      "I want to iterate through each object via a loop, so I'm essentially hoping to tackle just the 1's first, then loop through the 2's, etc.",
      "I would expect to see (spacing here is optional, not sure how jq would parse it):\n\n    loop { \"foo1\": \"bar1\", \"baz1\": \"fizz1\" }\n    loop { \"foo2\": \"bar2\", \"baz2\": \"fizz2\" }",
      "What about using the `-c` option:\n\n    $ jq -c '.[]' file | sed 's/^/loop /'\n\n<!--IFS-->\n\n    loop {\"foo1\":\"bar1\",\"baz1\":\"fizz1\"}\n    loop {\"foo2\":\"bar2\",\"baz2\":\"fizz2\"}",
      "echo \"$response\" | jq --raw-output '.[] | \"loop \" + tostring'\nloop {\"foo1\":\"bar1\",\"baz1\":\"fizz1\"}\nloop {\"foo2\":\"bar2\",\"baz2\":\"fizz2\"}"
    ],
    "utterance": "Output each object in the array on its own line, prefixed with the word 'loop'.",
    "expressions": [
      ".[] | \"loop \" + tostring",
      "-c '.[]' | sed 's/^/loop /'"
    ],
    "data": [
      {
        "input": [
          {
            "foo1": "bar1",
            "baz1": "fizz1"
          },
          {
            "foo2": "bar2",
            "baz2": "fizz2"
          }
        ],
        "output": [
          "loop {\"foo1\":\"bar1\",\"baz1\":\"fizz1\"}",
          "loop {\"foo2\":\"bar2\",\"baz2\":\"fizz2\"}"
        ]
      }
    ],
    "identifier": 60060802
  },
  {
    "context": [
      "I want to change the value of the last key (`replace_this`), using the `name` property of the parent object to generate a value like `generated_value_for_a_42`.",
      "The key problem here seems to be leaving the rest of the array unmodified, while updating specific elements. But the need to refer 'up the tree' to a parent property complicates matters.",
      "The following jq script solves the task:",
      "map(.name as $name | if has(\"list\") then .list |= map(if .key | contains(\"keep\") | not then .key = \"generated_value_for_\" + $name + \"_\" + .id else . end) else . end)"
    ],
    "utterance": "Update the key property to 'generated_value_for_{parent name}_{id}' only for array elements whose key does not contain 'keep', while leaving all other objects and properties unchanged.",
    "expressions": [
      "map(.name as $name |\n    if has(\"list\")\n    then .list |= map(if .key | contains(\"keep\") | not\n                      then .key = \"generated_value_for_\" + $name + \"_\" + .id\n                      else .\n                      end)\n    else .\n    end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "keep_me"
          },
          {
            "name": "leave_unchanged",
            "list": [
              {
                "id": "1",
                "key": "keep_this"
              }
            ]
          },
          {
            "name": "a",
            "list": [
              {
                "id": "2",
                "key": "also_keep_this"
              },
              {
                "id": "42",
                "key": "replace_this"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "keep_me"
          },
          {
            "name": "leave_unchanged",
            "list": [
              {
                "id": "1",
                "key": "keep_this"
              }
            ]
          },
          {
            "name": "a",
            "list": [
              {
                "id": "2",
                "key": "also_keep_this"
              },
              {
                "id": "42",
                "key": "generated_value_for_a_42"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60073976
  },
  {
    "context": [
      "jq -c -M '[.name,.connector.state,.tasks[].state] |\\",
      "You are abusing `\\`. Use:",
      "jq -c -M '[.name,.connector.state,.tasks[].state] |",
      "join(\":|:\")' |"
    ],
    "utterance": "Extract name, connector state, and all task states from connector status, then concatenate with ':|:' as a separator.",
    "expressions": [
      "[.name, .connector.state, .tasks[].state] | join(\":|:\")"
    ],
    "identifier": 60075893
  },
  {
    "context": [
      "Is there a way I can use ```jq``` to merge the JSON files so that the ```messages``` attribute is concatenated (order doesn't matter) and the others are left alone?",
      "The result from merging message_1.json and message_2.json would look like this:",
      "I have 11 JSON files, message_1.json, ..., message_11.json. I would like to merge them all into one ```messages.json``` file of this form containing **all of the messages** across the JSON files. How can I do this using ```jq``` via bash?",
      "One way, using slurp mode, which puts all the JSON files contents into a single array and then processes it by appending all the other's messages to the first one in that array:",
      "$  jq -s 'reduce .[1:][] as $m (.[0]; .messages += $m.messages)' message_*.json",
      "Here's one approach, which has the advantage of not requiring the -s option, which would consume more memory than necessary:",
      "jq 'reduce inputs as $in (.;\n  .messages += $in.messages)\n' $(for i in $(seq 1 11); do echo message_$i.json ; done)"
    ],
    "utterance": "Merge multiple files so the messages arrays are concatenated, preserving only one copy of other fields from the first file.",
    "expressions": [
      "jq -s 'reduce .[1:][] as $m (.[0]; .messages += $m.messages)' message_*.json",
      "jq 'reduce inputs as $in (.; .messages += $in.messages)' $(for i in $(seq 1 11); do echo message_$i.json ; done)"
    ],
    "data": [
      {
        "input": [
          {
            "participants": [
              {
                "name": "Person One"
              },
              {
                "name": "Person Two"
              }
            ],
            "messages": [
              {
                "sender_name": "Person One",
                "timestamp_ms": 2,
                "content": "Text2.",
                "type": "Generic"
              },
              {
                "sender_name": "Person Two",
                "timestamp_ms": 1,
                "content": "Text1.",
                "type": "Generic"
              }
            ],
            "title": "Person One",
            "is_still_participant": true,
            "thread_type": "Regular",
            "thread_path": "inbox/SomeString"
          },
          {
            "participants": [
              {
                "name": "Person One"
              },
              {
                "name": "Person Two"
              }
            ],
            "messages": [
              {
                "sender_name": "Person Two",
                "timestamp_ms": 4,
                "content": "Text4.",
                "type": "Generic"
              },
              {
                "sender_name": "Person One",
                "timestamp_ms": 3,
                "content": "Text3.",
                "type": "Generic"
              }
            ],
            "title": "Person One",
            "is_still_participant": true,
            "thread_type": "Regular",
            "thread_path": "inbox/SomeString"
          }
        ],
        "output": {
          "participants": [
            {
              "name": "Person One"
            },
            {
              "name": "Person Two"
            }
          ],
          "messages": [
            {
              "sender_name": "Person One",
              "timestamp_ms": 2,
              "content": "Text2.",
              "type": "Generic"
            },
            {
              "sender_name": "Person Two",
              "timestamp_ms": 1,
              "content": "Text1.",
              "type": "Generic"
            },
            {
              "sender_name": "Person Two",
              "timestamp_ms": 4,
              "content": "Text4.",
              "type": "Generic"
            },
            {
              "sender_name": "Person One",
              "timestamp_ms": 3,
              "content": "Text3.",
              "type": "Generic"
            }
          ],
          "title": "Person One",
          "is_still_participant": true,
          "thread_type": "Regular",
          "thread_path": "inbox/SomeString"
        }
      }
    ],
    "identifier": 59975714
  },
  {
    "identifier": 60087392
  },
  {
    "context": [
      "I'd like to use `jq` to update the JSON file.",
      "So for example, say `$SUBSCRIPTION_ID` is set to `abc-123`",
      "I can pull out the values using `.parameters[].value`, but I can't seem to find a way of setting each individual value.",
      "the solution should be reusable, and different JSON files will have different `parameters`, so I don't think I can use `--argjson`.",
      "jq '.parameters[].value |= (env[.[1:]] // .)' file",
      "Here is a \"data-driven\" approach based on the contents of the schema and the available environment variables:\n\n```\nexport SUBSCRIPTION_ID=\"abc-123\"\nexport TOPIC_NAME=\"SomeTopic\"\n\n< schema.json jq '.parameters \n    |= map_values(if .value | (startswith(\"$\") and env[.[1:]]) \n                  then .value |= env[.[1:]] else . end)'\n```",
      "Notice that none of the template names appear in the jq program."
    ],
    "utterance": "Replace values starting with $ in all parameters with the corresponding environment variable value using their names, leaving other values unchanged.",
    "expressions": [
      ".parameters[].value |= (env[.[1:]] // .)",
      ".parameters |= map_values(if .value | (startswith(\"$\") and env[.[1:]]) then .value |= env[.[1:]] else . end)"
    ],
    "data": [
      {
        "input": {
          "$schema": "https://schema.management.azure.com/schemas/2015-01-01/parametersTemplate.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "subscriptionId": {
              "value": "$SUBSCRIPTION_ID"
            },
            "topicName": {
              "value": "$TOPIC_NAME"
            }
          }
        },
        "output": {
          "$schema": "https://schema.management.azure.com/schemas/2015-01-01/parametersTemplate.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "subscriptionId": {
              "value": "abc-123"
            },
            "topicName": {
              "value": "SomeTopic"
            }
          }
        }
      }
    ],
    "identifier": 60061905
  },
  {
    "context": [
      "And I want to convert to this format where it's grouped by the certname. The challenge is I need to use value for to make it as the key as follow",
      "[ { \"certname\": \"server1\", \"memorysize\": \"62.76 GiB\", \"processorcount\": 12 }, { \"certname\": \"server2\", \"memorysize\": \"62.76 GiB\", \"processorcount\": 10 } ]",
      "The following is a commented jq script. Feel free to use it as is, or strip out the newlines and comments and use it as is.",
      "map({key:.certname, value: {certname}}) | unique | from_entries) as $init |",
      "reduce .[] as $attr ($init; .[$attr.certname][$attr.name] = $attr.value) |",
      "[.[]]"
    ],
    "utterance": "Group records by certname so that each resulting object has certname plus keys for memorysize and processorcount with their respective values.",
    "expressions": [
      "(map({key:.certname, value: {certname}}) | unique | from_entries) as $init | reduce .[] as $attr ($init; .[$attr.certname][$attr.name] = $attr.value) | [.[]]"
    ],
    "data": [
      {
        "input": [
          {
            "certname": "server1",
            "environment": "production",
            "name": "memorysize",
            "value": "62.76 GiB"
          },
          {
            "certname": "server1",
            "environment": "production",
            "name": "processorcount",
            "value": 12
          },
          {
            "certname": "server2",
            "environment": "production",
            "name": "memorysize",
            "value": "62.76 GiB"
          },
          {
            "certname": "server2",
            "environment": "production",
            "name": "processorcount",
            "value": 10
          }
        ],
        "output": [
          {
            "certname": "server1",
            "memorysize": "62.76 GiB",
            "processorcount": 12
          },
          {
            "certname": "server2",
            "memorysize": "62.76 GiB",
            "processorcount": 10
          }
        ]
      }
    ],
    "identifier": 60078795
  },
  {
    "context": [
      "Can't figure how to filter jq output to show only result or error message from json-rpc response.",
      "jq '.result? // .error.data.message?'"
    ],
    "utterance": "Show either the value of 'result' or, if it is not present, the error message located at error.data.message.",
    "expressions": [
      ".result? // .error.data.message?"
    ],
    "data": [
      {
        "input": {
          "result": "0001",
          "id": 1,
          "jsonrpc": "2.0"
        },
        "output": "0001"
      },
      {
        "input": {
          "error": {
            "code": -32000,
            "message": "Server error",
            "data": {
              "type": "TypeError",
              "args": [
                "'NoneType' object is not subscriptable"
              ],
              "message": "'NoneType' object is not subscriptable"
            }
          },
          "id": 1,
          "jsonrpc": "2.0"
        },
        "output": "'NoneType' object is not subscriptable"
      }
    ],
    "identifier": 60091657
  },
  {
    "context": [
      "I want to do like below, But this is not working. Any idea/leads on this will be appreciated.",
      "a=09800214851900C3",
      "jsonfile.json | jq '.${a}.label'",
      "it's preferable to define the variable in the context of jq itself, using a --arg varname value option",
      "you need to use .[\"09800214851900C3\"] instead",
      "jq --arg a 09800214851900C3 '.[$a].label' jsonfile.json"
    ],
    "utterance": "Retrieve the label value for the key 09800214851900C3 using a variable for the key.",
    "expressions": [
      "jq --arg a 09800214851900C3 '.[$a].label' jsonfile.json"
    ],
    "data": [
      {
        "input": {
          "09800214851900C3": {
            "label": "P7-R1-R16:S2",
            "name": "Geist Upgradable rPDU",
            "state": "normal",
            "order": 0,
            "type": "i03",
            "snmpInstance": 1,
            "lifetimeEnergy": "20155338",
            "outlet": {},
            "alarm": {
              "severity": "",
              "state": "none"
            },
            "layout": {
              "0": [
                "entity/total0",
                "entity/phase0",
                "entity/phase1",
                "entity/phase2"
              ]
            }
          }
        },
        "output": "P7-R1-R16:S2"
      }
    ],
    "identifier": 60079244
  },
  {
    "context": [
      "I want it to look like\n\n    {\n        \"foo\": \"bar\",\n        \"baz\": \"fizz\"\n    }\n\nIn other words, I want to delete the parent(s) but preserve the children.",
      "< input.json jq '.deleteMe[0]' | sponge input.json",
      "< input.json jq '.deleteMe[]' > input.tmp && mv input.tmp input.json"
    ],
    "utterance": "Extract the contents of the 'deleteMe' array, discarding all other top-level keys.",
    "expressions": [
      ".deleteMe[0]",
      ".deleteMe[]"
    ],
    "data": [
      {
        "input": {
          "useless": "stuff",
          "deleteMe": [
            {
              "foo": "bar",
              "baz": "fizz"
            }
          ]
        },
        "output": {
          "foo": "bar",
          "baz": "fizz"
        }
      }
    ],
    "identifier": 60079530
  },
  {
    "context": [
      "All details of the nested array in *f2.json* should be merged into *f1.json* as seen below",
      "jq -s '[0].\"a.b\".c += [1].\"a.b\".c | [0]' f1.json f2.json",
      "jq --slurpfile f2 f2.json '.\"a.b\".c += $f2[0].\"a.b\".c' f1.json"
    ],
    "utterance": "Merge the array at key c under a.b from a second file into the same array in the first file, keeping other properties in the first file unchanged.",
    "expressions": [
      "jq -s '.[0].\"a.b\".c += .[1].\"a.b\".c | .[0]' f1.json f2.json",
      "jq --slurpfile f2 f2.json '.\"a.b\".c += $f2[0].\"a.b\".c' f1.json"
    ],
    "data": [
      {
        "input": {
          "f1.json": {
            "a.b": {
              "c": [
                1,
                2
              ]
            },
            "d": "other data"
          },
          "f2.json": {
            "a.b": {
              "c": [
                3,
                4
              ]
            }
          }
        },
        "output": {
          "a.b": {
            "c": [
              1,
              2,
              3,
              4
            ]
          },
          "d": "other data"
        }
      }
    ],
    "identifier": 60097821
  },
  {
    "context": [
      "id=$(aws codebuild list-builds-for-project --project-name myproject | jq -r '.ids[0]')",
      "aws codebuild batch-get-builds --ids \"$id\" | jq '.builds[].phases[] | select (.phaseType==\"BUILD\") | .phaseStatus'"
    ],
    "utterance": "Get the phaseStatus value of the BUILD phase from the most recent completed build for the specified project.",
    "expressions": [
      ".builds[].phases[] | select (.phaseType==\"BUILD\") | .phaseStatus"
    ],
    "identifier": 60118935
  },
  {
    "context": [
      "I have a series of JSON files containing an array of records, e.g.",
      "I want to 1) extract a single field from each record and 2) output a single array containing all the field values from all input files.",
      "But I cannot figure out how to get `jq` to concatenate those output arrays into a single array!",
      "You need to use `--slurp` so that `jq` will apply its filter on the aggregation of all inputs rather than on each input.",
      "jq --slurp 'map(.records | map(.a)) | add' f?.json",
      "jq -s 'map(.records[].a)' f?.json",
      "jq -n '[inputs.records[].a]' f*.json",
      "jq -n 'reduce inputs.records[].a as $d (.; . += [$d])' f?.json",
      "$ jq '.records[] | .a' f?.json | jq -s"
    ],
    "utterance": "Extract the field 'a' from all records across multiple files and output a single array of these values.",
    "expressions": [
      "jq --slurp 'map(.records | map(.a)) | add' f?.json",
      "jq -s 'map(.records[].a)' f?.json",
      "jq -n '[inputs.records[].a]' f?.json",
      "jq -n 'reduce inputs.records[].a as $d (.; . += [$d])' f?.json",
      "jq '.records[] | .a' f?.json | jq -s"
    ],
    "data": [
      {
        "input": [
          {
            "records": [
              {
                "a": 1
              },
              {
                "a": 3
              }
            ]
          },
          {
            "records": [
              {
                "a": 2
              }
            ]
          }
        ],
        "output": [
          1,
          3,
          2
        ]
      }
    ],
    "identifier": 60099083
  },
  {
    "context": [
      "I would like to search the json file for all objects that have value in unique_number that match \"123456\" and return this value along with the IP address.",
      "jq should return something like - ```123456, 127.0.0.1```",
      "jq -r '.[]\n| select(.data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number==\"123456\")\n| \"\\(.ip), \\(.data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number)\"'",
      "jq -r '.[]\n| { ip, unique_number: .data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number }\n| select(.unique_number==\"123456\")\n| \"\\(.ip), \\(.unique_number)\"'",
      ".[]\n| { ip, unique_number: .data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number }\n| select(.unique_number==\"123456\")\n| [.ip, .unique_number]\n| join(\", \")"
    ],
    "utterance": "Find all objects where unique_number equals \"123456\" and return the unique_number and ip address in one line, separated by a comma.",
    "expressions": [
      ".[] | select(.data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number==\"123456\") | \"\\(.ip), \\(.data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number)\"",
      ".[] | { ip, unique_number: .data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number } | select(.unique_number==\"123456\") | \"\\(.ip), \\(.unique_number)\"",
      ".[] | { ip, unique_number: .data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number } | select(.unique_number==\"123456\") | [.ip, .unique_number] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "ip": "127.0.0.1",
          "data": {
            "tls": {
              "status": "success",
              "protocol": "tls",
              "result": {
                "handshake_log": {
                  "server_hello": {
                    "version": {
                      "name": "TLSv1.2",
                      "value": 1111
                    },
                    "random": "dGVzdA==",
                    "session_id": "dGVzdA==",
                    "cipher_suite": {
                      "name": "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256",
                      "value": 1122
                    },
                    "compression_method": 0
                  },
                  "server_certificates": {
                    "certificate": {
                      "raw": "dGVzdA==",
                      "parsed": {
                        "version": 3,
                        "unique_number": "123456",
                        "signature_algorithm": {
                          "name": "SHA256-RSA",
                          "oid": "1.2.4.5.6"
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": "127.0.0.1, 123456"
      }
    ],
    "identifier": 60098468
  },
  {
    "context": [
      "I want to fetch all the simple values in it (String, Int, bool etc but not dict and lists).",
      "Example:",
      "{\n\t\"a\": 10,\n\t\"b\": {\n\t\t\"d\": 20,\n\t\t\"e\": \"hello\"\n\t},\n\t\"c\": {\n\t\t\"z\": {\n\t\t\t\"f\": true\n\t\t}\n\t}\n}",
      "Expected output not necessarily in this order:",
      "10\n20\n\"hello\"\ntrue",
      "Recurse, selecting only the scalar values:",
      "jq 'recurse | scalars' tmp.json",
      "10\n20\n\"hello\"\ntrue"
    ],
    "utterance": "Fetch all the scalar values (such as 10, 20, \"hello\", true) from a nested structure, excluding objects and arrays.",
    "expressions": [
      "recurse | scalars"
    ],
    "data": [
      {
        "input": {
          "a": 10,
          "b": {
            "d": 20,
            "e": "hello"
          },
          "c": {
            "z": {
              "f": true
            }
          }
        },
        "output": [
          10,
          20,
          "hello",
          true
        ]
      }
    ],
    "identifier": 60117127
  },
  {
    "context": [
      "I want to use the results of a `jq` filter inside another `jq` filter. I\u2019ve done it with `xargs` but I feel It has to be a better way with a simple `jq` run.",
      "Is there a better way to do this with a single `jq` run?",
      "$ jq '.prof.Sma00K279a[.redundant_removed.Sma00K279a|keys[]]' file",
      "null",
      "{\n  \"Sma00K279a\": {\n    \"Smlt3938\": 1\n  }\n}",
      "null",
      "$ jq '(.prof|keys[]) as $k | .prof[$k][.redundant_removed[$k]|keys[]]' file"
    ],
    "utterance": "For each key in redundant_removed.Sma00K279a, retrieve the corresponding entry from prof.Sma00K279a using that key, returning the value if it exists.",
    "expressions": [
      ".prof.Sma00K279a[.redundant_removed.Sma00K279a|keys[]]",
      "(.prof|keys[]) as $k | .prof[$k][.redundant_removed[$k]|keys[]]"
    ],
    "data": [
      {
        "input": {
          "prof": {
            "Sma00K279a": {
              "SMLT_RS00075": {
                "Sma00K279a": {
                  "SMLT_RS00075": 1.0
                }
              },
              "SMLT_RS00180#": {
                "Sma00K279a": {
                  "SMLT_RS00180#": 1.0
                }
              },
              "Smlt0558": {
                "Sma00K279a": {
                  "Smlt3938": 1.0
                }
              }
            }
          },
          "redundant_removed": {
            "Sma00K279a": {
              "SMLT_RS22460": "SMLT_RS22690",
              "Smlt0558": "Smlt3938",
              "Smlt3573": "Smlt1093"
            }
          }
        },
        "output": [
          null,
          {
            "Sma00K279a": {
              "Smlt3938": 1
            }
          },
          null
        ]
      }
    ],
    "identifier": 60114720
  },
  {
    "context": [
      "I want to join these two jsons to produce the following output",
      "Is there a better to do this in python instead?",
      "A solution using `jq`:\n\n    <file1 jq --slurpfile f file2 '\n      {\n         clusterName:.[].clusterName,\n         nodes:map($f[],.nodes)|add|group_by(.hostname)|map(add)\n      }'\n\nThis build an object using both files.   \nThe first field `clusterName` is taken from same field of the second file.  \nThe second field `nodes` is the combination of objects of both based on `hostname` (done with `group_by` command)",
      "Here is a possible solution:\n\n    jq -s '{\n       clusterName:(.[][].clusterName?//empty),\n       nodes:map(.[].nodes[]?//.[])|group_by(.hostname)|map(add)\n    }' file1 file2",
      "cat master.json hostnames.json | jq '\n  # input: an array of objects, each with a \"nodes\" key\n  def mergeNode($node): \n    map(if .hostname == $node.hostname then . + $node else . end);\n  reduce inputs[] as $n (.; map_values( .nodes |= mergeNode($n) ))'"
    ],
    "utterance": "Combine a list of clusters containing nodes and a corresponding list of nodes with additional properties so that each node in a cluster is extended with properties from the nodes list by matching on hostname.",
    "expressions": [
      "<file1 jq --slurpfile f file2 '{ clusterName:.[].clusterName, nodes:map($f[],.nodes)|add|group_by(.hostname)|map(add) }'",
      "jq -s '{ clusterName:(.[][].clusterName?//empty), nodes:map(.[].nodes[]?//.[])|group_by(.hostname)|map(add) }' file1 file2",
      "cat master.json hostnames.json | jq '\n  def mergeNode($node): \n    map(if .hostname == $node.hostname then . + $node else . end);\n  reduce inputs[] as $n (.; map_values( .nodes |= mergeNode($n) ))'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "clusterName": "cluster1",
              "nodes": [
                {
                  "hostname": "server1",
                  "dse": "6.7.5"
                },
                {
                  "hostname": "server2",
                  "dse": "6.7.5"
                }
              ]
            },
            {
              "clusterName": "cluster2",
              "nodes": [
                {
                  "hostname": "server3",
                  "dse": "6.7.5"
                },
                {
                  "hostname": "server4",
                  "dse": "6.7.5"
                }
              ]
            }
          ],
          [
            {
              "hostname": "server1",
              "memorysize": "47.01 GiB",
              "processorcount": 12
            },
            {
              "hostname": "server2",
              "memorysize": "47.01 GiB",
              "processorcount": 12
            },
            {
              "hostname": "server3",
              "memorysize": "47.01 GiB",
              "processorcount": 10
            },
            {
              "hostname": "server4",
              "memorysize": "47.01 GiB",
              "processorcount": 11
            },
            {
              "hostname": "server5",
              "memorysize": "47.01 GiB",
              "processorcount": 12
            },
            {
              "hostname": "server6",
              "memorysize": "47.01 GiB",
              "processorcount": 12
            }
          ]
        ],
        "output": [
          {
            "clusterName": "cluster1",
            "nodes": [
              {
                "hostname": "server1",
                "dse": "6.7.5",
                "memorysize": "47.01 GiB",
                "processorcount": 12
              },
              {
                "hostname": "server2",
                "dse": "6.7.5",
                "memorysize": "47.01 GiB",
                "processorcount": 12
              }
            ]
          },
          {
            "clusterName": "cluster2",
            "nodes": [
              {
                "hostname": "server3",
                "dse": "6.7.5",
                "memorysize": "47.01 GiB",
                "processorcount": 10
              },
              {
                "hostname": "server4",
                "dse": "6.7.5",
                "memorysize": "47.01 GiB",
                "processorcount": 11
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60080554
  },
  {
    "context": [
      "I would like to fetch urls based on an environment variable `$ENV`",
      "jq --arg ENV \"$ENV\" -n '.\"env.ENV\"' envs.json",
      "jq --arg ENV \"$ENV\" '.[\"dev-cc1\"]' envs.json",
      "Try \n\n    ENV=\"dev-cc1\" jq '[env.ENV]' envs.json",
      "or \n\n    export ENV=\"dev-cc1\"\n    jq '[env.ENV]' envs.json",
      "or using a jq variable:\n\n    ENV=\"dev-cc1\"\n    jq --arg ENV \"$ENV\" '.[$ENV]' envs.json"
    ],
    "utterance": "Retrieve the object whose key matches the value of the ENV environment variable, such as 'dev-cc1'.",
    "expressions": [
      ".[env.ENV]",
      ".[$ENV]"
    ],
    "data": [
      {
        "input": {
          "dev-cc1": {
            "url": "https://my-url.com"
          },
          "dev-cc2": {
            "url": "https://my-url.com"
          }
        },
        "output": {
          "url": "https://my-url.com"
        }
      }
    ],
    "identifier": 60133307
  },
  {
    "context": [
      "Here is some sample JSON input:\n```\n[\n  {\n  \"HDR\": [1, \"abc\"],\n  \"DTL\": [ [101,\"Descr A\"], [102,\"Descr B\"] ]\n  }, {\n  \"HDR\": [2, \"def\"],\n  \"DTL\": [ [103,\"Descr C\"], [104,\"Descr D\"] ]\n  }\n]\n```",
      "Desired output:\n\n```\nHDR|1|abc\nDTL|101|Descr A\nDTL|102|Descr B\nHDR|2|def\nDTL|103|Descr C\nDTL|104|Descr D\n```",
      "jq -r 'map([\"HDR\"]+.HDR, [\"DTL\"] + .DTL[])[] | join(\"|\")' data.json"
    ],
    "utterance": "Output each object's HDR as one line and each DTL entry as subsequent lines, each prefixed by 'HDR' or 'DTL' and joined by '|' in the specified order.",
    "expressions": [
      "map([\"HDR\"]+.HDR, [\"DTL\"] + .DTL[])[] | join(\"|\")"
    ],
    "data": [
      {
        "input": [
          {
            "HDR": [
              1,
              "abc"
            ],
            "DTL": [
              [
                101,
                "Descr A"
              ],
              [
                102,
                "Descr B"
              ]
            ]
          },
          {
            "HDR": [
              2,
              "def"
            ],
            "DTL": [
              [
                103,
                "Descr C"
              ],
              [
                104,
                "Descr D"
              ]
            ]
          }
        ],
        "output": "HDR|1|abc\nDTL|101|Descr A\nDTL|102|Descr B\nHDR|2|def\nDTL|103|Descr C\nDTL|104|Descr D"
      }
    ],
    "identifier": 60122643
  },
  {
    "context": [
      "I have a JSON file:\n\n{\n  \"foo\": \"xxx\",\n  \"bar\": [\"yyy\",\"zzz\"]\n}\n\nI want to use JQ to convert this to:\n\nxxx yyy,zzz",
      "Note that I do not know the names of the keys in the JSON file in advance, and I am relying on the behaviour of `to_entries` to output the entries in order sorted by key",
      "If you don't know the key names, you could use this:\n\n    <file jq -r 'to_entries|map(.value|[strings?//.[]]|join(\",\"))|join(\" \")'",
      "Here's a solution that is agnostic both about the key names and their order, and is fairly robust in other respects:\n\n    jq -r 'to_entries\n      | sort_by(.value|type) \n      | reverse .  # \"string\" before \"array\"\n      | map(.value | if type == \"array\" then join(\",\") else tostring end)\n      | join(\" \")'"
    ],
    "utterance": "Print the string or comma-joined values from each key, in key order, as a single space-separated line.",
    "expressions": [
      "to_entries|map(.value|[strings?//.[]]|join(\",\"))|join(\" \")",
      "to_entries | sort_by(.key) | map(.value | if type == \"array\" then join(\",\") else tostring end) | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "foo": "xxx",
          "bar": [
            "yyy",
            "zzz"
          ]
        },
        "output": "xxx yyy,zzz"
      }
    ],
    "identifier": 60125581
  },
  {
    "context": [
      "I need to get from A_B and A_C Field2 and Field5.",
      "My goal is to save into two files called test2 and test3 which would look something like this:",
      "test2:\nA_B: 0.00000580\nA_C: 0.00049000",
      "test3:\nA_B: 0\nA_C: 0",
      "jq -r '\"A_B: \\(.A_B[\"Field2\"])\", \"A_C: \\(.A_C[\"Field2\"])\"' test > test2",
      "The equivalent command for `field5` and output file `test3` is\n\n    jq -r '\"A_B: \\(.A_B[\"Field5\"])\", \"A_C: \\(.A_C[\"Field5\"])\"' test > test3"
    ],
    "utterance": "Print Field2 for A_B and A_C in the format 'A_B: <value>' and 'A_C: <value>' on separate lines.",
    "expressions": [
      "\"A_B: \\(.A_B[\\\"Field2\\\"])\", \"A_C: \\(.A_C[\\\"Field2\\\"])\""
    ],
    "data": [
      {
        "input": {
          "A_B": {
            "Field1": "0.36564104",
            "Field2": "0.00000580",
            "Field3": "0.00000558",
            "Field4": 177,
            "Field5": "0"
          },
          "B_A": {
            "Field1": "19.02374743",
            "Field2": "0.00049000",
            "Field3": "0.00047179",
            "Field4": 253,
            "Field5": "0"
          },
          "A_C": {
            "Field1": "19.02374743",
            "Field2": "0.00049000",
            "Field3": "0.00047179",
            "Field4": 253,
            "Field5": "0"
          }
        },
        "output": "A_B: 0.00000580\nA_C: 0.00049000"
      }
    ],
    "identifier": 60132920
  },
  {
    "context": [
      "Now, I want to get {\"city\": \"abc\"} and {\"city\": \"ghi\";} but don't want to pass for-loop with bash (i think `jq` is a great tool with its own loop function).",
      "So I built a small json contains specific values.",
      "json-b(just a example):\n[\n  \"abc\",\n  \"ghi\"\n]",
      "Since you already have a working solution, let me first mention that if you want the results as an array, you could write:\n\n    jq --argfile array json-b.json 'map(select( .city as $city | $array | index($city)))' json-a.json",
      "Here's a solution that has a number of potential advantages as outlined below:\n```\n< json-a.json jq --argfile array json-b.json '\n  INDEX(.city)[$array[]]'\n```"
    ],
    "utterance": "Filter an array of objects to select only those whose 'city' field matches any value from a given list of cities: 'abc' and 'ghi'.",
    "expressions": [
      ".[] | .city as $c | select( [\"abc\",\"ghi\"] | index($c) )",
      "map(select( .city as $city | $array | index($city)))",
      "INDEX(.city)[$array[]]"
    ],
    "data": [
      {
        "input": [
          {
            "city": "abc"
          },
          {
            "city": "def"
          },
          {
            "city": "ghi"
          },
          {
            "city": "jkl"
          }
        ],
        "output": [
          {
            "city": "abc"
          },
          {
            "city": "ghi"
          }
        ]
      },
      {
        "input": [
          "abc",
          "ghi"
        ]
      }
    ],
    "identifier": 60138878
  },
  {
    "context": [
      "jq 'del(.entries[] | select(.var == \"foo\"))' input.json",
      "jq 'del(.entries[] | select(.var | contains(\"foo\")))' input.json",
      "If you're unable to update to `jq` 1.6 you should be able to use the following command instead, which I've successfully tested on `jq` 1.5 :",
      "jq '.entries |= map(select(.var | contains(\"foo\") | not))' file.json"
    ],
    "utterance": "Remove all entries where the 'var' field contains 'foo'.",
    "expressions": [
      ".entries |= map(select(.var | contains(\"foo\") | not))"
    ],
    "data": [
      {
        "input": {
          "entries": [
            {
              "name": "test1",
              "var": "foo"
            },
            {
              "name": "test2",
              "var": "bar"
            }
          ]
        },
        "output": {
          "entries": [
            {
              "name": "test2",
              "var": "bar"
            }
          ]
        }
      }
    ],
    "identifier": 60170239
  },
  {
    "context": [
      "`jq '.files[] | select(.uri | contains(\"RELEASE\") and contains(\".jar\"))'`",
      "This gives me a bunch of results that looks like multiple blocks of this:",
      "`jq '.files[] | select(.uri | contains(\"RELEASE\") and contains(\".jar\")) | max_by(.lastModified)'`",
      "But it returns error",
      "`max_by` requires an array as input, so in the spirit of your attempt, you might wish to consider:",
      ".files | map( select(.uri | contains(\"RELEASE\") and contains(\".jar\"))) | max_by(.lastModified)"
    ],
    "utterance": "Return the file with the most recent lastModified value where uri contains both \"RELEASE\" and \".jar\".",
    "expressions": [
      ".files | map(select(.uri | contains(\"RELEASE\") and contains(\".jar\"))) | max_by(.lastModified)"
    ],
    "identifier": 60180892
  },
  {
    "context": [
      "1. remove all elements with key X if we also have key X-release;",
      "2. rename elements with key X-release as X;",
      "I have json file like this one:",
      "{\n    \"abc\": \"A\",\n    \"abc-release\": \"B\",\n    \"bcd\":\"C\",\n    \"cde-release\":\"D\",\n    \"cde\":\"E\"\n}",
      "and would like to get resulting file like this:",
      "{\n    \"abc\": \"B\",\n    \"bcd\":\"C\",\n    \"cde\":\"D\"\n}",
      "The following constructive solution using jq has the advantage of being simple and efficient:",
      ". as $in\n| reduce (keys_unsorted[] | select(endswith(\"-release\")|not)) as $k ({};\n    . + {($k) : (($k + \"-release\") as $kr\n                 | $in\n                 | if has($kr) then .[$kr] else .[$k] end) } )"
    ],
    "utterance": "Replace values for each key by the value of the corresponding '-release' key if it exists, remove '-release' keys, and keep only the base keys.",
    "expressions": [
      ". as $in | reduce (keys_unsorted[] | select(endswith(\"-release\")|not)) as $k ({}; . + {($k) : (($k + \"-release\") as $kr | $in | if has($kr) then .[$kr] else .[$k] end) })"
    ],
    "data": [
      {
        "input": {
          "abc": "A",
          "abc-release": "B",
          "bcd": "C",
          "cde-release": "D",
          "cde": "E"
        },
        "output": {
          "abc": "B",
          "bcd": "C",
          "cde": "D"
        }
      }
    ],
    "identifier": 60158308
  },
  {
    "context": [
      "However, if I just try to extract the first 250 characters of the \"short_description\" column i get the following error:",
      "cat test.json|jq -r '.result[0:249].short_description'",
      "Apply the substring filter on the \"short_description\" string:",
      "jq -r '.result[].short_description[:250]' test.json"
    ],
    "utterance": "Extract the first 250 characters from each short_description field in all objects in the result array.",
    "expressions": [
      ".result[].short_description[:250]"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "short_description": "The Net Energy Metering (NEM) Customer Application Database is used to track Customer Applications for a Net Energy Metering Interconnection Application. In almost all cases, the driver of these applications is prompted by the customer installing solar panels on the roof or his or her residence. There are numerous steps required in order to process the NEM applications. The Net Energy Metering Database facilitates this process and allows ACME to keep track of the current status of each customer application.",
              "managed_by": "Bill Anderson",
              "u_storm_impact_flag": "",
              "business_criticality": "Medium",
              "u_compliance_flag": "",
              "active": "true",
              "emergency_tier": "Tier 3"
            }
          ]
        },
        "output": "The Net Energy Metering (NEM) Customer Application Database is used to track Customer Applications for a Net Energy Metering Interconnection Application. In almost all cases, the driver of these applications is prompted by the customer installing solar "
      }
    ],
    "identifier": 60174153
  },
  {
    "context": [
      "Given `{\"a\": 1234567890}`, I want `1,234,567,890` in the result, how this can be done with jq",
      "echo '{\"a\": 1234567890}' | jq -r 'def h: [while(length>0; .[:-3]) | .[-3:]] | reverse | join(\",\"); .a | tostring | h'",
      "Here's an idiomatic one-liner definition:",
      "def h: tostring | [while(length>0; .[:-3]) | .[-3:]] | reverse | join(\",\");",
      "echo '{\"a\": 12345}' | jq '.a' | xargs printf \"%' .f\\n\"",
      "Building on @peak's excellent answer from Feb 2020, I offer this version which also correctly handles negative numbers and numbers with digits after the decimal point (which are not supposed to have separators).",
      "def commas:\n\tif type == \"number\" then\n        (. < 0) as $neg |\n        abs |\n        tostring |\n        split(\".\") |\n        .[0] |= ([while (length > 0; .[:-3]) | .[-3:]] | reverse | join(\",\")) |\n        join(\".\") |\n        if $neg then \"-\" + . end\n\tend\n;"
    ],
    "utterance": "Format the value of key 'a' as a number with commas as thousands separators.",
    "expressions": [
      ".a | tostring | [while(length>0; .[:-3]) | .[-3:]] | reverse | join(\",\")",
      "def h: tostring | [while(length>0; .[:-3]) | .[-3:]] | reverse | join(\",\"); .a | h",
      "def commas: if type == \"number\" then (. < 0) as $neg | abs | tostring | split(\".\") | .[0] |= ([while (length > 0; .[:-3]) | .[-3:]] | reverse | join(\",\")) | join(\".\") | if $neg then \"-\" + . end end; .a | commas"
    ],
    "data": [
      {
        "input": {
          "a": 1234567890
        },
        "output": "1,234,567,890"
      }
    ],
    "identifier": 60148441
  },
  {
    "context": [
      "I just want to pass ORG_NAME from my environment, append \"MSP\" to the end of \"ORG_NAME\" and then pass that to my jq command.",
      "jq -s --arg ORG \"${ORG_NAME}MSP\"  '[0] * {\"channel_group\":{\"groups\":{\"Application\":{\"groups\": {\"$ORG\":[1]}}}}}' config.json ./channel-artifacts/${ORG_NAME}.json > modified_config.json"
    ],
    "utterance": "Insert the contents of the second file at the path channel_group.groups.Application.groups.{ORG_NAME}MSP, where ORG_NAME is an environment variable.",
    "expressions": [
      "-s --arg ORG \"${ORG_NAME}MSP\" '.\\[0] * {\"channel_group\":{\"groups\":{\"Application\":{\"groups\": {($ORG): .\\[1]}}}}}'"
    ],
    "identifier": 60197036
  },
  {
    "context": [
      "userGivenName=`echo $user | jq '.givenName'`",
      "userSurname=`echo $user | jq '.surname'`",
      "groupsMatch=$(echo $groups | jq -c --arg GivenName \"$userGivenName\" --arg Surname \"$userSurname\" 'map(select((.mail|contains($GivenName)) or (.mail|contains($Surname))))')"
    ],
    "utterance": "Extract the givenName and surname values from each object in the array.",
    "expressions": [
      ".givenName",
      ".surname"
    ],
    "data": [
      {
        "input": {
          "id": "123",
          "givenName": "jose",
          "surname": "sam"
        },
        "output": {
          "givenName": "jose",
          "surname": "sam"
        }
      }
    ],
    "identifier": 60219101
  },
  {
    "context": [
      "Now I want parse and extract keys which have state as \"ACTIVE\" so that my final output looks like below. That output should not include repos with \"READ_ONLY\" state.",
      "You can use the following :",
      "jq --raw-output 'map_values(select(.state == \"ACTIVE\")) | keys[]'"
    ],
    "utterance": "List all keys where the value's state is \"ACTIVE\".",
    "expressions": [
      "map_values(select(.state == \"ACTIVE\")) | keys[]",
      "to_entries | map(select(.value.state == \"ACTIVE\")) | .[].key"
    ],
    "data": [
      {
        "input": {
          "test/repo1": {
            "id": "Repo1",
            "description": "Repo1 Repository",
            "state": "ACTIVE",
            "web_links": [
              {
                "name": "gitweb",
                "url": "/web/repo1/summary"
              },
              {
                "name": "gitiles",
                "url": "/plugins/repo1",
                "target": "_blank"
              }
            ]
          },
          "test/repo2": {
            "id": "Repo1",
            "description": "Repo2 Repository",
            "state": "READ_ONLY",
            "web_links": [
              {
                "name": "gitweb",
                "url": "/web/repo2/summary"
              },
              {
                "name": "gitiles",
                "url": "/plugins/repo2",
                "target": "_blank"
              }
            ]
          },
          "test/repo3": {
            "id": "Repo1",
            "description": "Repo3 Repository",
            "state": "ACTIVE",
            "web_links": [
              {
                "name": "gitweb",
                "url": "/web/repo2/summary"
              },
              {
                "name": "gitiles",
                "url": "/plugins/repo3",
                "target": "_blank"
              }
            ]
          }
        },
        "output": [
          "test/repo1",
          "test/repo3"
        ]
      }
    ],
    "identifier": 60189520
  },
  {
    "context": [
      "i am trying to get the value of: \r\n\r\n> [data][allBlocks][edges][node][date][epoch][lastBlock][id]\r\n\r\nusing jq from the command line.",
      "i can query as far as [edges] but for some reason I cant get the data for [nodes] or anything past that.",
      "`.edges` is an array, so using your approach, you would have to take that into account, e.g. by writing:\r\n\r\n    .data.allBlocks.edges[].node.date.epoch.lastBlock.id",
      "Another of many alternatives you might wish to consider would be to use `..`, e.g.:\r\n\r\n    .. | try (.lastBlock.id) // empty"
    ],
    "utterance": "Extract all lastBlock id values found under data > allBlocks > edges > node > date > epoch > lastBlock > id.",
    "expressions": [
      ".data.allBlocks.edges[].node.date.epoch.lastBlock.id",
      ".. | try (.lastBlock.id) // empty",
      ".. | objects | .lastBlock.id // empty"
    ],
    "data": [
      {
        "input": {
          "data": {
            "allBlocks": {
              "pageInfo": {
                "hasNextPage": false,
                "hasPreviousPage": true,
                "startCursor": "190519",
                "endCursor": "190521"
              },
              "totalCount": "190522",
              "edges": [
                {
                  "node": {
                    "id": "27921be509a1336ceaa164cee00cda91c2719a1c0148239433e233ae1bb09c9b",
                    "date": {
                      "slot": "16338",
                      "epoch": {
                        "id": "60",
                        "firstBlock": {
                          "id": "917927a503ed3d9be307dd18f27680c11cb0c405a834c316e3920c7ed8b4e2e8"
                        },
                        "lastBlock": {
                          "id": "27ee50d49eacef10d9ccbfd3c29d09a1aea8268901776085c835ba34f607185b"
                        },
                        "totalBlocks": "1475"
                      }
                    }
                  }
                }
              ]
            }
          }
        },
        "output": [
          "27ee50d49eacef10d9ccbfd3c29d09a1aea8268901776085c835ba34f607185b"
        ]
      }
    ],
    "identifier": 60181242
  },
  {
    "context": [
      "I want to create a map out of it that will help me lookup the id's from a name and use it in the shell script. So something like map[\"Customs Clearance Requested\"] would give me 100000004 which I can use further.",
      "jq 'map(select(. [\"name\"] == \"Customs Clearance Requested\")[\"id\"])' <<< $data",
      "jq -j '.[] | \"\\(.name)\\u0000\\(.id)\\u0000\"' <<<\"$json\"",
      "jq -c '.[]|.name,.id'"
    ],
    "utterance": "Lookup the id corresponding to the name \"Customs Clearance Requested\" in the array.",
    "expressions": [
      "map(select(.name == \"Customs Clearance Requested\").id)",
      ".[] | select(.name == \"Customs Clearance Requested\") | .id",
      "to_entries | map({(.value.name): .value.id}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "id": 100000004,
            "name": "Customs Clearance Requested"
          },
          {
            "id": 100000005,
            "name": "Customs Cleared"
          },
          {
            "id": 100000006,
            "name": "Cargo Loaded to Vessel"
          }
        ],
        "output": [
          100000004
        ]
      }
    ],
    "identifier": 60213193
  },
  {
    "context": [
      "But we don't want to show user all of this, we just want to show index (id of input), application.process.id, application.name and media.name, in some reasonable format. It would be great to parse it _somehow_ to json, but even if I preprocess it somehow, the `jq` is way beyond my capabilities and quite complex.",
      "If the input is as reasonable as shown in the Q, the following  approach that only uses jq should be possible.",
      "construct(inputs | parse | select(.) | {(.key):.value})\n| map( {pid: .[\"application.process.id\"],\n        index,\n        appname: .[\"application.name\"],\n        medianame: .[\"media.name\"]} )",
      "With the example input, the output would be:\n[\n  {\n    \"pid\": \"1543\",\n    \"index\": 144,\n    \"appname\": \"MPlayer\",\n    \"medianame\": \"UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm\"\n  },\n  {\n    \"pid\": \"2831\",\n    \"index\": 145,\n    \"appname\": \"MPlayer\",\n    \"medianame\": \"Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm\"\n  }\n]"
    ],
    "utterance": "Extract the index, application.process.id, application.name, and media.name fields from the input and group them by each segment.",
    "expressions": [
      "def parse:\n  def interpret:\n    if . == null then .\n    elif startswith(\"\\\"\") and endswith(\"\\\"\")\n    then  .[1:-1]\n    else tonumber? // .\n    end;\n  (capture( \"(?<key>[^\\t:= ]*)(: | = )(?<value>.*)\" ) // null)\n  | if . then .value = (.value | interpret) else . end\n;\n\ndef construct(s): \n  [ foreach (s, 0) as $kv (null;\n      if $kv == 0 or $kv.index\n      then .complete = .accumulator | .accumulator = $kv\n      else .complete = null | .accumulator += $kv\n      end;\n      .complete // empty ) ]\n;\n\nconstruct(inputs | parse | select(.) | {(.key):.value})\n| map( {pid: .[\"application.process.id\"],\n        index,\n        appname: .[\"application.name\"],\n        medianame: .[\"media.name\"]} )"
    ],
    "data": [
      {
        "input": "    index: 144\n\tdriver: <protocol-native.c>\n\tflags: \n\tstate: RUNNING\n\tsink: 4 <alsa_output.pci-0000_05_00.0.analog-stereo>\n\tvolume: front-left: 15728 /  24% / -37.19 dB,   front-right: 15728 /  24% / -37.19 dB\n\t        balance 0.00\n\tmuted: no\n\tcurrent latency: 70.48 ms\n\trequested latency: 210.00 ms\n\tsample spec: float32le 2ch 44100Hz\n\tchannel map: front-left,front-right\n\t             Stereo\n\tresample method: copy\n\tmodule: 13\n\tclient: 245 <MPlayer>\n\tproperties:\n\t\tmedia.name = \"UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm\"\n\t\tapplication.name = \"MPlayer\"\n\t\tnative-protocol.peer = \"UNIX socket client\"\n\t\tnative-protocol.version = \"32\"\n\t\tapplication.process.id = \"1543\"\n\t\tapplication.process.user = \"mmucha\"\n\t\tapplication.process.host = \"vbDesktop\"\n\t\tapplication.process.binary = \"mplayer\"\n\t\tapplication.language = \"C\"\n\t\twindow.x11.display = \":0\"\n\t\tapplication.process.machine_id = \"720184179caa46f0a3ce25156642f7a0\"\n\t\tapplication.process.session_id = \"2\"\n\t\tmodule-stream-restore.id = \"sink-input-by-application-name:MPlayer\"\n    index: 145\n\tdriver: <protocol-native.c>\n\tflags: \n\tstate: RUNNING\n\tsink: 4 <alsa_output.pci-0000_05_00.0.analog-stereo>\n\tvolume: front-left: 24903 /  38% / -25.21 dB,   front-right: 24903 /  38% / -25.21 dB\n\t        balance 0.00\n\tmuted: no\n\tcurrent latency: 70.50 ms\n\trequested latency: 210.00 ms\n\tsample spec: float32le 2ch 48000Hz\n\tchannel map: front-left,front-right\n\t             Stereo\n\tresample method: speex-float-1\n\tmodule: 13\n\tclient: 251 <MPlayer>\n\tproperties:\n\t\tmedia.name = \"Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm\"\n\t\tapplication.name = \"MPlayer\"\n\t\tnative-protocol.peer = \"UNIX socket client\"\n\t\tnative-protocol.version = \"32\"\n\t\tapplication.process.id = \"2831\"\n\t\tapplication.process.user = \"mmucha\"\n\t\tapplication.process.host = \"vbDesktop\"\n\t\tapplication.process.binary = \"mplayer\"\n\t\tapplication.language = \"C\"\n\t\twindow.x11.display = \":0\"\n\t\tapplication.process.machine_id = \"720184179caa46f0a3ce25156642f7a0\"\n\t\tapplication.process.session_id = \"2\"\n\t\tmodule-stream-restore.id = \"sink-input-by-application-name:MPlayer\"\n",
        "output": [
          {
            "pid": "1543",
            "index": 144,
            "appname": "MPlayer",
            "medianame": "UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm"
          },
          {
            "pid": "2831",
            "index": 145,
            "appname": "MPlayer",
            "medianame": "Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm"
          }
        ]
      }
    ],
    "identifier": 59913240
  },
  {
    "context": [
      "So I want the top level keys where any of the `asset_id`s in `to_compute` match my input `asset_id`.",
      "The task can be accomplished without using environment variables, e.g.",
      "to_entries[] | {key, asset_id: .value.to_compute[].asset_id} | select(.asset_id==$ASSET_ID) | .key",
      "or more efficiently, using the filter:",
      "to_entries[] | select( any( .value.to_compute[]; .asset_id==$ASSET_ID) ) | .key"
    ],
    "utterance": "Return the top-level keys where any value in the nested to_compute array has asset_id equal to 12123121.",
    "expressions": [
      "to_entries[] | select(any(.value.to_compute[]; .asset_id == $ASSET_ID)) | .key",
      "to_entries[] | {key, asset_id: .value.to_compute[].asset_id} | select(.asset_id==$ASSET_ID) | .key",
      "to_entries[] | .value.to_compute[] + {job: .key} | select(.asset_id==$ASSET_ID) | .job"
    ],
    "data": [
      {
        "input": {
          "27852380038": {
            "compute_id": 34234234,
            "to_compute": [
              {
                "asset_id": 304221854,
                "new_scheme": "mynewscheme",
                "original_host": "oldscheme1234.location.com"
              },
              {
                "asset_id": 12123121,
                "new_scheme": "myotherscheme",
                "original_host": "olderscheme1234.location.com"
              }
            ]
          },
          "31352333022": {
            "compute_id": 43888877,
            "to_compute": [
              {
                "asset_id": 404221555,
                "new_scheme": "mynewscheme",
                "original_host": "oldscheme1234.location.com"
              },
              {
                "asset_id": 52123444,
                "new_scheme": "myotherscheme",
                "original_host": "olderscheme1234.location.com"
              }
            ]
          }
        },
        "output": "27852380038"
      }
    ],
    "identifier": 60230332
  },
  {
    "context": [
      "I want to update the key \"foo\" in b.json using jq with the matching value from a.json. It should also work with more than one entry in a.json.",
      "Thus the desired output is:\n\n    [\n      {\n        \"id\": 3,\n        \"foo\": \"cannot be replaced, id isn't in a.json, stay untouched\",\n        \"baz\": \"do not touch3\"\n      },\n      {\n        \"id\": 2,\n        \"foo\": \"foo new2\",\n        \"baz\": \"do not touch2\"\n      }\n    ]",
      "jq --argfile a a.json '\n  INDEX($a[]; .id) as $dict\n  | map( (.id|tostring) as $id\n         | if ($dict|has($id)) then .foo = $dict[$id].foo \n           else . end)' b.json"
    ],
    "utterance": "For each object, if its id exists in a second array, set its foo value to the foo value from the object with the same id in that array; otherwise, leave it unchanged.",
    "expressions": [
      "jq --argfile a a.json '\n  INDEX($a[]; .id) as $dict\n  | map( (.id|tostring) as $id\n         | if ($dict|has($id)) then .foo = $dict[$id].foo \n           else . end)' b.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": 3,
            "foo": "cannot be replaced, id isn't in a.json, stay untouched",
            "baz": "do not touch3"
          },
          {
            "id": 2,
            "foo": "should be replaced with 'foo new2'",
            "baz": "do not touch2"
          }
        ],
        "output": [
          {
            "id": 3,
            "foo": "cannot be replaced, id isn't in a.json, stay untouched",
            "baz": "do not touch3"
          },
          {
            "id": 2,
            "foo": "foo new2",
            "baz": "do not touch2"
          }
        ]
      }
    ],
    "identifier": 60228327
  },
  {
    "context": [
      "Is there a way to do the same thing with just `jq`?",
      "find -type f -print0 | ... # Convert the null-terminated lines to JSON strings",
      "Output:",
      "\"./ - \u306f\u3058\u3081\u307e\u3057\u3066 - \"",
      "\"./ GHI\\nJKL \"",
      "\"./ABC\\nDEF\"",
      "The following produces the output you\u2019ve specified:",
      "find . -type f -print0 | jq -Rs 'split(\"\\u0000\")[]'"
    ],
    "utterance": "Output each null-terminated line from the input as a separate JSON string, preserving special characters.",
    "expressions": [
      "jq -Rs 'split(\"\\u0000\")[]'"
    ],
    "data": [
      {
        "input": "./ - \u306f\u3058\u3081\u307e\u3057\u3066 - \u0000./ GHI\nJKL \u0000./ABC\nDEF\u0000",
        "output": [
          "./ - \u306f\u3058\u3081\u307e\u3057\u3066 - ",
          "./ GHI\nJKL ",
          "./ABC\nDEF"
        ]
      }
    ],
    "identifier": 60255414
  },
  {
    "context": [
      "messages=$( jq -rc '[.[].message] | unique | @sh' <<<'${commits}' )",
      "for message in $messages\ndo\n  echo \"message: $message\"\ndone",
      "messages: 'commit message 1' 'commit message 2' 'commit message 3'",
      "message: 'commit\nmessage: message\nmessage: 1'",
      "IFS=$'\\n' messages=( $(jq -rc '.[].message' <<<'${commits}') )",
      "readarray -d '' messages < <(jq -j '.[].message + \"\\u0000\"' <<<'${commits}')"
    ],
    "utterance": "Output all unique commit messages as array entries, preserving spaces, so each message with spaces is a single element.",
    "expressions": [
      "[.[].message] | unique | .[]",
      ".[].message"
    ],
    "data": [
      {
        "input": [
          {
            "author": {
              "email": "email@example.com",
              "name": "Chris",
              "username": "chris"
            },
            "committer": {
              "email": "email@example.com",
              "name": "Chris",
              "username": "chris"
            },
            "message": "commit message 1"
          },
          {
            "author": {
              "email": "email@example.com",
              "name": "John",
              "username": "jdoe"
            },
            "committer": {
              "email": "email@example.com",
              "name": "John",
              "username": "jdoe"
            },
            "message": "commit message 2"
          },
          {
            "author": {
              "email": "email@example.com",
              "name": "John",
              "username": "jdoe"
            },
            "committer": {
              "email": "email@example.com",
              "name": "John",
              "username": "jdoe"
            },
            "message": "commit message 3"
          }
        ],
        "output": [
          "commit message 1",
          "commit message 2",
          "commit message 3"
        ]
      }
    ],
    "identifier": 60226618
  },
  {
    "context": [
      "I want to use jq to help me make a file for every key, with the 3 specific values pertaining to that key, formatted in json.",
      "...will write, to `imageA.json`, the text:",
      "{\u001b\"pgpSignature\":\u001b\"productA-imageA-20190101-sig\",\u001b\"imageManifest\":\u001b\"productA-imageA-20190101-manifest\",\u001b\"image\":\u001b\"productA-imageA-20190101-image\"}"
    ],
    "utterance": "For each key under the images object, create a separate file named after that key, containing the associated pgpSignature, imageManifest, and image values in a structured object.",
    "expressions": [
      ".vendors[] | .products[] | .images | to_entries[] | .key as $key | .value.tags[] | {pgpSignature, imageManifest, image}"
    ],
    "data": [
      {
        "input": {
          "vendors": {
            "vendorA": {
              "products": {
                "productA": {
                  "images": {
                    "imageA": {
                      "tags": {
                        "2019-01-01": {
                          "pgpSignature": "productA-imageA-20190101-sig",
                          "imageManifest": "productA-imageA-20190101-manifest",
                          "image": "productA-imageA-20190101-image"
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": {
          "pgpSignature": "productA-imageA-20190101-sig",
          "imageManifest": "productA-imageA-20190101-manifest",
          "image": "productA-imageA-20190101-image"
        }
      }
    ],
    "identifier": 60269591
  },
  {
    "context": [
      "I want to sort below array based on `groupId` such that keys with smaller `groupId` come first in array.",
      "You can use `sort_by` like following:",
      "jq 'sort_by(.groupId)'"
    ],
    "utterance": "Sort an array so that objects with smaller groupId values come first.",
    "expressions": [
      "sort_by(.groupId)"
    ],
    "data": [
      {
        "input": [
          {
            "groupId": 11,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 22
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          },
          {
            "groupId": 31,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 122
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          },
          {
            "groupId": "0",
            "target": {
              "alarm_id": "69"
            },
            "upperThreshold": "20",
            "lowerThreshold": "10",
            "thresholdPeriod": "5"
          }
        ],
        "output": [
          {
            "groupId": "0",
            "target": {
              "alarm_id": "69"
            },
            "upperThreshold": "20",
            "lowerThreshold": "10",
            "thresholdPeriod": "5"
          },
          {
            "groupId": 11,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 22
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          },
          {
            "groupId": 31,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 122
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          }
        ]
      }
    ],
    "identifier": 60280053
  },
  {
    "context": [
      "I would like to extract the \"tls.handshake.certificate_raw\" values, but without success so far.",
      "The following shows that a simple application of jq to retrieve the named key requires about 26MB RAM.",
      "/usr/bin/time -lp jq '.. | objects | .[\"tls.handshake.certificate_raw\"] // empty'  Tshark.json",
      "jq --stream -c '(.[0]|index(\"tls.handshake.certificate_raw\")) as $ix\n                | select($ix) | .[0] |= .[$ix+1:]' Tshark.json |\n    jq -nc 'fromstream(inputs)'",
      "My final command:\n\n    jq --stream -c '(.[0]|index(\"tls.handshake.certificate_raw\")) as $ix\n                | select($ix) | .[0] |= .[$ix+1:]' Tshark.json |\n    jq -r -nc 'fromstream(inputs)[0]' | sort -u > Certificates.txt"
    ],
    "utterance": "Extract all values with the key tls.handshake.certificate_raw from the file, including when objects have duplicate keys.",
    "expressions": [
      ".. | objects | .[\"tls.handshake.certificate_raw\"] // empty",
      "jq --stream -c '(.[0]|index(\"tls.handshake.certificate_raw\")) as $ix | select($ix) | .[0] |= .[$ix+1:]' Tshark.json | jq -nc 'fromstream(inputs)'"
    ],
    "identifier": 60241245
  },
  {
    "context": [
      "I want to insert another value to the array in ruleGroup.json which has:",
      "{ \"groupId\": \"0\", \"target\": { \"alarm_id\": \"69\" }, \"upperThreshold\": \"20\", \"lowerThreshold\": \"10\", \"thresholdPeriod\": \"5\" }",
      "If the object you want to add is in a file, you should be using `--slurpfile` instead of trying to read it into a shell variable and then pass that to `jq`:",
      "$ jq --slurpfile obj ruleGroup.json '. + $obj' newFile.json"
    ],
    "utterance": "Append the contents of ruleGroup.json as a new element to the array in newFile.json.",
    "expressions": [
      ". + $obj"
    ],
    "data": [
      {
        "input": [
          {
            "groupId": 11,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 22
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          },
          {
            "groupId": 31,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 122
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          }
        ],
        "output": [
          {
            "groupId": 11,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 22
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          },
          {
            "groupId": 31,
            "lowerThreshold": 33,
            "target": {
              "alarm_id": 122
            },
            "thresholdPeriod": 3,
            "upperThreshold": 44
          },
          {
            "groupId": "0",
            "target": {
              "alarm_id": "69"
            },
            "upperThreshold": "20",
            "lowerThreshold": "10",
            "thresholdPeriod": "5"
          }
        ]
      }
    ],
    "identifier": 60273959
  },
  {
    "context": [
      "I have some text.txt file:\r\n\r\n    rabbit1-test1\r\n    rabbit1-test2\r\n    rabbit1-test3",
      "Why don't you use jq's split ?\r\n\r\n    jq -Rs --arg a '/' --arg c 'node1' '[ .[:-1] |\r\n          split(\"\\n\")[] |\r\n          { \"{#VHOSTNAME}\" : $a , \r\n            \"{#QUEUENAME}\": . , \r\n            \"{#NODENAME}\": $c } ] |\r\n           { \"data\" : . }' sample.txt\r\n\r\nOut:\r\n\r\n    {\r\n      \"data\": [\r\n        {\r\n          \"{#VHOSTNAME}\": \"/\",\r\n          \"{#QUEUENAME}\": \"rabbit1-test1\",\r\n          \"{#NODENAME}\": \"node1\"\r\n        },\r\n        {\r\n          \"{#VHOSTNAME}\": \"/\",\r\n          \"{#QUEUENAME}\": \"rabbit1-test2\",\r\n          \"{#NODENAME}\": \"node1\"\r\n        },\r\n        {\r\n          \"{#VHOSTNAME}\": \"/\",\r\n          \"{#QUEUENAME}\": \"rabbit1-test3\",\r\n          \"{#NODENAME}\": \"node1\"\r\n        }\r\n      ]\r\n    }"
    ],
    "utterance": "Convert each line from a text file into an object with keys {#VHOSTNAME}, {#QUEUENAME}, and {#NODENAME}, using '/' and 'node1' for the first and third, and output an object with a data array of those objects",
    "expressions": [
      "jq -Rs --arg a '/' --arg c 'node1' '[ .[:-1] | split(\"\\n\")[] | { \"{#VHOSTNAME}\" : $a , \"{#QUEUENAME}\": . , \"{#NODENAME}\": $c } ] | { \"data\" : . }' sample.txt"
    ],
    "data": [
      {
        "input": "rabbit1-test1\nrabbit1-test2\nrabbit1-test3\n",
        "output": {
          "data": [
            {
              "{#VHOSTNAME}": "/",
              "{#QUEUENAME}": "rabbit1-test1",
              "{#NODENAME}": "node1"
            },
            {
              "{#VHOSTNAME}": "/",
              "{#QUEUENAME}": "rabbit1-test2",
              "{#NODENAME}": "node1"
            },
            {
              "{#VHOSTNAME}": "/",
              "{#QUEUENAME}": "rabbit1-test3",
              "{#NODENAME}": "node1"
            }
          ]
        }
      }
    ],
    "identifier": 60281957
  },
  {
    "context": [
      "I want to match packages name `GeoIP` and print version number.",
      "How can I use `jq` to get this version number for matching package name? looking output like this\n    \"GeoIP\",\"1.5.0\"",
      "$ cat print-version.sh\n#!/bin/sh\ncat output.json | jq \".ansible_facts.packages.$1 | .[].version\"",
      "For example\n$ print-version.sh GeoIP\n\"1.5.0\"",
      "jq -r '[\"GeoIP\",\"1.5.0\"] | @csv'",
      "jq -r '[\"GeoIP\"] + [.[] | .GeoIP[].version] | @csv'",
      "jq -r '[\"GeoIP\"] + map(.GeoIP[].version) | @csv'",
      "jq -r --arg \"package\" \"GeoIP\" '[$package] + map(.[$package][].version) | @csv'",
      "jq -r '[ \"GeoIP\", .[].GeoIP[].version ] | @csv'",
      "jq -r --arg \"package\" \"GeoIP\" '[$package,(.[] | .[$package][].version)]| @csv'"
    ],
    "utterance": "Extract the name and version number for the package GeoIP as a CSV row where the name is 'GeoIP' and the version is '1.5.0'.",
    "expressions": [
      ".ansible_facts.packages.GeoIP[0].version",
      ".ansible_facts.packages[\"GeoIP\"][0].version",
      ".ansible_facts.packages.$1[0].version",
      ".ansible_facts.packages[$1][0].version",
      "[\"GeoIP\", .ansible_facts.packages.GeoIP[0].version] | @csv",
      "[$package, (.ansible_facts.packages[$package][0].version)] | @csv",
      "[\"GeoIP\"] + [.ansible_facts.packages.GeoIP[].version] | @csv",
      "[ \"GeoIP\", .ansible_facts.packages.GeoIP[].version ] | @csv",
      "--arg package GeoIP '[ $package, (.ansible_facts.packages[$package][].version) ] | @csv'"
    ],
    "data": [
      {
        "input": {
          "ansible_facts": {
            "packages": {
              "GConf2": [
                {
                  "arch": "x86_64",
                  "epoch": null,
                  "name": "GConf2",
                  "release": "8.el7",
                  "source": "rpm",
                  "version": "3.2.6"
                }
              ],
              "GeoIP": [
                {
                  "arch": "x86_64",
                  "epoch": null,
                  "name": "GeoIP",
                  "release": "14.el7",
                  "source": "rpm",
                  "version": "1.5.0"
                }
              ],
              "ImageMagick": [
                {
                  "arch": "x86_64",
                  "epoch": null,
                  "name": "ImageMagick",
                  "release": "18.el7",
                  "source": "rpm",
                  "version": "6.7.8.9"
                }
              ]
            }
          }
        },
        "output": "\"GeoIP\",\"1.5.0\""
      }
    ],
    "identifier": 60228560
  },
  {
    "context": [
      "I need to extend an array to create a dummy array with 100 values. And I cant do it. Also, I would like to have a random *age* on the objects.",
      "randoms 100 | jq -n --argfile template <(template) '\n  first($template[] | select(.name | test(\"M.*\"))) as $t\n  | [ $t | .age = inputs]\n'"
    ],
    "utterance": "Create an array with 100 objects matching a template, each with a random age value.",
    "expressions": [
      "randoms 100 | jq -n --argfile template <(template) 'first($template[] | select(.name | test(\"M.*\"))) as $t | [ $t | .age = inputs]'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Matias",
            "age": "33"
          }
        ],
        "output": [
          {
            "name": "Matias",
            "age": 57
          },
          {
            "name": "Matias",
            "age": 23
          }
        ]
      }
    ],
    "identifier": 60288601
  },
  {
    "context": [
      "now I want to combine the records which are having the name with 'bindu' and 'bindu s.",
      "I want the output like\n```\n[{\n    \"name\": \"bindu\",\n    \"age\": \"24\",\n    \"qualification\": \"b.tech\",\n    \"status\": \"married\"\n},\n{\n    \"name\": \"naveen\",\n    \"age\": \"23\",\n    \"qualification\": \"b.tech\",\n    \"status\": \"unmarried\"\n\n},\n{\n    \"name\": \"parvathi\",\n    \"age\": \"23\",\n    \"qualification\": \"m.tech\"\n    \"status\": \"\"\n},\n```",
      "This will rename and merge your objects by first name.",
      "jq 'map(.name |= split(\" \")[0]) | group_by(.name) | map(add)'"
    ],
    "utterance": "Merge records that share the same first name, combining their fields into a single object for each unique first name.",
    "expressions": [
      "map(.name |= split(\" \")[0]) | group_by(.name) | map(add)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "bindu",
            "age": "24",
            "qualification": "b.tech"
          },
          {
            "name": "naveen",
            "age": "23",
            "qualification": "b.tech"
          },
          {
            "name": "parvathi",
            "age": "23",
            "qualification": "m.tech"
          },
          {
            "name": "bindu s",
            "status": "married"
          },
          {
            "name": "naveen k",
            "status": "unmarried"
          }
        ],
        "output": [
          {
            "name": "bindu",
            "age": "24",
            "qualification": "b.tech",
            "status": "married"
          },
          {
            "name": "naveen",
            "age": "23",
            "qualification": "b.tech",
            "status": "unmarried"
          },
          {
            "name": "parvathi",
            "age": "23",
            "qualification": "m.tech"
          }
        ]
      }
    ],
    "identifier": 60286122
  },
  {
    "context": [
      "How to add to any leaf key:value with name of parent array and remove such dividing into arrays at all?",
      "[ to_entries[] | {pair: .key} + .value[] ]",
      "If you want to retain an entry corresponding to `{ \"binance_ZENBTC\": []}`, then the following filter would be appropriate:\n\n[to_entries[] | {pair: .key} + (.value[] // {}) ]"
    ],
    "utterance": "Flatten the object so that each element from all arrays becomes a single object with a new key 'pair' holding its original parent key.",
    "expressions": [
      "[ to_entries[] | {pair: .key} + .value[] ]",
      "[to_entries[] | {pair: .key} + (.value[] // {}) ]"
    ],
    "data": [
      {
        "input": {
          "binance_BTCUSDT": [
            {
              "price": "12/02 00:00",
              "time": "10232.79",
              "achg": -0.006151
            },
            {
              "time": "12/02 17:01",
              "price": "10342.92",
              "achg": -0.007977
            }
          ],
          "binance_ZECBNB": [
            {
              "time": "09/02 03:53",
              "price": "3.052",
              "achg": 0.1
            }
          ],
          "binance_ZENBTC": []
        },
        "output": [
          {
            "pair": "binance_BTCUSDT",
            "price": "12/02 00:00",
            "time": "10232.79",
            "achg": -0.006151
          },
          {
            "pair": "binance_BTCUSDT",
            "time": "12/02 17:01",
            "price": "10342.92",
            "achg": -0.007977
          },
          {
            "pair": "binance_ZECBNB",
            "time": "09/02 03:53",
            "price": "3.052",
            "achg": 0.1
          }
        ]
      }
    ],
    "identifier": 60290540
  },
  {
    "context": [
      "I want to create a CSV file with the output:",
      "https://www.test.com/products/gift-card,https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792",
      "jq -r '.[] | [.urlString, .imageUrl] | @csv'"
    ],
    "utterance": "Extract each entry's urlString and imageUrl, outputting as CSV rows, without requiring headers.",
    "expressions": [
      ".[] | [.urlString, .imageUrl] | @csv",
      "-r '.[] | [.urlString, .imageUrl] | @csv'"
    ],
    "data": [
      {
        "input": [
          {
            "urlString": "https://www.test.com/products/gift-card",
            "imageUrl": "https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792"
          },
          {
            "urlString": "https://www.test.com/products/gift-card",
            "imageUrl": "https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792"
          }
        ],
        "output": [
          "\"https://www.test.com/products/gift-card\",\"https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792\"",
          "\"https://www.test.com/products/gift-card\",\"https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792\""
        ]
      }
    ],
    "identifier": 60311790
  },
  {
    "context": [
      "I have a complex JSON file and I am trying to get the below result using JQ.",
      "Expected Result:",
      "{",
      "  \"Host\": \"Test.example.com\",",
      "  \"Title\": \"Ensure message of the day is configured properly\",",
      "  \"Status\": \"passed\"",
      "}",
      "{",
      "  \"Host\": \"Test.example.com\",",
      "  \"Title\": \"Ensure bond0 is present\",",
      "  \"Status\": \"passed\"",
      "}",
      "{",
      "  \"Host\": \"Test.example.com\",",
      "  \"Title\": \"Ensure the SELinux state is disabled\",",
      "  \"Status\": \"passed\"",
      "}",
      "I used the following JQ code to extract the fields , but the extracted values are repeating.",
      "**JQ Code:**",
      "jq  '{Host: .platform.target_id,Title: .profiles[].controls[].title,Status: .profiles[].controls[].results[].status}'",
      "Because you're iterating over `profiles[]` more than once, you're combining the results of one such iteration with the results of another. To avoid that, iterate only once, and get both `title` and `results` from the same `controls` list entry.",
      "jq  '\n.platform.target_id as $target |\n.profiles[].controls[] |\n{ Host: $target,\n  Title: .title,\n  Status: .results[].status }\n'"
    ],
    "utterance": "Extract the host, control title, and status from each control result, with each output object containing exactly one title and one status.",
    "expressions": [
      ".platform.target_id as $target | .profiles[].controls[] | { Host: $target, Title: .title, Status: .results[].status }"
    ],
    "data": [
      {
        "input": {
          "platform": {
            "name": "redhat",
            "release": "7.7",
            "target_id": "Test.example.com"
          },
          "profiles": [
            {
              "name": "my-test",
              "version": "0.1.0",
              "sha256": "6fea36d6c12b21cd51274774edb4200d983db45c4cfa8172eebb897b6f3db8fe",
              "title": "InSpec Profile",
              "maintainer": "The Authors",
              "summary": "An InSpec Compliance Profile",
              "license": "Apache-2.0",
              "copyright": "The Authors",
              "copyright_email": "you@example.com",
              "supports": [
                {
                  "platform": "os"
                }
              ],
              "attributes": [],
              "groups": [
                {
                  "id": "controls/1_motd.rb",
                  "controls": [
                    "1.1 motd check"
                  ],
                  "title": "Warning Banners"
                },
                {
                  "id": "controls/6_network.rb",
                  "controls": [
                    "6.1 Bonding"
                  ]
                },
                {
                  "id": "controls/12_selinux.rb",
                  "controls": [
                    "Selinux Config"
                  ]
                }
              ],
              "controls": [
                {
                  "id": "1.1 motd check",
                  "title": "Ensure message of the day is configured properly",
                  "desc": "Ensure message of the day is configured properly",
                  "descriptions": [
                    {
                      "label": "default",
                      "data": "Ensure message of the day is configured properly"
                    }
                  ],
                  "impact": 1,
                  "refs": [],
                  "tags": {},
                  "code": "control '1.1 motd check' do\n  title 'Ensure message of the day is configured properly'\n  desc  \"The contents of the /etc/motd file are displayed to users after login and function as a message of the day for authenticated users.\"\n  desc \"Ensure message of the day is configured properly\"\n  impact 1.0\n  \n  describe file('/etc/motd') do\n    its('content') { should_not be_empty }\n  end\nend\n",
                  "source_location": {
                    "line": 3,
                    "ref": "my-test/controls/1_motd.rb"
                  },
                  "waiver_data": {},
                  "results": [
                    {
                      "status": "passed",
                      "code_desc": "File /etc/motd content should not be empty",
                      "run_time": 0.099938054,
                      "start_time": "2020-02-07T11:31:47+11:00"
                    }
                  ]
                },
                {
                  "id": "6.1 Bonding",
                  "title": "Ensure bond0 is present",
                  "desc": "Check bonding is present",
                  "descriptions": [
                    {
                      "label": "default",
                      "data": "Check bonding is present"
                    }
                  ],
                  "impact": 1,
                  "refs": [],
                  "tags": {},
                  "code": "control '6.1 Bonding' do\n  title 'Ensure bond0 is present'\n  desc  \"Check bonding is present\"\n  impact 1.0\n  \n  only_if { sys_info.manufacturer != \"VMware, Inc.\" } \n\n  describe bond('bond0') do\n    it { should exist }\n    its('mode') { should eq 'IEEE 802.3ad Dynamic link aggregation' }\n  end\nend\n",
                  "source_location": {
                    "line": 1,
                    "ref": "my-test/controls/6_network.rb"
                  },
                  "waiver_data": {},
                  "results": [
                    {
                      "status": "skipped",
                      "code_desc": "No-op",
                      "run_time": 9.02e-06,
                      "start_time": "2020-02-07T11:31:47+11:00",
                      "resource": "No-op",
                      "skip_message": "Skipped control due to only_if condition."
                    }
                  ]
                },
                {
                  "id": "Selinux Config",
                  "title": "Ensure the SELinux state is disabled",
                  "desc": "Set SELinux to diabled",
                  "descriptions": [
                    {
                      "label": "default",
                      "data": "Set SELinux to diabled"
                    }
                  ],
                  "impact": 1,
                  "refs": [],
                  "tags": {},
                  "code": "control 'Selinux Config' do\n  title 'Ensure the SELinux state is disabled'\n  desc  \"Set SELinux to diabled\"\n  impact 1.0\n\n    describe file('/etc/selinux/config') do\n    its(:content) { should match(/^SELINUX=disabled\\s*(?:#.*)?$/) }\n  end\nend\n",
                  "source_location": {
                    "line": 1,
                    "ref": "my-test/controls/12_selinux.rb"
                  },
                  "waiver_data": {},
                  "results": [
                    {
                      "status": "passed",
                      "code_desc": "File /etc/selinux/config content should match /^SELINUX=disabled\\s*(?:#.*)?$/",
                      "run_time": 0.120881444,
                      "start_time": "2020-02-07T11:31:47+11:00"
                    }
                  ]
                }
              ],
              "status": "loaded"
            }
          ],
          "statistics": {
            "duration": 0.223533139
          },
          "version": "4.18.24"
        },
        "output": [
          {
            "Host": "Test.example.com",
            "Title": "Ensure message of the day is configured properly",
            "Status": "passed"
          },
          {
            "Host": "Test.example.com",
            "Title": "Ensure bond0 is present",
            "Status": "skipped"
          },
          {
            "Host": "Test.example.com",
            "Title": "Ensure the SELinux state is disabled",
            "Status": "passed"
          }
        ]
      }
    ],
    "identifier": 60105691
  },
  {
    "context": [
      "What I need would be a new \"status\" field in each innermost collection as the sum of the \"healthy\" and \"unhealthy\" states, like this:",
      "Is there a way to iterate in this manner:\n\n`jq '.[].slots[].instances[].services[] += { \"status\": ($iterator.healthy + $iterator.unhealthy) }'`",
      "You're looking for `|=` operator.\n```\n.[].slots[].instances[].services[] |= (.status = .unhealthy + .healthy)\n```"
    ],
    "utterance": "Add a status field to each service object, equal to the sum of its healthy and unhealthy fields.",
    "expressions": [
      ".[].slots[].instances[].services[] |= (.status = .unhealthy + .healthy)"
    ],
    "data": [
      {
        "input": [
          {
            "cluster": "one",
            "slots": [
              {
                "instances": [
                  {
                    "number": 0,
                    "services": [
                      {
                        "name": "A",
                        "unhealthy": 0,
                        "healthy": 4
                      },
                      {
                        "name": "B",
                        "unhealthy": 2,
                        "healthy": 2
                      }
                    ]
                  },
                  {
                    "number": 1,
                    "services": [
                      {
                        "name": "B",
                        "unhealthy": 0,
                        "healthy": 6
                      },
                      {
                        "name": "C",
                        "unhealthy": 0,
                        "healthy": 2
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "cluster": "two",
            "slots": [
              {
                "instances": [
                  {
                    "number": 1,
                    "services": [
                      {
                        "name": "A",
                        "unhealthy": 1,
                        "healthy": 9
                      },
                      {
                        "name": "C",
                        "unhealthy": 0,
                        "healthy": 10
                      }
                    ]
                  },
                  {
                    "number": 0,
                    "services": [
                      {
                        "name": "B",
                        "unhealthy": 0,
                        "healthy": 9
                      },
                      {
                        "name": "D",
                        "unhealthy": 0,
                        "healthy": 14
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "cluster": "one",
            "slots": [
              {
                "instances": [
                  {
                    "number": 0,
                    "services": [
                      {
                        "name": "A",
                        "unhealthy": 0,
                        "healthy": 4,
                        "status": 4
                      },
                      {
                        "name": "B",
                        "unhealthy": 2,
                        "healthy": 2,
                        "status": 4
                      }
                    ]
                  },
                  {
                    "number": 1,
                    "services": [
                      {
                        "name": "B",
                        "unhealthy": 0,
                        "healthy": 6,
                        "status": 6
                      },
                      {
                        "name": "C",
                        "unhealthy": 0,
                        "healthy": 2,
                        "status": 2
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "cluster": "two",
            "slots": [
              {
                "instances": [
                  {
                    "number": 1,
                    "services": [
                      {
                        "name": "A",
                        "unhealthy": 1,
                        "healthy": 9,
                        "status": 10
                      },
                      {
                        "name": "C",
                        "unhealthy": 0,
                        "healthy": 10,
                        "status": 10
                      }
                    ]
                  },
                  {
                    "number": 0,
                    "services": [
                      {
                        "name": "B",
                        "unhealthy": 0,
                        "healthy": 9,
                        "status": 9
                      },
                      {
                        "name": "D",
                        "unhealthy": 0,
                        "healthy": 14,
                        "status": 14
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60237816
  },
  {
    "context": [
      "I want to use jq to select, group_by (key1), and sort_by (key1) the file.",
      "I don't want to rely on Unix sort and I'm looking for a way to use jq's sort_by().",
      "I figured out that this can be challenging because from what I understand, sort_by() requires an array as input, which implies that the array is loaded in memory. Since the file may not fit in memory, I'm looking for a way using jq's sort_by() without reading the entire file in memory.",
      "Obviously it would be great is sort_by worked like Unix sort but I don't have the means to find out.",
      "[The following was written before the question was updated to explain that the input consists of multiple JSON entities.]",
      "To simplify things a bit, the following assumes that you have a huge file consisting of a single JSON array.  Since, by assumption, this file is too big to read into memory, the first step will be to get each of the top-level array elements on a line by itself.  That can be done using jq's --stream command-line option, as described in the [jq FAQ][1], e.g. perhaps along the lines of:",
      "    jq -cn --stream 'fromstream( inputs|(.[0] |= .[1:]) | select(. != [[]]) )'",
      "The next step is to prefix each of these lines with the \"sort by\" value, as described in the link included in the Q.  (That is, jq can easily be used.)",
      "Next, run the operating system sort."
    ],
    "utterance": "Sort a data set by the value of key1 without loading the entire data into memory.",
    "expressions": [],
    "data": [
      {
        "input": [
          {
            "key1": "value11",
            "key2": "value21",
            "key3": "value31"
          },
          {
            "key1": "value11",
            "key2": "value22",
            "key3": "value32"
          },
          {
            "key1": "value11",
            "key2": "value22",
            "key3": "value32"
          },
          {
            "key1": "value13",
            "key2": "value23",
            "key3": "value33"
          },
          {
            "key1": "value13",
            "key2": "value24",
            "key3": "value34"
          },
          {
            "key1": "value16",
            "key2": "value26",
            "key3": "value36"
          },
          {
            "key1": "value17",
            "key2": "value27",
            "key3": "value37"
          }
        ]
      }
    ],
    "identifier": 60292458
  },
  {
    "context": [
      "I get this:\r\n```\r\n{\r\n  \"types\": [\r\n    \"Microsoft.ApiManagement/service/apis\"\r\n  ],\r\n  \"apis\": {\r\n    \"type\": \"Microsoft.ApiManagement/service/apis\"\r\n  }\r\n}\r\n```",
      "When I expected this:\r\n```\r\n{\r\n  \"types\": [\r\n    \"Microsoft.ApiManagement/service/apis\",\r\n    \"Microsoft.ApiManagement/service/apis/schemas\"\r\n  ],\r\n  \"apis\": {\r\n    \"type\": \"Microsoft.ApiManagement/service/apis\"\r\n  }\r\n}\r\n```",
      "To produce the output you expect, the simplest is not to use variables at all.  You could, for example, simply write:\r\n\r\n    .resources[].type\r\n"
    ],
    "utterance": "Produce an object with a 'types' array containing the 'type' values from all elements, and an 'apis' key with the element where 'type' is equal to 'Microsoft.ApiManagement/service/apis'.",
    "expressions": [
      "{ types: [.resources[].type], apis: (.resources[] | select(.type == \"Microsoft.ApiManagement/service/apis\")) }"
    ],
    "data": [
      {
        "input": {
          "resources": [
            {
              "type": "Microsoft.ApiManagement/service/apis"
            },
            {
              "type": "Microsoft.ApiManagement/service/apis/schemas"
            }
          ]
        },
        "output": {
          "types": [
            "Microsoft.ApiManagement/service/apis",
            "Microsoft.ApiManagement/service/apis/schemas"
          ],
          "apis": {
            "type": "Microsoft.ApiManagement/service/apis"
          }
        }
      }
    ],
    "identifier": 60327817
  },
  {
    "context": [
      "i want the output to be if \"status\": 301 then display \"url:\"",
      "jq '.results[] | select(.status==301) | .url' /tmp/json"
    ],
    "utterance": "Return all url fields from entries where status equals 301.",
    "expressions": [
      ".results[] | select(.status==301) | .url"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "input": {
                "FUZZ": "actuator",
                "HOST": "https://zzlckzc4kz-3.algolia.net"
              },
              "position": 13,
              "status": 301,
              "length": 162,
              "words": 5,
              "lines": 8,
              "redirectlocation": "https://algolia.net/1/404",
              "resultfile": "",
              "url": "https://zzlckzc4kz-3.algolia.net/actuator"
            },
            {
              "input": {
                "FUZZ": "actuator/heapdump",
                "HOST": "https://zzlckzc4kz-3.algolia.net"
              },
              "position": 24,
              "status": 301,
              "length": 162,
              "words": 5,
              "lines": 8,
              "redirectlocation": "https://algolia.net/1/404",
              "resultfile": "",
              "url": "https://zzlckzc4kz-3.algolia.net/actuator/heapdump"
            }
          ]
        },
        "output": [
          "https://zzlckzc4kz-3.algolia.net/actuator",
          "https://zzlckzc4kz-3.algolia.net/actuator/heapdump"
        ]
      }
    ],
    "identifier": 60331877
  },
  {
    "context": [
      "I want the value of \"id\" (c490ffaf-92ea-4a29-9614-ab36a088f366 in this example) from the block where the value from \"clientId\" is \"account\"",
      ".[]\n| select(.clientId == \"account\")\n| .id"
    ],
    "utterance": "Extract the value of the id field where clientId equals 'account'.",
    "expressions": [
      ".[] | select(.clientId == \"account\") | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "c490ffaf-92ea-4a29-9614-ab36a088f366",
            "clientId": "account",
            "name": "${client_account}",
            "rootUrl": "${authBaseUrl}",
            "baseUrl": "/realms/test1/account/",
            "surrogateAuthRequired": false,
            "enabled": true,
            "clientAuthenticatorType": "client-secret"
          },
          {
            "id": "2daa32334-24322-4a29-43242-423223",
            "clientId": "swap",
            "name": "${client_swap}",
            "rootUrl": "${authBaseUrl}",
            "baseUrl": "/realms/test/swap/",
            "surrogateAuthRequired": false,
            "enabled": true,
            "clientAuthenticatorType": "client-secret"
          },
          {
            "id": "e22112-11111-4a329-22211-333312",
            "clientId": "broker",
            "name": "${client_broker}",
            "rootUrl": "${authBaseUrl}",
            "baseUrl": "/realms/test/broker/",
            "surrogateAuthRequired": false,
            "enabled": true,
            "clientAuthenticatorType": "client-secret"
          }
        ],
        "output": "c490ffaf-92ea-4a29-9614-ab36a088f366"
      }
    ],
    "identifier": 60335775
  },
  {
    "context": [
      "I&#39;d like to retrieve that (or one) dict out of the array with the most northern position (i. e. where `lat` has a maximum) using ```jq```.",
      "So `jq &#39;max_by(.lat)&#39; input.json `",
      "`max_by` is a function that  will scan a array and return the element that is the greater ."
    ],
    "utterance": "Select the object in an array where lat is maximal.",
    "expressions": [
      "max_by(.lat)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Rangsdorf, Bahnhof",
            "lat": 52.294125,
            "lon": 13.431112
          },
          {
            "name": "Leipzig, Hauptbahnhof",
            "lat": 51.344817,
            "lon": 12.381321
          },
          {
            "name": "Senftenberg, Bahnhof",
            "lat": 51.52679,
            "lon": 14.003977
          }
        ],
        "output": {
          "name": "Rangsdorf, Bahnhof",
          "lat": 52.294125,
          "lon": 13.431112
        }
      }
    ],
    "identifier": 60361634
  },
  {
    "context": [
      "I try get the first number:\r\n\r\n    jq .number test.txt\r\n\r\nBut it get all number.",
      "As you see, by default, jq reads the entire input stream.  The -n command-line option turns this behavior off, so one (efficient) solution would be:\r\n\r\n    jq -n 'input.number' test.txt",
      "If your jq does not have `input`, then now would be an excellent time to upgrade; if that is not possible:\r\n\r\n    jq -s '.[0].number' test.txt"
    ],
    "utterance": "Select the value of the number field from the first object in a newline-delimited input.",
    "expressions": [
      "jq -n 'input.number' test.txt",
      "jq -s '.[0].number' test.txt"
    ],
    "data": [
      {
        "input": [
          {
            "type": "home",
            "number": "212 555-1234"
          },
          {
            "type": "fax",
            "number": "646 555-4567"
          }
        ],
        "output": "212 555-1234"
      }
    ],
    "identifier": 60369670
  },
  {
    "context": [
      "I need values *without* the surrounding quotes \"\".",
      "If you want unquoted strings in CSV, you can use `join(\",\")` in place of `@csv`, but it will not work well when some string itself has comma in it.",
      "one of the simplest being `@tsv | gsub(\"\\\\t\";\",\")`, but you then run the risk of producing invalid CSV."
    ],
    "utterance": "Output the fields .format.filename, .format.format_name, and .format.tags.album_artist separated by commas without any surrounding quotes.",
    "expressions": [
      "[.format.filename, .format.format_name, .format.tags.album_artist] | join(\",\")",
      "[.format.filename, .format.format_name, .format.tags.album_artist] | @tsv | gsub(\"\\t\";\",\")"
    ],
    "data": [
      {
        "input": {
          "format": {
            "filename": "01 Jubilee.flac",
            "format_name": "flac",
            "tags": {
              "album_artist": "Bill Charlap Trio"
            }
          }
        },
        "output": "01 Jubilee.flac,flac,Bill Charlap Trio"
      }
    ],
    "identifier": 60350315
  },
  {
    "context": [
      "how do I make it ```96,28,35,80```?",
      "A small tweak of your jq filter would do the trick:\r\n\r\n    .movie_results[] | [.id, .genre_ids[]] | join(&quot;,&quot;)",
      "Here&#39;s an alternative that avoids using double quotes (`&quot;`) in the filter:\r\n\r\n    .movie_results[] | [.id] + .genre_ids | @csv"
    ],
    "utterance": "Output the id followed by all genre_ids as a single comma-separated string for each movie result.",
    "expressions": [
      ".movie_results[] | [.id, .genre_ids[]] | join(\",\")",
      ".movie_results[] | [.id] + .genre_ids | @csv"
    ],
    "data": [
      {
        "input": {
          "movie_results": [
            {
              "genre_ids": [
                28,
                35,
                80
              ],
              "id": 96
            }
          ]
        },
        "output": "96,28,35,80"
      }
    ],
    "identifier": 60368686
  },
  {
    "context": [
      "How do i get the output in the below format's (2 Columns)\n\n    19.514049550078127\t2020-02-13T20:15:00Z\n    12.721997782508938\t2020-02-13T19:15:00Z\n    13.318820949213313\t2020-02-13T18:15:00Z\n    15.994192991030545\t2020-02-13T17:15:00Z\n    18.13096421299414\t2020-02-13T16:15:00Z\n\nwith Heading as CPUUtilization (2 columns)\n\n    CPUUtilization\n    19.514049550078127\t2020-02-13T20:15:00Z\n    12.721997782508938\t2020-02-13T19:15:00Z\n    13.318820949213313\t2020-02-13T18:15:00Z\n    15.994192991030545\t2020-02-13T17:15:00Z\n    18.13096421299414\t2020-02-13T16:15:00Z\n\nAnd in single column\n    \n    19.514049550078127\t\n    12.721997782508938\t\n    13.318820949213313\t\n    15.994192991030545\t\n    18.13096421299414\t\n    \nHow can achieve this ?",
      "To output in the 2 columns format:\n```\njq -r  '.Datapoints[] | [.ExtendedStatistics.p80, .Timestamp] | @tsv' input.json | sort -nr\n```",
      "With Heading as CPUUtilization (2 columns):\n```\necho CPUUtilization; jq -r  '.Datapoints[] | [.ExtendedStatistics.p80, .Timestamp] | @tsv' input.json | sort -nr \n```",
      "And in single column:\n```\njq -r  '.Datapoints[] | [.ExtendedStatistics.p80] | @tsv' input.json | sort -nr\n```"
    ],
    "utterance": "Output the p80 extended statistic and the timestamp from each data point as tab-separated values, sorted numerically in descending order by p80 value, with or without a heading, and as a single-column list of sorted p80 values.",
    "expressions": [
      ".Datapoints[] | [.ExtendedStatistics.p80, .Timestamp] | @tsv",
      ".Datapoints[] | [.ExtendedStatistics.p80] | @tsv"
    ],
    "data": [
      {
        "input": {
          "Label": "CPUUtilization",
          "Datapoints": [
            {
              "Timestamp": "2020-02-13T20:15:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 19.514049550078127
              }
            },
            {
              "Timestamp": "2020-02-13T19:15:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 12.721997782508938
              }
            },
            {
              "Timestamp": "2020-02-13T18:15:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 13.318820949213313
              }
            },
            {
              "Timestamp": "2020-02-13T17:15:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 15.994192991030545
              }
            },
            {
              "Timestamp": "2020-02-13T16:15:00Z",
              "Unit": "Percent",
              "ExtendedStatistics": {
                "p80": 18.13096421299414
              }
            }
          ]
        },
        "output": [
          "19.514049550078127\t2020-02-13T20:15:00Z",
          "18.13096421299414\t2020-02-13T16:15:00Z",
          "15.994192991030545\t2020-02-13T17:15:00Z",
          "13.318820949213313\t2020-02-13T18:15:00Z",
          "12.721997782508938\t2020-02-13T19:15:00Z"
        ]
      }
    ],
    "identifier": 60331676
  },
  {
    "context": [
      "I have multiple JSON files `one.json`, `two.json`, `three.json` with the below format and I want to create a consolidated array from them using `jq`. So, from all the files I want to extract `Name` and `Value` field inside the `Parameters` and use them to create an array where the `id` value will be constructed from the `Name` value and `value` field will be constructed using `Value` field value.",
      "jq -n 'reduce inputs.Parameters[] as $d (.; . + [ { id: $d.Name, value: $d.Value } ])' one.json two.json three.json"
    ],
    "utterance": "Combine multiple files and extract the Name and Value fields under Parameters from each, creating an array of objects with id set to Name and value set to Value.",
    "expressions": [
      "jq -n 'reduce inputs.Parameters[] as $d (.; . + [ { id: $d.Name, value: $d.Value } ])' one.json two.json three.json"
    ],
    "data": [
      {
        "input": [
          {
            "Parameters": [
              {
                "Name": "id1",
                "Value": "one",
                "Version": 2,
                "LastModifiedDate": 1581663187.36
              }
            ]
          },
          {
            "Parameters": [
              {
                "Name": "id2",
                "Value": "xyz",
                "Version": 2,
                "LastModifiedDate": 1581663187.36
              }
            ]
          },
          {
            "Parameters": [
              {
                "Name": "id3",
                "Value": "xyz",
                "Version": 2,
                "LastModifiedDate": 1581663187.36
              }
            ]
          }
        ],
        "output": [
          {
            "id": "id1",
            "value": "one"
          },
          {
            "id": "id2",
            "value": "xyz"
          },
          {
            "id": "id3",
            "value": "xyz"
          }
        ]
      }
    ],
    "identifier": 60371968
  },
  {
    "context": [
      "i want to read all of the tasks and, for each one, output a single line composed of the following fields :\n\ttask[n].inputData.transfers[].target.filename, task[n].outputData.transferLength, task[n].updateDate",
      "the trick was to pipe the `.tasks[]` into an expression where the parens were placed around the field elements as a group, which apparently will apply whatever is inside the parens to each element of the array individually, in sequence. then using @dmitry example as a guide, i also placed the elements inside right and left brackets to recreate array elements that i could then select, which could then be output onto 1 line each with `| @csv`.",
      "so the final chain that worked for me is :\n```\n.task[] | ([.inputData.transfers[].target.filename, .outputData.transferLength, .updateDate]) | [(.[0],.[2],.[3])] | @csv'\n```\n"
    ],
    "utterance": "For each task, output target.filename for each transfer, transferLength, and updateDate together on one line.",
    "expressions": [
      ".tasks[] | ([.inputData.transfers[].target.filename, .outputData.transferLength, .updateDate]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "inputData": {
              "transfers": [
                {
                  "source": {
                    "directory": "/path/to/source",
                    "filename": "somefile.mp3"
                  },
                  "target": {
                    "directory": "/path/to/target",
                    "filename": "somefile.mp3"
                  }
                },
                {
                  "source": {
                    "content": "<?xml version=\\\"1.0\\\" encoding=\\\"UTF-8\\\"?><delivery>content description</delivery>",
                    "encoding": "UTF-8"
                  },
                  "target": {
                    "directory": "/path/to/target",
                    "filename": "somefile.xml"
                  }
                }
              ]
            },
            "outputData": {
              "transferDuration": "00:00:37:10",
              "transferLength": 187813298
            },
            "updateDate": "2020-02-21T14:37:18.329Z",
            "updateUser": "bob"
          }
        ],
        "output": [
          "\"somefile.mp3\",187813298,\"2020-02-21T14:37:18.329Z\"",
          "\"somefile.xml\",187813298,\"2020-02-21T14:37:18.329Z\""
        ]
      }
    ],
    "identifier": 60372707
  },
  {
    "context": [
      "I need to change `helm_chart_version`'s value to - say - `0.1.2`.",
      "jq '(.Item.settings.L[] | select(.M.label.S == \"helm_chart_version\")) |= (.M.value.S = \"0.1.2\")'",
      "walk(if type == \"object\" and .label.S == \"helm_chart_version\"\n         then .value.S = \"0.1.2\" else . end)"
    ],
    "utterance": "Update helm_chart_version's value field to 0.1.2 wherever its label matches.",
    "expressions": [
      "jq '(.Item.settings.L[] | select(.M.label.S == \"helm_chart_version\")) |= (.M.value.S = \"0.1.2\")'",
      "walk(if type == \"object\" and .label.S == \"helm_chart_version\" then .value.S = \"0.1.2\" else . end)",
      ".Item.settings |= walk(if type == \"object\" \n            and has(\"label\")\n            and any(.label[]; . == \"helm_chart_version\")\n            then .value |= map_values(\"0.1.2\")\n            else . \n            end)"
    ],
    "data": [
      {
        "input": {
          "Item": {
            "aws:rep:deleting": {
              "BOOL": false
            },
            "service": {
              "S": "g"
            },
            "settings": {
              "L": [
                {
                  "M": {
                    "fe_enabled": {
                      "BOOL": false
                    },
                    "stack_type": {
                      "S": "all"
                    },
                    "label": {
                      "S": "helm_chart_name"
                    },
                    "value": {
                      "S": "gate"
                    }
                  }
                },
                {
                  "M": {
                    "fe_enabled": {
                      "BOOL": true
                    },
                    "stack_type": {
                      "S": "all"
                    },
                    "label": {
                      "S": "helm_chart_version"
                    },
                    "value": {
                      "S": "0.1.1"
                    }
                  }
                }
              ]
            },
            "label": {
              "S": "gate"
            },
            "service_children": {
              "L": []
            },
            "independent": {
              "BOOL": true
            }
          }
        },
        "output": {
          "Item": {
            "aws:rep:deleting": {
              "BOOL": false
            },
            "service": {
              "S": "g"
            },
            "settings": {
              "L": [
                {
                  "M": {
                    "fe_enabled": {
                      "BOOL": false
                    },
                    "stack_type": {
                      "S": "all"
                    },
                    "label": {
                      "S": "helm_chart_name"
                    },
                    "value": {
                      "S": "gate"
                    }
                  }
                },
                {
                  "M": {
                    "fe_enabled": {
                      "BOOL": true
                    },
                    "stack_type": {
                      "S": "all"
                    },
                    "label": {
                      "S": "helm_chart_version"
                    },
                    "value": {
                      "S": "0.1.2"
                    }
                  }
                }
              ]
            },
            "label": {
              "S": "gate"
            },
            "service_children": {
              "L": []
            },
            "independent": {
              "BOOL": true
            }
          }
        }
      }
    ],
    "identifier": 60382388
  }
]