[
  {
    "context": [
      "How can I use `jq` to convert this to:\r\n\r\n    {\r\n      \"Variables\":\r\n      {\r\n          \"var1\": \"foo\",\r\n          \"var2\": \"bar\",\r\n          ...\r\n      }\r\n    }",
      "you can wrap it inside a new object by putting a `.` in the location where you want your existing content to be:\r\n\r\n```\r\njq '{\"Variables\": .}' <in.json >out.json\r\n```"
    ],
    "utterance": "Wrap all key-value pairs in an object under a single 'Variables' key.",
    "expressions": [
      "{\"Variables\": .}"
    ],
    "data": [
      {
        "input": {
          "var1": "foo",
          "var2": "bar"
        },
        "output": {
          "Variables": {
            "var1": "foo",
            "var2": "bar"
          }
        }
      }
    ],
    "identifier": 57437838
  },
  {
    "context": [
      "I only want to print the entries that are simple types, e.g. not arrays or objects.",
      ".person | with_entries(select(.value | type | . != \"array\" and . != \"object\"))"
    ],
    "utterance": "Display only the immediate key-value pairs within the 'person' object whose values are not arrays or objects.",
    "expressions": [
      ".person | with_entries(select(.value | type | . != \"array\" and . != \"object\"))"
    ],
    "data": [
      {
        "input": {
          "person": {
            "address": {
              "city": "NY",
              "street": "Wall Street"
            },
            "god": true,
            "nicks": [
              "Lar",
              "L",
              "Yo"
            ],
            "name": "Larry",
            "id": 1
          }
        },
        "output": {
          "god": true,
          "name": "Larry",
          "id": 1
        }
      }
    ],
    "identifier": 57400852
  },
  {
    "context": [
      "But when I try to use `test` or `match` with `Age` I get following error,\n\n```\njq -r 'select(.details.Age | match(32))'\njq: error (at <stdin>:6): number not a string or array\n```",
      "Your .Age value is a number, but regexes work on strings, so if you really want to use regexes, you would have to transform the number to a string. This can be done using `tostring`, but please remember that the `tostring` representation of a JSON number might not always be what you think it will be.",
      "p.s. That should be `match(\"\\\\d\")`"
    ],
    "utterance": "Select objects where the Age field matches a digit pattern using a regular expression.",
    "expressions": [
      "select(.details.Age | tostring | match(\"\\\\d\"))"
    ],
    "data": [
      {
        "input": {
          "details": {
            "Age": 32,
            "Name": "reverent"
          }
        },
        "output": {
          "details": {
            "Age": 32,
            "Name": "reverent"
          }
        }
      }
    ],
    "identifier": 57447290
  },
  {
    "context": [
      "I need to add this code:\r\n\r\ndef walk(f):\r\n  . as $in\r\n  | if type == \"object\" then\r\n      reduce keys_unsorted[] as $key\r\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n  elif type == \"array\" then map( walk(f) ) | f\r\n  else f\r\n  end;\r\n\r\nTo my initialization file, but I cannot find it.",
      "if you want to use ~/.jq as a startup file, just create it. You might need to check (or alter) the HOME environment variable.  That is, jq's idea of where to look depends on HOME.",
      "So you may simply want to use the module system, though this has the disadvantage that you'll need to include an `include MODULE;` or `import MODULE as _;` directive in your scripts."
    ],
    "utterance": "Make the walk(f) function accessible for use in jq 1.5 installed via Chocolatey on Windows by placing its definition in the correct startup or module file.",
    "expressions": [
      "def walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys_unsorted[] as $key\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\n  elif type == \"array\" then map( walk(f) ) | f\n  else f\n  end;"
    ],
    "identifier": 57380717
  },
  {
    "context": [
      "I want something like\n\n    jq 'select(.x in [2,4])' <<<'[{\"x\":1}, {\"x\": 2}, {\"x\": 3}, {\"x\": 4}]'\n    [{\"x\": 2}, {\"x\": 4}]\n\nHow do I do this?",
      "Here's an efficient solution that has the advantage of also being simple and concise:\n\n    [2,4] as $list\n    | map(.x as $x | select( any($list[]; . == $x )))\n"
    ],
    "utterance": "Return all objects whose x value is 2 or 4.",
    "expressions": [
      "[2,4] as $list | map(select(.x as $x | any($list[]; . == $x)))"
    ],
    "data": [
      {
        "input": [
          {
            "x": 1
          },
          {
            "x": 2
          },
          {
            "x": 3
          },
          {
            "x": 4
          }
        ],
        "output": [
          {
            "x": 2
          },
          {
            "x": 4
          }
        ]
      }
    ],
    "identifier": 57383515
  },
  {
    "context": [
      "I am trying to extract the name of the parameter object (which cannot be known), but only if it has a \"defaultValue\" key listed.",
      "Desired output:",
      "\"componentName\": {\r\n    \"defaultValue\": \"storage\",\r\n    \"type\": \"string\"\r\n}",
      "Your desired output is not a valid JSON. The closest I know to get (without custom string formatting) is:",
      "jq '.parameters | map_values(select(has(\"defaultValue\")))'"
    ],
    "utterance": "Return all top-level keys from the 'parameters' object whose value contains a 'defaultValue' property, including both the key and value.",
    "expressions": [
      ".parameters | map_values(select(has(\"defaultValue\")))"
    ],
    "data": [
      {
        "input": {
          "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "componentName": {
              "defaultValue": "storage",
              "type": "string"
            },
            "subnetId": {
              "type": "string",
              "metadata": {
                "description": "The subnet to which this storage component belongs."
              }
            }
          },
          "variables": {}
        },
        "output": {
          "componentName": {
            "defaultValue": "storage",
            "type": "string"
          }
        }
      }
    ],
    "identifier": 57404630
  },
  {
    "context": [
      "And using `jq`, I'm trying to return a list of maps which displays the info like so: \n\n> GroupName , GroupId\n\nThis is what I've tried:\n\n    aws ec2 describe-security-groups  | jq -r '.SecurityGroups[] | to_entries[] | [ .GroupName.value , .GroupId.value]'\n\nUsing the above method returns:\n\n    [\n      null,\n      null\n    ]\n    [\n      null,\n      null\n    ]\n\nIn the example, the delimiter is \",\" but I'd like the displayed output to be like so  (example):\n\n    \"default - sg-abd837s\"\n\nHow can it be done by using `jq`?",
      "There should be no need to use `to_entries`:\n\n\n    .SecurityGroups[]\n    | [ .GroupName, .GroupId ]\n    | join(\" - \")\n\nproduces:\n\n\"default - sg-abd837s\"",
      "Using string interpolation:\n```\n.SecurityGroups[] | \"\\(.GroupName) - \\(.GroupId)\"\n```"
    ],
    "utterance": "Display each group's name and ID, formatted as 'GroupName - GroupId', for all security groups.",
    "expressions": [
      ".SecurityGroups[] | [ .GroupName, .GroupId ] | join(\" - \")",
      ".SecurityGroups[] | \"\\(.GroupName) - \\(.GroupId)\""
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "GroupName": "default",
              "GroupId": "sg-abd837s",
              "Description": "default VPC security group",
              "IpPermissions": [],
              "IpPermissionsEgress": [],
              "VpcId": "vpc-b3c29bcb",
              "OwnerId": "506490286752"
            }
          ]
        },
        "output": [
          "default - sg-abd837s"
        ]
      }
    ],
    "identifier": 57375281
  },
  {
    "context": [
      "Is there a way by only using jq that a comma separated list of values could be passed as an argument to the jq script and iterate through the ids and check them against the value of .id in the JSON file with the result being the objects that have that id?",
      "Sure. Though you'll need to parse (split) that list of ids to something that jq can work with, such as an array of ids. Then your problem becomes, given an array of keys, select objects that have any of these ids.",
      "select(.id | IN($ID|split(\",\")[]))",
      "For efficiency, it would be better to split $ID just once.",
      "INDEX($ID | splits(\",\"); .) as $dict\n| .[]\n| select($dict[.id])"
    ],
    "utterance": "Return all objects whose id matches any value in a comma-separated list provided as a single argument.",
    "expressions": [
      "select(.id | IN($ID|split(\",\")[]))",
      "INDEX($ID | splits(\",\"); .) as $dict | .[] | select($dict[.id])"
    ],
    "data": [
      {
        "input": [
          {
            "id": "8df993c1-57d5-46b3-a8a3-d95066934e5b",
            "name": "Alice"
          },
          {
            "id": "1d5441ca-5758-474d-a9fc-40d0f68aa538",
            "name": "Bob"
          },
          {
            "id": "notmatchingid",
            "name": "Charlie"
          }
        ],
        "output": [
          {
            "id": "8df993c1-57d5-46b3-a8a3-d95066934e5b",
            "name": "Alice"
          },
          {
            "id": "1d5441ca-5758-474d-a9fc-40d0f68aa538",
            "name": "Bob"
          }
        ]
      }
    ],
    "identifier": 57410632
  },
  {
    "context": [
      "Once the json file is created with data, then i will need to pull some fields like commit, repo, author, file fields from that json file.",
      "Now i wanted to get below values from each file generated above.",
      "commit=$(jq -r \".[$j]|.commit\" $orgs+$i.json)",
      "author=$(jq -r \".[$j]|.author\" $orgs+$i.json)",
      "file=$(jq -r \".[$j]|.file\" $orgs+$i.json)",
      "repo=$(jq -r \".[$j]|.repo\" $orgs+$i.json)"
    ],
    "utterance": "Extract commit, author, file, and repo fields from each element in an array in a file named $orgs+$i.json.",
    "expressions": [
      ".[] | {repo, file, author, commit}",
      "[.[] | {repo, file, author, commit}]"
    ],
    "identifier": 57464276
  },
  {
    "context": [
      "I want to extract the `name` field value from inside based on the `id` value.\r\nso, if I pass id value as 99900, it should return me DEF. How can I do that using jq.",
      "Use `select`:\r\n```\r\n$ jq -r --arg q 99900 '.[] | select(.id == $q).name' file\r\nDEF\r\n```"
    ],
    "utterance": "Extract the value of the name field where id equals 99900.",
    "expressions": [
      ".[] | select(.id == \"99900\").name",
      ".[] | select(.id == $q).name"
    ],
    "data": [
      {
        "input": {
          "11213-99900": {
            "cid": "11213-99900",
            "name": "DEF",
            "id": "99900"
          },
          "11213-12345": {
            "cid": "11213-12345",
            "name": "ABC",
            "id": "12345"
          },
          "11272-23456": {
            "cid": "11272-23456",
            "name": "YXX",
            "id": "23456"
          }
        },
        "output": "DEF"
      }
    ],
    "identifier": 57459947
  },
  {
    "context": [
      "I have to replace a value in a json file with the value of a bash variable.",
      "foo=/v1/proxytest",
      "cat $NAME | jq --arg foo \"$foo\" '.basePath = $foo' > test.json",
      "I used the below command and was able to replace the value of the basePath"
    ],
    "utterance": "Set the value of basePath to the value of a bash variable foo.",
    "expressions": [
      "jq --arg foo \"$foo\" '.basePath = $foo'"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "info": {
            "title": "DataSyncGtest",
            "version": "2.0",
            "description": "Lorem,ipsum,dorem"
          },
          "host": "stg.api.realogyfg.com",
          "basePath": "/v2/xxx/yyy/Newproxytest"
        },
        "output": {
          "swagger": "2.0",
          "info": {
            "title": "DataSyncGtest",
            "version": "2.0",
            "description": "Lorem,ipsum,dorem"
          },
          "host": "stg.api.realogyfg.com",
          "basePath": "/v1/proxytest"
        }
      }
    ],
    "identifier": 57477317
  },
  {
    "context": [
      "JSONPath has an expression to filter by node at arbitrary place `$..node`, which like `//node` in `xpath`. Is there any way to do that in `jq`?",
      "Here is the data & result for JSONPath `$..commit.committer`:",
      "How to do the same in (/translate to) `jq`?",
      "This should do it:\n```\n[..|objects|.commit.committer//empty]\n```",
      "curl -s 'https://api.github.com/repos/stedolan/jq/commits?per_page=5' \\\n   |jq 'map(..|.commit?.committer//empty)' "
    ],
    "utterance": "Find all committer objects located under any commit key at any depth in the structure.",
    "expressions": [
      "[..|objects|.commit.committer//empty]",
      "map(..|.commit?.committer//empty)"
    ],
    "identifier": 57480055
  },
  {
    "context": [
      "I try to extract the values of the `images` keys into a new key, so that {...input...} becomes something like this: {...output...}",
      "<file jq '.environments |= (.[] |= {images : (.apps|map(.[]))})'>",
      "This replaces the content of the `environments` object with the a new inner `images` object that contains the list images referred by `apps` and `image`.",
      "The array of images is built using the jq builtin `map()` function."
    ],
    "utterance": "For each environment, collect the values of the image keys under apps into an images array as the only property.",
    "expressions": [
      ".environments |= with_entries(.value |= {images: (.apps | map(.[]))})"
    ],
    "data": [
      {
        "input": {
          "environments": {
            "staging": {
              "apps": {
                "web": {
                  "image": "image1"
                }
              }
            },
            "production": {
              "apps": {
                "web": {
                  "image": "image2"
                },
                "admin": {
                  "image": "image3"
                }
              }
            }
          }
        },
        "output": {
          "environments": {
            "staging": {
              "images": [
                "image1"
              ]
            },
            "production": {
              "images": [
                "image2",
                "image3"
              ]
            }
          }
        }
      }
    ],
    "identifier": 57476555
  },
  {
    "context": [
      "I would want to get the last's value where First's value starts with \"J\".",
      "The jq equivalent for achieving the intended result is given below :-\n.people | .[] | select (.First | startswith(\"J\")) | .last",
      "So one of the possible solution for the above ask is \n\npeople.values(@)[?starts_with(First,`J`)].last"
    ],
    "utterance": "Get all 'last' values for objects where 'First' starts with 'J'.",
    "expressions": [
      ".people | .[] | select(.First | startswith(\"J\")) | .last"
    ],
    "data": [
      {
        "input": {
          "people": {
            "a": {
              "First": "James",
              "last": "1"
            },
            "b": {
              "First": "Jacob",
              "last": "2"
            },
            "c": {
              "First": "Jayden",
              "last": "3"
            },
            "d": {
              "First": "different",
              "last": "4"
            }
          }
        },
        "output": [
          "1",
          "2",
          "3"
        ]
      }
    ],
    "identifier": 57481891
  },
  {
    "context": [
      "I would like to delete all of the summary fields using JQ.",
      "If you want to eliminate the \"summary\" field wherever it occurs, no matter how deeply nested, then I'd use walk/1, e.g.",
      "walk(if type == \"object\" then del(.summary) else . end)"
    ],
    "utterance": "Remove all fields named 'summary', regardless of how deeply nested they are.",
    "expressions": [
      "walk(if type == \"object\" then del(.summary) else . end)"
    ],
    "data": [
      {
        "input": {
          "object1": {
            "summary": "Some summary I want removing",
            "keepMe": "please"
          }
        },
        "output": {
          "object1": {
            "keepMe": "please"
          }
        }
      },
      {
        "input": {
          "object2": {
            "summary": "Delete me too!",
            "keepMe": "pretty please"
          }
        },
        "output": {
          "object2": {
            "keepMe": "pretty please"
          }
        }
      }
    ],
    "identifier": 57488844
  },
  {
    "context": [
      "The manual says\n\n```\njq '[2:4]'\n   \"abcdefghi\"\n=> \"cd\"\n```",
      "$ jq '[2:4]' <<< abcdefghi\nparse error: Invalid numeric literal at line 2, column 0",
      "'abcdefghi' is not a valid JSON string, but '\"abcdefghi\"' is:",
      "$ jq '[2:4]' <<< '\"abcdefghi\"'\n\"cd\""
    ],
    "utterance": "Extract the substring from index 2 up to, but not including, index 4 of the string \"abcdefghi\".",
    "expressions": [
      ".[2:4]"
    ],
    "data": [
      {
        "input": "abcdefghi"
      },
      {
        "input": "\"abcdefghi\"",
        "output": "\"cd\""
      }
    ],
    "identifier": 57496298
  },
  {
    "context": [
      "But I want to search either \"a\" and \"b\" and the output that I would like is this.",
      "1",
      "2",
      "You can use alternate operator (`//`):",
      "$ jq '.[] | .a//.b' <<< '[{\"a\": 1},  {\"b\": 2}]'",
      "1",
      "2"
    ],
    "utterance": "Output the value of a if present, otherwise b, from each object in the input array.",
    "expressions": [
      ".[] | .a // .b"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 2
          }
        ],
        "output": [
          1,
          2
        ]
      }
    ],
    "identifier": 57498621
  },
  {
    "context": [
      "I just want to display all the possible fields in a simple table on the command line but I am not able to achieve it.",
      "Expected Output",
      "ID CWE  CVSS  Summary",
      "I figured it out myself",
      "The correct command is",
      "echo $(jq '.data[] | select(.vulnerable_configuration_cpe_2_2 | contains([\"2.4.38\"]))' search1.json) | jq -r '. | \"\\(.summary)\"'"
    ],
    "utterance": "Display selected fields (id, cwe, cvss, summary) for records where vulnerable_configuration_cpe_2_2 contains a string matching '2.4.38'.",
    "expressions": [
      ".data[] | select(.vulnerable_configuration_cpe_2_2[] | contains(\"2.4.38\")) | [.id, .cwe, .cvss, .summary] | @tsv"
    ],
    "identifier": 57475419
  },
  {
    "context": [
      "\"DB_PASSWORD is encrypted with KMS, so i want to use aws cli to decrypt the password in entrypoint.sh file before setting the Environment Variable: HASURA_GRAPHQL_DATABASE_URL\"",
      "\"if [ ${DB_PASSWORD_ENCYPTED} == \\\"true\\\" ]\\nthen\\n    echo \\\"loading KMS credentials\\\"\\n    decrypted_value_base64=$( \\\\n        aws --region ${AWS_REGION} kms decrypt \\\\n          --ciphertext-blob fileb://<(echo \\\"${DB_PASSWORD}\\\" | base64 -d) \\\\n          --query Plaintext \\\\n          --output text\\n    )\\n    decrypted_value=$(echo $decrypted_value_base64 | base64 -d)\\n    export HASURA_GRAPHQL_DATABASE_URL=postgres://${DB_USER}:${decrypted_value}@${DB_HOST}:${DB_PORT}/${DB_NAME}\\nelse\\n    export HASURA_GRAPHQL_DATABASE_URL=postgres://${DB_USER}:${DB_PASSWORD}@${DB_HOST}:${DB_PORT}/${DB_NAME}\\nfi\""
    ],
    "utterance": "Decrypt a base64-encoded KMS-encrypted string using aws cli and extract the plaintext value.",
    "expressions": [
      "aws --region ${AWS_REGION} kms decrypt --ciphertext-blob fileb://<(echo \"${DB_PASSWORD}\" | base64 -d) --query Plaintext --output text",
      "echo $decrypted_value_base64 | base64 -d"
    ],
    "identifier": 57496552
  },
  {
    "context": [
      "I use jq to get the needed data, Now the sh returns the output as String. How do i convert this output to json object ?",
      "here `efs_details` is a `java.lang.String` type.",
      "Q: How do i convert this output to json so that i can use the dot operator. (example `efs_details.name`)",
      "This was solved by writing a helper function that uses the JsonSurplerClassic() to convert the string to json.",
      "def make_json(string_val){\n   def jsonmaker = new JsonSlurperClassic()\n   def jsonval = jsonmaker.parseText(string_val)\n   println jsonval.getClass()\n   return jsonval\n}",
      "efs_details_json = make_json(efs_details)"
    ],
    "utterance": "Convert the string output from a shell command into an object so fields can be accessed using dot notation in a Jenkins pipeline.",
    "expressions": [],
    "data": [
      {
        "input": "{\n \"OwnerId\": \"2142342325\",\n \"name\": \"my_volume\",\n \"encrypted\": true\n}",
        "output": {
          "OwnerId": "2142342325",
          "name": "my_volume",
          "encrypted": true
        }
      }
    ],
    "identifier": 57503166
  },
  {
    "context": [
      "I want to check whether a property exists or not. If it exists I always want to get the first element in the array.",
      "VAR2=$(jq 'if has(\"var2\") then .[\"var2\"][0] else null end')",
      "so since you seem to want VAR2 to be null if the condition is not met, you could write: VAR2=$(jq 'if has(\"var2\") then .[\"var2\"][0] else null end')"
    ],
    "utterance": "Return the first element of 'var2' if it exists; otherwise, output null.",
    "expressions": [
      "if has(\"var2\") then .[\"var2\"][0] else null end"
    ],
    "data": [
      {
        "input": {
          "var1": [
            {
              "foo": "bar"
            }
          ],
          "var2": [
            {
              "fooooo": "baaaaar"
            }
          ]
        },
        "output": {
          "fooooo": "baaaaar"
        }
      },
      {
        "input": {
          "var1": [
            {
              "foo": "bar"
            }
          ]
        },
        "output": null
      }
    ],
    "identifier": 57517345
  },
  {
    "context": [
      "For the above input I try to store comments:login and comments:markdown",
      "Since `comments` is an array, writing `.comments[]` as you have done is a bit risky, as .comments might not have exactly one element.  It would be less risky to write `.comments[0]`, if that is in accordance with your requirements."
    ],
    "utterance": "Extract the login and markdown fields from each comment inside the comments array for each issue.",
    "expressions": [
      ".issues[] | .comments[] | {login, markdown}",
      ".issues[] | {key, comments: [.comments[] | {login, markdown}]}"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "AWtQSFvOvmpNDcmJ7zeY",
              "comments": [
                {
                  "key": "AWxxXwIoRqbStspvKH2w",
                  "login": "lmolenaar",
                  "htmlText": "<a href=\"https://jira.domain.nl/browse/xxx-30093\" target=\"_blank\">https://jira.domain.nl/browse/xxx-30093</a>",
                  "markdown": "https://jira.domain.nl/browse/xxx-30093",
                  "updatable": true,
                  "createdAt": "2019-08-08T15:15:47+0200"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "login": "lmolenaar",
            "markdown": "https://jira.domain.nl/browse/xxx-30093"
          }
        ]
      }
    ],
    "identifier": 57510887
  },
  {
    "context": [
      "I\u2019m trying to use `jq` to parse JSON that looks something like:\n\n{\n\t\"username\": \"billy\",\n\t\"hero\": {\n\t\t\"something\": \"goeshere\"\n\t},\n\t\"bumper\": {\n\t\t\"bumper2\": {\n\t\t\t\"bumper3\": \"splodge\"\n\t\t}\n\t},\n\t\"morgan\": [{\n\t\t\"abc\": 123\n\t}, 2, 4, {\n\t\t\"def\": 567\n\t}],\n\t\"password\": \"issilly\"\n}\n\ninto\n\nrequest.username == 'billy' && request.hero.something == 'goeshere' && request.bumper.bumper2.bumper3 == 'splodge' && request.morgan[0].abc == 123 && request.morgan[1] == 2 && request.morgan[2] == 4 && request.morgan[3].def == 567 && request.password == 'issilly'",
      "jq -r '\n  . as $data |\n  [path(.. | \n    select(type != \"object\" and type != \"array\")\n  )] |\n  map(\n    . as $path |\n    map(\"[\" + (. | tojson) + \"]\") |\n    join(\"\") |\n    \"request\\(.) = \\($data | getpath($path) | tojson)\"\n  ) |\n  join(\" && \")\n' < test.json",
      "Output:\n\nrequest[\"username\"] = \"billy\" &&\nrequest[\"hero\"][\"something\"] = \"goeshere\" &&\nrequest[\"bumper\"][\"bumper2\"][\"bumper3\"] = \"splodge\" &&\nrequest[\"morgan\"][0][\"abc\"] = 123 &&\nrequest[\"morgan\"][1] = 2 &&\nrequest[\"morgan\"][2] = 4 &&\nrequest[\"morgan\"][3][\"def\"] = 567 &&\nrequest[\"password\"] = \"issilly\"",
      "`paths(scalars)` outputs arrays representing paths to strings and numbers in `.`, and using `getpath` you can get values at those paths. So all you need is a function that converts path representations to path expressions, like:\n```\ndef pr2pe:\n  reduce .[] as $n ([];\n    if $n|type == \"string\"\n    then . + [$n]\n    elif $n|type == \"number\" and length\n    then .[-1] += \"[\\($n)]\"\n    else error(\"invalid path representation\")\n    end) | join(\".\");\n[ paths(scalars) as $p\n  | \"\\($p | pr2pe) == \\(getpath($p) | tojson)\" ]\n| join(\" && \")\n```"
    ],
    "utterance": "Produce a single string listing equality expressions for all leaf values in the input, using dot notation or index notation as appropriate, each prefixed by 'request', and joined with ' && ' separators.",
    "expressions": [
      ". as $data |\n  [path(.. | select(type != \"object\" and type != \"array\"))] |\n  map(\n    . as $path |\n    map(\"[\" + (. | tojson) + \"]\") |\n    join(\"\") |\n    \"request\\(.) = \\($data | getpath($path) | tojson)\"\n  ) |\n  join(\" && \")",
      "def pr2pe:\n  reduce .[] as $n ([];\n    if $n|type == \"string\"\n    then . + [$n]\n    elif $n|type == \"number\" and length\n    then .[-1] += \"[\\($n)]\"\n    else error(\"invalid path representation\")\n    end) | join(\".\");\n[ paths(scalars) as $p\n  | \"\\($p | pr2pe) == \\(getpath($p) | tojson)\" ]\n| join(\" && \")"
    ],
    "data": [
      {
        "input": {
          "username": "billy",
          "hero": {
            "something": "goeshere"
          },
          "bumper": {
            "bumper2": {
              "bumper3": "splodge"
            }
          },
          "morgan": [
            {
              "abc": 123
            },
            2,
            4,
            {
              "def": 567
            }
          ],
          "password": "issilly"
        },
        "output": "request[\"username\"] = \"billy\" && request[\"hero\"][\"something\"] = \"goeshere\" && request[\"bumper\"][\"bumper2\"][\"bumper3\"] = \"splodge\" && request[\"morgan\"][0][\"abc\"] = 123 && request[\"morgan\"][1] = 2 && request[\"morgan\"][2] = 4 && request[\"morgan\"][3][\"def\"] = 567 && request[\"password\"] = \"issilly\""
      }
    ],
    "identifier": 57474828
  },
  {
    "context": [
      "I have the following test.json file:\r\n\r\n    [{\"key1\":\"value1\"},{\"key2\":\"value2\"},{\"key2\":\"value2\"}]\r\n    [{\"key1\":\"value1\"},{\"key2\":\"value2\"}]\r\n\r\nIn this, I need to check for duplication only within the array element.",
      "I just need to report\r\n\r\n    {\"key\": \"{\\\"key2\\\":\\\"value2\\\"}\",\"value\": 2}\r\n\r\nEssentially, \"key2\":\"value2\" is duplicated only within the array and not across the array elements",
      "The following jq invocation seems to give your expected output:\r\n\r\n```\r\njq -sc '.[]\r\n  | group_by(.)[]\r\n  | select(length > 1)\r\n  | { key: first|tostring, value: length }'\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\"key\":\"{\\\"key2\\\":\\\"value2\\\"}\",\"value\":2}\r\n```"
    ],
    "utterance": "Identify objects that are duplicated within each top-level array and report the object and its count if it appears more than once within the same array.",
    "expressions": [
      ".[] | group_by(.)[] | select(length > 1) | { key: first|tostring, value: length }"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key1": "value1"
            },
            {
              "key2": "value2"
            },
            {
              "key2": "value2"
            }
          ],
          [
            {
              "key1": "value1"
            },
            {
              "key2": "value2"
            }
          ]
        ],
        "output": [
          {
            "key": "{\"key2\":\"value2\"}",
            "value": 2
          }
        ]
      }
    ],
    "identifier": 57510859
  },
  {
    "context": [
      "I mean, we use jq to read a file and then process its contents line by line; the output for each line is a distinct url generated with a line respectively.",
      "I want to generate output like {method: \"POST\", url: \"http://:6060\", body: {phoneNo: 13512345678}} for each line in the above file, but when executing the the jq commandline as the above, got nothing.",
      "Assuming tels.txt has the telephone numbers exactly as you want them, one per line, you could write:",
      "jq -R '{method: \"POST\", url: \"http://:6060\", body: {phoneNo: .}}' tels.txt"
    ],
    "utterance": "For each line in a file containing phone numbers, produce an object with method set to POST, url set to http://:6060, and body containing the phone number.",
    "expressions": [
      "jq -R '{method: \"POST\", url: \"http://:6060\", body: {phoneNo: .}}' tels.txt"
    ],
    "data": [
      {
        "input": "13512345678\n13712345600\n17212215600\n13512345889\n18912345678\n13912345678\n18612345999\n",
        "output": [
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "13512345678"
            }
          },
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "13712345600"
            }
          },
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "17212215600"
            }
          },
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "13512345889"
            }
          },
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "18912345678"
            }
          },
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "13912345678"
            }
          },
          {
            "method": "POST",
            "url": "http://:6060",
            "body": {
              "phoneNo": "18612345999"
            }
          }
        ]
      }
    ],
    "identifier": 57522841
  },
  {
    "context": [
      "How might one use `jq-1.5-1-a5b5cbe` to join a filtered set of arrays from STDIN to a set of objects which contains no common fields, assuming that all elements will be in predictable order?",
      "Standard Input (pre-slurpfile; generated by multiple GETs):",
      "{ \"ref\":\"objA\",\"arr\":[\"alpha\"] }",
      "{ \"ref\":\"objB\",\"arr\":[\"bravo\"] }",
      "Existing File:",
      "[{\"name\":\"foo\"},{\"name\":\"bar\"}]",
      "Desired Output:",
      "[{\"name\":\"foo\",\"arr\":[\"alpha\"]},{\"name\":\"bar\",\"arr\":[\"bravo\"]}]",
      "Get jq to read `file` before stdin, so that the first entity in `file` will be `.` and you can get everything else using `inputs`.",
      "$ multiGET | jq -c '. as $objects\n| [ foreach (inputs | {arr}) as $x (-1; .+1;\n    . as $i | $objects[$i] + $x\n) ]' file -\n[{\"name\":\"foo\",\"arr\":[\"alpha\"]},{\"name\":\"bar\",\"arr\":[\"bravo\"]}]"
    ],
    "utterance": "Combine a list of objects from a file with a list of arrays from input, matching them in order, and add the corresponding 'arr' field from each input to each object.",
    "expressions": [
      ". as $objects\n| [ foreach (inputs | {arr}) as $x (-1; .+1;\n    . as $i | $objects[$i] + $x\n) ]",
      "[$objects, map(del(.ref))]\n| transpose\n| map(add)"
    ],
    "data": [
      {
        "input": [
          {
            "ref": "objA",
            "arr": [
              "alpha"
            ]
          },
          {
            "ref": "objB",
            "arr": [
              "bravo"
            ]
          }
        ],
        "output": [
          {
            "name": "foo",
            "arr": [
              "alpha"
            ]
          },
          {
            "name": "bar",
            "arr": [
              "bravo"
            ]
          }
        ]
      },
      {
        "input": [
          {
            "name": "foo"
          },
          {
            "name": "bar"
          }
        ]
      }
    ],
    "identifier": 57542944
  },
  {
    "context": [
      "Curl Command output",
      "{\n    \"results\": [{\n            \"name\": \"smith Jones\",\n            \"DOB\": \"1992-03-26\",\n            \"Enrollmentdate\": \"2013-08-24\"\n\n        },\n\n        {\n            \"name\": \"Jacob Mathew\",\n            \"DOB\": \"1993-03-26\",\n            \"Enrollmentdate\": \"2014-10-02\"\n        },\n\n        {\n            \"name\": \"Anita Rodrigues\",\n            \"DOB\": \"1994-03-26\",\n            \"Enrollmentdate\": \"2015-02-19\"\n        }\n    ]\n}",
      "JQ commond used",
      "<curl-command>|jq '.results | map(.name), map(.DOB), map(.Enrollmentdate) | @csv' >file.csv",
      "My Output",
      "smith jones, Jacob Mathew, Anita Rodrigues\n1992-03-26, 1993-03-26, 1994-03-26\n2013-08-24, 2014-10-02, 2015-02-19",
      "This might not be csv exactly but below is the expected output.",
      "Name                 DOB             Enrollmentdate\nsmith jones,       1992-03-26,        2013-08-24\njacob Mathew,      1993-03-26,        2014-10-02\nAnitha Rodrigues,  1994-03-26,        2015-02-19",
      "With your sample JSON, the invocation:\n\n    jq -r '\n      .results[]\n      | [.name, .DOB, .Enrollmentdate ]\n      | @csv'\n\nproduces:\n\"smith Jones\",\"1992-03-26\",\"2013-08-24\"\n\"Jacob Mathew\",\"1993-03-26\",\"2014-10-02\"\n\"Anita Rodrigues\",\"1994-03-26\",\"2015-02-19\"",
      "If you don't want the (in this case) superfluous quotation marks, you could replace @csv by join(\",\") but it would be better to write a simple filter to take care of values with commas, etc.",
      "If the first result has the keys in the correct order, you could get away with:\n  (.results[0] | keys_unsorted),\n  (.results[]\n  | [.name, .DOB, .Enrollmentdate ])\n  | @csv",
      "But it would probably be better to use a bit of jq magic along the lines of the following:\n  (.results[0] | keys_unsorted) as $headers\n  | $headers,\n    (.results[]\n     | [getpath($headers[]|[.])])\n  | @csv"
    ],
    "utterance": "Convert an array of objects containing name, DOB, and Enrollmentdate fields into CSV format with headers and each row representing an individual's values in the correct columns.",
    "expressions": [
      ".results[] | [.name, .DOB, .Enrollmentdate ] | @csv",
      "(.results[0] | keys_unsorted), (.results[] | [.name, .DOB, .Enrollmentdate ]) | @csv",
      "(.results[0] | keys_unsorted) as $headers | $headers, (.results[] | [getpath($headers[]|[.])]) | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "name": "smith Jones",
              "DOB": "1992-03-26",
              "Enrollmentdate": "2013-08-24"
            },
            {
              "name": "Jacob Mathew",
              "DOB": "1993-03-26",
              "Enrollmentdate": "2014-10-02"
            },
            {
              "name": "Anita Rodrigues",
              "DOB": "1994-03-26",
              "Enrollmentdate": "2015-02-19"
            }
          ]
        },
        "output": [
          "\"name\",\"DOB\",\"Enrollmentdate\"",
          "\"smith Jones\",\"1992-03-26\",\"2013-08-24\"",
          "\"Jacob Mathew\",\"1993-03-26\",\"2014-10-02\"",
          "\"Anita Rodrigues\",\"1994-03-26\",\"2015-02-19\""
        ]
      }
    ],
    "identifier": 57504189
  },
  {
    "context": [
      "I have input\n{\n  \"data\": {\n    \"k1\": \"v1\"\n  },\n  \"item\": {\n    \"data\": {\n      \"k2\": \"v2\"\n    }\n  }, \n  \"list\": {\n    \"item\": {\n      \"data\": {\n        \"k3\": \"v3\",\n        \"k4\": \"v4\"\n      }\n    }\n  }\n}\nand I want to collect into a single array all of the values of all of the keys that are immediate children of a \"data\" key. So the output I want is\n[\"v1\",\"v2\",\"v3\",\"v4\"]\nI eventually figured out that this works\njq --compact-output '[.. | .data? | select(.) | to_entries | .[].value]'"
    ],
    "utterance": "Produce an array containing all values of keys that are immediate children of any object with the key \"data\" within the input structure.",
    "expressions": [
      "[.. | .data? | select(.) | to_entries | .[].value]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "k1": "v1"
          },
          "item": {
            "data": {
              "k2": "v2"
            }
          },
          "list": {
            "item": {
              "data": {
                "k3": "v3",
                "k4": "v4"
              }
            }
          }
        },
        "output": [
          "v1",
          "v2",
          "v3",
          "v4"
        ]
      }
    ],
    "identifier": 57549136
  },
  {
    "context": [
      "Is there a way to create the output object which contains \"C\" with `null` as value?",
      "One way to provide a default value is often to use the `//` \"alternative\" operator.",
      ".array[]\n| {id, \n   \"goodConversation\": \n     ((.conversations[]\n      | select(.type == \"good\")\n      | .conversation) // null) }",
      "If there is more than one \"good\" conversation, however, this may not be exactly what you want.  If it's not, then consider using `first`, e.g.:",
      ".array[]\n| {id,\n   \"goodConversation\":\n     ( first(.conversations[]\n             | select(.type == \"good\")\n             | .conversation) // null)}"
    ],
    "utterance": "For each element, output the id and the conversation value with type equal to \"good\", or null if no such conversation exists.",
    "expressions": [
      ".array[] | {id, \"goodConversation\": ((.conversations[] | select(.type == \"good\") | .conversation) // null)}",
      ".array[] | {id, \"goodConversation\": (first(.conversations[] | select(.type == \"good\") | .conversation) // null)}"
    ],
    "data": [
      {
        "input": {
          "array": [
            {
              "id": "A",
              "conversations": [
                {
                  "conversation": "1",
                  "type": "good"
                },
                {
                  "conversation": "2",
                  "type": "bad"
                }
              ]
            },
            {
              "id": "B",
              "conversations": [
                {
                  "conversation": "3",
                  "type": "good"
                },
                {
                  "conversation": "4",
                  "type": "bad"
                }
              ]
            },
            {
              "id": "C",
              "conversations": [
                {
                  "conversation": "5",
                  "type": "bad"
                },
                {
                  "conversation": "6",
                  "type": "bad"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "A",
            "goodConversation": "1"
          },
          {
            "id": "B",
            "goodConversation": "3"
          },
          {
            "id": "C",
            "goodConversation": null
          }
        ]
      }
    ],
    "identifier": 57549929
  },
  {
    "context": [
      "I am trying to read json file and get a single object out of it, by reading that object into bash script variable.",
      "search_command=\".defines[] | select(.id==$current_id)\"",
      "out_json=\"$(jq \"$search_command\" source.json)\"",
      "search_command='.defines[] | select(.id==$x)'",
      "out_json=$(jq --argjson x \"$current_id\" \"$search_command\" source.json)"
    ],
    "utterance": "Extract the object where id equals the value of the bash variable current_id and store it in a bash variable.",
    "expressions": [
      "jq \".defines[] | select(.id==$current_id)\" source.json",
      "jq --argjson x \"$current_id\" '.defines[] | select(.id==$x)' source.json"
    ],
    "identifier": 57570967
  },
  {
    "context": [
      "I am trying to change it so that when CrashTested is `false`, then it outputs **no** and when `true`, then **yes**",
      "`jq: error (at <stdin>:31): Cannot index string with string \"CrashTested\"`",
      "It might make more sense, though, to write  something along the following lines:",
      "`.Cars[] | [.Name, .ID, (if .CrashTested == \"true\" then \"yes\" elif .CrashTested == \"false\" then \"no\" else \"unknown\" end)] | @csv`",
      "def yn: if . == true or . == \"true\" then \"yes\" elif . == false or . == \"false\" then \"no\" else \"unknown\" end; .Cars[] | [.Name, .ID, (.CrashTested | yn) ]"
    ],
    "utterance": "For each car, output its Name, ID, and 'yes' if CrashTested is 'true', 'no' if 'false', otherwise 'unknown'.",
    "expressions": [
      ".Cars[] | [.Name, .ID, (if .CrashTested == \"true\" then \"yes\" elif .CrashTested == \"false\" then \"no\" else \"unknown\" end)]",
      "def yn: if . == true or . == \"true\" then \"yes\" elif . == false or . == \"false\" then \"no\" else \"unknown\" end; .Cars[] | [.Name, .ID, (.CrashTested | yn) ]"
    ],
    "data": [
      {
        "input": {
          "Cars": [
            {
              "Name": "Toyota Prius",
              "ID": 1,
              "CrashTested": "false"
            },
            {
              "Name": "Honda Accord",
              "ID": 2,
              "CrashTested": "true"
            },
            {
              "Name": "VW Beetle",
              "ID": 3,
              "CrashTested": "false"
            },
            {
              "Name": "Acura TL",
              "ID": 4,
              "CrashTested": "true"
            },
            {
              "Name": "Dodge Charger",
              "ID": 5,
              "CrashTested": "false"
            },
            {
              "Name": "Ford Focus",
              "ID": 6,
              "CrashTested": "true"
            }
          ]
        },
        "output": [
          [
            "Toyota Prius",
            1,
            "no"
          ],
          [
            "Honda Accord",
            2,
            "yes"
          ],
          [
            "VW Beetle",
            3,
            "no"
          ],
          [
            "Acura TL",
            4,
            "yes"
          ],
          [
            "Dodge Charger",
            5,
            "no"
          ],
          [
            "Ford Focus",
            6,
            "yes"
          ]
        ]
      }
    ],
    "identifier": 57564439
  },
  {
    "context": [
      "Now I need to add the contents of the smaller json file into the Main.Json file in the parameters array.",
      "You want `--slurpfile`, and you need to escape `/agents/delta` part of the path with quotes:",
      "$ jq --slurpfile newval insert.json '.paths.\"/agents/delta\".get.parameters += $newval' main.json"
    ],
    "utterance": "Append the contents of another file to the parameters array for the GET operation at path /agents/delta.",
    "expressions": [
      ".paths[\"/agents/delta\"].get.parameters += $newval"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "paths": {
            "/agents/delta": {
              "get": {
                "description": "lorem ipsum doram",
                "operationId": "getagentdelta",
                "summary": "GetAgentDelta",
                "tags": [
                  "Agents"
                ],
                "parameters": [
                  {
                    "name": "since",
                    "in": "query",
                    "description": "Format - date-time (as date-time in RFC3339). The time from which you need changes from. You should use the format emitted by Date's toJSON method (for example, 2017-04-23T18:25:43.511Z). If a timestamp older than a week is passed, a business rule violation will be thrown which will require the client to change the from date. As a best-practice, for a subsequent call to this method, send the timestamp when you <b>started</b> the previous delta call (instead of when you completed processing the response or the max of the lastUpdateOn timestamps of the returned records). This will ensure that you do not miss any changes that occurred while you are processing the response from this method",
                    "required": true,
                    "type": "string"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "swagger": "2.0",
          "paths": {
            "/agents/delta": {
              "get": {
                "description": "lorem ipsum doram",
                "operationId": "getagentdelta",
                "summary": "GetAgentDelta",
                "tags": [
                  "Agents"
                ],
                "parameters": [
                  {
                    "name": "since",
                    "in": "query",
                    "description": "Format - date-time (as date-time in RFC3339). The time from which you need changes from. You should use the format emitted by Date's toJSON method (for example, 2017-04-23T18:25:43.511Z). If a timestamp older than a week is passed, a business rule violation will be thrown which will require the client to change the from date. As a best-practice, for a subsequent call to this method, send the timestamp when you <b>started</b> the previous delta call (instead of when you completed processing the response or the max of the lastUpdateOn timestamps of the returned records). This will ensure that you do not miss any changes that occurred while you are processing the response from this method",
                    "required": true,
                    "type": "string"
                  },
                  {
                    "name": "Authorization",
                    "description": "This parameter represents the Authorization token obtained from the OKTA Authorization server. It is the Bearer token provided to authorize the consumer. Usage Authorization : Bearer token",
                    "in": "header",
                    "required": true,
                    "type": "string"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 57549904
  },
  {
    "context": [
      "I want to generate json array with jq in bash.",
      "I have my file named fileForV:",
      "    V    Apple is good for you",
      "    A    Broccoli is good for you",
      "jq -R '[inputs | split(\"\\t\") | {\"FruitOrVeg\":.[0],\"Good?\":.[1]}]'<<EOF fileForV EOF",
      "Here is a typical transcript, using the input as shown but with one tab per line:",
      "$ jq-1.5 -n -R '[inputs | split(\"\\t\") | {\"FruitOrVeg\":.[0],\"Good?\":.[1]}]' input.tsv",
      "[",
      "  {",
      "    \"FruitOrVeg\": \"V\",",
      "    \"Good?\": \"Apple is good for you\"",
      "  },",
      "  {",
      "    \"FruitOrVeg\": \"A\",",
      "    \"Good?\": \"Broccoli is good for you\"",
      "  }",
      "]"
    ],
    "utterance": "Convert a tab-separated text file with two columns to an array of objects with keys 'FruitOrVeg' and 'Good?', mapping the first and second columns respectively.",
    "expressions": [
      "[inputs | split(\"\\t\") | {\"FruitOrVeg\": .[0], \"Good?\": .[1]}]"
    ],
    "data": [
      {
        "input": "V\tApple is good for you\nA\tBroccoli is good for you\n",
        "output": [
          {
            "FruitOrVeg": "V",
            "Good?": "Apple is good for you"
          },
          {
            "FruitOrVeg": "A",
            "Good?": "Broccoli is good for you"
          }
        ]
      }
    ],
    "identifier": 57566308
  },
  {
    "context": [
      "I\u2019m trying to print out a field called \"end\" from a json file using `jq` but am running into the following error:",
      "$ jq .end /tmp/out.json\nerror: syntax error, unexpected end, expecting $end\n.end\n ^^^\n1 compile error",
      "This issue (https://github.com/stedolan/jq/issues/256) suggests using `.[\"end\"]` as the selector but that doesn't seem to work either.",
      "$ jq .[\"end\"] /tmp/out.json\nerror: syntax error, unexpected end\n.[end]\n  ^^^\n1 compile error",
      "You have to protect them by quoting the whole thing:\n\n    jq '[\"end\"]'"
    ],
    "utterance": "Extract the field named end from an object, where end is a reserved word.",
    "expressions": [
      ".end",
      ".[\"end\"]"
    ],
    "data": [
      {
        "input": {
          "start": 10,
          "end": 20
        },
        "output": 20
      }
    ],
    "identifier": 57582199
  },
  {
    "context": [
      "I want to retain the objects that contain `\"true\"` values, and to remove keys whose value is not `true`.",
      "Here is the result I'm trying to achieve:\n\n    {\n      \"thing1\": {\n        \"b\": true\n      },\n      \"thing2\": {\n        \"a\": true,\n        \"b\": true,\n        \"c\": true,\n        \"d\": true\n      },\n      \"thing3\": {\n        \"a\": true\n      }\n    }",
      "# First remove the subkeys that are not truthy:\nmap_values(with_entries(select(.value)))\n# ... then remove the empty dictionaries:\n| with_entries(select(.value|length > 0))",
      "Another jq script:\n\n    <file jq 'del(..|select(. == false))'\n\nThis recursively goes to all nodes (operator `..`) and deletes all elements whose value would be `false`."
    ],
    "utterance": "Keep only those keys within each top-level object whose value is true, and remove the keys with false values.",
    "expressions": [
      "map_values(with_entries(select(.value))) | with_entries(select(.value|length > 0))",
      "del(..|select(. == false))"
    ],
    "data": [
      {
        "input": {
          "thing1": {
            "a": false,
            "b": true,
            "c": false,
            "d": false
          },
          "thing2": {
            "a": true,
            "b": true,
            "c": true,
            "d": true
          },
          "thing3": {
            "a": true,
            "b": false,
            "c": false,
            "d": false
          }
        },
        "output": {
          "thing1": {
            "b": true
          },
          "thing2": {
            "a": true,
            "b": true,
            "c": true,
            "d": true
          },
          "thing3": {
            "a": true
          }
        }
      }
    ],
    "identifier": 57578108
  },
  {
    "context": [
      "I need the `id` values (*gecko.id so to speak) or `error` if there is none:",
      "You can use a combination of the `?` \"error suppression\" and `//` \"alternative` operators :",
      "'(($variantA[0].browser_specific_settings, $variantB[0].applications) | .gecko.id)? // \"error\"'",
      "You can use a filter as below that could work with both your sample JSON content provided",
      "jq '.. | if type == \"object\" and has(\"id\") then .id else empty end'",
      "(.. | objects | select(has(\"id\"))).id // \"error\"",
      "first(.. | objects | select(has(\"id\")).id ) // \"error\""
    ],
    "utterance": "Return the value of gecko.id if present, or 'error' if it is missing.",
    "expressions": [
      "((.browser_specific_settings, .applications) | .gecko.id)? // \"error\"",
      "(.. | objects | select(has(\"id\"))).id // \"error\"",
      "first(.. | objects | select(has(\"id\")).id ) // \"error\""
    ],
    "data": [
      {
        "input": {
          "browser_specific_settings": {
            "gecko": {
              "id": "{95ad7b39-5d3e-1029-7285-9455bcf665c0}",
              "strict_min_version": "68.0"
            }
          }
        },
        "output": "{95ad7b39-5d3e-1029-7285-9455bcf665c0}"
      },
      {
        "input": {
          "applications": {
            "gecko": {
              "id": "j30D-3YFPUvj9u9izFoPSjlNYZfF22xS@foobar",
              "strict_min_version": "53.0"
            }
          }
        },
        "output": "j30D-3YFPUvj9u9izFoPSjlNYZfF22xS@foobar"
      },
      {
        "input": {
          "browser_specific_settings": {
            "gecko": {
              "strict_min_version": "68.0"
            }
          }
        },
        "output": "error"
      }
    ],
    "identifier": 57571424
  },
  {
    "identifier": 57602000
  },
  {
    "context": [
      "What is the easy way to delete arbitrary values from entire JSON by a specific label/key? My JSON may have an arbitrary depth, so deleting by the label should be done recursively.",
      "and I want to remove all the elements with the label `\"remove\"`, so that the final result would look like this:",
      "This gets the desired result in jq.\n\n    jq 'del(..|.remove?)'"
    ],
    "utterance": "Remove all entries with the key \"remove\" at any depth from the data structure.",
    "expressions": [
      "del(..|.remove?)"
    ],
    "data": [
      {
        "input": {
          "root": [
            {
              "name": "blah 1",
              "remove": [
                1,
                2,
                3
              ],
              "new list": [
                {
                  "name": "blah 2",
                  "remove": null,
                  "new list": [
                    {
                      "name": "blah 3",
                      "remove": [
                        {
                          "name": "blah 4",
                          "new list": []
                        },
                        {
                          "name": "blah 5",
                          "new list": []
                        }
                      ]
                    }
                  ]
                },
                {
                  "name": "blah 6",
                  "new list": []
                }
              ]
            }
          ]
        },
        "output": {
          "root": [
            {
              "name": "blah 1",
              "new list": [
                {
                  "name": "blah 2",
                  "new list": [
                    {
                      "name": "blah 3"
                    }
                  ]
                },
                {
                  "name": "blah 6",
                  "new list": []
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 57611682
  },
  {
    "context": [
      "With jq I would like the heaviest Feline whose race is Bengal of these two json file.",
      "So the output will be \n\n    {\n      \"Feline\": [\n        {\n          \"Name\": \"Lynx\",\n          \"Race\": \"Bengal\",\n          \"Weight\": \"15\"\n        }\n      ]\n    }",
      "$ jq -n '{Feline: [\n  [inputs.Feline[] | select(.Race==\"Bengal\")] | max_by(.Weight)\n]}' file1 file2",
      "$ jq -s '[.[] | .Feline[] | select(.Race == \"Bengal\")] | max_by(.Weight) | {\"Feline\": [.]} ' f1 f2"
    ],
    "utterance": "Find the heaviest feline with race equal to Bengal from two files, and output it as an object with a Feline array.",
    "expressions": [
      "{Feline: [[inputs.Feline[] | select(.Race==\"Bengal\")] | max_by(.Weight)]}",
      "[.[] | .Feline[] | select(.Race == \"Bengal\")] | max_by(.Weight) | {\"Feline\": [.]} "
    ],
    "data": [
      {
        "input": {
          "Feline": [
            {
              "Name": "Leo",
              "Race": "Bengal",
              "Weight": "12"
            },
            {
              "Name": "Diego",
              "Race": "Toyger",
              "Weight": "24"
            }
          ]
        }
      },
      {
        "input": {
          "Feline": [
            {
              "Name": "Lynx",
              "Race": "Bengal",
              "Weight": "15"
            },
            {
              "Name": "Simba",
              "Race": "Ussuri",
              "Weight": "14"
            }
          ]
        },
        "output": {
          "Feline": [
            {
              "Name": "Lynx",
              "Race": "Bengal",
              "Weight": "15"
            }
          ]
        }
      }
    ],
    "identifier": 57623064
  },
  {
    "context": [
      "I would like to merge all files and convert them to json in a different format, with sdg indexes as key, and related projects as list values.",
      "Expected Output:",
      "{ \"1\": [ { \"name\": \"Bahmni\", \"description: \"...\" } ], \"3\": [ { \"name\": \"GNU Health\", \"description: \"...\" }, { \"name\": \"Bahmni\", \"description: \"...\" } ], \"10\": [ { \"name: \"A11Y\", \"description: \"...\" } ] }",
      "For simplicity, I'm going to assume that the .yaml conversion to .json has already been done. Slightly adapting your filter, it's easy to see that:",
      "jq '{ (.sdgs[]|tostring): del(.sdgs) }' a11y.json gnu_health.json bahmni.json",
      "To combine them into a single object is a tiny bit tricky.",
      "let's first define a helper function which can be used to group single-key objects by key:",
      "def group_by_keys: reduce .[] as $o ({};  reduce ($o | to_entries[]) as $kv (.; .[$kv.key]",
      "jq -n '\n  def group_by_keys: reduce .[] as $o ({}; \n     reduce ($o | to_entries[]) as $kv (.; .[$kv.key] += [$kv.value]));\n  [inputs | {(.sdgs[]|tostring): del(.sdgs) }] | group_by_keys\n' a11y.json gnu_health.json bahmni.json"
    ],
    "utterance": "Group a list of project objects, each with a list of numeric 'sdgs', by sdg number so that each sdg key maps to a list of projects (with name and description) associated with it.",
    "expressions": [
      "jq -n '\ndef group_by_keys: reduce .[] as $o ({}; reduce ($o | to_entries[]) as $kv (.; .[$kv.key] += [$kv.value]));\n[inputs | {(.sdgs[]|tostring): del(.sdgs) }] | group_by_keys\n' a11y.json gnu_health.json bahmni.json"
    ],
    "data": [
      {
        "input": [
          {
            "description": "GNU Health is a Free/Libre project for health practitioners, health institutions and governments. It provides the functionality of Electronic Medical Record (EMR), Hospital Management (HMIS) and Health Information System (HIS).",
            "sdgs": [
              3
            ],
            "name": "GNU Health"
          },
          {
            "description": "This Accessibility Project is a community-driven effort to make web accessibility easier by leveraging a worldwide community of developer knowledge.",
            "sdgs": [
              10
            ],
            "name": "A11Y"
          },
          {
            "description": "Bahmni is an Open Source hospital Management System focusing on poor/underserved and public hospitals in the developing world. It's aimed to being a generic system which can be used for multiple diseases and hospitals in different countries.",
            "sdgs": [
              1,
              3
            ],
            "name": "Bahmni"
          }
        ],
        "output": {
          "1": [
            {
              "name": "Bahmni",
              "description": "Bahmni is an Open Source hospital Management System focusing on poor/underserved and public hospitals in the developing world. It's aimed to being a generic system which can be used for multiple diseases and hospitals in different countries."
            }
          ],
          "3": [
            {
              "name": "GNU Health",
              "description": "GNU Health is a Free/Libre project for health practitioners, health institutions and governments. It provides the functionality of Electronic Medical Record (EMR), Hospital Management (HMIS) and Health Information System (HIS)."
            },
            {
              "name": "Bahmni",
              "description": "Bahmni is an Open Source hospital Management System focusing on poor/underserved and public hospitals in the developing world. It's aimed to being a generic system which can be used for multiple diseases and hospitals in different countries."
            }
          ],
          "10": [
            {
              "name": "A11Y",
              "description": "This Accessibility Project is a community-driven effort to make web accessibility easier by leveraging a worldwide community of developer knowledge."
            }
          ]
        }
      }
    ],
    "identifier": 57586614
  },
  {
    "context": [
      "I need to add the above json file value into the below json, only if the below path\r\n`.paths.<any method that starts with />.get.parameters` does not have that object already. \r\nIf it exists that object needs to be removed and the contents of the above Auth.json needs to be added.",
      "You got it almost right, but missing the part to identify those objects whose name contains `/`. You can use `startswith()` on the keyname",
      "Additionally, if you would like to compare if `.parameters` object does not already contain the Authentication object, change your if condition to\r\n\r\n    if (.key|startswith(\"/\")) and (.value.get.parameters[] != $auth)"
    ],
    "utterance": "Replace or insert the Authorization object in all .paths.<key starting with />.get.parameters arrays, ensuring only the Auth object is present.",
    "expressions": [
      ".paths |= with_entries( if (.key | startswith(\"/\")) then .value.get.parameters = $auth | . else . end )"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "paths": {
            "/agents/delta": {
              "get": {
                "description": "lorem ipsum doram",
                "operationId": "getagentdelta",
                "summary": "GetAgentDelta",
                "tags": [
                  "Agents"
                ],
                "parameters": [
                  {
                    "name": "since",
                    "in": "query",
                    "description": "Format - date-time (as date-time in RFC3339). The time from which you need changes from. You should use the format emitted by Date's toJSON method (for example, 2017-04-23T18:25:43.511Z). If a timestamp older than a week is passed, a business rule violation will be thrown which will require the client to change the from date. As a best-practice, for a subsequent call to this method, send the timestamp when you <b>started</b> the previous delta call (instead of when you completed processing the response or the max of the lastUpdateOn timestamps of the returned records). This will ensure that you do not miss any changes that occurred while you are processing the response from this method",
                    "required": true,
                    "type": "string"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "swagger": "2.0",
          "paths": {
            "/agents/delta": {
              "get": {
                "description": "lorem ipsum doram",
                "operationId": "getagentdelta",
                "summary": "GetAgentDelta",
                "tags": [
                  "Agents"
                ],
                "parameters": [
                  {
                    "name": "Authorization",
                    "description": "This parameter represents the Authorization token obtained from the OKTA Authorization server. It is the Bearer token provided to authorize the consumer. Usage Authorization : Bearer token",
                    "in": "header",
                    "required": true,
                    "type": "string"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 57623522
  },
  {
    "context": [
      "So, I need to create `yq`-expression to make delays lower",
      ".records is an array, so you could use this filter:",
      ".records |= map(.delay /= 3)",
      "Or you might prefer:",
      ".records[].delay |= (. /= 3)"
    ],
    "utterance": "Divide each delay value in the records array by 3.",
    "expressions": [
      ".records |= map(.delay /= 3)",
      ".records[].delay |= (. /= 3)"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "delay": 841,
              "content": "..."
            },
            {
              "delay": 19,
              "content": "..."
            },
            {
              "delay": 6,
              "content": "..."
            },
            {
              "delay": 28,
              "content": "..."
            }
          ]
        },
        "output": {
          "records": [
            {
              "delay": 280.3333333333333,
              "content": "..."
            },
            {
              "delay": 6.333333333333333,
              "content": "..."
            },
            {
              "delay": 2,
              "content": "..."
            },
            {
              "delay": 9.333333333333334,
              "content": "..."
            }
          ]
        }
      }
    ],
    "identifier": 57626741
  },
  {
    "identifier": 57627243
  },
  {
    "context": [
      "What I need the output to be, is as follows:",
      "[",
      "  {\"name\":\"someName1\",\"value\":\"someValue1\"},",
      "  {\"name\":\"someName2\",\"value\":\"someValue2\"},",
      "  {\"name\":\"someName3\",\"value\":\"someValue3\"},",
      "  {\"name\":\"someName4\",\"value\":\"someValue4\"},",
      "  {\"name\":\"someName5\",\"value\":\"someValue5\"},",
      "  {\"name\":\"someName6\",\"value\":\"someValue6\"},",
      "  {\"name\":\"someName7\",\"value\":\"someValue7\"}",
      "]",
      "A simple (hackish) solution would be to add one more invocation of jq along the lines of:",
      "    jq -s . deploy.json | sponge deploy.json",
      "I suggest to only ouptut the relevant value from inside the loop and have `jq` work on the output of the loop. It is made easier if you have the loop output correct JSON (strings must be enclosed in double quotes), as the combination of --raw-input and --slurp that is otherwise necessary requires splitting the input around \\n.",
      "done < input.txt | jq --slurp 'map({ key: ., value: .})'"
    ],
    "utterance": "Combine multiple newline-delimited objects into a single array of objects, each with name and value fields corresponding to each item's key.",
    "expressions": [
      "jq -s . deploy.json",
      "jq --slurp 'map({name: ., value: .})'"
    ],
    "data": [
      {
        "input": [
          "{\"name\":\"someName1\",\"value\":\"someValue1\"}",
          "{\"name\":\"someName2\",\"value\":\"someValue2\"}",
          "{\"name\":\"someName3\",\"value\":\"someValue3\"}",
          "{\"name\":\"someName4\",\"value\":\"someValue4\"}",
          "{\"name\":\"someName5\",\"value\":\"someValue5\"}",
          "{\"name\":\"someName6\",\"value\":\"someValue6\"}",
          "{\"name\":\"someName7\",\"value\":\"someValue7\"}"
        ],
        "output": [
          {
            "name": "someName1",
            "value": "someValue1"
          },
          {
            "name": "someName2",
            "value": "someValue2"
          },
          {
            "name": "someName3",
            "value": "someValue3"
          },
          {
            "name": "someName4",
            "value": "someValue4"
          },
          {
            "name": "someName5",
            "value": "someValue5"
          },
          {
            "name": "someName6",
            "value": "someValue6"
          },
          {
            "name": "someName7",
            "value": "someValue7"
          }
        ]
      }
    ],
    "identifier": 57585761
  },
  {
    "context": [
      "i need to filter based on a list of numbers, say for our example\n\n    15947\n    15948\n(i have a list of thousands of serials numbers, that are separated by the newline)",
      "The key to using jq to partition the objects into three files is to tag the objects and invoke jq with the -c command-line option.  You then process the tagged output using a tool such as `awk`.  This last part has been covered in several other SO Q&As, so I'll just focus on the tagging part, which can be accomplished using `foreach`:",
      "INDEX($sn | splits(\"\\n\") | select(length>0); .) as $dict\n| foreach .[] as $in ({parity:0};\n    if ($in | $dict[.serial])\n    then .code = 2\n    else .code = .parity\n    | .parity |= (.+1 % 2)\n    end;\n    .code, $in )"
    ],
    "utterance": "Filter objects whose serial number is in a provided newline-separated list; output matching objects together and split non-matching objects into two separate chunks with half of them in each chunk.",
    "expressions": [
      "INDEX($sn | splits(\"\\n\") | select(length>0); .) as $dict\n| foreach .[] as $in ({parity:0};\n    if ($in | $dict[.serial])\n    then .code = 2\n    else .code = .parity\n    | .parity |= (.+1 % 2)\n    end;\n    .code, $in )"
    ],
    "data": [
      {
        "input": [
          {
            "_id": {
              "productno": "5d538a"
            },
            "serial": "15947",
            "description": "text"
          },
          {
            "_id": {
              "productno": "5d587"
            },
            "serial": "15948",
            "description": "text"
          },
          {
            "_id": {
              "productno": "5d5c38c"
            },
            "serial": "15949",
            "description": "more text"
          },
          {
            "_id": {
              "productno": "5d5c38c"
            },
            "serial": "15967",
            "description": "more text"
          }
        ],
        "output": [
          {
            "_id": {
              "productno": "5d538a"
            },
            "serial": "15947",
            "description": "text"
          },
          {
            "_id": {
              "productno": "5d587"
            },
            "serial": "15948",
            "description": "text"
          }
        ],
        "output_non_matching_file_B": [
          {
            "_id": {
              "productno": "5d5c38c"
            },
            "serial": "15949",
            "description": "more text"
          }
        ],
        "output_non_matching_file_C": [
          {
            "_id": {
              "productno": "5d5c38c"
            },
            "serial": "15967",
            "description": "more text"
          }
        ]
      }
    ],
    "identifier": 57624276
  },
  {
    "context": [
      "Source data looks like this",
      "I expect a result like this",
      "The code below achieves the job, but I would like to pass the array of columns to be injected into the child arrays, the name of the primary result and an array containing the array field names.",
      "It\u2019s a lot more easier to achieve this using multiple `reduce`s, like:",
      "split_data(\"person\"; [\"name\", \"year\"]; [\"phones\", \"email\"])",
      "Here's a straightforward solution to the generic problem (it uses `reduce` only once, in a helper function).",
      "Here finally is the function that takes as arguments the $parent, $ids, and columns of interest.",
      "split_data(\"person\"; [\"name\", \"year\"]; [\"phones\", \"email\"])"
    ],
    "utterance": "Reorganize a list so that specified keys are collected under a top-level object as arrays: one array per parent with all its info, and one array per child array field, with each child object merged with selected parent fields.",
    "expressions": [
      "def pick($ary):\n  . as $in\n  | reduce $ary[] as $k ({};\n      . + {($k): $in[$k]});\n\ndef split_data($parent; $ids; $arr_cols):\n  (.[0]|keys_unsorted - $arr_cols - $ids) as $extra\n  | { ($parent): [.[] | pick($ids + $extra)] }\n  + ([$arr_cols[] as $k\n     | {($k): [.[] | pick($ids) + .[$k][]] }] | add) ;\n\nsplit_data(\"person\"; [\"name\", \"year\"]; [\"phones\", \"email\"])",
      "def split_data($parent; $ids; $arr_cols):\n    ($arr_cols | map([.])) as $p\n    | reduce .[] as $in ({}; .[$parent] += [$in | delpaths($p)]\n        | (reduce $ids[] as $k ({}; . + {($k): $in[$k]}) as $s\n        | reduce $arr_cols[] as $k (.; .[$k] += [$in[$k][] + $s])\n    );\n\nsplit_data(\"person\"; [\"name\", \"year\"]; [\"phones\", \"email\"])"
    ],
    "data": [
      {
        "input": [
          {
            "phones": [
              {
                "phone": "555-555-1234",
                "type": "home"
              },
              {
                "phone": "555-555-5678",
                "type": "mobile"
              }
            ],
            "email": [
              {
                "email": "a@b.com",
                "type": "work"
              },
              {
                "email": "x@c.com",
                "type": "home"
              }
            ],
            "name": "john doe",
            "year": "2012",
            "city": "cupertino",
            "zip": "555004"
          },
          {
            "phones": [
              {
                "phone": "555-666-1234",
                "type": "home"
              },
              {
                "phone": "555-666-5678",
                "type": "mobile"
              }
            ],
            "email": [
              {
                "email": "a@b.com",
                "type": "work"
              },
              {
                "email": "x@c.com",
                "type": "home"
              }
            ],
            "name": "jane doe",
            "year": "2000",
            "city": "los angeles",
            "zip": "555004"
          }
        ],
        "output": {
          "person": [
            {
              "name": "john doe",
              "year": "2012",
              "city": "cupertino",
              "zip": "555004"
            },
            {
              "name": "jane doe",
              "year": "2000",
              "city": "los angeles",
              "zip": "555004"
            }
          ],
          "phones": [
            {
              "name": "john doe",
              "year": "2012",
              "phone": "555-555-1234",
              "type": "home"
            },
            {
              "name": "john doe",
              "year": "2012",
              "phone": "555-555-5678",
              "type": "mobile"
            },
            {
              "name": "jane doe",
              "year": "2000",
              "phone": "555-666-1234",
              "type": "home"
            },
            {
              "name": "jane doe",
              "year": "2000",
              "phone": "555-666-5678",
              "type": "mobile"
            }
          ],
          "email": [
            {
              "name": "john doe",
              "year": "2012",
              "email": "a@b.com",
              "type": "work"
            },
            {
              "name": "john doe",
              "year": "2012",
              "email": "x@c.com",
              "type": "home"
            },
            {
              "name": "jane doe",
              "year": "2000",
              "email": "a@b.com",
              "type": "work"
            },
            {
              "name": "jane doe",
              "year": "2000",
              "email": "x@c.com",
              "type": "home"
            }
          ]
        }
      }
    ],
    "identifier": 57534926
  },
  {
    "context": [
      "\"I have a JSON file with several uid fields that are numeric but I need to convert them to string. These uid fields are nested in different places in the file.\"",
      "\"I tried this command: jq '(.. | .uid?) |= (tostring)' which somewhat worked but it added a \\\"uid\\\" field (e.g.  \\\"uid\\\": \\\"null\\\") to any dictionaries that didn't have one to begin with.\"",
      "\"The correct way of doing this is walk: walk( if type == \\\"object\\\" and has(\\\"uid\\\") then .uid |= tostring else . end )\""
    ],
    "utterance": "Convert all nested uid fields with numeric values to strings without creating new uid fields in objects that do not have them.",
    "expressions": [
      "walk( if type == \"object\" and has(\"uid\") then .uid |= tostring else . end )"
    ],
    "identifier": 57648741
  },
  {
    "context": [
      "I want to get the key of the arrays that has an object which has `\"value1\"` for key: `\"filterkey1\"`. So in this case the output must be:",
      "Get *subkey*s using `keys_unsorted`, and check if their values have `filterkey1: \"value1\"` pair using `any`:",
      "```\n.key1 | [\n    keys_unsorted[] as $k\n    | if any(.[$k][]; .filterkey1==\"value1\")\n    then $k \n    else empty end\n]\n```"
    ],
    "utterance": "Select the keys of object properties whose array contains an object where filterkey1 is \"value1\".",
    "expressions": [
      ".key1 | [keys_unsorted[] as $k | if any(.[$k][]; .filterkey1==\"value1\") then $k else empty end]"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "subkey1": [
              {
                "filterkey1": "value1",
                "filterkey2": "value2"
              },
              {
                "filterkey1": "value3",
                "filterkey2": "value4"
              }
            ],
            "subkey2": [
              {
                "filterkey1": "value5",
                "filterkey2": "value6"
              },
              {
                "filterkey1": "value7",
                "filterkey2": "value8"
              }
            ],
            "subkey3": [
              {
                "filterkey1": "value1",
                "filterkey2": "value6"
              },
              {
                "filterkey1": "value9",
                "filterkey2": "value4"
              }
            ]
          },
          "key2": {}
        },
        "output": [
          "subkey1",
          "subkey3"
        ]
      }
    ],
    "identifier": 57642287
  },
  {
    "context": [
      "I want to create a JQ function that allows me to \r\nto filter an array in the JSON tree, based on parent&#39;s / sibling properties;",
      "Desired Output (All the array data, + newly created array \" \"conflictsInPeriod\"\", **inside each element of the array**):",
      "Maybe this is closer to what you&#39;re looking for:\r\n\r\n```\r\ndef etl(keyname; arrayname; cond; result):\r\n  def etl:\r\n    . as $parent\r\n    | .[arrayname][]\r\n    | { parent: $parent, child: .}\r\n    | select(cond) | result;\r\n\r\n  {(keyname): map(etl)}\r\n ;\r\n\r\n## Invocation:\r\netl(\"conflictsInPeriod\";\r\n    \"events\";\r\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) < .child.endDate)\r\n      and\r\n      (.child.vendorId == .parent.workorder.vendorId);\r\n   {\r\n     event: .child.id,\r\n     wo_sd: .parent.workorder.startDate[:10],\r\n     workorder_id: .parent.workorder.id\r\n   }\r\n)\r\n```"
    ],
    "utterance": "For each top-level object, add a new array containing the ids and details of events where the event's vendorId matches the workorder vendorId and the event's endDate is after the workorder startDate minus 12 weeks.",
    "expressions": [
      "def etl(keyname; arrayname; cond; result):\n  def etl:\n    . as $parent\n    | .[arrayname][]\n    | { parent: $parent, child: .}\n    | select(cond) | result;\n\n  {(keyname): map(etl)}\n ;\n\netl(\"conflictsInPeriod\";\n    \"events\";\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) < .child.endDate)\n      and\n      (.child.vendorId == .parent.workorder.vendorId);\n   {\n     event: .child.id,\n     wo_sd: .parent.workorder.startDate[:10],\n     workorder_id: .parent.workorder.id\n   }\n)"
    ],
    "data": [
      {
        "input": [
          {
            "storeId": "s2",
            "storehouseInfo": {
              "id": "025453",
              "name": "00211 NW, OR",
              "maxPallets": 10
            },
            "workorder": {
              "id": "w2s2",
              "startDate": "2019-09-06T10:00:00.000Z",
              "vendorId": "v2"
            },
            "events": [
              {
                "id": "e4",
                "storeId": "s2",
                "vendorId": "v1",
                "startDate": "2019-09-05T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e5",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-05T00:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e10",
                "storeId": "s2",
                "vendorId": "v1",
                "startDate": "2019-09-06T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e11",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-06T00:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e12",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-06T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              }
            ]
          }
        ],
        "output": [
          {
            "conflictsInPeriod": [
              {
                "event": "e5",
                "wo_sd": "2019-09-06",
                "workorder_id": "w2s2"
              },
              {
                "event": "e11",
                "wo_sd": "2019-09-06",
                "workorder_id": "w2s2"
              },
              {
                "event": "e12",
                "wo_sd": "2019-09-06",
                "workorder_id": "w2s2"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 57558872
  },
  {
    "context": [
      "I\u2019d like to just print `a`. I don\u2019t find how to do so.",
      "$ jq '. ' <<< '\"a\"'",
      "\"a\"",
      "Use the `--raw-output`/`-r` flag.",
      "With this option, if the filter\u2019s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes."
    ],
    "utterance": "Print the value a without quotes from the string input \"a\".",
    "expressions": [
      "jq -r '.'"
    ],
    "data": [
      {
        "input": "\"a\"",
        "output": "a"
      }
    ],
    "identifier": 57650743
  },
  {
    "context": [
      "I would need to Parse this 16000 lines of json objects and fitler the documents/objects which match criteria that whose leaf element/field : `statusInfo/status` in not \"UP\" and of those filtered objects, just return    ` \"name\" , \"serviceUrl\",\"status\"`",
      "$ jq --stream -n 'fromstream(1|truncate_stream(inputs))\n    | select(.statusInfo.status != \"UP\")\n    | .name, .serviceUrl, .statusInfo.status\n' input.json"
    ],
    "utterance": "Extract all objects where statusInfo.status is not \"UP\" and return the values of name, serviceUrl, and statusInfo.status fields.",
    "expressions": [
      "fromstream(1|truncate_stream(inputs)) | select(.statusInfo.status != \"UP\") | .name, .serviceUrl, .statusInfo.status"
    ],
    "data": [
      {
        "input": [
          {
            "id": "9c108ec5",
            "name": "USER-V2",
            "managementUrl": "http://aws-ec2.aws.com:5784/",
            "healthUrl": "http://aws-ec2.aws.com:5784/health",
            "serviceUrl": "http://aws-ec2.aws.com:5784/",
            "statusInfo": {
              "status": "UP",
              "timestamp": 1566663146681,
              "details": {
                "description": " Eureka Discovery Client",
                "status": "UP"
              }
            },
            "source": "discovery",
            "metadata": {},
            "info": {
              "component": "user",
              "description": "User REST Resource",
              "version": "2.2.1",
              "git": {
                "commit": {
                  "time": "07/27/2018 @ 15:06:55 CDT",
                  "id": "b2a1b37"
                },
                "branch": "refs/tags/v2.2.1"
              }
            }
          },
          {
            "id": "1a381f20",
            "name": "ADMIN-V1",
            "managementUrl": "http://aws-ec2.aws.com:4435/",
            "healthUrl": "http://aws-ec2.aws.com:4435/health",
            "serviceUrl": "http://aws-ec2.aws.com:4435/",
            "statusInfo": {
              "status": "Warning",
              "timestamp": 1566663146682,
              "details": {
                "description": "Spring Cloud Eureka Discovery Client",
                "status": "Warning"
              }
            },
            "source": "discovery",
            "metadata": {},
            "info": {
              "description": "Exchange Admin REST Resource",
              "api": {
                "version": "1.2.1",
                "name": "admin",
                "link": "https://app.swaggerhub.com/apis/AWSExchange/admin/1.2.1"
              },
              "implementation": "admin",
              "version": "1.1.0",
              "git": {
                "commit": {
                  "time": "01/04/2019 @ 15:36:48 UTC",
                  "id": "39d5551"
                },
                "branch": "refs/tags/v1.1.0"
              }
            }
          }
        ],
        "output": [
          "ADMIN-V1",
          "http://aws-ec2.aws.com:4435/",
          "Warning"
        ]
      }
    ],
    "identifier": 57640053
  },
  {
    "identifier": 57658528
  },
  {
    "context": [
      "I try to merge them, using `jq`. For each person from the first file (in the second file migth be more persons, which should be ignored) create list of it's attributes. So an output should look something like this:\r\n\r\n```\r\n[\r\n  {\r\n    \"person1\":\r\n      [\r\n        { \"attribute1\": \"yui\", \"attribute2\": \"hjk\" }\r\n      ]\r\n  },\r\n  {\r\n    \"person2\":\r\n      [\r\n        { \"attribute1\": \"wer\", \"attribute2\": \"sdf\" },\r\n        { \"attribute1\": \"ert\", \"attribute2\": \"dfg\" },\r\n        { \"attribute1\": \"rty\", \"attribute2\": \"fgh\" }\r\n      ]\r\n  }\r\n]\r\n```",
      "jq 'reduce (input[]|to_entries[]) as $e (add;\r\n  if has($e.key) then .[$e.key] += [$e.value] else . end\r\n) | [keys_unsorted[] as $k|{($k): .[$k]}]' file1 file2",
      "add as $dict\r\n# aggregation:\r\n| (reduce input[] as $record ({};\r\n   ($record|keys_unsorted[0]) as $person\r\n   | if $dict[$person] then .[$person] += [$record[$person]] else . end )) as $answer\r\n# re-arrangement\r\n| reduce ($dict|keys_unsorted[]) as $person ([]; . + [ {($person): $answer[$person] } ] )"
    ],
    "utterance": "For each person in the first file, collect a list of their attribute objects from the second file (ignoring extra persons in the second file) and output as an array of objects per person.",
    "expressions": [
      "reduce (input[]|to_entries[]) as $e (add; if has($e.key) then .[$e.key] += [$e.value] else . end) | [keys_unsorted[] as $k|{($k): .[$k]}]",
      "add as $dict | (reduce input[] as $record ({};\n   ($record|keys_unsorted[0]) as $person\n   | if $dict[$person] then .[$person] += [$record[$person]] else . end )) as $answer | reduce ($dict|keys_unsorted[]) as $person ([]; . + [ {($person): $answer[$person] } ] )"
    ],
    "data": [
      {
        "input": [
          [
            {
              "person1": []
            },
            {
              "person2": []
            }
          ],
          [
            {
              "person2": {
                "attribute1": "wer",
                "attribute2": "sdf"
              }
            },
            {
              "person2": {
                "attribute1": "ert",
                "attribute2": "dfg"
              }
            },
            {
              "person2": {
                "attribute1": "rty",
                "attribute2": "fgh"
              }
            },
            {
              "person3": {
                "attribute1": "tyu",
                "attribute2": "ghj"
              }
            },
            {
              "person1": {
                "attribute1": "yui",
                "attribute2": "hjk"
              }
            }
          ]
        ],
        "output": [
          {
            "person1": [
              {
                "attribute1": "yui",
                "attribute2": "hjk"
              }
            ]
          },
          {
            "person2": [
              {
                "attribute1": "wer",
                "attribute2": "sdf"
              },
              {
                "attribute1": "ert",
                "attribute2": "dfg"
              },
              {
                "attribute1": "rty",
                "attribute2": "fgh"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 57637890
  },
  {
    "context": [
      "Json exampel:\r\n \r\n        {  \r\n       \"alliances_info\":{  \r\n          \"744085325458334213\":{  \r\n             \"emblem\":3,\r\n             \"name\":\"wellwell\",\r\n             \"member_count\":1,\r\n             \"level\":1,\r\n             \"military_might\":1035,\r\n             \"public\":false,\r\n             \"tag\":\"MELL\",\r\n             \"slogan\":\"\",\r\n             \"id\":744085325458334213\r\n          },\r\n          \"744128593839677958\":{  \r\n             \"emblem\":0,\r\n             \"name\":\"Brave\",\r\n             \"member_count\":1,\r\n             \"level\":1,\r\n             \"military_might\":1035,\r\n             \"public\":false,\r\n             \"tag\":\"GABA\",\r\n             \"slogan\":\"\",\r\n             \"id\":744128593839677958\r\n          },\r\n          ...",
      "If you want an array at all, you probably want one array containing all the alliances like this:\r\n\r\n```\r\n$ jq '.alliances_info | [ .[] | { alliance_name: .name, alliance_id: .id } ]' so.json\r\n[\r\n  {\r\n    \"alliance_name\": \"wellwell\",\r\n    \"alliance_id\": 744085325458334200\r\n  },\r\n  {\r\n    \"alliance_name\": \"Brave\",\r\n    \"alliance_id\": 744128593839678000\r\n  },\r\n  ...\r\n]\r\n```",
      "That inner expression starts with .[] which means to produce one output for each JSON value (ignoring the keys) in the input object. For us, that will be the objects named \"744085325458334213\", \"744128593839677958\", \u2026",
      "$ jq '.alliances_info | [ .[] | { alliance_name: .name, alliance_id: .id } ]' so.json",
      "I read the input from a file and the funny thing is that the file is Unicode but no UTF8. after recoding the command is working fine."
    ],
    "utterance": "List all alliances as objects with their names and ids in a single array.",
    "expressions": [
      ".alliances_info | [ .[] | { alliance_name: .name, alliance_id: .id } ]"
    ],
    "data": [
      {
        "input": {
          "alliances_info": {
            "744085325458334213": {
              "emblem": 3,
              "name": "wellwell",
              "member_count": 1,
              "level": 1,
              "military_might": 1035,
              "public": false,
              "tag": "MELL",
              "slogan": "",
              "id": 744085325458334213
            },
            "744128593839677958": {
              "emblem": 0,
              "name": "Brave",
              "member_count": 1,
              "level": 1,
              "military_might": 1035,
              "public": false,
              "tag": "GABA",
              "slogan": "",
              "id": 744128593839677958
            },
            "746034084459209223": {
              "emblem": 0,
              "name": "Queen",
              "member_count": 1,
              "level": 1,
              "military_might": 1035,
              "public": false,
              "tag": "QUE",
              "slogan": "",
              "id": 746034084459209223
            },
            "750446471312466445": {
              "emblem": 0,
              "name": "Phoenix Inc",
              "member_count": 35,
              "level": 6,
              "military_might": 453369,
              "public": true,
              "tag": "PHOI",
              "slogan": "",
              "id": 750446471312466445
            },
            "750446518934594062": {
              "emblem": 11,
              "name": "Australia",
              "member_count": 44,
              "level": 8,
              "military_might": 957211,
              "public": true,
              "tag": "AUST",
              "slogan": "Go Australia",
              "id": 750446518934594062
            }
          },
          "server_version": "v7.190.4-master.000000006"
        },
        "output": [
          {
            "alliance_name": "wellwell",
            "alliance_id": 744085325458334213
          },
          {
            "alliance_name": "Brave",
            "alliance_id": 744128593839677958
          },
          {
            "alliance_name": "Queen",
            "alliance_id": 746034084459209223
          },
          {
            "alliance_name": "Phoenix Inc",
            "alliance_id": 750446471312466445
          },
          {
            "alliance_name": "Australia",
            "alliance_id": 750446518934594062
          }
        ]
      }
    ],
    "identifier": 57570621
  },
  {
    "context": [
      "I have this json: {\"temperature\":\"21\", \"humidity\":\"12.3\", \"message\":\"Today ID 342 is running\"}",
      "I want to use jq to obtain this json: {\"temp\":\"21\", \"hum\":\"12.3\", \"id\":\"342\"}",
      "what i want to do is extract the ID number 342 and put it in the new json with a different key name.",
      "I want to use a regex because i know that the ID number comes lways after the \"ID\" part.",
      "jq '{ temp: .temperature, hum: .humidity, id: (.message | capture(\"ID (?<id>[[:digit:]]+)\").id) }' <old.json >new.json"
    ],
    "utterance": "Extract the number following 'ID' in the 'message' string and output an object with keys 'temp', 'hum', and 'id' using the respective values.",
    "expressions": [
      "{ temp: .temperature, hum: .humidity, id: (.message | capture(\"ID (?<id>[[:digit:]]+)\").id) }"
    ],
    "data": [
      {
        "input": {
          "temperature": "21",
          "humidity": "12.3",
          "message": "Today ID 342 is running"
        },
        "output": {
          "temp": "21",
          "hum": "12.3",
          "id": "342"
        }
      }
    ],
    "identifier": 57649735
  },
  {
    "context": [
      "Ok i solved the problem by disabling the defautl pretty print of jq. I added the -c option and now every json is on one line:",
      "jq -c . file.json > file2.json"
    ],
    "utterance": "Produce compact, single-line output for each object without newlines, tabs, or pretty formatting.",
    "expressions": [
      "jq -c . file.json"
    ],
    "data": [
      {
        "input": [
          {
            "temperature": "21",
            "humidity": "12.3",
            "message": "Today ID 342 is running"
          },
          {
            "temperature": "13",
            "humidity": "40.1",
            "message": "Today ID 98 is running"
          }
        ],
        "output": [
          "{\"temperature\":\"21\",\"humidity\":\"12.3\",\"message\":\"Today ID 342 is running\"}",
          "{\"temperature\":\"13\",\"humidity\":\"40.1\",\"message\":\"Today ID 98 is running\"}"
        ]
      }
    ],
    "identifier": 57657193
  },
  {
    "context": [
      "I have to verify that the base64 encoded and gzipped contents of a property in a json file are the same as the raw ones using bash.",
      "I have been able to extract the property using jq:",
      "cat src/my-file.json | jq '.Attachment[] | .Contents[\"@Value\"] | @base64d'",
      "Below is a quick workaround; output raw base64 string and decode it using `base64` utility:",
      "jq -r '.Attachment[] | .Contents[\"@Value\"]' src/my-file.json | base64 -d | gunzip"
    ],
    "utterance": "Extract the value of the @Value property nested inside Contents from each element of Attachment, for use in further decoding.",
    "expressions": [
      ".Attachment[] | .Contents[\"@Value\"]"
    ],
    "data": [
      {
        "input": {
          "Attachment": [
            {
              "Contents": {
                "@Value": "H4sIAAAAAAAAE0rOyCxWAKJEhZLU4hUAgAA="
              }
            }
          ]
        },
        "output": "H4sIAAAAAAAAE0rOyCxWAKJEhZLU4hUAgAA="
      }
    ],
    "identifier": 57651787
  },
  {
    "context": [
      "I have this JSON:\r\n\r\n    {\"item\":2, \"url\":\"domain/house/23/bedroom\"}\r\n\r\nI'm trying to use jq to obtain this new JSON:\r\n\r\n    {\"item\":2, \"number\":\"23\", \"room\":\"bedroom\"}\r\n\r\nIs it possible to do this in JQ?",
      "Split `url` by slashes, and use the result for generating new fields.\r\n```\r\n{item} + (.url / \"/\" | {number: .[-2], room: .[-1]})\r\n```"
    ],
    "utterance": "Extract the second to last and last segments from the 'url' field and output them as 'number' and 'room' fields, alongside the original 'item' field.",
    "expressions": [
      "{item} + (.url / \"/\" | {number: .[-2], room: .[-1]})"
    ],
    "data": [
      {
        "input": {
          "item": 2,
          "url": "domain/house/23/bedroom"
        },
        "output": {
          "item": 2,
          "number": "23",
          "room": "bedroom"
        }
      }
    ],
    "identifier": 57672861
  },
  {
    "context": [
      "I take a string with values separated by `,`. I need to place \"around them\" the double quotes and, after each split, do a trim.",
      "It doesn't works if I use `input=\"TAG1,TAG2\"` (i.e. no space after `,`)",
      "If I use`input=\"   TAG1,   TAG2   \"`, it keep spaces and don't trim each match. It should, for each item.",
      "Here is a `jq` solution:",
      "jq -cR '. | gsub(\"^ +| +$\"; \"\") | split(\" *, *\"; \"\")' <<< \"TAG1,TAG2\"",
      "[\"TAG1\",\"TAG2\"]",
      "jq -cR '. | gsub(\"^ +| +$\"; \"\") | split(\" *, *\"; \"\")' <<< \"   TAG1,       TAG2     \"",
      "[\"TAG1\",\"TAG2\"]"
    ],
    "utterance": "Split a string by commas (with or without surrounding spaces), trim whitespace from each value, and output an array with each value wrapped in double quotes.",
    "expressions": [
      ". | gsub(\"^ +| +$\"; \"\") | split(\" *, *\"; \"\")"
    ],
    "data": [
      {
        "input": "TAG1,TAG2",
        "output": [
          "TAG1",
          "TAG2"
        ]
      },
      {
        "input": "   TAG1,      TAG2    ",
        "output": [
          "TAG1",
          "TAG2"
        ]
      }
    ],
    "identifier": 57672838
  },
  {
    "context": [
      "< my api call here >  | jq  '.results[].response.error + \" ==> \" + .results[].msg'",
      "I have got 4 rows, instead of 2.",
      "You are iterating independently by using results twice, so you get every combination of the errors and messages, instead you want to pipe results elements in as the input to use each result alone:",
      "jq  '.results[] | .response.error + \" ==> \" + .msg'"
    ],
    "utterance": "For each result entry, concatenate the response.error message and the msg field with ' ==> ' in between.",
    "expressions": [
      ".results[] | .response.error + \" ==> \" + .msg"
    ],
    "data": [
      {
        "input": {
          "count": 7,
          "results": [
            {
              "index": 1,
              "response": {
                "error": "Restore full config failed Case1."
              },
              "status_code": 500,
              "msg": "[Fullconfig:POST:blalblablabla:admin] Status code: 500",
              "sort": [
                1562572224627
              ]
            },
            {
              "index": 2,
              "response": {
                "error": "Restore full config failed Case2."
              },
              "status_code": 500,
              "msg": "[Fullconfig:POST:blalblabla:admin] Status code: 500",
              "sort": [
                1562572216215
              ]
            }
          ]
        },
        "output": [
          "Restore full config failed Case1. ==> [Fullconfig:POST:blalblabla:admin] Status code: 500",
          "Restore full config failed Case2. ==> [Fullconfig:POST:blalblabla:admin] Status code: 500"
        ]
      }
    ],
    "identifier": 57682306
  },
  {
    "context": [
      "I want to add a dynamically generated array to a json file.",
      "I'd like to generate an array based on dynamic values and finally create the following output:",
      "The Remove array's content is stored in a (cmd) %variable%.",
      "jq -n --arg items \"%variable%\" \"{ Remove: $items | split(\\\",\\\") }\"",
      "What is the best way to insert this array into the original file?",
      "Given the string input string `Twitter,Wikipedia (en)`, you can use jq to update the JSON data:",
      "<file jq --arg i 'Twitter,Wikipedia (en)' '.policies.SearchEngines += ({ Remove: $i | split(\",\") })'"
    ],
    "utterance": "Insert a Remove array containing the values from a comma-separated string variable into the policies.SearchEngines object under the Remove key.",
    "expressions": [
      ".policies.SearchEngines += { Remove: ($i | split(\",\")) }"
    ],
    "data": [
      {
        "input": {
          "policies": {
            "SearchBar": "separate",
            "SearchEngines": {
              "PreventInstalls": false
            }
          }
        },
        "output": {
          "policies": {
            "SearchBar": "separate",
            "SearchEngines": {
              "PreventInstalls": false,
              "Remove": [
                "Twitter",
                "Wikipedia (en)"
              ]
            }
          }
        }
      }
    ],
    "identifier": 57691878
  },
  {
    "context": [
      "The conditions are \"locator\": \"mmc1\" and \"#name\": \"section-title\".",
      ".. | .[\"$$\"]?\n | select((.[]? | .\"#name\" == \"section-title\"?) and (..[]? | .locator? | test(\"mmc[0-9]+\")?))\n | [\n(..[]? | select(.locator? | test(\"mmc[0-9]+\")?) | .locator)\n, (.[] | select(.\"#name\" == \"section-title\") | ._)\n] | @tsv",
      "To find all objects with #name == \"section-title\" and select the _ value:\n\n    ..|select(objects.\"#name\" == \"section-title\")._",
      "Putting it all together:\n\n    [(..|objects.locator|strings), (..|select(objects.\"#name\" == \"section-title\")._)] | @tsv",
      "..\n| .[\"$$\"]?\n| (.. | objects | .locator | strings | select(test(\"mmc[0-9]+\")) ) as $locator\n| (.. | objects | select(.[\"#name\"] == \"section-title\") | ._) as $st\n| [$locator, $st]\n| @tsv"
    ],
    "utterance": "Return a tab-separated pair containing the locator value matching mmc[0-9]+ and the _ value from an object with #name equal to section-title, only from contexts where both exist under the same $$ array.",
    "expressions": [
      ".. | .[\"$$\"]?\n | select((.[]? | .\"#name\" == \"section-title\"?) and (..[]? | .locator? | test(\"mmc[0-9]+\")?))\n | [ (..[]? | select(.locator? | test(\"mmc[0-9]+\")?) | .locator) , (.[] | select(.\"#name\" == \"section-title\") | ._) ] | @tsv",
      "..\n| .[\"$$\"]?\n| (.. | objects | .locator | strings | select(test(\"mmc[0-9]+\")) ) as $locator\n| (.. | objects | select(.[\"#name\"] == \"section-title\") | ._) as $st\n| [$locator, $st]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "$$": [
            {
              "#name": "label",
              "_": "Appendix A"
            },
            {
              "#name": "section-title",
              "$": {
                "id": "sectitle0145"
              },
              "_": "Supplementary data"
            },
            {
              "#name": "para",
              "$": {
                "id": "p0210",
                "view": "all"
              },
              "$$": [
                {
                  "#name": "__text__",
                  "_": "The following is the supplementary data related to this article:"
                },
                {
                  "#name": "display",
                  "$$": [
                    {
                      "#name": "e-component",
                      "$": {
                        "id": "ec1"
                      },
                      "$$": [
                        {
                          "#name": "link",
                          "$": {
                            "locator": "mmc1",
                            "type": "simple",
                            "role": "http://data.elsevier.com/vocabulary/ElsevierContentTypes/46.1",
                            "href": "pii:S2212877817302818/mmc1",
                            "id": "aep-link-id8"
                          }
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "mmc1\tSupplementary data"
      }
    ],
    "identifier": 57651071
  },
  {
    "context": [
      "How can I transform this nested json into a CSV file I can load into a spreadsheet?",
      "The output should look like this:",
      "date,messages_sent,matches,messages_received,swipes_passes,swipes_likes,app_opens",
      "\"date\" , \"app_opens\", \"matches\", \"messages_received\", \"messages_sent\", \"swipes_likes\", \"swipes_passes\"",
      "\"2018-06-03\", 3, 3, 30, 7, 30, 56",
      "[\"date\", \"messages_sent\", \"matches\", \"messages_received\", \"swipes_passes\", \"swipes_likes\", \"app_opens\"] as $keys\n| .Usage \n| ([.[] | keys_unsorted] | add | unique) as $dates\n| $keys,\n  ($dates[] as $d | [$d] + [ .[$keys[1:][]][$d] ])\n|  @csv"
    ],
    "utterance": "Convert usage statistics by date for fields messages_sent, matches, messages_received, swipes_passes, swipes_likes, and app_opens to CSV format with a header row and one row per date.",
    "expressions": [
      ".Usage as $u|$u|keys as $k|([\"date\"]+$k|@csv),(.[$k[0]]|keys|map(. as $d|[.]+($k|map($u[.][$d]))|@csv))[]",
      "[\"date\", \"messages_sent\", \"matches\", \"messages_received\", \"swipes_passes\", \"swipes_likes\", \"app_opens\"] as $keys\n| .Usage \n| ([.[] | keys_unsorted] | add | unique) as $dates\n| $keys,\n  ($dates[] as $d | [$d] + [ .[$keys[1:][]][$d] ])\n|  @csv"
    ],
    "data": [
      {
        "input": {
          "Usage": {
            "app_opens": {
              "2018-06-03": 3,
              "2018-06-04": 10,
              "2018-06-05": 2
            },
            "messages_sent": {
              "2018-06-03": 7,
              "2018-06-04": 9,
              "2018-06-05": 0
            },
            "matches": {
              "2018-06-03": 3,
              "2018-06-04": 1,
              "2018-06-05": 7
            },
            "messages_received": {
              "2018-06-03": 30,
              "2018-06-04": 1,
              "2018-06-05": 20
            },
            "swipes_passes": {
              "2018-06-03": 56,
              "2018-06-04": 1,
              "2018-06-05": 8
            },
            "swipes_likes": {
              "2018-06-03": 30,
              "2018-06-04": 4,
              "2018-06-05": 4
            }
          }
        },
        "output": [
          "\"date\",\"messages_sent\",\"matches\",\"messages_received\",\"swipes_passes\",\"swipes_likes\",\"app_opens\"",
          "\"2018-06-03\",7,3,30,56,30,3",
          "\"2018-06-04\",9,1,1,1,4,10",
          "\"2018-06-05\",0,7,20,8,4,2"
        ]
      }
    ],
    "identifier": 57666633
  },
  {
    "context": [
      "I want to filter the object start with string \"40007\" like that : `.orderid=\"40007\"`.",
      "jq '.data[] | select(.orderid | startswith(\"40007\"))' output.json"
    ],
    "utterance": "Filter objects where orderid starts with \"40007\".",
    "expressions": [
      ".data[] | select(.orderid | startswith(\"40007\"))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "orderid": "40007600",
              "price": "9.99",
              "listingname": "iPhone 8",
              "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg",
              "photo": "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL.jpg"
            },
            {
              "orderid": "40007598",
              "price": "9.99",
              "listingname": "iPhone 8 Plus",
              "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg",
              "photo": "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL.jpg"
            },
            {
              "orderid": "40007595",
              "price": "9.39",
              "listingname": "Nadelflaschen",
              "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg",
              "photo": "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL.jpg"
            }
          ]
        },
        "output": [
          {
            "orderid": "40007600",
            "price": "9.99",
            "listingname": "iPhone 8",
            "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg",
            "photo": "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL.jpg"
          },
          {
            "orderid": "40007598",
            "price": "9.99",
            "listingname": "iPhone 8 Plus",
            "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg",
            "photo": "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL.jpg"
          },
          {
            "orderid": "40007595",
            "price": "9.39",
            "listingname": "Nadelflaschen",
            "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg",
            "photo": "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL.jpg"
          }
        ]
      }
    ],
    "identifier": 57694872
  },
  {
    "context": [
      "What I'm trying to do is select the cardType,MaskedPan,amount and datetime out of the data.",
      "Ideally I'd be able to just have a field in the CSV for cardType,MaskedPan,amount and datetime instead of pulling the \"Value\" that contains all of it.",
      "The ingredient you're missing is `fromjson`, which converts a stringified JSON to JSON.",
      ".TransactionDetails[0].Value\n| fromjson\n| [.cardType, .maskedPan] + (.paymentDetails | [.amount, .dateTime])\n| @csv"
    ],
    "utterance": "Extract cardType, maskedPan, amount, and dateTime fields from the stringified Value property inside TransactionDetails and output them as CSV fields.",
    "expressions": [
      ".TransactionDetails[0].Value | fromjson | [.cardType, .maskedPan] + (.paymentDetails | [.amount, .dateTime]) | @csv"
    ],
    "data": [
      {
        "input": {
          "TransactionDetails": [
            {
              "TransactionId": 123456789,
              "Name": "BlacklinePaymentDetail",
              "Value": "{\"cardType\":\"Visa\",\"maskedPan\":\"1234\",\"paymentDetails\":{\"reference\":\"123456789012\",\"amount\":99.99,\"dateTime\":\"2019/08/27 08:41:09\"}}",
              "ShowOnTill": false,
              "PrintOnOrder": false,
              "PrintOnReceipt": false
            }
          ]
        },
        "output": "\"Visa\",\"1234\",99.99,\"2019/08/27 08:41:09\""
      }
    ],
    "identifier": 57699779
  },
  {
    "context": [
      "I have a file containing structured log lines like so:",
      "I'd like to sort them by `.time`. How can I do it with `jq`?",
      "Those are separate entities, you need to slurp them first to make sorting possible, then you can undo the slurping to get the same look as the original input. Like:",
      "jq -cs 'sort_by(.time)[]' log.log"
    ],
    "utterance": "Sort all input log records by their `time` field.",
    "expressions": [
      "jq -cs 'sort_by(.time)[]' log.log"
    ],
    "data": [
      {
        "input": [
          {
            "generation_id": 13,
            "level": "info",
            "member_id": "sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1",
            "msg": "starting consumer",
            "time": "2019-08-28T18:24:46.303Z"
          },
          {
            "generation_id": 13,
            "initial_offset": 178921,
            "level": "info",
            "member_id": "sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1",
            "msg": "starting to consume from partition",
            "partition": 18,
            "time": "2019-08-28T18:24:46.304Z"
          },
          {
            "generation_id": 13,
            "initial_offset": -1,
            "level": "info",
            "member_id": "sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1",
            "msg": "starting to consume from partition",
            "partition": 19,
            "time": "2019-08-28T18:24:46.305Z"
          }
        ],
        "output": [
          {
            "generation_id": 13,
            "level": "info",
            "member_id": "sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1",
            "msg": "starting consumer",
            "time": "2019-08-28T18:24:46.303Z"
          },
          {
            "generation_id": 13,
            "initial_offset": 178921,
            "level": "info",
            "member_id": "sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1",
            "msg": "starting to consume from partition",
            "partition": 18,
            "time": "2019-08-28T18:24:46.304Z"
          },
          {
            "generation_id": 13,
            "initial_offset": -1,
            "level": "info",
            "member_id": "sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1",
            "msg": "starting to consume from partition",
            "partition": 19,
            "time": "2019-08-28T18:24:46.305Z"
          }
        ]
      }
    ],
    "identifier": 57698550
  },
  {
    "context": [
      "I want to add the resulting URL to existing JSON structure like:\n[\n  {\n    \"url\": \"google.com\",\n    \"redirection\": \"http://www.google.com\"\n  },\n  {\n    \"url\": \"microsoft.com\",\n    \"redirection\": \"https://www.microsoft.com\"\n  }\n]",
      "jq -r '.[].url' <<<\"$json\" |\nwhile read -r url; do\n    printf '{\"url:\" \"%s\", \"redirection\": \"%s\"}\\n' \\\n        \"$url\" \"$(curl -LSs -o /dev/null -w '%{url_effective}' \"$url\")\"\ndone |\njq -s",
      "echo \"$json\" | jq -r '.[].url' | while read url; do\n    redirect=$(curl -LSs \\\n                    -o /dev/null \\\n                    -w '%{url_effective}' \\\n                    \"${url}\" 2>/dev/null)\n    jq --null-input --arg url \"${url}\" --arg redirect \"${redirect}\" \\\n        '{url:$url, redirect: $redirect}'\ndone | jq -s",
      "echo \"$json\" | jq -r '.[].url' | while read line; do\n    prefix=\"${line}\\t\"\n    curl -LSs -o /dev/null -w \"${prefix}\"'%{url_effective}'\"\\n\" \"$line\" 2>/dev/null\ndone | jq -r --raw-input 'split(\"\\t\")|{\"url\":.[0],\"redirection\":.[1]}'",
      "jq -r '\"-o /dev/null\\nurl = \\(.[].url)\"' file |\ncurl -sSLK- -w'%{url_effective}\\n' |\njq -R 'fromjson | map(. + {redirection: input})' file -"
    ],
    "utterance": "Add each URL's redirection result as a new field to each object in the list, so that each entry includes both the original URL and its final redirected address.",
    "expressions": [
      "jq -r '.[].url' <<<\"$json\" | while read -r url; do printf '{\"url\": \"%s\", \"redirection\": \"%s\"}\\n' \"$url\" \"$(curl -LSs -o /dev/null -w '%{url_effective}' \"$url\")\"; done | jq -s",
      "jq -r '.[].url' <<<\"$json\" | while read url; do redirect=$(curl -LSs -o /dev/null -w '%{url_effective}' \"$url\" 2>/dev/null); jq --null-input --arg url \"$url\" --arg redirect \"$redirect\" '{url:$url, redirection: $redirect}'; done | jq -s",
      "jq -r '.[].url' <<<\"$json\" | while read line; do prefix=\"${line}\\t\"; curl -LSs -o /dev/null -w \"${prefix}\"'%{url_effective}'\"\\n\" \"$line\" 2>/dev/null; done | jq -r --raw-input 'split(\"\\t\")|{\"url\":.[0],\"redirection\":.[1]}'",
      "jq -r '\"-o /dev/null\\nurl = \\(.[].url)\"' file | curl -sSLK- -w'%{url_effective}\\n' | jq -R 'fromjson | map(. + {redirection: input})' file -"
    ],
    "data": [
      {
        "input": [
          {
            "url": "google.com"
          },
          {
            "url": "microsoft.com"
          }
        ],
        "output": [
          {
            "url": "google.com",
            "redirection": "http://www.google.com"
          },
          {
            "url": "microsoft.com",
            "redirection": "https://www.microsoft.com"
          }
        ]
      }
    ],
    "identifier": 57689809
  },
  {
    "context": [
      "In my bash script I have a dictionary/map like:\r\n\r\n    k1: v1\r\n    k2: v2\r\n    k3: v3\r\n\r\nCan I possibly use `jq --slurp` or `jq --raw-input` to actually convert this to JSON like this:\r\n\r\n{\r\n  \"k1\": \"v1\",\r\n  \"k2\": \"v2\",\r\n  \"k3\": \"v3\"\r\n}\r\n",
      "[inputs | select(length>0) \r\n | [splits(\": *\")] \r\n | {(.[0]): .[1]} ]\r\n| add",
      "jq -n -R -f tojson.jq input.txt",
      "Here is a bash function which can create json dicts, by handling basic json types by adding a prefix to the bash values",
      "_nwise(2)\n        | {\n            (.[0]):\n            (\n                if .[1]|startswith(\"s:\") then .[1][2:]\n                elif .[1]|startswith(\"n:\") then .[1][2:]|tonumber\n                elif .[1] == \"b:true\" then true\n                elif .[1] == \"b:false\" then false\n                else .[1]\n                end\n            )\n        }\n    "
    ],
    "utterance": "Convert lines in key: value format into an object, each key mapped to its value as a string.",
    "expressions": [
      "[inputs | select(length>0) | [splits(\": *\")] | {(.[0]): .[1]} ] | add"
    ],
    "data": [
      {
        "input": "k1: v1\nk2: v2\nk3: v3",
        "output": {
          "k1": "v1",
          "k2": "v2",
          "k3": "v3"
        }
      }
    ],
    "identifier": 57699438
  },
  {
    "context": [
      "I am trying to convert it to a hash-like data structure (associate array in zsh/bash) to get number of hosts in each availabe zone. The preferred result will be this based on the data above:\r\n```\r\navailabe_zone_A -> 2\r\navailabe_zone_B -> 1\r\n```",
      "then you could either group and count:\r\n\r\n    $ jq -nr '[inputs.host/\"-\"|last]|group_by(.)[]|\"\\(.[0]) -> \\(length)\"' input.json\r\n    availabe_zone_A -> 2\r\n    availabe_zone_B -> 1",
      "or iterate the values tallying as you go:\r\n\r\n    $ jq -nr '\r\n    reduce (inputs.host/\"-\"|last) as $k ({}; .[$k] += 1)|to_entries[]|\"\\(.key) -> \\(.value)\"\r\n    ' input.json\r\n    availabe_zone_A -> 2\r\n    availabe_zone_B -> 1",
      "With the following in program.jq:\r\n    # bag of words\r\n    def bow(stream): \r\n      reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n    \r\n    bow(inputs | .host | sub(\"^.*-availabe\";\"availabe\"))",
      "If you really want the output in the STRING --> N format,\r\nadd -r to the command-line options, and add the following\r\ntwo lines to program.jq: \r\n    | to_entries[]\r\n    | \"\\(.key) --> \\(.value)\""
    ],
    "utterance": "Count occurrences of each available zone suffix in the host fields and display the results as 'zone_name -> count'.",
    "expressions": [
      "[inputs.host/\"-\"|last]|group_by(.)[]|\"\\(.[0]) -> \\(length)\"",
      "reduce (inputs.host/\"-\"|last) as $k ({}; .[$k] += 1)|to_entries[]|\"\\(.key) -> \\(.value)\"",
      "def bow(stream): reduce stream as $word ({}; .[($word|tostring)] += 1); bow(inputs | .host | sub(\"^.*-availabe\";\"availabe\")) | to_entries[] | \"\\(.key) --> \\(.value)\""
    ],
    "data": [
      {
        "input": [
          {
            "status": "closed",
            "host": "host1-availabe_zone_A"
          },
          {
            "status": "closed",
            "host": "host2-availabe_zone_B"
          },
          {
            "status": "closed",
            "host": "host3-availabe_zone_A"
          }
        ],
        "output": [
          "availabe_zone_A -> 2",
          "availabe_zone_B -> 1"
        ]
      }
    ],
    "identifier": 57696097
  },
  {
    "context": [
      "repo=$(jq -r '.ssh_url' <<< \"${content}\" )",
      "Replace:\n\ncurl ... -d '{\"name\":\"$1\", \"private\":true}'\n\n...with:\n\ncurl ... -d \"$(jq -n --arg name \"$1\" '{\"name\": $name, \"private\": true}')\"",
      "That is to say: Nothing was wrong with how you were using `jq` to *parse* JSON; the problem is that you were trying to *create* JSON *without* using `jq`."
    ],
    "utterance": "Extract the value of the ssh_url field from the API response.",
    "expressions": [
      ".ssh_url",
      "jq -r '.ssh_url'"
    ],
    "data": [
      {
        "input": {
          "id": 123456,
          "name": "example-repo",
          "ssh_url": "git@github.com:user/example-repo.git",
          "clone_url": "https://github.com/user/example-repo.git",
          "private": true
        },
        "output": "git@github.com:user/example-repo.git"
      }
    ],
    "identifier": 57712370
  },
  {
    "context": [
      "I want to create a new property in an array's element in the JSON tree",
      "insideETL(\"conflictsInPeriod\"; \"events\"; ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) < .child.endDate) and (.child.vendorId == .parent.workorder.vendorId); { event: .child.id, wo_sd: .parent.workorder.startDate[:10], workorder_id: .parent.workorder.id } )",
      "Here\u2019s one way to do so:\ndef add(arrayname):\n  etl(arrayname;\n    \"events\";\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) < .child.endDate)\n      and\n      (.child.vendorId == .parent.workorder.vendorId);\n   {\n     event: .child.id,\n     wo_sd: .parent.workorder.startDate[:10],\n     workorder_id: .parent.workorder.id\n   }\n  )\n  ;\n\n[add(\"conflictsInPeriod\") + .[]]"
    ],
    "utterance": "Add a new array property 'conflictsInPeriod' to each item, containing objects for all events where the event's vendorId matches the workorder's vendorId and the event's endDate is after 12*7 days before the workorder's startDate, extracting event id, workorder start date (YYYY-MM-DD), and workorder id.",
    "expressions": [
      "def etl(keyname; arrayname; cond; result):\n  def etl:\n    . as $parent\n    | .[arrayname][]\n    | { parent: $parent, child: .}\n    | select(cond) | result;\n {(keyname): map(etl)}\n ;\n\ndef add(arrayname):\n  etl(arrayname;\n    \"events\";\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) < .child.endDate)\n      and\n      (.child.vendorId == .parent.workorder.vendorId);\n   {\n     event: .child.id,\n     wo_sd: .parent.workorder.startDate[:10],\n     workorder_id: .parent.workorder.id\n   }\n  )\n  ;\n\n[add(\"conflictsInPeriod\") + .[]]"
    ],
    "data": [
      {
        "input": [
          {
            "storeId": "s2",
            "storehouseInfo": {
              "id": "025453",
              "name": "00211 NW, OR",
              "maxPallets": 10
            },
            "workorder": {
              "id": "w2s2",
              "startDate": "2019-09-06T10:00:00.000Z",
              "vendorId": "v2"
            },
            "events": [
              {
                "id": "e4",
                "storeId": "s2",
                "vendorId": "v1",
                "startDate": "2019-09-05T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e5",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-05T00:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e10",
                "storeId": "s2",
                "vendorId": "v1",
                "startDate": "2019-09-06T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e11",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-06T00:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e12",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-06T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              }
            ]
          }
        ],
        "output": [
          {
            "conflictsInPeriod": [
              {
                "event": "e5",
                "wo_sd": "2019-09-06",
                "workorder_id": "w2s2"
              },
              {
                "event_id": "e11",
                "wo_sd": "2019-09-06",
                "workorder_id": "w2s2"
              },
              {
                "event_id": "e12",
                "wo_sd": "2019-09-06",
                "workorder_id": "w2s2"
              }
            ],
            "storeId": "s2",
            "storehouseInfo": {
              "id": "025453",
              "name": "00211 NW, OR",
              "maxPallets": 10
            },
            "workorder": {
              "id": "w2s2",
              "startDate": "2019-09-06T10:00:00.000Z",
              "vendorId": "v2"
            },
            "events": [
              {
                "id": "e4",
                "storeId": "s2",
                "vendorId": "v1",
                "startDate": "2019-09-05T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e5",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-05T00:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e10",
                "storeId": "s2",
                "vendorId": "v1",
                "startDate": "2019-09-06T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e11",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-06T00:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              },
              {
                "id": "e12",
                "storeId": "s2",
                "vendorId": "v2",
                "startDate": "2019-09-06T10:00:00.000Z",
                "endDate": "2019-09-14T00:00:00.000Z",
                "palletsUsed": 5
              }
            ]
          }
        ]
      }
    ],
    "identifier": 57573760
  },
  {
    "context": [
      "I always want to include the `_index`-field as `index`, and I want to include the whole `accordions`-list IF IT EXISTS in the object.",
      "The problem as stated does not require any recursion.  Using your attempt as a model, one could in fact simply write:\r\n\r\n    .hits[]\r\n    | {index: ._index} \r\n    + (if has(\"accordions\") then {accordions} else {} end)",
      "Or, with quite different semantics:\r\n\r\n    .hits[] | {index: ._index} + . | del(._index)"
    ],
    "utterance": "Produce an array of objects containing the field 'index' (with value from '_index') and, if present, the 'accordions' field, for each element in 'hits'.",
    "expressions": [
      ".hits[] | {index: ._index} + (if has(\"accordions\") then {accordions} else {} end)",
      ".hits[] | {index: ._index} + . | del(._index)"
    ],
    "data": [
      {
        "input": {
          "hits": [
            {
              "_index": "main"
            },
            {
              "_index": "main",
              "accordions": [
                {
                  "id": "1",
                  "accordionBody": "body1",
                  "accordionInnerButtonTexts": [
                    "button11",
                    "button12"
                  ]
                },
                {
                  "id": "2",
                  "accordionBody": "body2",
                  "accordionInnerButtonTexts": [
                    "button21",
                    "button22"
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "index": "main"
          },
          {
            "index": "main",
            "accordions": [
              {
                "id": "1",
                "accordionBody": "body1",
                "accordionInnerButtonTexts": [
                  "button11",
                  "button12"
                ]
              },
              {
                "id": "2",
                "accordionBody": "body2",
                "accordionInnerButtonTexts": [
                  "button21",
                  "button22"
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 57709400
  },
  {
    "context": [
      "We are trying to parse a JSON file to a tsv file. We are having problems trying to eliminate duplicate Id with unique.",
      "cat getEvent_all.json | jq -cr '.[] | [.Id] | unique_by(.[].Id)'",
      "A reasonable approach would be to use `unique_by`, e.g.:",
      "unique_by(.Id)[]\n| [.Id, .Name]\n| @tsv"
    ],
    "utterance": "Output tab-separated Id and Name pairs, excluding duplicate entries based on Id.",
    "expressions": [
      "unique_by(.Id)[] | [.Id, .Name] | @tsv",
      "map([.Id, .Name]) | unique_by(.[0])[] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "101",
            "Name": "Yugi"
          },
          {
            "Id": "101",
            "Name": "Yugi"
          },
          {
            "Id": "102",
            "Name": "David"
          }
        ],
        "output": "101\tYugi\n102\tDavid"
      }
    ],
    "identifier": 57769610
  },
  {
    "context": [
      "I want to edit this json file:",
      "And I want to add these json objects to the file:",
      "1. \"headers\": {}",
      "2. \"ext_ad_info_mappings\": []",
      "3. \"enabled\": true",
      "The output I want is like this:",
      "{\n\t\"headers\": {},\n\t\"shipping_orders\": [{\n\t}],\n\t\"timestamp\": 100,\n\t\"shoporders\": [{\n\t\t\"buyer_remark\": null,\n\t\t\"ext_ad_info_mappings\": []\n\t}],\n\t\"payment_channel_info\": {\n\t\t\"shipping_method\": 28,\n\t\t\"grouping_info\": {\n\t\t\t\"groups\": [{\n\t\t\t\t\"display_info\": {\n\t\t\t\t\t\"discount\": 1,\n\t\t\t\t\t\"enabled\": true\n\t\t\t\t}\n\t\t\t}]\n\t\t}\n\t}\n}",
      "Just locate where in the tree you want to set the values and set them.",
      ".headers = {}\n  | .shoporders[].ext_ad_info_mappings = []\n  | .payment_channel_info.grouping_info.groups[].display_info.enabled = true"
    ],
    "utterance": "Add an empty 'headers' object at the top level, an empty 'ext_ad_info_mappings' array to each element in 'shoporders', and set 'enabled' to true in each 'display_info' object inside 'payment_channel_info.grouping_info.groups'.",
    "expressions": [
      ".headers = {} | .shoporders[].ext_ad_info_mappings = [] | .payment_channel_info.grouping_info.groups[].display_info.enabled = true"
    ],
    "data": [
      {
        "input": {
          "shipping_orders": [
            {}
          ],
          "timestamp": 100,
          "shoporders": [
            {
              "buyer_remark": null
            }
          ],
          "payment_channel_info": {
            "shipping_method": 28,
            "grouping_info": {
              "groups": [
                {
                  "display_info": {
                    "discount": 1
                  }
                }
              ]
            }
          }
        },
        "output": {
          "headers": {},
          "shipping_orders": [
            {}
          ],
          "timestamp": 100,
          "shoporders": [
            {
              "buyer_remark": null,
              "ext_ad_info_mappings": []
            }
          ],
          "payment_channel_info": {
            "shipping_method": 28,
            "grouping_info": {
              "groups": [
                {
                  "display_info": {
                    "discount": 1,
                    "enabled": true
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 57763285
  },
  {
    "context": [
      "\"I would like to list all the Ids and roles in a given json but where there  is only a single role, rather than an array of 1 it provides it as an object...\"",
      "\"This is the output I'd like (so I can pipe to a csv)\n1,Job1\n2,Job2\n3,Job3\"",
      "\"The following produces the CSV shown below. It would be easy to tweak the program to remove the double-quotation marks, etc.\"",
      "```\n.Person[]\n| .Roles.Role\n| if type == \"array\" then .[] else . end\n| [.[\"@Id\"], .Name]\n| @csv\n```",
      "\"Output\n\"1\",\"Job1\"\n\"2\",\"Job2\"\n\"3\",\"Job3\"\""
    ],
    "utterance": "List all Ids and roles, handling fields where a single role appears as an object and multiple roles as an array, with output formatted as lines of Id and role name pairs.",
    "expressions": [
      ".Person[] | .Roles.Role | if type == \"array\" then .[] else . end | [.[\"@Id\"], .Name] | @csv"
    ],
    "data": [
      {
        "input": {
          "Person": [
            {
              "Roles": {
                "Role": {
                  "@Id": "1",
                  "Name": "Job1"
                }
              }
            },
            {
              "Roles": {
                "Role": [
                  {
                    "@Id": "2",
                    "Name": "Job2"
                  },
                  {
                    "@Id": "3",
                    "Name": "Job3"
                  }
                ]
              }
            }
          ]
        },
        "output": "\"1\",\"Job1\"\n\"2\",\"Job2\"\n\"3\",\"Job3\"\n"
      }
    ],
    "identifier": 57748823
  },
  {
    "context": [
      "I only want to print",
      "server.xyz",
      "client1.abc",
      "client2.def",
      "and this IP",
      "192.168.56.5",
      "192.168.56.10",
      "192.168.56.15",
      "cat file | jq -r '.nodes | keys[]'",
      "If you want `ip` as well,",
      "cat file | jq -r '.nodes | to_entries[] | [.key, .value.\":ip\"] | @tsv'"
    ],
    "utterance": "Print all node names and their corresponding :ip values as tab-separated pairs.",
    "expressions": [
      ".nodes | to_entries[] | [.key, .value[\":ip\"]] | @tsv"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "server.xyz": {
              ":ip": "192.168.56.5",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap-master.sh"
            },
            "client1.abc": {
              ":ip": "192.168.56.10",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap-node.sh"
            },
            "client1.def": {
              ":ip": "192.168.56.15",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap-node.sh"
            }
          }
        },
        "output": "server.xyz\t192.168.56.5\nclient1.abc\t192.168.56.10\nclient1.def\t192.168.56.15"
      }
    ],
    "identifier": 57780262
  },
  {
    "context": [
      "I am trying to use jq in a Bash script to dynamically add entries to this file under the specific \"app\". In my example there's only one \"app\" defined (app1) but in a real world scenario there would be more.",
      "jq --arg title \"$title\" \\\n   --arg filename \"$filename\" \\\n   --arg version \"$version\" \\\n   --arg date \"$date\" \\\n   --arg id \"$id\" '\n  .applications[$title] += [{$id, $filename, $version, $date}]'"
    ],
    "utterance": "Add a new entry with specified id, filename, version, and date to the list under the key given by a variable in applications.",
    "expressions": [
      ".applications[$title] += [{\"id\": $id, \"filename\": $filename, \"version\": $version, \"date\": $date}]",
      ".applications[$title] += [{$id, $filename, $version, $date}]"
    ],
    "data": [
      {
        "input": {
          "applications": {
            "app1": [
              {
                "id": "1",
                "filename": "install_latest_app.pkg",
                "version": "1.2.3",
                "date": "20190903"
              },
              {
                "id": "2",
                "filename": "install_latest_app.pkg",
                "version": "1.2.4",
                "date": "20190904"
              },
              {
                "id": "3",
                "filename": "install_latest_app.pkg",
                "version": "1.2.5",
                "date": "20190905"
              }
            ]
          }
        },
        "output": {
          "applications": {
            "app1": [
              {
                "id": "1",
                "filename": "install_latest_app.pkg",
                "version": "1.2.3",
                "date": "20190903"
              },
              {
                "id": "2",
                "filename": "install_latest_app.pkg",
                "version": "1.2.4",
                "date": "20190904"
              },
              {
                "id": "3",
                "filename": "install_latest_app.pkg",
                "version": "1.2.5",
                "date": "20190905"
              },
              {
                "id": "6",
                "filename": "install_latest_app.pkg",
                "version": "1.2.6",
                "date": "20190906"
              }
            ]
          }
        }
      }
    ],
    "identifier": 57791502
  },
  {
    "context": [
      "I want to assign this variable as a value to volumesFrom key for first appId:builds.",
      "First you have to find the microservice object of interest:",
      ".microservices[] | select(.appId == \"builds\")",
      "Then with that, you could then update the `volumesFrom` value:",
      "(.microservices[] | select(.appId == \"builds\")).volumesFrom = ..."
    ],
    "utterance": "Set the volumesFrom property for the microservice object where appId equals \"builds\" to a new value.",
    "expressions": [
      "(.microservices[] | select(.appId == \"builds\")).volumesFrom = $volumes"
    ],
    "data": [
      {
        "input": {
          "build": {
            "tag": "189",
            "buildtime": "2019-07-19-08-05"
          },
          "microservices": [
            {
              "appId": "builds",
              "imageName": "build-server:8",
              "volumesFrom": []
            },
            {
              "appId": "studio",
              "imageName": "tci-webserver:4074",
              "volumesFrom": [
                "tci-download-studio:xxx"
              ]
            },
            {
              "appId": "site",
              "imageName": "site:22",
              "volumesFrom": null
            }
          ]
        },
        "output": {
          "build": {
            "tag": "189",
            "buildtime": "2019-07-19-08-05"
          },
          "microservices": [
            {
              "appId": "builds",
              "imageName": "build-server:8",
              "volumesFrom": "NEW_VALUE"
            },
            {
              "appId": "studio",
              "imageName": "tci-webserver:4074",
              "volumesFrom": [
                "tci-download-studio:xxx"
              ]
            },
            {
              "appId": "site",
              "imageName": "site:22",
              "volumesFrom": null
            }
          ]
        }
      }
    ],
    "identifier": 57798565
  },
  {
    "context": [
      "I want to replace:\r\n\r\n 1. `itemid` with the value of `321`\r\n 2. `quantity` with the value of `1`\r\n 3. `price` with the value of `100000`\r\n 4. `shopid` with the value of `789`",
      "jq --raw-output &#39;.orders[].items = 321&#39; file.json",
      "The complication here is that your stringified JSON isn&#39;t properly stringified.  One option would be to make it valid stringified JSON, perform the updates, and stringify it again.",
      ".orders |= (gsub(\"''\";\"\\\"\\\"\") | fromjson)\n| .orders[0].items[0] |= (.itemid = 321 | .quantity=1 | .price = 100000 | .shopid = 789)\n| .orders[0].shopid = 789\n| .orders |= tojson"
    ],
    "utterance": "Replace itemid with 321, quantity with 1, price with 100000, and shopid with 789 in all items inside orders, where orders is a stringified array.",
    "expressions": [
      ".orders |= (gsub(\"''\";\"\\\"\\\"\") | fromjson)\n| .orders[0].items[0] |= (.itemid = 321 | .quantity=1 | .price = 100000 | .shopid = 789)\n| .orders[0].shopid = 789\n| .orders |= tojson",
      ".orders|=(fromjson|map(((.items[].itemid|=321)|(.items[].quantity|=1)|(.items[].price|=10000)|(.items[].shopid|=789)))|tojson)"
    ],
    "data": [
      {
        "input": {
          "orders": "[{\"items\":[{\"itemid\":'',\"quantity\":'',\"price\":'',\"currency\":\"IDR\",\"shopid\":'',\"item_group_id\":null,\"add_on_deal_id\":null,\"checkout\":true}],\"shopid\":''}]",
          "check_voucher_payment_criteria": false,
          "need_wallet_active_info": false
        },
        "output": {
          "orders": "[{\"items\":[{\"itemid\":321,\"quantity\":1,\"price\":100000,\"currency\":\"IDR\",\"shopid\":789,\"item_group_id\":null,\"add_on_deal_id\":null,\"checkout\":true}],\"shopid\":789}]",
          "check_voucher_payment_criteria": false,
          "need_wallet_active_info": false
        }
      }
    ],
    "identifier": 57800829
  },
  {
    "context": [
      "I have a shell script file as below:\n\n    name=$(jq '.name' /xxx/deploy-tool.json)\n    nugetFileVersion=$(jq '.version' /xxx/deploy-tool.json)",
      "When you run `jq .version` you get the output `\"1.2.0-dev.29\"`. You need it without the quotes. To get that, add `-r` (`--raw-output`) to your jq call:\n\n    jq -r '.version' yourfile"
    ],
    "utterance": "Extract the value of the 'version' key without surrounding quotes for assignment in a shell variable to use as a command parameter.",
    "expressions": [
      "jq -r '.version' /xxx/deploy-tool.json"
    ],
    "data": [
      {
        "input": {
          "name": "xxx.DEPLOY",
          "version": "1.2.0-dev.29"
        },
        "output": "1.2.0-dev.29"
      }
    ],
    "identifier": 57820251
  },
  {
    "context": [
      "Because i am only interested in certain informations i tried to get the name and the text of the tweet with the following command:",
      "twurl /1.1/users/search.json?q=judo | jq \".[] | { name: .name, text: .text }\"",
      "and i get this:",
      "{ \"name\": \"#JudoWorlds \ud83e\udd55\", \"text\": null }",
      "Why is this and how can i fix it?",
      "If you need nested 'text' value from 'status' field you should use:",
      ".[] | { name: .name, text: .status.text }",
      "Or shorter version:",
      ".[] | { name, text: .status.text }"
    ],
    "utterance": "Extract each user's name and the text of their most recent tweet from the user search results.",
    "expressions": [
      ".[] | { name: .name, text: .status.text }",
      ".[] | { name, text: .status.text }"
    ],
    "data": [
      {
        "input": [
          {
            "id": 173752759,
            "name": "#JudoWorlds \ud83e\udd55",
            "status": {
              "text": "#JudoWorlds The Alternative Promo \n\n@NeilAdamsJudo https://....."
            }
          },
          {
            "id": 2,
            "name": "Example User",
            "status": null
          }
        ],
        "output": [
          {
            "name": "#JudoWorlds \ud83e\udd55",
            "text": "#JudoWorlds The Alternative Promo \n\n@NeilAdamsJudo https://....."
          },
          {
            "name": "Example User",
            "text": null
          }
        ]
      }
    ],
    "identifier": 57726159
  },
  {
    "context": [
      "\"I'm trying to output displayName from JSON which has both ... 'source': '0.0.0.0/0' and tcpOptions': 'destinationPortRange': 'min': 80\"",
      "\"The result should display only ... rule-1\"",
      "\"But it displays both rules (which is incorrect)\"",
      "\"Use any instead: .[] | select(any(.secrule[]; .source==\\\"0.0.0.0/0\\\" and .tcpOptions.destinationPortRange.min==80)).displayName\""
    ],
    "utterance": "Return the displayName for items where any secrule has source equal to 0.0.0.0/0 and tcpOptions.destinationPortRange.min equal to 80.",
    "expressions": [
      ".[] | select(any(.secrule[]; .source==\"0.0.0.0/0\" and .tcpOptions.destinationPortRange.min==80)).displayName"
    ],
    "data": [
      {
        "input": [
          {
            "displayName": "rule-1",
            "secrule": [
              {
                "source": "0.0.0.0/0",
                "tcpOptions": {
                  "destinationPortRange": {
                    "min": 80,
                    "max": 80
                  }
                }
              },
              {
                "source": "0.0.0.0/0",
                "tcpOptions": {
                  "destinationPortRange": {
                    "min": 443,
                    "max": 443
                  }
                }
              }
            ]
          },
          {
            "displayName": "rule-2",
            "secrule": [
              {
                "source": "0.0.0.0/0",
                "tcpOptions": {
                  "destinationPortRange": {
                    "min": 443,
                    "max": 443
                  }
                }
              },
              {
                "source": "20.0.0.0/0",
                "tcpOptions": {
                  "destinationPortRange": {
                    "min": 80,
                    "max": 80
                  }
                }
              }
            ]
          }
        ],
        "output": "rule-1"
      }
    ],
    "identifier": 57811213
  },
  {
    "context": [
      "what I need to get as a result of the modification is this\n[\n  [\n    [\"1\", \"grp1-001\"],\n    [\"2\", \"grp1-002\"],\n    [\"3\", \"grp1-003\"],\n    [\"4\", \"grp1-004\"],\n    [\"5\", \"grp1-005\"],\n    [\"6\", \"grp1-006\"],\n  ],\n  [\n    [\"1\", \"grp2-001\"],\n    [\"2\", \"grp2-002\"],\n    [\"3\", \"grp2-003\"],\n    [\"4\", \"grp2-004\"],\n    [\"5\", \"grp2-005\"],\n    [\"6\", \"grp2-006\"],\n  ],",
      "Which means I need to keep the external structure (outside array and an internal grouping) but convert the inner dict to an array and replace the \"ID\" key with a value (that will come from external source like `--argjson`).",
      "Assuming you're just taking the objects and transforming them to pairs of the index in the array and the `ID` value, you could do this:\n\n    map([to_entries[] | [.key + 1, .value.ID | tostring]])\n"
    ],
    "utterance": "For each inner array, convert each object to a two-element array with the 1-based index as a string and the 'ID' value.",
    "expressions": [
      "map([to_entries[] | [(.key + 1 | tostring), .value.ID | tostring]])"
    ],
    "data": [
      {
        "input": [
          [
            {
              "ID": "grp1-001"
            },
            {
              "ID": "grp1-002"
            },
            {
              "ID": "grp1-003"
            },
            {
              "ID": "grp1-004"
            },
            {
              "ID": "grp1-005"
            },
            {
              "ID": "grp1-006"
            }
          ],
          [
            {
              "ID": "grp2-001"
            },
            {
              "ID": "grp2-002"
            },
            {
              "ID": "grp2-003"
            },
            {
              "ID": "grp2-004"
            },
            {
              "ID": "grp2-005"
            },
            {
              "ID": "grp2-006"
            }
          ]
        ],
        "output": [
          [
            [
              "1",
              "grp1-001"
            ],
            [
              "2",
              "grp1-002"
            ],
            [
              "3",
              "grp1-003"
            ],
            [
              "4",
              "grp1-004"
            ],
            [
              "5",
              "grp1-005"
            ],
            [
              "6",
              "grp1-006"
            ]
          ],
          [
            [
              "1",
              "grp2-001"
            ],
            [
              "2",
              "grp2-002"
            ],
            [
              "3",
              "grp2-003"
            ],
            [
              "4",
              "grp2-004"
            ],
            [
              "5",
              "grp2-005"
            ],
            [
              "6",
              "grp2-006"
            ]
          ]
        ]
      }
    ],
    "identifier": 57813671
  },
  {
    "context": [
      "But now I have to added it under every object within the  `.paths.<any method that starts with />.<any value>.parameters`.",
      "I also have to be able to remove any object with `\"name\": \"Authorization\"` if it exists and replace it with the contents of auth.json.",
      "And here's a program that matches one interpretation of your second set of requirements regarding removal of \"Authorization\" entries:",
      ".paths |= with_entries(\n  if (.key|startswith(\"/\"))\n  then .value |= map_values(\n    if has(\"parameters\")\n    then\n    # first delete and then add\n      .parameters |= map(select( .name != \"Authorization\"))\n      | .parameters += $auth\n    else  . end )\n  else . end)\n"
    ],
    "utterance": "Replace any object with name equal to Authorization within all parameters arrays under all HTTP methods in all path objects, with the object from auth.json, and add it if missing.",
    "expressions": [
      ".paths |= with_entries(\n  if (.key|startswith(\"/\"))\n  then .value |= map_values(\n    if has(\"parameters\")\n    then\n      .parameters |= map(select( .name != \"Authorization\"))\n      | .parameters += $auth\n    else  . end )\n  else . end)"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "paths": {
            "/agents/delta": {
              "get": {
                "description": "lorem ipsum doram",
                "parameters": [
                  {
                    "name": "since",
                    "in": "query"
                  }
                ]
              },
              "put": {
                "description": "lorem ipsum doram",
                "parameters": [
                  {
                    "name": "since",
                    "in": "query"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "swagger": "2.0",
          "paths": {
            "/agents/delta": {
              "get": {
                "description": "lorem ipsum doram",
                "parameters": [
                  {
                    "name": "since",
                    "in": "query"
                  },
                  {
                    "name": "Authorization",
                    "description": "this is authorization",
                    "in": "header"
                  }
                ]
              },
              "put": {
                "description": "lorem ipsum doram",
                "parameters": [
                  {
                    "name": "since",
                    "in": "query"
                  },
                  {
                    "name": "Authorization",
                    "description": "this is authorization",
                    "in": "header"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 57819081
  },
  {
    "context": [
      "I would like to get all `topics` in this `json`:",
      "With this input:\r\n\r\n    {\r\n        \"exercises\": [\r\n            {\r\n                \"topics\": [\r\n                    \"foo\"\r\n                ]\r\n            },\r\n            {\r\n    \r\n                \"topics\": [\r\n                    \"bar\",\r\n                    \"baz\"\r\n                ]\r\n            },\r\n            {\r\n                \"topics\": [\r\n                    \"foo\",\r\n                    \"qux\"\r\n                ]\r\n            }\r\n        ]\r\n    }",
      "I would like this output:\r\n\r\n    foo\r\n    bar\r\n    baz\r\n    qux",
      "How about \r\n\r\n    < config.json jq '.. | objects | .topics[]?'",
      "If you want to remove duplicates, you could pipe the above into `sort -u`, or use jq to do the same, e.g. using `unique`.",
      "here is a `..`-free solution to the problem at hand: \r\n\r\n    < config.json jq '[.[][]?.topics[]?] | unique[]'"
    ],
    "utterance": "List all unique values from every topics array contained anywhere in the input, each on its own line.",
    "expressions": [
      ".. | objects | .topics[]?",
      "[.[][]?.topics[]?] | unique[]"
    ],
    "data": [
      {
        "input": {
          "exercises": [
            {
              "topics": [
                "foo"
              ]
            },
            {
              "topics": [
                "bar",
                "baz"
              ]
            },
            {
              "topics": [
                "foo",
                "qux"
              ]
            }
          ]
        },
        "output": [
          "foo",
          "bar",
          "baz",
          "qux"
        ]
      }
    ],
    "identifier": 57820379
  },
  {
    "context": [
      "What I actually want do do is something like this:\n\necho '{\"foo\": [\"baz\"]}' | jq --arg key \"foo\" --arg value \"bar\" '.($key) += [$value]'",
      "jq: error: try .[\"field\"] instead of .field for unusually named fields at <top-level>, line 1:",
      "You need to use square parens `[..]` instead of `(..)` as reported in the error message. Just do\n\n    jq --arg key \"foo\" --arg value \"bar\" '.[$key] += [$value]'"
    ],
    "utterance": "Append a given value to the array at a dynamically specified object key.",
    "expressions": [
      ".[$key] += [$value]"
    ],
    "data": [
      {
        "input": {
          "foo": [
            "baz"
          ]
        },
        "output": {
          "foo": [
            "baz",
            "bar"
          ]
        }
      }
    ],
    "identifier": 57850797
  },
  {
    "context": [
      "I am trying to extract the key value pairs `name` and `transcription.normalized` from a JSON object.",
      "I really want a single script that pulls those 2 fields in a format that I can easily dump to a CSV file.",
      "jq -r '.documents[].pages[].fields[] | [.name, .transcription.normalized] | @csv' file"
    ],
    "utterance": "Extract the name and transcription.normalized values from each field and output them as CSV rows.",
    "expressions": [
      ".documents[].pages[].fields[] | [.name, .transcription.normalized] | @csv"
    ],
    "data": [
      {
        "input": {
          "documents": [
            {
              "pages": [
                {
                  "fields": [
                    {
                      "id": 1,
                      "state": "complete",
                      "substate": null,
                      "exceptions": [],
                      "name": "Sender Account Number",
                      "output_name": null,
                      "field_definition_attributes": {
                        "required": false,
                        "data_type": "Account Number",
                        "multiline": false,
                        "consensus_required": false,
                        "supervision_override": null
                      },
                      "transcription": {
                        "raw": "1685-0441-1",
                        "normalized": "168504411",
                        "source": "machine_transcription",
                        "data_deleted": false,
                        "user_transcribed": null,
                        "row_index": null
                      },
                      "field_image_url": "/api/v4/image/be167a88-9d1d-43bc-82b2-3d96d8c06656?start_x=0.3110429607297866&start_y=0.1052441592299208&end_x=0.5696909842243418&end_y=0.16043316955780607"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "\"Sender Account Number\",\"168504411\""
        ]
      }
    ],
    "identifier": 57836648
  },
  {
    "context": [
      "I want to get a count of all the records that are \"source\": \"machine_transcription\",",
      "jq-only solution (which assumes the input JSON is an object with a key named \"fields\" as shown in the question)...",
      ".fields\n| length as $length\n| count( .[]|.transcription.source == \"machine_transcription\" ) as $count"
    ],
    "utterance": "Count how many entries in the 'fields' array have a 'transcription.source' equal to 'machine_transcription'.",
    "expressions": [
      ".fields | map(select(.transcription.source == \"machine_transcription\")) | length",
      "[.fields[] | select(.transcription.source == \"machine_transcription\")] | length"
    ],
    "data": [
      {
        "input": {
          "fields": [
            {
              "id": 1,
              "state": "complete",
              "substate": null,
              "exceptions": [],
              "name": "Sender Account Number",
              "output_name": null,
              "field_definition_attributes": {
                "required": false,
                "data_type": "Account Number",
                "multiline": false,
                "consensus_required": false,
                "supervision_override": null
              },
              "transcription": {
                "raw": "1685-0441-1",
                "normalized": "168504411",
                "source": "machine_transcription",
                "data_deleted": false,
                "user_transcribed": null,
                "row_index": null
              },
              "field_image_url": "/api/v4/image/be167a88-9d1d-43bc-82b2-3d96d8c06656?start_x=0.3110429607297866&start_y=0.1052441592299208&end_x=0.5696909842243418&end_y=0.16043316955780607"
            },
            {
              "id": 2,
              "transcription": {
                "source": "manual_transcription"
              }
            }
          ]
        },
        "output": 1
      }
    ],
    "identifier": 57847233
  },
  {
    "context": [
      "I would like to obtain a result like:\n[\"David\", \"Mary\", \"1\", \"2019-08-28\"]\n[\"David\", \"Mary\", \"2\", \"2019-08-29\"]\n[\"David\", \"Mary\", \"3\", \"2019-08-30\"]\n[\"Mar\", \"Alex\", \"1\", \"2019-07-28\"]\n[\"Mar\", \"Alex\", \"2\", \"2019-07-29\"]",
      "Is possible to do something similar to this?\njq -c '.[] | .actions[] | [.idMembers[], .id, .date] '",
      "Make an array out of each object under `actions` and add it to `idMembers`.\n```\n.[] | .idMembers + (.actions[] | map(.))\n```"
    ],
    "utterance": "For each entry, output an array that concatenates all idMembers, the id from an action, and the date from that action, and emit one array per action.",
    "expressions": [
      ".[] | .actions[] | [.idMembers[], .id, .date]",
      ".[] | .idMembers + [.actions[].id, .actions[].date]",
      ".[] | .actions[] | .idMembers + [.id, .date]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "aaa",
            "idMembers": [
              "David",
              "Mary"
            ],
            "actions": [
              {
                "id": "1",
                "date": "2019-08-28"
              },
              {
                "id": "2",
                "date": "2019-08-29"
              },
              {
                "id": "3",
                "date": "2019-08-30"
              }
            ]
          },
          {
            "id": "bbb",
            "idMembers": [
              "Mar",
              "Alex"
            ],
            "actions": [
              {
                "id": "1",
                "date": "2019-07-28"
              },
              {
                "id": "2",
                "date": "2019-07-29"
              }
            ]
          }
        ],
        "output": [
          [
            "David",
            "Mary",
            "1",
            "2019-08-28"
          ],
          [
            "David",
            "Mary",
            "2",
            "2019-08-29"
          ],
          [
            "David",
            "Mary",
            "3",
            "2019-08-30"
          ],
          [
            "Mar",
            "Alex",
            "1",
            "2019-07-28"
          ],
          [
            "Mar",
            "Alex",
            "2",
            "2019-07-29"
          ]
        ]
      }
    ],
    "identifier": 57840933
  },
  {
    "context": [
      "for each element in the first array, show the entire second array.",
      "The input json would look like:\r\n{\r\n  \"data\": [\r\n    {\r\n      \"countries\": [\"GB\", \"JE\"],\r\n      \"currencies\": [\"GBP\", \"EUR\"]\r\n    }\r\n  ]\r\n}",
      "The output json should look like:\r\n{\r\n  \"GB\": [\"GBP\", \"EUR\"],\r\n  \"JE\": [\"GBP\", \"EUR\"]\r\n}",
      ".data[] | [\r\n  { (.countries[]): .currencies }\r\n] | add",
      ".data[] | reduce { (.countries[]): .currencies } as $f ({}; . + $f)"
    ],
    "utterance": "For each country in the 'countries' array, produce an object where the key is the country and the value is the full 'currencies' array.",
    "expressions": [
      ".data[] | [ { (.countries[]): .currencies } ] | add",
      ".data[] | reduce { (.countries[]): .currencies } as $f ({}; . + $f)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "countries": [
                "GB",
                "JE"
              ],
              "currencies": [
                "GBP",
                "EUR"
              ]
            }
          ]
        },
        "output": {
          "GB": [
            "GBP",
            "EUR"
          ],
          "JE": [
            "GBP",
            "EUR"
          ]
        }
      }
    ],
    "identifier": 57858399
  },
  {
    "context": [
      "I want to return it, e.g. `foo-f-o-o`.",
      "1. Detect if an element `foo*` exists",
      "2. If *yes*, return that element's name, in the given case: `foo-f-o-o`",
      "3. If *not*, return `false`",
      "Is there a way to apply a regex like `/^foo.*/` in jq for the matching value?",
      "use `startswith`:",
      "first(.arr[] | select(startswith(\"foo\"))) // false"
    ],
    "utterance": "Return the first array element that starts with 'foo', or false if none exist.",
    "expressions": [
      "first(.arr[] | select(startswith(\"foo\"))) // false"
    ],
    "data": [
      {
        "input": {
          "arr": [
            "foo-f-o-o",
            "bar",
            "baz",
            "qux",
            "quux",
            "corge",
            "grault"
          ]
        },
        "output": "foo-f-o-o"
      },
      {
        "input": {
          "arr": [
            "bar",
            "baz",
            "qux",
            "quux"
          ]
        },
        "output": false
      }
    ],
    "identifier": 57893412
  },
  {
    "context": [
      "I want to delete the `inner` array from the `outer` array whose elements have specific values and and is of certain length. E.g., if I want to delete the `inner` array which contains values `\"val1\"` and `\"val2\"` the result should be:",
      "jq 'del( .outer[]|select(.inner[0].value == \"val1\"))'",
      "but I do not know how to check for the second condition, the length and on top of that the values may appear in any order.",
      "The `jq` filter you are looking for is:\n\n    del(.outer[] | select(.inner | map(.value) | sort == [\"val1\", \"val2\"]))",
      ".inner | map(.value) produces an array that contains the values associated to the value key from all objects contained by .inner.",
      "sort is needed because == does a one-to-one comparison of arrays. This way it matches the objects contained in .inner no matter their order.",
      "Here is a solution which should work on all versions of jq at least from version 1.3 onwards, and which is readily adapted to take into account additional criteria, as mentioned in the Q:",
      "def retain( match ): (map(.value) | sort) != match;",
      ".outer |= map( select( .inner | retain( [\"val1\", \"val2\"] ) ))"
    ],
    "utterance": "Delete all elements from the outer array whose inner array consists solely of the values \"val1\" and \"val2\" in any order.",
    "expressions": [
      "del(.outer[] | select(.inner | map(.value) | sort == [\"val1\", \"val2\"]))",
      "def retain( match ): (map(.value) | sort) != match;\n.outer |= map( select( .inner | retain( [\"val1\", \"val2\"] ) ))"
    ],
    "data": [
      {
        "input": {
          "outer": [
            {
              "inner": [
                {
                  "value": "val1"
                },
                {
                  "value": "val3"
                }
              ]
            },
            {
              "inner": [
                {
                  "value": "val2"
                },
                {
                  "value": "val1"
                }
              ]
            },
            {
              "inner": [
                {
                  "value": "val2"
                },
                {
                  "value": "val1"
                },
                {
                  "value": "val3"
                }
              ]
            }
          ]
        },
        "output": {
          "outer": [
            {
              "inner": [
                {
                  "value": "val1"
                },
                {
                  "value": "val3"
                }
              ]
            },
            {
              "inner": [
                {
                  "value": "val2"
                },
                {
                  "value": "val1"
                },
                {
                  "value": "val3"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 57854868
  },
  {
    "context": [
      "I have a JSON file that looks like this:\r\n    {\"stat.blah\":123,\"stat.taco\":495,\"stat.yum... etc.",
      "Notice how they decided to use a period in the identifying field associated with the value? This makes using jq very difficult because it associates the period as a separator to dig down into child values in the JSON.",
      "Is there a way in bash I can do some special escape to make it ignore the period?",
      "Use [generic object index] ... syntax, e.g:\r\n```\r\n.[\"stat.taco\"]\r\n```",
      "If your jq is sufficiently recent, then you can use the chained-dot notation by quoting the keys with special characters, e.g.\r\n    .\"stat.taco\""
    ],
    "utterance": "Extract the value for the key 'stat.taco' where the key contains a period.",
    "expressions": [
      ".[\"stat.taco\"]",
      ".\"stat.taco\""
    ],
    "data": [
      {
        "input": {
          "stat.blah": 123,
          "stat.taco": 495,
          "stat.yum": 77
        },
        "output": 495
      }
    ],
    "identifier": 57918504
  },
  {
    "context": [
      "I want to get `\"\\\"aaa\\\"\\nbbb\"` instead.",
      "How can I escape `\"aaa\"\\nbbb` with `jq` properly ?",
      "Use the --slurp/-s command-line option.",
      "$ printf \"\\\"aaa\\\"\\nbbb\"| jq -asR ",
      "\"\\\"aaa\\\"\\nbbb\""
    ],
    "utterance": "Escape the multi-line text \"aaa\"\\nbbb as a single quoted string with embedded newline and escaped quotes.",
    "expressions": [
      "jq -asR"
    ],
    "data": [
      {
        "input": "\"aaa\"\nbbb",
        "output": "\"\\\"aaa\\\"\\nbbb\""
      }
    ],
    "identifier": 57944483
  },
  {
    "context": [
      "So for example, if I input UUID a68f5249-828c-4265-9317-fc902b0d65b9 it should search the JSON file, find the matching UUID and then return the name Burrito.",
      "You can use select:",
      "jq -r  --arg query Burrito '.[] | select( .name == $query ) | .uuid ' tst.json"
    ],
    "utterance": "Given a list of objects, retrieve the name corresponding to a specific UUID value of a68f5249-828c-4265-9317-fc902b0d65b9.",
    "expressions": [
      "jq -r --arg uuid 'a68f5249-828c-4265-9317-fc902b0d65b9' '.[] | select(.uuid == $uuid) | .name'"
    ],
    "data": [
      {
        "input": [
          {
            "uuid": "832390ed-58ed-4338-bf97-eb42f123d9f3",
            "name": "Nacho"
          },
          {
            "uuid": "5b55ea5e-96f4-48d3-a258-75e152d8236a",
            "name": "Taco"
          },
          {
            "uuid": "a68f5249-828c-4265-9317-fc902b0d65b9",
            "name": "Burrito"
          }
        ],
        "output": "Burrito"
      }
    ],
    "identifier": 57935298
  },
  {
    "context": [
      "Suppose I have the following stdout output from an expression\n\n```\n Min 1st_Qu Median Mean 3rd_Qu Max NAs \n  1.000 1.000 2.000 1.875 2.250 3.000       1 \n```\n\nAnd the goal is: \n```\n{ \"Min\":1.0, \"1st_Qu\":1.0, ..., \"NAs\":1 }\n```\n",
      "jq -n -R '[inputs | [splits(\" +\") | select(length>0)]]\n  | transpose | map({(.[0]): .[1]|tonumber}) | add'",
      "def zip(headers):\n  . as $in\n  | reduce range(0; headers|length) as $i ({}; .[headers[$i]] = ($in[$i]) );\n\ndef s2a: [splits(\" +\") | select(length>0)];\n\n(input | s2a) as $h\n| inputs | s2a | map(tonumber) | zip($h)\n"
    ],
    "utterance": "Convert two lines (first with column labels, second with values) separated by spaces into a single object mapping each label to its corresponding number.",
    "expressions": [
      "[inputs | [splits(\" +\") | select(length>0)]] | transpose | map({(.[0]): .[1]|tonumber}) | add",
      "(input | [splits(\" +\") | select(length>0)]) as $h| inputs | [splits(\" +\") | select(length>0)] | map(tonumber) | reduce range(0; $h|length) as $i ({}; .[$h[$i]] = .[$i])"
    ],
    "data": [
      {
        "input": [
          " Min 1st_Qu Median Mean 3rd_Qu Max NAs ",
          "  1.000 1.000 2.000 1.875 2.250 3.000       1 "
        ],
        "output": {
          "Min": 1.0,
          "1st_Qu": 1.0,
          "Median": 2.0,
          "Mean": 1.875,
          "3rd_Qu": 2.25,
          "Max": 3.0,
          "NAs": 1
        }
      }
    ],
    "identifier": 57913058
  },
  {
    "context": [
      "So I want to match all data where the name have some text, ...",
      "Then this `jq` equation that doesn't work for me is this:",
      "RESULTS=$(echo \"$MYJSONDATA\" | jq --raw-output --arg TOSEARCH \"$TXTIWANT\" '.[] | select(.name|test(\"$TOSEARCH.\";\"i\")) .name')",
      "But I always got an error or all data, I think because $TOSEARCH is not expanded.",
      "Maybe there's a better way to search a string inside a value?",
      "So if you simply want to find the `.name` values that contain $TXTIWANT literally (ignoring case), ...",
      "jq --raw-output --arg TOSEARCH \"$TXTIWANT\" '\n  ($TOSEARCH|ascii_upcase) as $up\n  | .[]\n  | .name\n  | select(ascii_upcase|index($up))'\n"
    ],
    "utterance": "Find all objects where the 'name' field contains the value of a search string, case-insensitive, and output their 'name' values.",
    "expressions": [
      "jq --raw-output --arg TOSEARCH \"$TXTIWANT\" '($TOSEARCH|ascii_upcase) as $up | .[] | .name | select(ascii_upcase|index($up))'"
    ],
    "data": [
      {
        "input": [
          {
            "hash": "333333333333333333333333333",
            "name": "testtosearchcaseinsensitive",
            "magnet_uri": "magnet:somedata",
            "size": 1243989552,
            "progress": 1.0,
            "dlspeed": 0,
            "upspeed": 0,
            "priority": 0,
            "num_seeds": 0,
            "num_complete": 2,
            "num_leechs": 0,
            "num_incomplete": 32,
            "ratio": 0.0,
            "eta": "1.01:11:52",
            "state": "stalledUP",
            "seq_dl": false,
            "f_l_piece_prio": false,
            "category": "category",
            "tags": "",
            "super_seeding": false,
            "force_start": false,
            "save_path": "/data/path/",
            "added_on": 1567358333,
            "completion_on": 1567366287,
            "tracker": "somedata",
            "dl_limit": null,
            "up_limit": null,
            "downloaded": 1244073666,
            "uploaded": 0,
            "downloaded_session": 0,
            "uploaded_session": 0,
            "amount_left": 0,
            "completed": 1243989552,
            "ratio_limit": 1.0,
            "seen_complete": 1567408837,
            "last_activity": 1567366979,
            "time_active": "1.01:00:41",
            "auto_tmm": true,
            "total_size": 1243989552,
            "max_ratio": 1,
            "max_seeding_time": 2880,
            "seeding_time_limit": 2880
          },
          {
            "hash": "44444444444444",
            "name": "dontmatch",
            "magnet_uri": "magnet:somedata",
            "size": 2996838603,
            "progress": 1.0,
            "dlspeed": 0,
            "upspeed": 0,
            "priority": 0,
            "num_seeds": 0,
            "num_complete": 12,
            "num_leechs": 0,
            "num_incomplete": 0,
            "ratio": 0.06452786606740063,
            "eta": "100.00:00:00",
            "state": "stalledUP",
            "seq_dl": false,
            "f_l_piece_prio": false,
            "category": "category",
            "tags": "",
            "super_seeding": false,
            "force_start": false,
            "save_path": "/data/path/",
            "added_on": 1566420155,
            "completion_on": 1566424710,
            "tracker": "some data",
            "dl_limit": null,
            "up_limit": null,
            "downloaded": 0,
            "uploaded": 193379600,
            "downloaded_session": 0,
            "uploaded_session": 0,
            "amount_left": 0,
            "completed": 2996838603,
            "ratio_limit": -2.0,
            "seen_complete": 4294967295,
            "last_activity": 1566811636,
            "time_active": "10.23:07:42",
            "auto_tmm": true,
            "total_size": 2996838603,
            "max_ratio": -1,
            "max_seeding_time": -1,
            "seeding_time_limit": -2
          }
        ],
        "output": [
          "testtosearchcaseinsensitive"
        ]
      }
    ],
    "identifier": 57762380
  },
  {
    "context": [
      "I\u2019d like to perform vector math operations on a json array that stores numbers. In short how can we achieve one to one arithmetic operations by using jq?",
      "should produce\n[3,8]",
      "jq '. | transpose | map(reduce .[] as $item (1; . * $item))' <<< \"[[1,2],[3,4]]\"",
      "jq '[.[]] | transpose | map(reduce .[] as $item (1; . * $item))' <<< \"{\"a\":[1,2], \"b\":[3,4]}\"",
      "def pairwise: transpose | map(.[0] * .[1]);",
      "[[1,2],[3,4]] | pairwise",
      "{ \"a\":[1,2], \"b\":[3,4] } | [.a,.b] | pairwise",
      "{ \"a\":[1,2], \"b\":[3,4] } | [.[]] | pairwise",
      "def pairwise:\n   .[0] as $x | .[1] as $y \n   | reduce range(0; $x|length) as $i ([]; . + [$x[$i] * $y[$i]]);"
    ],
    "utterance": "Multiply two equal-length arrays element-wise to produce an array of the products.",
    "expressions": [
      ". | transpose | map(reduce .[] as $item (1; . * $item))",
      "[.[]] | transpose | map(reduce .[] as $item (1; . * $item))",
      "def pairwise: transpose | map(.[0] * .[1]); [[1,2],[3,4]] | pairwise",
      "def pairwise: transpose | map(.[0] * .[1]); {\"a\":[1,2], \"b\":[3,4]} | [.a,.b] | pairwise",
      "def pairwise: transpose | map(.[0] * .[1]); {\"a\":[1,2], \"b\":[3,4]} | [.[]] | pairwise",
      "def pairwise: .[0] as $x | .[1] as $y | reduce range(0; $x|length) as $i ([]; . + [$x[$i] * $y[$i]]); [[1,2],[3,4]] | pairwise"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2
          ],
          [
            3,
            4
          ]
        ],
        "output": [
          3,
          8
        ]
      },
      {
        "input": {
          "a": [
            1,
            2
          ],
          "b": [
            3,
            4
          ]
        },
        "output": [
          3,
          8
        ]
      }
    ],
    "identifier": 57918971
  },
  {
    "context": [
      "If your input file consists of several separate entities, to get the first one:\n```\njq -n 'input' file\n```",
      "or,\n```\njq -n 'first(inputs)' file\n```",
      "In the first two cases, you can write `jq -n input` to select the first entity, and in the case of an array of entities, `jq .[0]` will suffice."
    ],
    "utterance": "Select the first object from a file containing multiple JSON objects, each on its own line or as a sequence.",
    "expressions": [
      "jq -n 'input' file",
      "jq -n 'first(inputs)' file"
    ],
    "data": [
      {
        "input": [
          {
            "by": "pg",
            "id": 160705,
            "poll": 160704,
            "score": 335,
            "text": "Yes, ban them; I'm tired of seeing Valleywag stories on News.YC.",
            "time": 1207886576,
            "type": "pollopt"
          },
          {
            "by": "dpapathanasiou",
            "id": 16070,
            "kids": [
              16078
            ],
            "parent": 16069,
            "text": "Dividends don't mean that much: Microsoft in its dominant years (when they had 40%-plus margins and were raking in the cash) never paid a dividend (they did so only recently).",
            "time": 1177355133,
            "type": "comment"
          }
        ],
        "output": {
          "by": "pg",
          "id": 160705,
          "poll": 160704,
          "score": 335,
          "text": "Yes, ban them; I'm tired of seeing Valleywag stories on News.YC.",
          "time": 1207886576,
          "type": "pollopt"
        }
      }
    ],
    "identifier": 57945921
  },
  {
    "context": [
      "I'm trying to merge duplicate entries; for example... I'd like: ...to become: ...",
      "I'd like it to be as flexible and forgiving as possible; if arrays need to be created for multiple entries, if there are duplicates within the nested objects they are merged properly as well, etc.",
      "With any such definition, we may now proceed to an answer:",
      ".Statement |= merge(.Sid)"
    ],
    "utterance": "Merge objects in the Statement array that have the same Sid, combining array values without duplicates and merging nested objects recursively.",
    "expressions": [
      "def merge(a; b):\n  def merge_objects($x;$y):\n    (($x|keys_unsorted) + ($y|keys_unsorted) | unique) as $keys\n    | reduce $keys[] as $k (null; . + {($k): merge($x[$k]; $y[$k])});\n  if a == b then a\n  elif a == null then b\n  elif b == null then a\n  elif (a|type) | (. == (b|type)) and (. == \"object\") \n    then merge_objects(a;b)\n  elif (a|type == \"array\") and (b|type) == \"array\"\n    then (a + b) | unique\n  elif (a|type == \"array\") then a + [b] | unique\n  elif (b|type == \"array\") then [a] + b | unique\n  else [a, b] | unique\n  end ;\n\ndef merge(f):\n  def merge: reduce .[] as $object (null; merge(.; $object));\n  group_by(f)\n  | map(merge) ;\n\n.Statement |= merge(.Sid)"
    ],
    "data": [
      {
        "input": {
          "Version": "2008-10-17",
          "Id": "SomeBucketPolicy",
          "Statement": [
            {
              "Sid": "Stmt1234567890987",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::726481726312:root"
              },
              "Action": [
                "s3:GetBucketAcl",
                "s3:GetBucketPolicy"
              ],
              "Resource": "arn:aws:s3:::it-lab-test"
            },
            {
              "Sid": "Stmt3423424566754",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::726481726312:root"
              },
              "Action": "s3:PutObject",
              "Resource": "arn:aws:s3:::it-lab-test/*"
            },
            {
              "Sid": "SomeAPIUser",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::536415397313:user/SomeAPIUser"
              },
              "Action": [
                "s3:GetObject",
                "s3:GetObjectVersion",
                "s3:GetObjectRetention"
              ],
              "Resource": "arn:aws:s3:::it-lab-test/*"
            },
            {
              "Sid": "SomeAPIUser",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::536415397313:user/SomeAPIUser"
              },
              "Action": [
                "s3:GetObject",
                "s3:GetObjectVersion",
                "s3:GetObjectTagging"
              ],
              "Resource": [
                "arn:aws:s3:::it-lab-test/*",
                "arn:aws:s3:::another-test-bucket/*",
                "arn:aws:s3:::someother-test-bucket/*"
              ]
            }
          ]
        },
        "output": {
          "Version": "2008-10-17",
          "Id": "SomeBucketPolicy",
          "Statement": [
            {
              "Sid": "Stmt1234567890987",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::726481726312:root"
              },
              "Action": [
                "s3:GetBucketAcl",
                "s3:GetBucketPolicy"
              ],
              "Resource": "arn:aws:s3:::it-lab-test"
            },
            {
              "Sid": "Stmt3423424566754",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::726481726312:root"
              },
              "Action": "s3:PutObject",
              "Resource": "arn:aws:s3:::it-lab-test/*"
            },
            {
              "Sid": "SomeAPIUser",
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::536415397313:user/SomeAPIUser"
              },
              "Action": [
                "s3:GetObject",
                "s3:GetObjectVersion",
                "s3:GetObjectRetention",
                "s3:GetObjectTagging"
              ],
              "Resource": [
                "arn:aws:s3:::it-lab-test/*",
                "arn:aws:s3:::another-test-bucket/*",
                "arn:aws:s3:::someother-test-bucket/*"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 57872562
  }
]