[
  {
    "identifier": 58059443
  },
  {
    "context": [
      "is there a way to do blurry search key recursively and case insensitive by jq?",
      "def blurry($f):\n  ($f | ascii_upcase) as $ucf\n  | to_entries[]\n  | select((.key|ascii_upcase) == $ucf)\n  | .value;",
      ".. | blurry(\"NetworkSettings\")? | objects",
      "def veryBlurry($f):\n  ($f | ascii_upcase) as $ucf\n  | to_entries[]\n  | select(.key | ascii_upcase | index($ucf))\n  | .value;"
    ],
    "utterance": "Recursively search for all object keys containing the substring 'network' in a case-insensitive manner.",
    "expressions": [
      "def veryBlurry($f):\n  ($f | ascii_upcase) as $ucf\n  | to_entries[]\n  | select(.key | ascii_upcase | index($ucf))\n  | .value;\n.. | veryBlurry(\"network\")? | objects"
    ],
    "identifier": 58063955
  },
  {
    "context": [
      "I want to replace the version of $APP_NAME to the new version $NEW_VERSION. Given APP_NAME=my-app-2 and NEW_VERSION=v1.0.0",
      "jq --arg appName my-app-2 --arg newVersion v1.0.0 '.[$appName]=$newVersion'"
    ],
    "utterance": "Update the value of the key matching my-app-2 to v1.0.0 where the key name is given by a variable.",
    "expressions": [
      "jq --arg appName my-app-2 --arg newVersion v1.0.0 '.[$appName]=$newVersion'"
    ],
    "data": [
      {
        "input": {
          "my-app-1": "v1.0.0",
          "my-app-2": "v0.9.1",
          "my-app-3": "v2.1.7"
        },
        "output": {
          "my-app-1": "v1.0.0",
          "my-app-2": "v1.0.0",
          "my-app-3": "v2.1.7"
        }
      }
    ],
    "identifier": 57988655
  },
  {
    "context": [
      "I need help in correcting jq test cases syntax. Following is output file & trying to test ID list with command below. Gives error index to string type.",
      "[[ $(echo $output| jq -r '.output.value[] | select(.identity).id_list') == *\"id2\"*  ]]",
      "output = {\n   \"resource_output\": {\n \n\t\"value\": {\n\t\t   \"identity\": [\n\t\t\t{\n\t\t\t  \"id_list\": [\n\t\t\t\t\"/subscriptions/---/id1\",\n\t\t\t\t\"/subscriptions/---/id2\",\n\t\t\t\t\"/subscriptions/--/id3\"\n\t\t\t ],\n\t\t\t \"principal_id\": \"\",\n\t\t\t \"tenant_id\": \"\",\n\t\t\t \"type\": \"managed\"\n\t\t   }\n\t\t ]\n\t}\n\t}",
      "jq -r '.resource_output.identity[].id_list[] | select(test(\"id2\"))'",
      "Output:\n\n    /subscriptions/---/id2"
    ],
    "utterance": "Find all strings in the id_list arrays within resource_output.identity where the string contains 'id2'.",
    "expressions": [
      ".resource_output.identity[].id_list[] | select(test(\"id2\"))"
    ],
    "data": [
      {
        "input": {
          "resource_output": {
            "value": {
              "identity": [
                {
                  "id_list": [
                    "/subscriptions/---/id1",
                    "/subscriptions/---/id2",
                    "/subscriptions/--/id3"
                  ],
                  "principal_id": "",
                  "tenant_id": "",
                  "type": "managed"
                }
              ]
            }
          }
        },
        "output": "/subscriptions/---/id2"
      }
    ],
    "identifier": 58038240
  },
  {
    "context": [
      "The output I'm looking for is:\n\nSmith, Bill\nSmith, Alice\nSmith, Mary\nBrown, Gil\nBrown, Bob\nBrown, Mary\nSanchez, Gil\nSanchez, Jose\nSanchez, Marlena",
      "I created a jq query that looks like this:\n\njq -r '.people | \"\\(.names[].last_name), \\(.names[].first_names[].name)\"' nameFile.json | sort",
      "But the output I get is:\n\nBrown, Alice\nBrown, Bill\nBrown, Bob\nBrown, Gil\nBrown, Gil\nBrown, Jose\nBrown, Marlena\nBrown, Mary\nBrown, Mary\nSanchez, Alice\nSanchez, Bill\nSanchez, Bob\nSanchez, Gil\nSanchez, Gil\nSanchez, Jose\nSanchez, Marlena\nSanchez, Mary\nSanchez, Mary\nSmith, Alice\nSmith, Bill\nSmith, Bob\nSmith, Gil\nSmith, Gil\nSmith, Jose\nSmith, Marlena\nSmith, Mary\nSmith, Mary",
      "To get the results you want, you have to iterate over `.names` outside the loop that iterates over `.first_names`:\n\n.people\n| .names[]\n| \"\\(.last_name), \\(.first_names[].name)\""
    ],
    "utterance": "For each person, output all combinations of last_name and each first_names[].name, formatted as 'LastName, FirstName'",
    "expressions": [
      ".people.names[] | \"\\(.last_name), \\(.first_names[].name)\""
    ],
    "data": [
      {
        "input": {
          "people": {
            "names": [
              {
                "last_name": "Smith",
                "first_names": [
                  {
                    "name": "Bill"
                  },
                  {
                    "name": "Alice"
                  },
                  {
                    "name": "Mary"
                  }
                ]
              },
              {
                "last_name": "Brown",
                "first_names": [
                  {
                    "name": "Gil"
                  },
                  {
                    "name": "Bob"
                  },
                  {
                    "name": "Mary"
                  }
                ]
              },
              {
                "last_name": "Sanchez",
                "first_names": [
                  {
                    "name": "Gil"
                  },
                  {
                    "name": "Jose"
                  },
                  {
                    "name": "Marlena"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "Smith, Bill",
          "Smith, Alice",
          "Smith, Mary",
          "Brown, Gil",
          "Brown, Bob",
          "Brown, Mary",
          "Sanchez, Gil",
          "Sanchez, Jose",
          "Sanchez, Marlena"
        ]
      }
    ],
    "identifier": 58085500
  },
  {
    "context": [
      "I want to extract data like this:\n\n### sheet1\njq '(something command)' sample.json\n```\n{\n    \"web\": {\n        \"hosts\": [\n            \"172.17.0.3\",\n            \"172.17.0.4\"\n        ]\n    },\n    \"db\": {\n        \"hosts\": [\n            \"172.17.0.5\"\n        ]\n    }\n}\n```",
      "Here's a short, straight-forward and efficient solution -- efficient in part because it avoids `group_by` by courtesy of the following generic helper function:\n\ndef add_by(f;g): reduce .[] as $x ({}; .[$x|f] += [$x|g]);\n\n.sheet1\n| add_by(.role; .ip1) \n| map_values( {hosts: .} )",
      "This produces the required output:\n{\n \"web\": {\n    \"hosts\": [\n      \"172.17.0.3\",\n      \"172.17.0.4\"\n    ]\n  },\n  \"db\": {\n    \"hosts\": [\n      \"172.17.0.5\"\n    ]\n  }\n}\n"
    ],
    "utterance": "Group the rows in 'sheet1' by the value of 'role' and output an object where each role has a 'hosts' array containing the values of 'ip1'.",
    "expressions": [
      "def add_by(f;g): reduce .[] as $x ({}; .[$x|f] += [$x|g]);\n.sheet1 | add_by(.role; .ip1) | map_values({hosts: .})"
    ],
    "data": [
      {
        "input": {
          "sheet1": [
            {
              "hostname": "sv001",
              "role": "web",
              "ip1": "172.17.0.3"
            },
            {
              "hostname": "sv002",
              "role": "web",
              "ip1": "172.17.0.4"
            },
            {
              "hostname": "sv003",
              "role": "db",
              "ip1": "172.17.0.5",
              "ip2": "172.18.0.5"
            }
          ],
          "sheet2": [
            {
              "hostname": "sv004",
              "role": "web",
              "ip1": "172.17.0.6"
            },
            {
              "hostname": "sv005",
              "role": "db",
              "ip1": "172.17.0.7"
            },
            {
              "hostname": "vsv006",
              "role": "db",
              "ip1": "172.17.0.8"
            }
          ],
          "sheet3": []
        },
        "output": {
          "web": {
            "hosts": [
              "172.17.0.3",
              "172.17.0.4"
            ]
          },
          "db": {
            "hosts": [
              "172.17.0.5"
            ]
          }
        }
      }
    ],
    "identifier": 58041795
  },
  {
    "context": [
      "I just want to get the output as below format and not sure how to get it.",
      "**Expected Output:**",
      "{",
      "\"JIRA-1\":\"KINDLEAMZ-67578\",",
      "\"JIRA-2\":\"KINDLEAMZ-68661\",",
      "\"JIRA-3\":\"KINDLEAMZ-68167\"",
      "}",
      "How can I get key value from each of the array and display like above? and JIRA-n will be increase based on the result.",
      "Given an array, you can use `to_entries/1` to map the array an array of index and values. You could then map out to the keys and values you want on the object either using `reduce` or `with_entries/1`.",
      "reduce (.issues | to_entries[]) as {$key,$value} ({};\n    .[\"JIRA-\\($key + 1)\"] = $value.key\n)",
      ".issues | with_entries({key: \"JIRA-\\(.key + 1)\", value: .value.key})",
      "reduce (.issues | to_entries[]) as $e ({};\n    .[\"JIRA-\\($e.key + 1)\"] = $e.value.key\n)"
    ],
    "utterance": "Create an object mapping keys named JIRA-1, JIRA-2, ... to the key values from each element of the issues array, incrementing the index for each entry.",
    "expressions": [
      "reduce (.issues | to_entries[]) as {$key,$value} ({};\n    .[\"JIRA-\\($key + 1)\"] = $value.key\n)",
      ".issues | with_entries({key: \"JIRA-\\(.key + 1)\", value: .value.key})",
      "reduce (.issues | to_entries[]) as $e ({};\n    .[\"JIRA-\\($e.key + 1)\"] = $e.value.key\n)"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "1999875",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/1999875",
              "key": "KINDLEAMZ-67578"
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "2019428",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/2019428",
              "key": "KINDLEAMZ-68661"
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "2010958",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/2010958",
              "key": "KINDLEAMZ-68167"
            }
          ]
        },
        "output": {
          "JIRA-1": "KINDLEAMZ-67578",
          "JIRA-2": "KINDLEAMZ-68661",
          "JIRA-3": "KINDLEAMZ-68167"
        }
      }
    ],
    "identifier": 58051286
  },
  {
    "context": [
      "I want to use jq to summarize elements with the same description field value.",
      "So that each unique field value of description gets it's own element with the amount field summarized.",
      "If you want `description` and `amount` in the output, you could tweak the above as follows:",
      ".frames |= \n  (sum_by(.description; .amount) \n   | to_entries \n   | map( {description: .key, amount: .value} ))"
    ],
    "utterance": "Summarize elements by description, producing one element per unique description with the total sum of their amount fields.",
    "expressions": [
      ".frames |= (sum_by(.description; .amount) | to_entries | map({description: .key, amount: .value}))"
    ],
    "data": [
      {
        "input": {
          "frames": [
            {
              "description": "Stuff",
              "amount": 8
            },
            {
              "description": "Stuff",
              "amount": 4
            },
            {
              "description": "other_stuff",
              "amount": 2
            },
            {
              "description": "more_stuff",
              "amount": 20
            }
          ]
        },
        "output": {
          "frames": [
            {
              "description": "Stuff",
              "amount": 12
            },
            {
              "description": "other_stuff",
              "amount": 2
            },
            {
              "description": "more_stuff",
              "amount": 20
            }
          ]
        }
      }
    ],
    "identifier": 58095487
  },
  {
    "context": [
      "Each entry (the first level of {}) has many fields/subfields. I don't want to specify so many field names. And there is no guarantee that the fields/subfields are the same across all the entries. Therefore, I'd like the result column contains a union of all the fileds/subfields. The columns names should be ordered as close as possible as the original json file. (E.g., those subfields in the same field should be listed together in the tsv).",
      "Here is a jq solution which will work for any array of JSON objects, without restriction...",
      "def json2headers:\n  def isscalar: type | . != \"array\" and . != \"object\";\n  def isflat: all(.[]; isscalar);\n  paths as $p\n  | getpath($p)\n  | if type == \"array\" and isflat then $p\n     elif isscalar and (($p[-1]|type) == \"string\") then $p\n     else empty end ;\n\ndef json2array($header):\n   [$header[] as $p | (try getpath($p) catch null)] ;\n\ndef json2tsv:\n  ( [.[] | json2headers] | unique) as $h\n  | ([$h[]|join(\"_\") ],\n     (.[]\n      | json2array($h)\n      | map( if type == \"array\" then map(tostring)|join(\"|\") else tostring end)))\n  | @tsv ;",
      "jq -r -L. 'include \"json2tsv\"; json2tsv' input.json"
    ],
    "utterance": "Flatten objects with varying and nested fields into a TSV where columns represent the union of all scalar and flat array paths, ordered to keep related subfields together.",
    "expressions": [
      "def json2headers:\n  def isscalar: type | . != \"array\" and . != \"object\";\n  def isflat: all(.[]; isscalar);\n  paths as $p\n  | getpath($p)\n  | if type == \"array\" and isflat then $p\n     elif isscalar and (($p[-1]|type) == \"string\") then $p\n     else empty end ;\n\ndef json2array($header):\n   [$header[] as $p | (try getpath($p) catch null)] ;\n\ndef json2tsv:\n  ( [.[] | json2headers] | unique) as $h\n  | ([$h[]|join(\"_\") ],\n     (.[]\n      | json2array($h)\n      | map( if type == \"array\" then map(tostring)|join(\"|\") else tostring end)))\n  | @tsv ;",
      "jq -r -L. 'include \"json2tsv\"; json2tsv' input.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": [
              1,
              2
            ],
            "b": {
              "c": 3,
              "d": [
                {
                  "e": 4
                },
                {
                  "e": 5,
                  "f": 6
                }
              ]
            }
          },
          {
            "b": {
              "d": [
                {
                  "e": 4
                },
                {
                  "f": 6,
                  "e": 5
                }
              ],
              "c": 3
            },
            "a": [
              101,
              102
            ]
          }
        ],
        "output": "a\tb_c\tb_d_0_e\tb_d_1_e\tb_d_1_f\n1|2\t3\t4\t5\t6\n101|102\t3\t4\tnull\t6"
      }
    ],
    "identifier": 57978050
  },
  {
    "context": [
      "Now I want to create JSON array with multiple source and destination",
      "How to generate JSON Array with multiple sources and destinations (JSON string) in Bash?",
      "source_dest_pairs=(\n  sourcebucket1:destinationbucket1\n  sourcebucket2:destinationbucket2\n  sourcebucket3:destinationbucket3\n)",
      "jq -Rn '\n  def instructionsForPair($source; $dest): {\n    \"Name\":\"S3DistCp step\",\n    \"HadoopJarStep\": {\n      \"Args\":[\n        \"s3-dist-cp\",\n        \"--s3Endpoint=s3.amazonaws.com\",\n        \"--src=\\($source)\",\n        \"--dest=\\($dest)\"\n      ],\n      \"Jar\":\"command-runner.jar\"\n    }\n  };\n\n  [ inputs \n  | capture(\"^(?<source>[^:]+):(?<dest>.*)$\"; \"\")\n  | select(.)\n  | instructionsForPair(.source; .dest) ]\n' < <(printf '%s\\n' \"${source_dest_pairs[@]}\")"
    ],
    "utterance": "Create an array where each element describes an S3DistCp step for each source:destination pair, with sourcebucket1/destinationbucket1, sourcebucket2/destinationbucket2, and sourcebucket3/destinationbucket3.",
    "expressions": [
      "jq -Rn '\n  def instructionsForPair($source; $dest): {\n    \"Name\":\"S3DistCp step\",\n    \"HadoopJarStep\": {\n      \"Args\":[\n        \"s3-dist-cp\",\n        \"--s3Endpoint=s3.amazonaws.com\",\n        \"--src=\\($source)\",\n        \"--dest=\\($dest)\"\n      ],\n      \"Jar\":\"command-runner.jar\"\n    }\n  };\n\n  [ inputs \n  | capture(\"^(?<source>[^:]+):(?<dest>.*)$\"; \"\")\n  | select(.)\n  | instructionsForPair(.source; .dest) ]\n'"
    ],
    "data": [
      {
        "input": [
          "sourcebucket1:destinationbucket1",
          "sourcebucket2:destinationbucket2",
          "sourcebucket3:destinationbucket3"
        ],
        "output": [
          {
            "Name": "S3DistCp step",
            "HadoopJarStep": {
              "Args": [
                "s3-dist-cp",
                "--s3Endpoint=s3.amazonaws.com",
                "--src=sourcebucket1",
                "--dest=destinationbucket1"
              ],
              "Jar": "command-runner.jar"
            }
          },
          {
            "Name": "S3DistCp step",
            "HadoopJarStep": {
              "Args": [
                "s3-dist-cp",
                "--s3Endpoint=s3.amazonaws.com",
                "--src=sourcebucket2",
                "--dest=destinationbucket2"
              ],
              "Jar": "command-runner.jar"
            }
          },
          {
            "Name": "S3DistCp step",
            "HadoopJarStep": {
              "Args": [
                "s3-dist-cp",
                "--s3Endpoint=s3.amazonaws.com",
                "--src=sourcebucket3",
                "--dest=destinationbucket3"
              ],
              "Jar": "command-runner.jar"
            }
          }
        ]
      }
    ],
    "identifier": 58065369
  },
  {
    "context": [
      "I just want to get the output as below format and not sure how to get it.",
      "**Expected Output:**\n\n    {\n    \"JIRA-1\":\"KINDLEAMZ-67578\",\n    \n    \"JIRA-2\":\"KINDLEAMZ-68661\",\n    \n    \"JIRA-3\":\"KINDLEAMZ-68167\"\n    }",
      "How can I get key value from each of the array and display like above? and JIRA-n will be increase based on the result.",
      "After fixing the posted JSON, the following gives the desired result:\n```\n.issues\n| with_entries( .key |= \"JIRA-\\(. + 1)\" | .value |= .key )\n```"
    ],
    "utterance": "Generate an object mapping JIRA-1, JIRA-2, ... to the key field of each issue, with numbering based on position in the issues array.",
    "expressions": [
      ".issues | with_entries(.key |= \"JIRA-\\(.+1)\" | .value |= .key)"
    ],
    "data": [
      {
        "input": {
          "expand": "schema,names",
          "startAt": 0,
          "maxResults": 50,
          "total": 4,
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "1999875",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/1999875",
              "key": "KINDLEAMZ-67578"
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "2019428",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/2019428",
              "key": "KINDLEAMZ-68661"
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "2010958",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/2010958",
              "key": "KINDLEAMZ-68167"
            }
          ]
        },
        "output": {
          "JIRA-1": "KINDLEAMZ-67578",
          "JIRA-2": "KINDLEAMZ-68661",
          "JIRA-3": "KINDLEAMZ-68167"
        }
      }
    ],
    "identifier": 58093380
  },
  {
    "context": [
      "I just want to add timestamp into the above payload and send it as request for some service.",
      "AS per I know the below command will help us to get current stamp on linux:",
      "JQ has builtin functions for playing with dates, such as:",
      "```\r\n. + {date: (now | strflocaltime(\"%r\"))}\r\n```",
      "One of many possibilities:\r\n\r\n    $ jq --arg date $(date +\"%r\") '. + {date: $date}'"
    ],
    "utterance": "Add the current date and time as a new field 'date' to the data, using the hour-minute-second AM/PM format.",
    "expressions": [
      ". + {date: (now | strflocaltime(\"%r\"))}",
      ". + {date: $date}"
    ],
    "data": [
      {
        "input": {
          "username": "achu",
          "password": "test1234"
        },
        "output": {
          "username": "achu",
          "password": "test1234",
          "date": "1:20:30 AM PST"
        }
      }
    ],
    "identifier": 58106341
  },
  {
    "context": [
      "Input data: /tmp/h1.tabs, tab delimited:",
      "Desired Output:",
      "{\r\n    \"A1\": {\r\n        \"Comment\": \"Disabled\",\r\n        \"Flavor\": \"Controller\",\r\n        \"State\": \"DiskOne\"\r\n    },\r\n    \"B2\": {\r\n        \"Alarm\": \"Alarm Not present\",\r\n        \"Comment\": \"Not Applicable\",\r\n        \"ConnectorCount\": \"12\",\r\n        \"Flavor\": \"Controller\",\r\n        \"State\": \"Not Applicable\"\r\n    },\r\n    \"C3\": {\r\n        \"Comment\": \"Not Applicable\",\r\n        \"ConnectorCount\": \"0\",\r\n        \"Flavor\": \"Controller\",\r\n        \"Media\": \"Not Applicable\",\r\n        \"State\": \"Alarm Not present\"\r\n    }\r\n}",
      "`reduce` is your friend..\n```\nreduce (inputs / \"\\t\") as [$k, $v] ([];\n    if $k == \"INPUT\" then\n        .[0] = $v\n    else\n        .[1][.[0]] += {($k): $v}\n    end\n) | .[1]\n```",
      "Note that you need to specify -n and -R options on the command line for this to work"
    ],
    "utterance": "Group tab-delimited key-value input by each value of 'INPUT', associating subsequent key-value pairs until the next 'INPUT', producing an object keyed by each 'INPUT' value with corresponding sub-objects of the fields.",
    "expressions": [
      "reduce (inputs / \"\\t\") as [$k, $v] ([];\n    if $k == \"INPUT\" then\n        .[0] = $v\n    else\n        .[1][.[0]] += {($k): $v}\n    end\n) | .[1]"
    ],
    "data": [
      {
        "input": [
          "INPUT\tA1",
          "Flavor\tController",
          "Comment\tDisabled",
          "State\tDiskOne",
          "INPUT\tB2",
          "Flavor\tController",
          "Comment\tNot Applicable",
          "State\tNot Applicable",
          "ConnectorCount\t12",
          "Alarm\tAlarm Not present",
          "INPUT\tC3",
          "Flavor\tController",
          "Comment\tNot Applicable",
          "Media\tNot Applicable",
          "ConnectorCount\t0",
          "State\tAlarm Not present"
        ],
        "output": {
          "A1": {
            "Flavor": "Controller",
            "Comment": "Disabled",
            "State": "DiskOne"
          },
          "B2": {
            "Flavor": "Controller",
            "Comment": "Not Applicable",
            "State": "Not Applicable",
            "ConnectorCount": "12",
            "Alarm": "Alarm Not present"
          },
          "C3": {
            "Flavor": "Controller",
            "Comment": "Not Applicable",
            "Media": "Not Applicable",
            "ConnectorCount": "0",
            "State": "Alarm Not present"
          }
        }
      }
    ],
    "identifier": 58100728
  },
  {
    "context": [
      "Input (Response.Json):",
      "{ \"expand\": \"schema,names\", \"startAt\": 0, \"maxResults\": 50, \"total\": 4, \"issues\": [{ \"expand\": \"operations,versionedRepresentations,editmeta,changelog,renderedFields\", \"id\": \"1999875\", \"self\": \"https://amazon.kindle.com/jira/rest/api/2/issue/1999875\", \"key\": \"KINDLEAMZ-67578\" }, { \"expand\": \"operations,versionedRepresentations,editmeta,changelog,renderedFields\", \"id\": \"2019428\", \"self\": \"https://amazon.kindle.com/jira/rest/api/2/issue/2019428\", \"key\": \"KINDLEAMZ-68661\" }, { \"expand\": \"operations,versionedRepresentations,editmeta,changelog,renderedFields\", \"id\": \"2010958\", \"self\": \"https://amazon.kindle.com/jira/rest/api/2/issue/2010958\", \"key\": \"KINDLEAMZ-68167\" }] }",
      "**Expected Output:**",
      "{\n\"JIRA-1\":\"KINDLEAMZ-67578\",\n\n\"JIRA-2\":\"KINDLEAMZ-68661\",\n\n\"JIRA-3\":\"KINDLEAMZ-68167\"\n}",
      "I&#39;ve verified that the following works with your JSON sample;",
      ".issues | reduce to_entries[] as $kv ({}; .[\"JIRA-\\($kv.key)\"] = $kv.value.key )"
    ],
    "utterance": "Create an object with keys 'JIRA-1', 'JIRA-2', 'JIRA-3', each mapping to the corresponding issue's key value from the input, numbered in order.",
    "expressions": [
      ".issues | reduce to_entries[] as $kv ({}; .[\"JIRA-\\($kv.key+1)\"] = $kv.value.key )"
    ],
    "data": [
      {
        "input": {
          "expand": "schema,names",
          "startAt": 0,
          "maxResults": 50,
          "total": 4,
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "1999875",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/1999875",
              "key": "KINDLEAMZ-67578"
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "2019428",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/2019428",
              "key": "KINDLEAMZ-68661"
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "2010958",
              "self": "https://amazon.kindle.com/jira/rest/api/2/issue/2010958",
              "key": "KINDLEAMZ-68167"
            }
          ]
        },
        "output": {
          "JIRA-1": "KINDLEAMZ-67578",
          "JIRA-2": "KINDLEAMZ-68661",
          "JIRA-3": "KINDLEAMZ-68167"
        }
      }
    ],
    "identifier": 58103344
  },
  {
    "context": [
      "I want to have a resulting jq that outputs 'status' == \"SUCCESS\" if `.journey_execution_metrics.journey_execution_metrics.failed == 0`, and 'status' == \"FAILED\" if not.",
      "but that returns a boolean value of my conditional for success, not \"FAILED\"",
      "Here's a solution, formatted for readability:",
      "if .journey_execution_metrics.failed == 0\nthen \"SUCCESS\"\nelse \"FAILED\"\nend"
    ],
    "utterance": "Set a new top-level field 'status' to \"SUCCESS\" if the 'failed' field in 'journey_execution_metrics' is 0, otherwise set it to \"FAILED\".",
    "expressions": [
      ". + {status: (if .journey_execution_metrics.failed == 0 then \"SUCCESS\" else \"FAILED\" end)}"
    ],
    "data": [
      {
        "input": {
          "plan_execution_metrics": {
            "total": 2,
            "passed": 1,
            "failed": 1
          },
          "journey_execution_metrics": {
            "total": 151,
            "passed": 140,
            "failed": 11
          }
        },
        "output": {
          "plan_execution_metrics": {
            "total": 2,
            "passed": 1,
            "failed": 1
          },
          "journey_execution_metrics": {
            "total": 151,
            "passed": 140,
            "failed": 11
          },
          "status": "FAILED"
        }
      },
      {
        "input": {
          "plan_execution_metrics": {
            "total": 2,
            "passed": 2,
            "failed": 0
          },
          "journey_execution_metrics": {
            "total": 3,
            "passed": 3,
            "failed": 0
          }
        },
        "output": {
          "plan_execution_metrics": {
            "total": 2,
            "passed": 2,
            "failed": 0
          },
          "journey_execution_metrics": {
            "total": 3,
            "passed": 3,
            "failed": 0
          },
          "status": "SUCCESS"
        }
      }
    ],
    "identifier": 58108036
  },
  {
    "context": [
      "I have 2 `json` files:",
      "file1.json",
      "[\n {\n  \"name\":\"value\",\n  \"description\":\"value\"\n },\n {\n  \"name\":\"value1\",\n  \"description\":\"value1\"\n }\n]",
      "file2.json",
      "[\n {\n  \"url\":\"value\"   \n },\n {\n  \"url\":\"value1\"\n }\n]",
      "**Expected result:**",
      "[\n {\n  \"name\":\"value\",\n  \"description\":\"value\"\n  \"url\":\"value\"\n\n },\n {\n  \"name\":\"value1\",\n  \"description\":\"value1\",\n  \"url\":\"value1\"\n }\n]",
      "I tried with `jq` : ",
      "jq -s '[0] * .[1]' file1 file2",
      "With jq, thanks to `transpose`, it's a one-liner:",
      "jq -s 'transpose | map(add)' file1.json file2.json ",
      "[\n  {\n    \"name\": \"value\",\n    \"description\": \"value\",\n    \"url\": \"value\"\n  },\n  {\n    \"name\": \"value1\",\n    \"description\": \"value1\",\n    \"url\": \"value1\"\n  }\n]"
    ],
    "utterance": "Merge corresponding objects from two arrays, one containing objects with fields name and description, and the other with the field url, so that each object in the result combines all fields at the same index.",
    "expressions": [
      "jq -s 'transpose | map(add)' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "value",
              "description": "value"
            },
            {
              "name": "value1",
              "description": "value1"
            }
          ],
          [
            {
              "url": "value"
            },
            {
              "url": "value1"
            }
          ]
        ],
        "output": [
          {
            "name": "value",
            "description": "value",
            "url": "value"
          },
          {
            "name": "value1",
            "description": "value1",
            "url": "value1"
          }
        ]
      }
    ],
    "identifier": 58116921
  },
  {
    "context": [
      "msp@coolpad:~/projects/lol$ jq .name lol.json",
      "jq: error: Could not open file lol.json: Permission denied",
      "cat lol.json | jq .name"
    ],
    "utterance": "Select the value of the 'name' key from a file named lol.json.",
    "expressions": [
      "jq .name lol.json",
      "cat lol.json | jq .name"
    ],
    "data": [
      {
        "input": {
          "name": "lol"
        },
        "output": "lol"
      }
    ],
    "identifier": 58128001
  },
  {
    "context": [
      "I need to parse it to get : \n{\n  \"eks-nodegroup-AZ1\" : \"$DesiredCapacityForEks-nodegroup-AZ1\",\n  \"eks-nodegroup-AZ2\" : \"$DesiredCapacityForEks-nodegroup-AZ2\",\n  \"eks-nodegroup-AZ3\" : \"$DesiredCapacityForEks-nodegroup-AZ3\",\n  \"eks-nodegroup-AZX\" : \"$DesiredCapacityForEks-nodegroup-AZX\",\n}\n",
      "Try with your `response`, \n```\nresponse | jq '.AutoScalingGroups[] | {(.AutoScalingGroupName): .DesiredCapacity}' | jq -s add\n```"
    ],
    "utterance": "Produce an object mapping each AutoScalingGroupName to its DesiredCapacity value for all auto scaling groups in the input.",
    "expressions": [
      ".AutoScalingGroups[] | {(.AutoScalingGroupName): .DesiredCapacity} | jq -s add",
      ".AutoScalingGroups | map({(.AutoScalingGroupName): .DesiredCapacity}) | add"
    ],
    "data": [
      {
        "input": {
          "AutoScalingGroups": [
            {
              "AutoScalingGroupName": "eks-nodegroup-AZ1",
              "DesiredCapacity": 1
            },
            {
              "AutoScalingGroupName": "eks-nodegroup-AZ2",
              "DesiredCapacity": 1
            }
          ]
        },
        "output": {
          "eks-nodegroup-AZ1": 1,
          "eks-nodegroup-AZ2": 1
        }
      }
    ],
    "identifier": 58099305
  },
  {
    "context": [
      "I would like to loop through each object in this array, and pick out the id of each value name \"test1\"",
      "Here is an example which assumes corrected json in `test.json`",
      "$ jq -M    '.items[] | select(.name == \"test1\") | .id' test.json",
      "You can use `-r` to exclude the quotes e.g.",
      "$ jq -M -r '.items[] | select(.name == \"test1\") | .id' test.json"
    ],
    "utterance": "Extract the id of each object in the items array where the name is \"test1\".",
    "expressions": [
      ".items[] | select(.name == \"test1\") | .id"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": "12sd31sd",
              "name": "test1",
              "createdDate": 1554894979
            },
            {
              "id": "sz978z7",
              "name": "test2",
              "createdDate": 1569595456
            },
            {
              "id": "sd213sd121",
              "name": "test1",
              "createdDate": 1569592293
            },
            {
              "id": "c4556c456c",
              "name": "test1",
              "createdDate": 1569592293
            }
          ]
        },
        "output": [
          "12sd31sd",
          "sd213sd121",
          "c4556c456c"
        ]
      }
    ],
    "identifier": 58137786
  },
  {
    "context": [
      "By jq-win64.exe \"[.format.duration]\" %%~ni.mkv.json the duration of the movie is read correctly from the file and jq echos [\"1:36:55.184000\"]",
      "If you still want to parse FFprobe's JSON, then there's no need to create json-files either, as you can simply pipe it to JQ instead:",
      "ffprobe.exe -v 0 -i <input> -show_format -of json | jq.exe -r .format.duration",
      "Create a variable:",
      "FOR /F \"delims=\" %%A IN ( 'ffprobe.exe -v 0 -i <input> -show_format -of json ^| jq.exe -r .format.duration' ) DO SET duration=%%A"
    ],
    "utterance": "Extract the value of the 'duration' field located at 'format.duration' in the given structure.",
    "expressions": [
      ".format.duration",
      "-r .format.duration"
    ],
    "data": [
      {
        "input": {
          "format": {
            "filename": "TestFile_1080p_26Mbs_8bit_BT709.mkv",
            "nb_streams": 1,
            "nb_programs": 0,
            "format_name": "matroska,webm",
            "format_long_name": "Matroska / WebM",
            "start_time": "0:00:00.000000",
            "duration": "1:36:55.184000",
            "size": "17.586597 Gibyte",
            "bit_rate": "25.978148 Mbit/s",
            "probe_score": 100,
            "tags": {
              "title": "TestFile",
              "encoder": "libmakemkv v1.14.4 (1.3.5/1.4.7) win(x64-release)",
              "creation_time": "2019-08-17T21:01:18.000000Z"
            }
          }
        },
        "output": "1:36:55.184000"
      }
    ],
    "identifier": 58125645
  },
  {
    "context": [
      "How can I get this result(prometheus format):\r\n\r\n```\r\nmtr_loss{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 0\r\nmtr_snt{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 10\r\nmtr_last{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 36.28\r\nmtr_avg{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 39.43\r\nmtr_best{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 34.77\r\nmtr_wrst{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 67.37\r\nmtr_stdev{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 8.15\r\n```",
      "mtr -jnbz  www.google.com | \r\n tr -d \"%\" |\r\n jq -r '.report.hubs[] \r\n        | \"mtr_loss{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Loss)\\nmtr_sent{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Snt)\\nmtr_last{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Last)\\nmtr_avg{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Avg)\\nmtr_best{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Best)\\nmtr_wrst{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Wrst)\\nmtr_stdev{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.StDev)\" '",
      "def kv:\r\n  . as $in\r\n  | reduce keys_unsorted[] as $k ([]; . + [\"\\\"\\($k)\\\"=\\\"\\($in[$k])\\\"\"] )\r\n  | join(\",\")\r\n  | \"{\" + . + \"}\" ;\r\n\r\ndef ht($s):\r\n  keys_unsorted[] as $key\r\n  | .[$key] as $value\r\n  | \"mtr_\\($key|ascii_downcase|gsub(\"%\";\"\"))\\($s) \\($value)\";\r\n  \r\n({count,host,ASN} | kv) as $s\r\n| {\"Loss%\", Snt, Last, Avg, Best, Wrst, StDev}\r\n| ht($s)"
    ],
    "utterance": "Output each hub's Loss%, Snt, Last, Avg, Best, Wrst, and StDev fields as separate Prometheus-style metrics with count, host, and ASN as labels.",
    "expressions": [
      ".report.hubs[] | \"mtr_loss{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Loss)\\nmtr_sent{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Snt)\\nmtr_last{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Last)\\nmtr_avg{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Avg)\\nmtr_best{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Best)\\nmtr_wrst{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.Wrst)\\nmtr_stdev{count=\\\"\\(.count)\\\",host=\\\"\\(.host)\\\",asn=\\\"\\(.ASN)\\\"} \\(.StDev)\"",
      "def kv: . as $in | reduce keys_unsorted[] as $k ([]; . + [\"\\\"\\($k)\\\"=\\\"\\($in[$k])\\\"\"] ) | join(\",\") | \"{\" + . + \"}\" ;\ndef ht($s): keys_unsorted[] as $key | .[$key] as $value | \"mtr_\\($key|ascii_downcase|gsub(\"%\";\"\"))\\($s) \\($value)\";\n({count,host,ASN} | kv) as $s\n| {\"Loss%\", Snt, Last, Avg, Best, Wrst, StDev}\n| ht($s)"
    ],
    "data": [
      {
        "input": [
          {
            "count": "1",
            "host": "1.1.1.1",
            "ASN": "AS???",
            "Loss%": 0,
            "Snt": 10,
            "Last": 36.28,
            "Avg": 39.43,
            "Best": 34.77,
            "Wrst": 62.37,
            "StDev": 8.15
          },
          {
            "count": "2",
            "host": "2.2.2.2",
            "ASN": "AS???",
            "Loss%": 100,
            "Snt": 10,
            "Last": 0,
            "Avg": 0,
            "Best": 0,
            "Wrst": 0,
            "StDev": 0
          }
        ],
        "output": [
          "mtr_loss{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 0",
          "mtr_snt{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 10",
          "mtr_last{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 36.28",
          "mtr_avg{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 39.43",
          "mtr_best{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 34.77",
          "mtr_wrst{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 62.37",
          "mtr_stdev{\"count\"=\"1\",\"host\"=\"1.1.1.1\",\"ASN\"=\"AS???\"} 8.15",
          "mtr_loss{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 100",
          "mtr_snt{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 10",
          "mtr_last{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 0",
          "mtr_avg{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 0",
          "mtr_best{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 0",
          "mtr_wrst{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 0",
          "mtr_stdev{\"count\"=\"2\",\"host\"=\"2.2.2.2\",\"ASN\"=\"AS???\"} 0"
        ]
      }
    ],
    "identifier": 58087455
  },
  {
    "context": [
      "I would like to merge 2 json files with JQ. But only for the present keys in first file.",
      "\"oof\" entry should not be present.",
      "Expected merged.\n{\n  \"@@locale\": \"en\",\n  \"foo\": \"bar2\"\n}",
      "Consider:\n\njq -n '.\n  | input as $first         # read first input\n  | input as $second        # read second input\n  | $first * $second        # make the merger of the two the context item\n  | [ to_entries[]          # ...then break it out into key/value pairs\n    | select($first[.key])  # ...and filter those for whether they exist in the first input\n  ] | from_entries          # ...before reassembling into a single object.' first.json second.json",
      "And here's a one-liner, which happens to be quite efficient:\n\n    jq --argfile first first.json '. as $in | $first | with_entries(.value = $in[.key] )' second.json"
    ],
    "utterance": "Replace the values in the first file with corresponding values from the second file, but only for the keys present in the first file.",
    "expressions": [
      "jq -n '.\n  | input as $first\n  | input as $second\n  | $first * $second\n  | [ to_entries[] | select($first[.key]) ] | from_entries' first.json second.json",
      "jq --argfile first first.json '. as $in | $first | with_entries(.value = $in[.key] )' second.json"
    ],
    "data": [
      {
        "input": {
          "first.json": {
            "@@locale": "en",
            "foo": "bar1"
          },
          "second.json": {
            "@@locale": "en",
            "foo": "bar2",
            "oof": "rab"
          }
        },
        "output": {
          "@@locale": "en",
          "foo": "bar2"
        }
      }
    ],
    "identifier": 58141909
  },
  {
    "context": [
      "However i just want the Name, Version, Description and URL fields.",
      "I would like an output as :\r\n\r\n{\r\n  \"Name\"            : \"acl\",\r\n  \"Version\"         : \"2.2.53-1\",\r\n  \"Description\"     : \"Access control list utilities\": \" libraries and headers\",\r\n  \"URL\"             : \"http://savannah.nongnu.org/projects/acl\"\r\n}\r\n\r\n{ \"Name\"            : \"archlinux-keyring\",\r\n  \"Version\"         : \"20190827-1\",\r\n  \"Description\"     : \"Arch Linux PGP keyring\",\r\n  \"URL\"             : \"https://projects.archlinux.org/archlinux-keyring.git/\"\r\n} \r\n",
      "Here is a jq script that converts such values into a stream of key-value objects\r\nand collects them into aggregate objects based on the value of the Name attribute\r\n\r\n```\r\ndef kvpairs:                                                    # e.g. (note spaces)\r\n    inputs                                                      # \"Name    : vi\"\r\n  | capture(\"^(?<key>[^:]+):(?<value>.+)$\")                     # { \"key\": \"Name   \", \"value\": \" vi\" }\r\n  | (.key, .value) |= gsub(\"^\\\\s+|\\\\s+$\";\"\")                    # { \"key\": \"Name\", \"value\": \"vi\" }\r\n  ;\r\n\r\n  reduce kvpairs as $kv (\r\n      { result:{}, cur:null }                                   # initial state\r\n    ; if $kv.key == \"Name\" then .cur = $kv.value else . end     # track current object\r\n    | .result[.cur][$kv.key] = $kv.value                        # apply update to current object\r\n  )\r\n| .result[]                                                     # generate result\r\n| { Name, Version, Description, URL }                           # with only these members\r\n```",
      "Sample execution assuming the above in `test.jq` and pacman output in `test.pac`\r\n```\r\n$ jq -MRn -f test.jq test.pac\r\n{\r\n  \"Name\": \"vi\",\r\n  \"Version\": \"1:070224-2\",\r\n  \"Description\": \"The original ex/vi text editor\",\r\n  \"URL\": \"http://ex-vi.sourceforge.net/\"\r\n}\r\n{\r\n  \"Name\": \"dbus\",\r\n  \"Version\": \"1.4.1-1\",\r\n  \"Description\": \"Freedesktop.org message bus system\",\r\n  \"URL\": \"http://www.freedesktop.org/Software/dbus\"\r\n}\r\n```"
    ],
    "utterance": "Extract only the Name, Version, Description, and URL fields for each package from pacman -Qi output in a multi-object stream, one object per package.",
    "expressions": [
      "def kvpairs:\n    inputs\n  | capture(\"^(?<key>[^:]+):(?<value>.+)$\")\n  | (.key, .value) |= gsub(\"^\\\\s+|\\\\s+$\"; \"\");\n\nreduce kvpairs as $kv (\n    { result:{}, cur:null }\n  ; if $kv.key == \"Name\" then .cur = $kv.value else . end\n  | .result[.cur][$kv.key] = $kv.value\n)\n| .result[]\n| { Name, Version, Description, URL }"
    ],
    "data": [
      {
        "input": "Name            : vi\nVersion         : 1:070224-2\nDescription     : The original ex/vi text editor\nArchitecture    : x86_64\nURL             : http://ex-vi.sourceforge.net/\nLicenses        : custom:ex\nGroups          : base\nProvides        : None\nDepends On      : ncurses\nOptional Deps   : s-nail: used by the preserve command for notification [installed]\nRequired By     : None\nOptional For    : None\nConflicts With  : None\nReplaces        : None\nInstalled Size  : 290.00 KiB\nPackager        : Evangelos Foutras <evangelos@foutrelis.com>\nBuild Date      : Sun 06 Sep 2015 09:34:15 PM CEST\nInstall Date    : Mon 03 Oct 2016 07:18:13 PM CEST\nInstall Reason  : Explicitly installed\nInstall Script  : No\nValidated By    : Signature\n\nName            : dbus\nVersion         : 1.4.1-1\nURL             : http://www.freedesktop.org/Software/dbus\nLicenses        : GPL custom\nGroups          : None\nProvides        : None\nDepends On      : dbus-core>=1.4.1 libx11\nOptional Deps   : None\nRequired By     : avahi perl-net-dbus qt system-tools-backends\nConflicts With  : None\nReplaces        : None\nInstalled Size  : 112.00 K\nPackager        : Jan de Groot <jgc@archlinux.org>\nArchitecture    : i686\nBuild Date      : Wed Dec 22 14:39:28 2010\nInstall Date    : Sun Jan 2 16:05:50 2011\nInstall Reason  : Installed as a dependency for another package\nInstall Script  : No\nDescription     : Freedesktop.org message bus system\n",
        "output": [
          {
            "Name": "vi",
            "Version": "1:070224-2",
            "Description": "The original ex/vi text editor",
            "URL": "http://ex-vi.sourceforge.net/"
          },
          {
            "Name": "dbus",
            "Version": "1.4.1-1",
            "Description": "Freedesktop.org message bus system",
            "URL": "http://www.freedesktop.org/Software/dbus"
          }
        ]
      }
    ],
    "identifier": 58112422
  },
  {
    "context": [
      "The output I'm looking for is:\n```\nacme\nDev\ntwister\nSmith, Bill\nSmith, Alice\nSmith, Mary\nBrown, Gil\nBrown, Bob\nBrown, Mary\nSanchez, Gil\nSanchez, Jose\nSanchez, Marlena\n```",
      "Simply use the \",\" operator to join the two queries, e.g.\n\n```\n.people\n| (.company, .department, .perks.play),\n  (.names[] | \"\\(.last_name), \\(.first_names[].name)\")\n```"
    ],
    "utterance": "Output the company, department, perks.play values, followed by each last_name combined with each of their first_names.name for all entries.",
    "expressions": [
      ".people | (.company, .department, .perks.play), (.names[] | \"\\(.last_name), \\(.first_names[].name)\")"
    ],
    "data": [
      {
        "input": {
          "people": {
            "company": "Acme",
            "department": "Dev",
            "perks": {
              "eat": "pizza",
              "drink": "beer",
              "play": "twister"
            },
            "names": [
              {
                "last_name": "Smith",
                "first_names": [
                  {
                    "name": "Bill"
                  },
                  {
                    "name": "Alice"
                  },
                  {
                    "name": "Mary"
                  }
                ]
              },
              {
                "last_name": "Brown",
                "first_names": [
                  {
                    "name": "Gil"
                  },
                  {
                    "name": "Bob"
                  },
                  {
                    "name": "Mary"
                  }
                ]
              },
              {
                "last_name": "Sanchez",
                "first_names": [
                  {
                    "name": "Gil"
                  },
                  {
                    "name": "Jose"
                  },
                  {
                    "name": "Marlena"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "Acme",
          "Dev",
          "twister",
          "Smith, Bill",
          "Smith, Alice",
          "Smith, Mary",
          "Brown, Gil",
          "Brown, Bob",
          "Brown, Mary",
          "Sanchez, Gil",
          "Sanchez, Jose",
          "Sanchez, Marlena"
        ]
      }
    ],
    "identifier": 58142603
  },
  {
    "context": [
      "Need to join this array with one line so output will be:",
      "key1=value1&key2=value2",
      "I can join it values:",
      "jq '[].query | join(\"&\")'",
      "\"value1&value2\"",
      "Or",
      "Get key value string:",
      "jq '[].query | to_entries[] | \"\\(.key)=\\(.value)\"'",
      "\"key1=value1\"",
      "\"key2=value2\"",
      "But how to concatenate this?",
      "You can use this jq script:",
      " <file jq -r '[].query|to_entries|map([.key,.value]|join(\"=\"))|join(\"&\")'",
      "This joins twice the array containing the keys and values with `=` and `&` characters."
    ],
    "utterance": "Return for each object a single string of key-value pairs in the format key1=value1&key2=value2, joining all keys and values in the 'query' object with '&'.",
    "expressions": [
      ".[].query | to_entries | map([.key,.value]|join(\"=\")) | join(\"&\")"
    ],
    "data": [
      {
        "input": [
          {
            "query": {
              "key1": "value1",
              "key2": "value2"
            }
          }
        ],
        "output": "key1=value1&key2=value2"
      }
    ],
    "identifier": 58168677
  },
  {
    "context": [
      "I want to retrieve only the description and store it in another variable.",
      "echo $var | jq -r '.description'",
      "echo $var | jq '... | .description?'",
      "echo $var | jq '.result[] | .description?'",
      "echo $var | jq '.result[].description'"
    ],
    "utterance": "Retrieve the description values from every object in the result array.",
    "expressions": [
      ".result[].description",
      ".result[] | .description?",
      ".. | .description?"
    ],
    "data": [
      {
        "input": {
          "jsonrpc": "2.0",
          "result": [
            {
              "triggerid": "17169",
              "expression": "{19444}=1",
              "description": "Zabbix agent on {HOST.NAME} is unreachable for 5 minutes",
              "url": "",
              "status": "0",
              "value": "1",
              "priority": "3",
              "lastchange": "1569589239",
              "comments": "",
              "error": "",
              "templateid": "13437",
              "type": "0",
              "state": "0",
              "flags": "0",
              "recovery_mode": "0",
              "recovery_expression": "",
              "correlation_mode": "0",
              "correlation_tag": "",
              "manual_close": "0",
              "details": ""
            },
            {
              "triggerid": "18123",
              "expression": "{20525}=1",
              "description": "Zabbix agent on {HOST.NAME} is unreachable for 5 minutes",
              "url": "",
              "status": "0",
              "value": "1",
              "priority": "3",
              "lastchange": "1569590703",
              "comments": "",
              "error": "",
              "templateid": "13437",
              "type": "0",
              "state": "0",
              "flags": "0",
              "recovery_mode": "0",
              "recovery_expression": "",
              "correlation_mode": "0",
              "correlation_tag": "",
              "manual_close": "0",
              "details": ""
            }
          ],
          "id": 1
        },
        "output": [
          "Zabbix agent on {HOST.NAME} is unreachable for 5 minutes",
          "Zabbix agent on {HOST.NAME} is unreachable for 5 minutes"
        ]
      }
    ],
    "identifier": 58162970
  },
  {
    "context": [
      "I want to find running state's href.",
      "If I talk with example I want to find href key is https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/b28832cb-2a97-4ec8-848f-35fec95eb867/ by way of running key.",
      "select( any(.attributes[]; .value==\"running\" and .name == \"state\") )",
      ".relations.link[]\n| select(any(.attributes[]?; .value==\"running\" and .name == \"state\")).href"
    ],
    "utterance": "Retrieve the href value from an item in relations.link where one of the attributes has name equal to 'state' and value equal to 'running'.",
    "expressions": [
      ".relations.link[] | select(has(\"attributes\")) | select(any(.attributes[]; .value==\"running\" and .name == \"state\")) | .href",
      ".relations.link[] | select(any(.attributes[]?; .value==\"running\" and .name == \"state\")).href"
    ],
    "data": [
      {
        "input": {
          "relations": {
            "total": 9,
            "link": [
              {
                "href": "https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/",
                "rel": "up"
              },
              {
                "href": "https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/",
                "rel": "add"
              },
              {
                "attributes": [
                  {
                    "value": "8f961082-cccc-412f-9244-16ba5b949dbe",
                    "name": "id"
                  },
                  {
                    "value": "2019-09-28T17:20:40.691-01:00",
                    "name": "startDate"
                  },
                  {
                    "value": "2019-09-28T17:20:43.949-01:00",
                    "name": "endDate"
                  },
                  {
                    "value": "completed",
                    "name": "state"
                  },
                  {
                    "value": "test",
                    "name": "name"
                  },
                  {
                    "name": "currentItemDisplayName"
                  }
                ],
                "href": "https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/8f961082-cccc-412f-9244-16ba5b949dbe/",
                "rel": "down"
              },
              {
                "attributes": [
                  {
                    "value": "b28832cb-2a97-4ec8-848f-35fec95eb867",
                    "name": "id"
                  },
                  {
                    "value": "2019-09-28T17:21:04.643-01:00",
                    "name": "startDate"
                  },
                  {
                    "value": "running",
                    "name": "state"
                  },
                  {
                    "value": "test",
                    "name": "name"
                  },
                  {
                    "name": "currentItemDisplayName"
                  }
                ],
                "href": "https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/b28832cb-2a97-4ec8-848f-35fec95eb867/",
                "rel": "down"
              }
            ]
          }
        },
        "output": "https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/b28832cb-2a97-4ec8-848f-35fec95eb867/"
      }
    ],
    "identifier": 58154603
  },
  {
    "context": [
      "The question. How can i get elements for example of `mycentralapplication` via `jq` library in `bash` or `shell` ? For example, i have to receive only `mycentralapplication` in output",
      "You can use this jq script:\r\n\r\n    aws ... | jq 'map(select(.[][][]?|contains(\"mycentralapplication\")))'\r\n\r\nThis selects all nested arrays elements containing the string `mycentralapplication`"
    ],
    "utterance": "Filter to return only those elements whose innermost string contains 'mycentralapplication'.",
    "expressions": [
      "map(select(.[][][]?|contains(\"mycentralapplication\")))"
    ],
    "data": [
      {
        "input": [
          [
            [
              "i-d21eei21e912e0e91",
              "192.168.1.203",
              [
                "mycentralapplication-DEV-10"
              ]
            ]
          ],
          [
            [
              "i-ddaswed1e12415155",
              "192.168.1.210",
              [
                "mycentralapplication-DEV-103"
              ]
            ]
          ],
          [
            [
              "i-dass1241211agh354",
              "192.168.1.202",
              [
                "myindexapplication-DEV-53"
              ]
            ]
          ],
          [
            [
              "i-2143214251assaa11",
              "192.168.1.211",
              [
                "myserviceapplication-DEV-52"
              ]
            ]
          ],
          [
            [
              "i-d2112421521assas1",
              "192.168.1.207",
              [
                "mycentralapplication-DEV-10"
              ]
            ]
          ],
          [
            [
              "i-sadas11112424111a",
              "192.168.1.196",
              [
                "myapplication-DEV-106"
              ]
            ]
          ]
        ],
        "output": [
          [
            [
              "i-d21eei21e912e0e91",
              "192.168.1.203",
              [
                "mycentralapplication-DEV-10"
              ]
            ]
          ],
          [
            [
              "i-ddaswed1e12415155",
              "192.168.1.210",
              [
                "mycentralapplication-DEV-103"
              ]
            ]
          ],
          [
            [
              "i-d2112421521assas1",
              "192.168.1.207",
              [
                "mycentralapplication-DEV-10"
              ]
            ]
          ]
        ]
      }
    ],
    "identifier": 58168903
  },
  {
    "context": [
      "I have hundreds of files formatted like this:\n{\n\t\"settings\": [\n\t\t{\n\t\t\t\"name\": \"A\",\n\t\t\t\"value\": \"A_value\"\n\t\t},\n\t\t{\n\t\t\t\"name\": \"B\",\n\t\t\t\"value\": \"B_value\"\n\t\t},\n\t\t{\n\t\t\t\"name\": \"C\",\n\t\t\t\"value\": \"C_value\"\n\t\t},\n\t\t{\n\t\t\t\"name\": \"D\",\n\t\t\t\"value\": \"D_value\"\n\t\t}\n\t]\n}",
      "need to modifiy them by taking some of names and values to another array but only the specific ones for e.g. B and D so the file will look like:\n{\n\t\"settings\": [\n\t\t{\n\t\t\t\"name\": \"A\",\n\t\t\t\"value\": \"A_value\"\n\t\t},\n\t\t{\n\t\t\t\"name\": \"C\",\n\t\t\t\"value\": \"C_value\"\n\t\t}\n\t],\n    \"settings2\": [\n\t\t{\n\t\t\t\"name\": \"B\",\n\t\t\t\"value\": \"B_value\"\n\t\t},\n\t\t{\n\t\t\t\"name\": \"D\",\n\t\t\t\"value\": \"D_value\"\n\t\t}\n\t]\n}",
      "I have a list of \"names\" that have to be moved.",
      "jq --argjson toMove \"$to_move\" '{\n    \"settings\":  [.settings[] | select([.name] | inside($toMove) | not)],\n    \"settings2\": [.settings[] | select([.name] | inside($toMove))]\n}' file.json"
    ],
    "utterance": "Move objects with name equal to B or D from the settings array to a new settings2 array, leaving other objects in settings.",
    "expressions": [
      "{\n  \"settings\":  [.settings[] | select([.name] | inside($toMove) | not)],\n  \"settings2\": [.settings[] | select([.name] | inside($toMove))]\n}"
    ],
    "data": [
      {
        "input": {
          "settings": [
            {
              "name": "A",
              "value": "A_value"
            },
            {
              "name": "B",
              "value": "B_value"
            },
            {
              "name": "C",
              "value": "C_value"
            },
            {
              "name": "D",
              "value": "D_value"
            }
          ]
        },
        "output": {
          "settings": [
            {
              "name": "A",
              "value": "A_value"
            },
            {
              "name": "C",
              "value": "C_value"
            }
          ],
          "settings2": [
            {
              "name": "B",
              "value": "B_value"
            },
            {
              "name": "D",
              "value": "D_value"
            }
          ]
        }
      }
    ],
    "identifier": 58169770
  },
  {
    "context": [
      "I have below JSON file and would like to update the values of these keys `--resType` and `--LogLevel` using `jq`.",
      "{\n    \"--resType\": \"FILE\",\n    \"--LogLevel\": \"INFO\"\n}",
      "./jq .--resType=Test config.json>test.json",
      "But, I see an error that says",
      "\"jq: error: Test/0 is not defined at <top-level>, line 1:\"."
    ],
    "utterance": "Update the value of the key --resType to Test in the object where the key name starts with two dashes.",
    "expressions": [
      ".[\"--resType\"] = \"Test\""
    ],
    "data": [
      {
        "input": {
          "--resType": "FILE",
          "--LogLevel": "INFO"
        },
        "output": {
          "--resType": "Test",
          "--LogLevel": "INFO"
        }
      }
    ],
    "identifier": 58178909
  },
  {
    "context": [
      "I try to get channnel name which method is <is_shared = \"true\">.",
      "Instead, compare booleans with booleans: .channels[] | select(.is_shared == true)",
      "conditionals compare implicitly against true, so if you have == true somewhere, this is redundant 99% of the time and can be simplified: .channels[] | select(.is_shared)"
    ],
    "utterance": "List all channels where is_shared is true.",
    "expressions": [
      ".channels[] | select(.is_shared == true)",
      ".channels[] | select(.is_shared)"
    ],
    "data": [
      {
        "input": {
          "ok": true,
          "channels": [
            {
              "id": "C2U56FH6Z",
              "name": "hoge_general",
              "is_shared": false
            },
            {
              "id": "C12345",
              "name": "shared_chan",
              "is_shared": true
            }
          ]
        },
        "output": {
          "id": "C12345",
          "name": "shared_chan",
          "is_shared": true
        }
      }
    ],
    "identifier": 58178918
  },
  {
    "context": [
      "Would it be possible to have a single command to select when `.Action == '*'` and `.Resource == '*'` exist within the Statement, whether it's an array, an object, and where it's nested?",
      "\"Of course something like: jq '.PolicyVersion.Document.Statement[] | select((.Action == \"*\") and .Resource == \"*\")' works for an array and jq '.PolicyVersion.Document.Statement | select((.Action == \"*\") and .Resource == \"*\")' works for when it's not an array but I'd like to acheive this in one command.\"",
      "The following might be more generic than you need, or maybe too generic, so feel free to season to taste:\n```\n..\n| objects\n| select(.Statement)\n| .Statement\n| if type == \"array\" then .[] else . end\n| select(.Action == \"*\" and .Resource == \"*\")\n```",
      "Another approach which is quite specific to this particular case:\n```\n.PolicyVersion.Document.Statement\n| ..\n| select(type == \"object\" and .Action == \"*\" and .Resource == \"*\")\n```"
    ],
    "utterance": "Find all Statement entries, whether arrays or objects and at any nesting level, where Action equals '*' and Resource equals '*'.",
    "expressions": [
      ".. | objects | select(.Statement) | .Statement | if type == \"array\" then .[] else . end | select(.Action == \"*\" and .Resource == \"*\")",
      ".PolicyVersion.Document.Statement | .. | select(type == \"object\" and .Action == \"*\" and .Resource == \"*\")"
    ],
    "data": [
      {
        "input": {
          "PolicyVersion": {
            "CreateDate": "2017-07-13T18:59:21Z",
            "VersionId": "v2",
            "Document": {
              "Version": "2012-10-17",
              "Statement": {
                "Action": "*",
                "Resource": "*",
                "Effect": "Allow"
              }
            },
            "IsDefaultVersion": true
          }
        },
        "output": {
          "Action": "*",
          "Resource": "*",
          "Effect": "Allow"
        }
      },
      {
        "input": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Effect": "Allow",
              "Action": "*",
              "Resource": "*"
            }
          ]
        },
        "output": {
          "Effect": "Allow",
          "Action": "*",
          "Resource": "*"
        }
      },
      {
        "input": {
          "PolicyVersion": {
            "CreateDate": "2017-07-13T18:59:21Z",
            "VersionId": "v2",
            "Document": {
              "Version": "2012-10-17",
              "Statement": [
                {
                  "Action": "*",
                  "Resource": "*",
                  "Effect": "Allow"
                }
              ]
            },
            "IsDefaultVersion": true
          }
        },
        "output": {
          "Action": "*",
          "Resource": "*",
          "Effect": "Allow"
        }
      }
    ],
    "identifier": 58122691
  },
  {
    "context": [
      "I'm looking for output that looks like the following:",
      "Acme\nDev\nbeer\nSmith, Bill, Billy\nSmith, Alice, Al\nSmith, Mary, Mare\nBrown, Gil, Gillie\nBrown, Bob, Bobby\nBrown, Mary, Big M\nSanchez, Gil, Gilster\nSanchez, Jose, Jo\nSanchez, Marlena, Marly",
      "jq -r '.people | \n  .company, .department, .perks.drink, \n  (.names[] | .last_name as $last |\n    .first_names[] |\n    \"\\($last), \\(.name), \\(.nickname)\"\n  )'"
    ],
    "utterance": "Output the company, department, drink perk, and for each person: their last name, each first name and nickname as a combined string in the format 'Last, Name, Nickname'.",
    "expressions": [
      ".people | .company, .department, .perks.drink, (.names[] | .last_name as $last | .first_names[] | \"\u001b$last), \u001b(.name), \u001b(.nickname)\")"
    ],
    "data": [
      {
        "input": {
          "people": {
            "company": "Acme",
            "department": "Dev",
            "perks": {
              "eat": "pizza",
              "drink": "beer",
              "play": "twister"
            },
            "names": [
              {
                "last_name": "Smith",
                "first_names": [
                  {
                    "name": "Bill",
                    "nickname": "Billy"
                  },
                  {
                    "name": "Alice",
                    "nickname": "Al"
                  },
                  {
                    "name": "Mary",
                    "nickname": "Mare"
                  }
                ]
              },
              {
                "last_name": "Brown",
                "first_names": [
                  {
                    "name": "Gil",
                    "nickname": "Gillie"
                  },
                  {
                    "name": "Bob",
                    "nickname": "Bobby"
                  },
                  {
                    "name": "Mary",
                    "nickname": "Big M"
                  }
                ]
              },
              {
                "last_name": "Sanchez",
                "first_names": [
                  {
                    "name": "Gil",
                    "nickname": "Gilster"
                  },
                  {
                    "name": "Jose",
                    "nickname": "Jo"
                  },
                  {
                    "name": "Marlena",
                    "nickname": "Marly"
                  }
                ]
              }
            ]
          }
        },
        "output": "Acme\nDev\nbeer\nSmith, Bill, Billy\nSmith, Alice, Al\nSmith, Mary, Mare\nBrown, Gil, Gillie\nBrown, Bob, Bobby\nBrown, Mary, Big M\nSanchez, Gil, Gilster\nSanchez, Jose, Jo\nSanchez, Marlena, Marly"
      }
    ],
    "identifier": 58176740
  },
  {
    "context": [
      "But I am missing next level parsing to get just **football** as output",
      "$ jq -Mr '.[] | capture(\"Hobbies=(?<Hobbies>[[:alnum:]]+)\") | .Hobbies' test.json",
      "Here is an approach that uses [`capture`](https://stedolan.github.io/jq/manual/#capture\\(val\\),capture\\(regex;flags\\)) on the non-json strings in the array."
    ],
    "utterance": "Extract the value Football associated with Hobbies from the array.",
    "expressions": [
      ".[] | capture(\"Hobbies=(?<Hobbies>[[:alnum:]]+)\") | .Hobbies"
    ],
    "data": [
      {
        "input": [
          "[[Input=[Name=ABC, createDateTime=2019-30-11, RollNumber=9]]]",
          "[[SubjectList=[Summer=, Winter=, Autumn=, Spring=, rList=, sList=, additionalList=, emailList=, FoodList=, sAssignmentList=, summerworkList=, outdoorList=, movielist=]]]",
          "[ProcessingDate=2018-10-06]",
          "[Hobbies=Football]",
          "[Phone=Android,,]"
        ],
        "output": "Football"
      }
    ],
    "identifier": 58180768
  },
  {
    "context": [
      "Your sample JSON has \"configResolveClass\" as the top-level key, so you could use the following as your jq program:\n\n    .configResolveClass.outConfigs.faultInst[] | @base64",
      "The immediate error with your attempt is _not_ using the parent field `.configResolveClass` before the `.outConfigs` node.",
      "jq -r '.configResolveClass.outConfigs.faultInst[] | .\"@cause\"' json"
    ],
    "utterance": "Extract the value of the @cause field from each object in the faultInst array under configResolveClass.outConfigs.",
    "expressions": [
      ".configResolveClass.outConfigs.faultInst[] | .\"@cause\"",
      ".configResolveClass.outConfigs.faultInst[].\"@cause\""
    ],
    "data": [
      {
        "input": {
          "configResolveClass": {
            "@guid": "ddsd2222e2/5d0cce7c-5296-4a2a-b6c3-05bewwewerwewe",
            "@response": "yes",
            "@classId": "faultInst",
            "outConfigs": {
              "faultInst": [
                {
                  "@ack": "yes",
                  "@cause": "power-problem",
                  "@changeSet": "",
                  "@code": "F0369",
                  "@created": "2019-07-22T15:56:14.616",
                  "@descr": "Power supply 1 in fabric interconnect A power: error",
                  "@dn": "sys/switch-A/psu-1/fault-F0369",
                  "@highestSeverity": "major",
                  "@id": "109305",
                  "@lastTransition": "2019-07-22T15:56:14.616",
                  "@lc": "",
                  "@occur": "1",
                  "@origSeverity": "major",
                  "@prevSeverity": "major",
                  "@rule": "equipment-psu-power-supply-problem",
                  "@severity": "major",
                  "@tags": "network,server",
                  "@type": "environmental"
                },
                {
                  "@ack": "yes",
                  "@cause": "equipment-inoperable",
                  "@changeSet": "",
                  "@code": "F0374",
                  "@created": "2019-07-22T15:56:14.616",
                  "@descr": "Power supply 1 in fabric interconnect A operability: inoperable",
                  "@dn": "sys/switch-A/psu-1/fault-F0374",
                  "@highestSeverity": "major",
                  "@id": "109306",
                  "@lastTransition": "2019-07-22T15:56:14.616",
                  "@lc": "",
                  "@occur": "1",
                  "@origSeverity": "major",
                  "@prevSeverity": "major",
                  "@rule": "equipment-psu-inoperable",
                  "@severity": "major",
                  "@tags": "network,server",
                  "@type": "equipment"
                }
              ]
            }
          }
        },
        "output": [
          "power-problem",
          "equipment-inoperable"
        ]
      }
    ],
    "identifier": 58139608
  },
  {
    "context": [
      "I need to retrieve the \"message\" variable from the website and store it in a variable.",
      "This is the output of the website example.web:8080/rest/message",
      "[{\"id\":33,\"message\":\"Dash\",\"lastUpdated\":1569922857154,\"userName\":null}]",
      "If you have `jq` tool with you, could you please try following(not tested).",
      "curl -# -L \"http://example.web:8080/rest/message\" | jq '.[] | .message'"
    ],
    "utterance": "Extract the value of the message field from an array of objects where each object contains keys including message.",
    "expressions": [
      ".[] | .message"
    ],
    "data": [
      {
        "input": [
          {
            "id": 33,
            "message": "Dash",
            "lastUpdated": 1569922857154,
            "userName": null
          }
        ],
        "output": "Dash"
      }
    ],
    "identifier": 58182684
  },
  {
    "context": [
      "How can I add, or modify if the element already exists, an element for each object in an array using `jq`?",
      "To do something with each element in an array, use `map`:",
      "jq 'map(.common=\"something\")'"
    ],
    "utterance": "Add or update the key 'common' with the value 'something' for every object in the array.",
    "expressions": [
      "map(.common=\"something\")"
    ],
    "data": [
      {
        "input": [
          {
            "firstname": "Sophie",
            "lastname": "Haydock"
          },
          {
            "firstname": "Toussaint",
            "lastname": "Louverture"
          }
        ],
        "output": [
          {
            "firstname": "Sophie",
            "lastname": "Haydock",
            "common": "something"
          },
          {
            "firstname": "Toussaint",
            "lastname": "Louverture",
            "common": "something"
          }
        ]
      }
    ],
    "identifier": 58227822
  },
  {
    "context": [
      "I have a JSON file containing application clients and their associated application features:",
      "I'm trying to turn this into the following CSV:",
      "client,feature\nclient-A,feature-x\nclient-B,feature-x\nclient-B,feature-y\nclient-C,feature-z\nclient-D,feature-x\nclient-D,feature-z",
      "What's an easy way using `jq` to get this done?",
      "you can convert use the following pipeline:",
      "<yourfile.json jq -r 'to_entries | .[] | { key: .key, value: .value[] } | [ .key, .value ] | @csv'"
    ],
    "utterance": "Produce a two-column CSV listing each client-feature pair for every feature associated with each client.",
    "expressions": [
      "to_entries | .[] | { key: .key, value: .value[] } | [ .key, .value ] | @csv"
    ],
    "data": [
      {
        "input": {
          "client-A": [
            "feature-x"
          ],
          "client-B": [
            "feature-x",
            "feature-y"
          ],
          "client-C": [
            "feature-z"
          ],
          "client-D": [
            "feature-x",
            "feature-z"
          ]
        },
        "output": [
          "\"client-A\",\"feature-x\"",
          "\"client-B\",\"feature-x\"",
          "\"client-B\",\"feature-y\"",
          "\"client-C\",\"feature-z\"",
          "\"client-D\",\"feature-x\"",
          "\"client-D\",\"feature-z\""
        ]
      }
    ],
    "identifier": 58193396
  },
  {
    "context": [
      "jq -c '.[]' <<< '[{\"name\" : \"alpha\"},{\"name\" : \"beta\"},{\"name\" : \"gama\"},{\"name\" : \"delta\"}]'",
      "I am expecting every object to be printed on separate lines, just like the one below which i ran on Ubuntu 18,",
      "{ \"name\": \"alpha\" }\n....\n{ \"name\": \"beta\" }\n....\n{ \"name\": \"gama\" }\n....\n{ \"name\": \"delta\" }\n....",
      "But on Ubuntu 16, I am getting this output,\n{\"name\":\"alpha\"} {\"name\":\"beta\"} {\"name\":\"gama\"} {\"name\":\"delta\"}\n....",
      "jq -c '.[]' <<< '[{\"name\" : \"alpha\"},{\"name\" : \"beta\"},{\"name\" : \"gama\"},{\"name\" : \"delta\"}]' |while read i;do\necho ${i}\necho \"....\"\ndone",
      "while IFS= read -r line; do\n  echo \"$line\"\n  echo \"...\"\ndone <<< \"$(jq -c '.[]' <<< '[{\"name\" : \"alpha\"},{\"name\" : \"beta\"},{\"name\" : \"gama\"},{\"name\" : \"delta\"}]')\"",
      "while read i; do\n  echo ${i}\n  echo \"....\"\ndone <<< \"$(jq -c '.[]' <<< '[{\"name\" : \"alpha\"},{\"name\" : \"beta\"},{\"name\" : \"gama\"},{\"name\" : \"delta\"}]')\""
    ],
    "utterance": "Extract each object from an array, with each object on a separate line.",
    "expressions": [
      ".[]",
      "-c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "alpha"
          },
          {
            "name": "beta"
          },
          {
            "name": "gama"
          },
          {
            "name": "delta"
          }
        ],
        "output": [
          {
            "name": "alpha"
          },
          {
            "name": "beta"
          },
          {
            "name": "gama"
          },
          {
            "name": "delta"
          }
        ]
      }
    ],
    "identifier": 58234533
  },
  {
    "context": [
      "Given the following JSON object, using jq, how to get the last two elements for each item?",
      "Expected result:\r\n{\r\n  \"foo\": {\r\n    \"efg\": { \"key1\": \"value1\" },\r\n    \"fgh\": { \"key1\": \"value1\" }\r\n  }, \r\n  \"bar\": {\r\n    \"ghi\": { \"key1\": \"value1\" }\r\n  }, \r\n  \"qux\": {\r\n    \"jkl\": { \"key1\": \"value1\" },\r\n    \"klm\": { \"key1\": \"value1\" }\r\n  }\r\n  /* ... */\r\n}",
      "One option is to delete all fields but the last N (2 here) using delpaths. You need to convert key names to path representations though. E.g:\nmap_values(delpaths(keys_unsorted[:-2] | map([.])))",
      "A straightforward and efficient solution:\n\n    map_values( to_entries[-2:] | from_entries)"
    ],
    "utterance": "Return an object where, for each top-level key, only the last two key-value pairs from its value object are kept.",
    "expressions": [
      "map_values( to_entries[-2:] | from_entries )",
      "map_values(delpaths(keys_unsorted[:-2] | map([.])))"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "abc": {
              "key1": "value1"
            },
            "bcd": {
              "key1": "value1"
            },
            "cde": {
              "key1": "value1"
            },
            "def": {
              "key1": "value1"
            },
            "efg": {
              "key1": "value1"
            },
            "fgh": {
              "key1": "value1"
            }
          },
          "bar": {
            "ghi": {
              "key1": "value1"
            }
          },
          "qux": {
            "hij": {
              "key1": "value1"
            },
            "ijk": {
              "key1": "value1"
            },
            "jkl": {
              "key1": "value1"
            },
            "klm": {
              "key1": "value1"
            }
          }
        },
        "output": {
          "foo": {
            "efg": {
              "key1": "value1"
            },
            "fgh": {
              "key1": "value1"
            }
          },
          "bar": {
            "ghi": {
              "key1": "value1"
            }
          },
          "qux": {
            "jkl": {
              "key1": "value1"
            },
            "klm": {
              "key1": "value1"
            }
          }
        }
      }
    ],
    "identifier": 58181874
  },
  {
    "context": [
      "What would be the appropriate `jq` query to replace the `value` of the `name: foo` element or create/add the element to the array, if it doesn't already exist?",
      ".elements \n|=  (map(.name) | index(\"foo\")) as $ix\n    | if $ix \n      then .[$ix][\"value\"] = \"BAR\" \n      else . + [{name: \"foo\", value: \"BAR\"}]\n      end",
      ".elements |= upsert(\"foo\"; \"BAR\")",
      "def upsert($foo; $bar):\n  (map(.name) | index($foo)) as $ix\n  | if $ix then .[$ix][\"value\"] = $bar else . + [{name: $foo, value: $bar}] end;"
    ],
    "utterance": "Update the value of the element where name equals foo to BAR, or add an element with name foo and value BAR if it does not exist.",
    "expressions": [
      ".elements |= (map(.name) | index(\"foo\")) as $ix | if $ix then .[$ix][\"value\"] = \"BAR\" else . + [{name: \"foo\", value: \"BAR\"}] end",
      "def upsert($foo; $bar): (map(.name) | index($foo)) as $ix | if $ix then .[$ix][\"value\"] = $bar else . + [{name: $foo, value: $bar}] end; .elements |= upsert(\"foo\"; \"BAR\")"
    ],
    "data": [
      {
        "input": {
          "elements": [
            {
              "name": "disregard",
              "value": "me"
            },
            {
              "name": "foo",
              "value": "bar"
            },
            {
              "name": "dont-edit",
              "value": "me"
            }
          ]
        },
        "output": {
          "elements": [
            {
              "name": "disregard",
              "value": "me"
            },
            {
              "name": "foo",
              "value": "BAR"
            },
            {
              "name": "dont-edit",
              "value": "me"
            }
          ]
        }
      },
      {
        "input": {
          "elements": [
            {
              "name": "disregard",
              "value": "me"
            },
            {
              "name": "dont-edit",
              "value": "me"
            }
          ]
        },
        "output": {
          "elements": [
            {
              "name": "disregard",
              "value": "me"
            },
            {
              "name": "dont-edit",
              "value": "me"
            },
            {
              "name": "foo",
              "value": "BAR"
            }
          ]
        }
      }
    ],
    "identifier": 58239765
  },
  {
    "context": [
      "I want to pipe the output to `jq` so that I can return the key and name from each object, e.g. \"63\" \"Tree\" (I am not concerned if the result is in parentheses or how the fields are separated or whether \"name\": is included.)",
      "A succinct, efficient, and some would say elegant, solution:",
      "    map_values(.name)",
      "One of many alternatives:",
      "    with_entries( {key, value: .value.name} )"
    ],
    "utterance": "For each top-level object, output its key along with the value of its \"name\" field, for example: \"63\" and \"Tree\".",
    "expressions": [
      "map_values(.name)",
      "with_entries( {key, value: .value.name} )"
    ],
    "data": [
      {
        "input": {
          "63": {
            "state": {
              "on": false,
              "alert": "select",
              "mode": "automation",
              "reachable": true
            },
            "swupdate": {
              "state": "notupdatable",
              "lastinstall": "2019-09-15T11:19:15"
            },
            "type": "plug",
            "name": "Tree",
            "modelid": "XXX",
            "manufacturername": "XXX",
            "productname": "plug",
            "capabilities": {
              "certified": false,
              "control": {},
              "streaming": {
                "renderer": false,
                "proxy": false
              }
            },
            "config": {
              "archetype": "plug",
              "function": "functional",
              "direction": "omnidirectional"
            },
            "uniqueid": "00:0d:6f:ff:fe:da:c9:dc-01",
            "swversion": "2.0.022"
          }
        },
        "output": {
          "63": "Tree"
        }
      }
    ],
    "identifier": 58268892
  },
  {
    "context": [
      "Also, how to add the scores of two different players separately?",
      "{\r\n    \"game\":\r\n        {\"player1\": {\"score\": 2},\r\n         \"player2\": {\"score\": 20}}}\r\n{\r\n    \"game\": \r\n        {\"player1\": {\"score\": 4},\r\n         \"player2\": {\"score\": 40}}}\r\n",
      "$ cat foo.json | jq '???'",
      "{ \"player1\": 6, \"player2\": 60} ",
      "jq -n 'reduce inputs.game as $game ({};\r\n  reduce ($game|keys_unsorted)[] as $player (.;\r\n    .[$player] += $game[$player].score\r\n  )\r\n)' file",
      "add_by_column(inputs | .game | map_values(.score) )",
      "reduce kvrows as $e ({}; .[$e.key] += $e.value)"
    ],
    "utterance": "Calculate the sum of each player's score across multiple streamed objects, producing an object with each player's total.",
    "expressions": [
      "reduce inputs.game as $game ({};\n  reduce ($game|keys_unsorted)[] as $player (.;\n    .[$player] += $game[$player].score\n  )\n)",
      "add_by_column(inputs | .game | map_values(.score) )",
      "def kvrows: inputs[] | .[] |= .[] | to_entries[] ;\nreduce kvrows as $e ({}; .[$e.key] += $e.value)"
    ],
    "data": [
      {
        "input": [
          {
            "game": {
              "player1": {
                "score": 2
              },
              "player2": {
                "score": 20
              }
            }
          },
          {
            "game": {
              "player1": {
                "score": 4
              },
              "player2": {
                "score": 40
              }
            }
          }
        ],
        "output": {
          "player1": 6,
          "player2": 60
        }
      }
    ],
    "identifier": 58243611
  },
  {
    "context": [
      "I have a file which has multiple individual JSON arrays, which I want to combine (and remove empty arrays) into a single JSON array",
      "Required output",
      "[\n\t[\n\t\t\"asdfsdfsdf\",\n\t\t\"CCsdfnceR1\",\n\t\t\"running\",\n\t\t\"us-east-1a\",\n\t\t\"34.6X.7X.2X\",\n\t\t\"10.75.170.118\"\n\t],\n\t[\n\t\t\"tyutyut\",\n\t\t\"CENTOS-BASE\",\n\t\t\"stopped\",\n\t\t\"us-west-2b\",\n\t\tnull,\n\t\t\"10.87.159.249\"\n\t],\n\t[\n\t\t\"tyutyut\",\n\t\t\"dfgdfg-TEST\",\n\t\t\"stopped\",\n\t\t\"us-west-2b\",\n\t\t\"54.2X.8.X8\",\n\t\t\"10.87.159.247\"\n\t]\n]",
      "This selects only non-empty arrays none of whose elements is an array, and puts them into an array:\n```\njq -n '[ inputs | .. | select(type==\"array\" and .!=[] and all(.[]; type!=\"array\")) ]' file\n```",
      "With this def, and the following \"main\" program:\n[inputs | peel]\nan invocation of jq using the -n option produces the expected result."
    ],
    "utterance": "Combine all non-empty nested arrays from multiple array inputs in a file into a single flattened array, omitting empty arrays.",
    "expressions": [
      "[ inputs | .. | select(type==\"array\" and .!=[] and all(.[]; type!=\"array\")) ]",
      "def peel:\n  if type == \"array\"\n  then if length == 0 then empty\n       elif length == 1 and (.[0] | type) == \"array\" then .[0] | peel\n       elif all(.[]; type==\"array\") then .[] | peel\n       else [.[] | peel]\n       end\n  else .\n  end;\n[inputs | peel]"
    ],
    "data": [
      {
        "input": [
          [],
          [],
          [
            [
              [
                "asdfsdfsdf",
                "CCsdfnceR1",
                "running",
                "us-east-1a",
                "34.6X.7X.2X",
                "10.75.170.118"
              ]
            ]
          ],
          [],
          [],
          [
            [
              [
                "tyutyut",
                "CENTOS-BASE",
                "stopped",
                "us-west-2b",
                null,
                "10.87.159.249"
              ]
            ],
            [
              [
                "tyutyut",
                "dfgdfg-TEST",
                "stopped",
                "us-west-2b",
                "54.2X.8.X8",
                "10.87.159.247"
              ]
            ]
          ]
        ],
        "output": [
          [
            "asdfsdfsdf",
            "CCsdfnceR1",
            "running",
            "us-east-1a",
            "34.6X.7X.2X",
            "10.75.170.118"
          ],
          [
            "tyutyut",
            "CENTOS-BASE",
            "stopped",
            "us-west-2b",
            null,
            "10.87.159.249"
          ],
          [
            "tyutyut",
            "dfgdfg-TEST",
            "stopped",
            "us-west-2b",
            "54.2X.8.X8",
            "10.87.159.247"
          ]
        ]
      }
    ],
    "identifier": 58227118
  },
  {
    "context": [
      "Assuming you&#39;re not interested in key names that happen to look like URLs, you could consider using something like the following:",
      "jq -r &#39;.. | strings | capture(\"(?<x>(http|https)://[^\\\"\"]+)\") | .x&#39;"
    ],
    "utterance": "Extract all string values that match the pattern (http|https)://[^\\\"]+.",
    "expressions": [
      ".. | strings | capture(\"(?<x>(http|https)://[^\\\"\"]+)\") | .x"
    ],
    "identifier": 58272827
  },
  {
    "context": [
      "I would like to filter some lines based on \"person\" key value and put them to another jsonlines file, preferably named the same as \"person\" key value. For instance, file named \"Senator Andrzej Szczypiorski.json\" should contain each line of BIG.json that had exactly \"Senator Andrzej Szczypiorski\" value under the \"person\" key.",
      "jq -c 'select(.filename==\"path_to_file2\" and .date==\"2016-10-22\")' input.txt > output.txt"
    ],
    "utterance": "Extract all objects where the person key is exactly Senator Andrzej Szczypiorski.",
    "expressions": [
      "select(.person == \"Senator Andrzej Szczypiorski\")"
    ],
    "data": [
      {
        "input": [
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.4",
            "txt": "Rzeczpospolita Polska powraca..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.5",
            "txt": "Powiedzia\u0142em, \u017ce Polska wraca..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.6",
            "txt": "St\u0105d w\u0142a\u015bnie dzisiejsze zetkni\u0119cie si\u0119..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.7",
            "txt": "O c\u00f3\u017c idzie w kwestii samorz\u0105du..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.8",
            "txt": "Jest to zmiana rewolucyjna..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.9",
            "txt": "Towarzyszy\u0142o nam, i to zrozumia\u0142e..."
          },
          {
            "filename": "other/file2.xml",
            "period": "1989-1991",
            "title": "Something else",
            "date": "1990-01-20",
            "person": "Senator Someone Else",
            "txt_id": "u-88.1",
            "txt": "Text from someone else"
          }
        ],
        "output": [
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.4",
            "txt": "Rzeczpospolita Polska powraca..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.5",
            "txt": "Powiedzia\u0142em, \u017ce Polska wraca..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.6",
            "txt": "St\u0105d w\u0142a\u015bnie dzisiejsze zetkni\u0119cie si\u0119..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.7",
            "txt": "O c\u00f3\u017c idzie w kwestii samorz\u0105du..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.8",
            "txt": "Jest to zmiana rewolucyjna..."
          },
          {
            "filename": "ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml",
            "period": "1989-1991",
            "title": "17 posiedzenie Senatu PRL/RP",
            "date": "1990-01-19",
            "person": "Senator Andrzej Szczypiorski",
            "txt_id": "u-59.9",
            "txt": "Towarzyszy\u0142o nam, i to zrozumia\u0142e..."
          }
        ]
      }
    ],
    "identifier": 58181835
  },
  {
    "context": [
      "I need the .index, before each json line of ._source.",
      "I need the result to look like this:\n```\n{\"index\": {}}\n{/* ._source json line*/}\n{\"index\": {}}\n{/* ._source json line*/}\nand so on...\n```",
      "I got it. Using `jq '.index,._source'` did the trick."
    ],
    "utterance": "Display an object with key 'index' followed by the corresponding '_source' object for each item, repeating this sequence for each entry.",
    "expressions": [
      ".index, ._source"
    ],
    "identifier": 58305729
  },
  {
    "context": [
      "Given this json file `wtf.json`:\r\n\r\n    {\r\n      \"I-am-test-v2\": {\r\n        \"exist\": true\r\n      },\r\n      \"works\": {\r\n        \"exist\": true\r\n      }\r\n    }",
      "yet I cannot select:\r\n\r\n    $ jq .I-am-test-v2 wtf.json\r\n\r\nas that will yield in error:",
      "I also tried:\r\n\r\n    jq .[\"I-am-test-v2\"] wtf.json\r\n\r\n",
      "You can access it via proper enquotation via:\r\n\r\n    jq '[\"I-am-test-v2\"]' wtf.json ",
      "You need to tell `jq` that it's a string by double quoting your key.",
      "<wtf.json jq '.\"I-am-test-v2\"' "
    ],
    "utterance": "Extract the value associated with the key I-am-test-v2, where the key contains dashes.",
    "expressions": [
      ".[\"I-am-test-v2\"]",
      ".\"I-am-test-v2\""
    ],
    "data": [
      {
        "input": {
          "I-am-test-v2": {
            "exist": true
          },
          "works": {
            "exist": true
          }
        },
        "output": {
          "exist": true
        }
      }
    ],
    "identifier": 58288556
  },
  {
    "context": [
      "I am struggling to use `jq` to massage the input data so that the first level keys are preserved, while the lower level JSON gets converted to escaped strings.",
      "Is there a \"pure\" `jq` solution to this?",
      "`with_entries` and `tostring` seem to do the trick:",
      "$ jq 'with_entries(.value |= tostring )' example.json",
      "Try this",
      "jq \"{a: .a, b: .b | tostring, f: .f}\" input.json",
      "You can use `jq` with [`map_values`][1] and [`tojson`][2]:",
      "jq 'map_values(if type == \"object\" then tojson else . end)' file"
    ],
    "utterance": "Convert all first-level object values to strings if they are objects, escaping any lower-level structures, while preserving first-level keys and leaving scalar values unchanged.",
    "expressions": [
      "with_entries(.value |= tostring )",
      "{a: .a, b: .b | tostring, f: .f}",
      "map_values(if type == \"object\" then tojson else . end)"
    ],
    "data": [
      {
        "input": {
          "a": "1",
          "b": {
            "c": "2",
            "d": {
              "e": "3"
            }
          },
          "f": "4"
        },
        "output": {
          "a": "1",
          "b": "{\"c\":\"2\",\"d\":{\"e\":\"3\"}}",
          "f": "4"
        }
      }
    ],
    "identifier": 58303358
  },
  {
    "context": [
      "But I want to get the result in a TSV format, as this.\r\n\r\n```\r\nP04637<TAB>1<TAB>22\r\nP04637<TAB>26<TAB>27\r\n...\r\n```",
      "Does anybody know what is the correct jq command to extract the output in this format?",
      ".[][0]\r\n| [.[0]] + (.[2].disorder.consranges[])\r\n| @tsv",
      "The following will handle both the two variants in the update to the Q:\r\n```\r\n  .[][0]\r\n  | try [.[0]] + (.[2].disorder.consranges[])\r\n  | @tsv\r\n```",
      "Here is an illustration of one way to increase the flexibility of the program with respect to the structure of the inputs, without using `try` at all:\r\n```\r\n.[][]\r\n| .[0] as $p\r\n| ..\r\n| objects\r\n| select(has(\"disorder\"))\r\n| [$p] + (.disorder.consranges[])\r\n| @tsv\r\n```"
    ],
    "utterance": "Extract all consranges for each protein accession and print each range as a line with the accession, start, and end, separated by tabs.",
    "expressions": [
      ".[][0] | [.[0]] + (.[2].disorder.consranges[]) | @tsv",
      ".[][0] | try [.[0]] + (.[2].disorder.consranges[]) | @tsv",
      ".[][] | .[0] as $p | .. | objects | select(has(\"disorder\")) | [$p] + (.disorder.consranges[]) | @tsv"
    ],
    "data": [
      {
        "input": [
          [
            "P04637",
            "Some Value",
            {
              "disorder": {
                "consranges": [
                  [
                    "1",
                    "22"
                  ],
                  [
                    "26",
                    "27"
                  ],
                  [
                    "30",
                    "31"
                  ]
                ]
              }
            }
          ],
          [
            "P51608",
            "Another Value",
            {
              "disorder": {
                "consranges": [
                  [
                    "1",
                    "118"
                  ],
                  [
                    "151",
                    "281"
                  ]
                ]
              }
            }
          ]
        ],
        "output": "P04637\t1\t22\nP04637\t26\t27\nP04637\t30\t31\nP51608\t1\t118\nP51608\t151\t281"
      }
    ],
    "identifier": 58194056
  },
  {
    "context": [
      "I'd like to join the arrays '.fileStats' and '.files' so that there's only one array.",
      "but being able to select the objects based on '.wanted' being true/false and then retrieving '.name' is more desirable.",
      "jq '.arguments.torrents[] | range(.fileStats|length) as $i| select(.fileStats[$i].wanted)| .fileStats[$i]+.files[$i]'",
      "It gives the following output with your input.",
      "{\n  \"bytesCompleted\": 0,\n  \"priority\": 0,\n  \"wanted\": true,\n  \"length\": 99,\n  \"name\": \"2.exe\"\n}",
      "{\n  \"bytesCompleted\": 0,\n  \"priority\": 0,\n  \"wanted\": true,\n  \"length\": 4833317512,\n  \"name\": \"3.iso\"\n}"
    ],
    "utterance": "Join the elements of the .fileStats and .files arrays by index, merging their fields, and output only those with wanted set to true.",
    "expressions": [
      ".arguments.torrents[] | range(.fileStats|length) as $i| select(.fileStats[$i].wanted)| .fileStats[$i]+.files[$i]"
    ],
    "data": [
      {
        "input": {
          "arguments": {
            "torrents": [
              {
                "fileStats": [
                  {
                    "bytesCompleted": 0,
                    "priority": 0,
                    "wanted": false
                  },
                  {
                    "bytesCompleted": 0,
                    "priority": 0,
                    "wanted": true
                  },
                  {
                    "bytesCompleted": 0,
                    "priority": 0,
                    "wanted": true
                  }
                ],
                "files": [
                  {
                    "bytesCompleted": 0,
                    "length": 30,
                    "name": "1.txt"
                  },
                  {
                    "bytesCompleted": 0,
                    "length": 99,
                    "name": "2.exe"
                  },
                  {
                    "bytesCompleted": 0,
                    "length": 4833317512,
                    "name": "3.iso"
                  }
                ]
              }
            ]
          },
          "result": "success"
        },
        "output": [
          {
            "bytesCompleted": 0,
            "priority": 0,
            "wanted": true,
            "length": 99,
            "name": "2.exe"
          },
          {
            "bytesCompleted": 0,
            "priority": 0,
            "wanted": true,
            "length": 4833317512,
            "name": "3.iso"
          }
        ]
      }
    ],
    "identifier": 58351561
  },
  {
    "context": [
      "It basically i want to combine the object where both id's are same.",
      "< sample.json jq -n '[inputs[]]\n  | group_by(.id)\n  | map( reduce .[] as $x\n           (.[0]|{id}; \n           .secondaryAddresses += ($x | .secondaryAddresses)))'",
      "aggregate_by( inputs[]; .id; .secondaryAddresses)\n| map_values( add )\n| to_entries\n| map( {id: .key, secondaryAddresses: .value } )"
    ],
    "utterance": "Combine objects with the same id by merging their secondaryAddresses fields into a single object for each id.",
    "expressions": [
      "[inputs[]]\n| group_by(.id)\n| map(reduce .[] as $x (.[0]|{id}; .secondaryAddresses += ($x | .secondaryAddresses)))",
      "aggregate_by( inputs[]; .id; .secondaryAddresses)\n| map_values( add )\n| to_entries\n| map({id: .key, secondaryAddresses: .value})"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "7972",
              "secondaryAddresses": {
                "1-2G8AXE": {
                  "isDefaultBillingAddress": "true",
                  "isDefaultShippingAddress": "true"
                }
              }
            }
          ],
          [
            {
              "id": "7972",
              "secondaryAddresses": {
                "1-4BR2P6B": {
                  "isDefaultBillingAddress": "false",
                  "isDefaultShippingAddress": "false"
                }
              }
            }
          ],
          [
            {
              "id": "6980",
              "secondaryAddresses": {
                "1-9BR289B": {
                  "isDefaultBillingAddress": "false",
                  "isDefaultShippingAddress": "false"
                }
              }
            }
          ],
          [
            {
              "id": "6980",
              "secondaryAddresses": {
                "1-8B0989B": {
                  "isDefaultBillingAddress": "false",
                  "isDefaultShippingAddress": "false"
                }
              }
            }
          ]
        ],
        "output": [
          {
            "id": "7972",
            "secondaryAddresses": {
              "1-2G8AXE": {
                "isDefaultBillingAddress": "true",
                "isDefaultShippingAddress": "true"
              },
              "1-4BR2P6B": {
                "isDefaultBillingAddress": "false",
                "isDefaultShippingAddress": "false"
              }
            }
          },
          {
            "id": "6980",
            "secondaryAddresses": {
              "1-9BR289B": {
                "isDefaultBillingAddress": "false",
                "isDefaultShippingAddress": "false"
              },
              "1-8B0989B": {
                "isDefaultBillingAddress": "false",
                "isDefaultShippingAddress": "false"
              }
            }
          }
        ]
      }
    ],
    "identifier": 58308298
  },
  {
    "context": [
      "I need to display the InstanceId where \"Key\" == \"environment\" and \"Value\" == \"ops\".",
      "this will output the `InstanceId`s of JSON objects that contain a `Tag` with `Key` `environment` and `Value` `ops`.",
      "jq 'select( .Tags[] | (.Key == \"environment\" and .Value == \"ops\")) | .InstanceId' < source.json",
      "select( any(.Tags[]; .Key==\"environment\" and .Value == \"ops\") )\n| .InstanceId",
      "{\"Key\": \"environment\", \"Value\": \"ops\"} as $object\n| select( .Tags | index($object) )\n| .InstanceId"
    ],
    "utterance": "Return the InstanceId for each object that has a tag with Key equal to environment and Value equal to ops.",
    "expressions": [
      "select( .Tags[] | (.Key == \"environment\" and .Value == \"ops\")) | .InstanceId",
      "select( any(.Tags[]; .Key==\"environment\" and .Value == \"ops\") ) | .InstanceId",
      "{\"Key\": \"environment\", \"Value\": \"ops\"} as $object | select( .Tags | index($object) ) | .InstanceId"
    ],
    "data": [
      {
        "input": [
          {
            "InstanceId": "i-9KwoRGF6jbhYdZi823aE4qN",
            "Tags": [
              {
                "Key": "blah",
                "Value": "server-blah"
              },
              {
                "Key": "environment",
                "Value": "ops"
              },
              {
                "Key": "server_role",
                "Value": "appserver"
              },
              {
                "Key": "Name",
                "Value": "some_name"
              },
              {
                "Key": "product",
                "Value": "some_server"
              }
            ]
          },
          {
            "InstanceId": "i-OTHER",
            "Tags": [
              {
                "Key": "environment",
                "Value": "dev"
              }
            ]
          }
        ],
        "output": [
          "i-9KwoRGF6jbhYdZi823aE4qN"
        ]
      }
    ],
    "identifier": 58384507
  },
  {
    "context": [
      "jq --arg ip \"$IP\" '.nodes|.app|.ip = $ip' nodes.json",
      "ssh -o StrictHostKeyChecking=no -i key.pem user@\"172.13.1.23\" \"jq --arg ip \"127.0.0.1\" '.nodes|.app|.ip = $ip' nodes.json\"",
      "`$ip` is in double quotes, and so is expanded locally. You need to escape the dollar sign.",
      "ssh -o StrictHostKeyChecking=no -i key.pem user@\"172.13.1.23\" \\\n  \"jq --arg ip \"127.0.0.1\" '.nodes|.app|.ip = \\$ip' nodes.json\""
    ],
    "utterance": "Update the ip field under nodes.app to 127.0.0.1 in the data.",
    "expressions": [
      "jq --arg ip \"127.0.0.1\" '.nodes|.app|.ip = $ip' nodes.json"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "app": {
              "ip": "old-value",
              "cpus": 16,
              "memory": 64
            },
            "is_manager": true,
            "nodes": 1
          }
        },
        "output": {
          "nodes": {
            "app": {
              "ip": "127.0.0.1",
              "cpus": 16,
              "memory": 64
            },
            "is_manager": true,
            "nodes": 1
          }
        }
      }
    ],
    "identifier": 58396392
  },
  {
    "context": [
      "the .Principal.AWS contains value in one and array of values in another",
      "If its an array I am using join to combine the values and then  for object i am getting error",
      ".AssumeRolePolicyDocument.Statement[] | select (.Principal.AWS? != \"null\") | (.Principal.AWS |join (\"###\"))",
      "jq: error (at stackflow.json:46): Cannot iterate over string (\"arn:aws:ia...)\r\n",
      "The following jq filter produces the desired result:",
      ".RoleName + \" \" +\n  (.AssumeRolePolicyDocument.Statement[]\n   | select( .Principal.AWS? != null )\n   | .Principal.AWS\n   | if type == \"array\" then join(\"###\") else tostring end )"
    ],
    "utterance": "For each object, output the RoleName followed by the AWS principal value(s) from all Statement entries; if AWS is an array, join its values with ###, otherwise use its string value.",
    "expressions": [
      ".RoleName + \" \" + (.AssumeRolePolicyDocument.Statement[] | select(.Principal.AWS? != null) | .Principal.AWS | if type == \"array\" then join(\"###\") else tostring end)"
    ],
    "data": [
      {
        "input": [
          {
            "RoleName": "AccessKeyRotation-LambdaRole",
            "AssumeRolePolicyDocument": {
              "Statement": [
                {
                  "Effect": "Allow",
                  "Principal": {
                    "Service": "lambda.amazonaws.com"
                  },
                  "Action": "sts:AssumeRole"
                }
              ]
            }
          },
          {
            "RoleName": "allow-test-account-to-hostedzones",
            "AssumeRolePolicyDocument": {
              "Statement": [
                {
                  "Sid": "",
                  "Effect": "Allow",
                  "Principal": {
                    "AWS": [
                      "arn:aws:iam::426544XX7585196:root",
                      "arn:aws:iam::640XXX556689289:root"
                    ]
                  },
                  "Action": "sts:AssumeRole"
                }
              ]
            }
          },
          {
            "RoleName": "allow-test-env-access-to-route53",
            "AssumeRolePolicyDocument": {
              "Version": "2012-10-17",
              "Statement": [
                {
                  "Effect": "Allow",
                  "Principal": {
                    "AWS": "arn:aws:iam::445666XX779289:root"
                  },
                  "Action": "sts:AssumeRole"
                }
              ]
            }
          }
        ],
        "output": [
          "allow-test-account-to-hostedzones arn:aws:iam::426544XX7585196:root###arn:aws:iam::640XXX556689289:root",
          "allow-test-env-access-to-route53 arn:aws:iam::445666XX779289:root"
        ]
      }
    ],
    "identifier": 58351976
  },
  {
    "context": [
      "Is it possible to pass and use in jq a variable of type array?",
      "jq --arg ips \"${IPs[0]}\" '.nodes.app.ip = $ips[0] | .nodes.data.ip = $ips[1]' nodes.json",
      "jq -Rn --argjson original_doc \"$original_doc\" '\n  input | split(\"\\u0000\") as $ips\n  | $original_doc\n  | .nodes.app.ip = $ips[0]\n  | .nodes.data.ip = $ips[1]\n' < <(printf '%s\\0' \"${IPs[@]}\")",
      "jq --argjson ips \"$IPs_json\" '\n    .nodes.app.ip = $ips[0]\n  | .nodes.data.ip = $ips[1]\n' <<<'{\"nodes\": { \"app\": {}, \"data\": {} }}'"
    ],
    "utterance": "Set .nodes.app.ip and .nodes.data.ip to the first and second elements of a shell array variable respectively.",
    "expressions": [
      ".nodes.app.ip = $ips[0] | .nodes.data.ip = $ips[1]"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "app": {},
            "data": {}
          }
        },
        "output": {
          "nodes": {
            "app": {
              "ip": "1.2.3.4"
            },
            "data": {
              "ip": "5.6.7.8"
            }
          }
        }
      }
    ],
    "identifier": 58399373
  },
  {
    "context": [
      "Is it possible to print parts of the document in a filter and then move on to select further down and print more later?",
      "select(.some.more.depth==\"here\") | tee .version | .some.more.depth",
      "That&#39;s what the comma operator does, and what it&#39;s for. It runs two expressions in the same context and produces all of the outputs of both."
    ],
    "utterance": "Select documents where .some.more.depth equals \"here\" and output both the value of .version and the value of .some.more.depth.",
    "expressions": [
      "select(.some.more.depth==\"here\") | .version, .some.more.depth"
    ],
    "data": [
      {
        "input": {
          "version": "1",
          "some": {
            "more": {
              "depth": "here"
            }
          }
        },
        "output": [
          "1",
          "here"
        ]
      }
    ],
    "identifier": 58402639
  },
  {
    "context": [
      "how can I format it this way using jq?",
      "group_by(.name) | map({\n    key: .[0].name,\n    values: (group_by(.city) | map({\n        key: .[0].city,\n        values: map({number,type})\n    }))\n})"
    ],
    "utterance": "Group an array of objects first by the value of the 'name' field and then by the 'city' field, nesting the results so that each outer group's key is the name, containing values for each city key, which contain arrays of objects with only the 'number' and 'type' fields.",
    "expressions": [
      "group_by(.name) | map({\n  key: .[0].name,\n  values: (group_by(.city) | map({\n    key: .[0].city,\n    values: map({number,type})\n  }))\n})"
    ],
    "data": [
      {
        "input": [
          {
            "name": "A",
            "number": 1,
            "type": "apple",
            "city": "NYC"
          },
          {
            "name": "A",
            "number": "5",
            "type": "apple",
            "city": "LA"
          },
          {
            "name": "A",
            "number": 2,
            "type": "apple",
            "city": "NYC"
          },
          {
            "name": "B",
            "number": 3,
            "type": "apple",
            "city": "NYC"
          }
        ],
        "output": [
          {
            "key": "A",
            "values": [
              {
                "key": "LA",
                "values": [
                  {
                    "number": "5",
                    "type": "apple"
                  }
                ]
              },
              {
                "key": "NYC",
                "values": [
                  {
                    "number": 1,
                    "type": "apple"
                  },
                  {
                    "number": 2,
                    "type": "apple"
                  }
                ]
              }
            ]
          },
          {
            "key": "B",
            "values": [
              {
                "key": "NYC",
                "values": [
                  {
                    "number": 3,
                    "type": "apple"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 58401262
  },
  {
    "context": [
      "For the above json file, I want print parent-child relation in a row.",
      "I also want to have the mapping from keys to names.",
      "In your case, each child knows its own parent so the task is trivial using `..`:",
      ".. | objects | .children[]? | [.parent,.key] | @tsv",
      "Similarly for key-name pairs:",
      ".. | objects | .children[]? | [.key, .name] | @tsv"
    ],
    "utterance": "List each parent-child key pair and each key-name pair in a tree structure, one per row, tab-separated.",
    "expressions": [
      ".. | objects | .children[]? | [.parent,.key] | @tsv",
      ".. | objects | .children[]? | [.key, .name] | @tsv"
    ],
    "identifier": 58404267
  },
  {
    "context": [
      "My .csv output must contain an ID field, a Medal field and a field for # of Medals and look like this....\n\n    1019761328,\"medalCarius\",1\n    1019761328,\"medalHalonen\",3\n    1019761328,\"aimer\",6\n\n    ...... etc. repeated for every ID",
      "You can expand `.value` again with another application of `to_entries[]` and then generate csv output with [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\(foo\\)).\ne.g.\n\n    .data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | \"\\(.id),\\(.val.key),\\(.val.value)\"",
      "For your specific case a more robust way would be to use [`@csv`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) instead of string interpolation. e.g. \n```\n.data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | [.id, .val.key, .val.value] | @csv\n```",
      "If you know the id is a number and want the output to reflect that you can use [`tonumber`](https://stedolan.github.io/jq/manual/#tonumber) as well:\n\n```\n.data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | [(.id|tonumber), .val.key, .val.value] | @csv\n```"
    ],
    "utterance": "Output each ID, medal name, and medal count as one line per medal with three columns: ID, medal, count",
    "expressions": [
      ".data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | \"\\(.id),\\(.val.key),\\(.val.value)\"",
      ".data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | [.id, .val.key, .val.value] | @csv",
      ".data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | [(.id|tonumber), .val.key, .val.value] | @csv"
    ],
    "data": [
      {
        "input": {
          "status": "ok",
          "meta": {
            "count": 4
          },
          "data": {
            "1019761328": {
              "achievements": {
                "medalCarius": 1,
                "medalHalonen": 3,
                "aimer": 6
              },
              "frags": {
                "crucialShotMedal": 0
              },
              "max_series": {
                "armorPiercer": 18
              }
            }
          }
        },
        "output": [
          "\"1019761328\",\"medalCarius\",1",
          "\"1019761328\",\"medalHalonen\",3",
          "\"1019761328\",\"aimer\",6",
          "\"1019761328\",\"crucialShotMedal\",0",
          "\"1019761328\",\"armorPiercer\",18"
        ]
      }
    ],
    "identifier": 58271333
  },
  {
    "context": [
      "For every item in the \"sub list\", i would need to create another record in my csv file.",
      "I am having trouble with record 2 because MeterRates is actually the list where i need both, the attribute and the value. I would need record 2, once parsed, to correspond to 3 records in the CSV file where each record contains one item of the list in the MeterRates.",
      "You could just add a new property to hold the value of the corresponding `MeterRate`.",
      ".Meters[] | .MeterRate = (.MeterRates | to_entries[])\n    | [.EffectiveDate, .IncludedQuantity, .MeterCategory, .MeterId , .MeterName,\n       .MeterRate.key, .MeterRate.value,\n       .MeterRegion, .MeterStatus, .MeterSubCategory, .MeterTags[], .Units]\n    | @csv"
    ],
    "utterance": "Output a CSV with one row for each key/value pair in MeterRates, including the meter attributes, the MeterRates key, and the MeterRates value as columns.",
    "expressions": [
      ".Meters[] | .MeterRate = (.MeterRates | to_entries[]) | [.EffectiveDate, .IncludedQuantity, .MeterCategory, .MeterId , .MeterName, .MeterRate.key, .MeterRate.value, .MeterRegion, .MeterStatus, .MeterSubCategory, .MeterTags[], .Unit] | @csv"
    ],
    "data": [
      {
        "input": {
          "OfferTerms": [],
          "Meters": [
            {
              "EffectiveDate": "2019-03-01T00:00:00Z",
              "IncludedQuantity": 0,
              "MeterCategory": "Virtual Machines",
              "MeterId": "d0bf9053-17c4-4fec-8502-4eb8376343a7",
              "MeterName": "F2/F2s Low Priority",
              "MeterRates": {
                "0": 0.0766
              },
              "MeterRegion": "US West 2",
              "MeterStatus": "Active",
              "MeterSubCategory": "F/FS Series Windows",
              "MeterTags": [],
              "Unit": "1 Hour"
            },
            {
              "EffectiveDate": "2014-11-01T00:00:00Z",
              "IncludedQuantity": 0,
              "MeterCategory": "Azure DevOps",
              "MeterId": "c4d6fa88-0df9-4680-867a-b13c960a875f",
              "MeterName": "Virtual User Minute",
              "MeterRates": {
                "0": 0.0004,
                "1980000": 0.0002,
                "9980000": 0.0001
              },
              "MeterRegion": "",
              "MeterStatus": "Active",
              "MeterSubCategory": "Cloud-Based Load Testing",
              "MeterTags": [],
              "Unit": "1/Month"
            },
            {
              "EffectiveDate": "2017-04-01T00:00:00Z",
              "IncludedQuantity": 0,
              "MeterCategory": "SQL Database",
              "MeterId": "cb770eab-d5c8-45fd-ac56-8c35069f5a29",
              "MeterName": "P4 DTUs",
              "MeterRates": {
                "0": 68.64
              },
              "MeterRegion": "IN West",
              "MeterStatus": "Active",
              "MeterSubCategory": "Single Premium",
              "MeterTags": [],
              "Unit": "1/Day"
            }
          ]
        },
        "output": [
          "\"2019-03-01T00:00:00Z\",0,\"Virtual Machines\",\"d0bf9053-17c4-4fec-8502-4eb8376343a7\",\"F2/F2s Low Priority\",0,0.0766,\"US West 2\",\"Active\",\"F/FS Series Windows\",\"1 Hour\"",
          "\"2014-11-01T00:00:00Z\",0,\"Azure DevOps\",\"c4d6fa88-0df9-4680-867a-b13c960a875f\",\"Virtual User Minute\",0,0.0004,\"\",\"Active\",\"Cloud-Based Load Testing\",\"1/Month\"",
          "\"2014-11-01T00:00:00Z\",0,\"Azure DevOps\",\"c4d6fa88-0df9-4680-867a-b13c960a875f\",\"Virtual User Minute\",1980000,0.0002,\"\",\"Active\",\"Cloud-Based Load Testing\",\"1/Month\"",
          "\"2014-11-01T00:00:00Z\",0,\"Azure DevOps\",\"c4d6fa88-0df9-4680-867a-b13c960a875f\",\"Virtual User Minute\",9980000,0.0001,\"\",\"Active\",\"Cloud-Based Load Testing\",\"1/Month\"",
          "\"2017-04-01T00:00:00Z\",0,\"SQL Database\",\"cb770eab-d5c8-45fd-ac56-8c35069f5a29\",\"P4 DTUs\",0,68.64,\"IN West\",\"Active\",\"Single Premium\",\"1/Day\""
        ]
      }
    ],
    "identifier": 58398334
  },
  {
    "context": [
      "Since this question is tagged jq, and since yq is just a wrapper around jq, here's one solution using yq alone:",
      "yq -r '.data.\"my-config.yaml\"' configmap.yml |\n  yq .keyA.keyB"
    ],
    "utterance": "Extract the value of keyA.keyB ('a-value') from the my-config.yaml field inside the data of a ConfigMap resource file.",
    "expressions": [
      ".data[\"my-config.yaml\"] | from_yaml | .keyA.keyB"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "kind": "ConfigMap",
          "metadata": {
            "name": "my-configmap",
            "namespace": "some-namespace"
          },
          "data": {
            "my-config.yaml": "keyA:\n  keyB: a-value\n"
          }
        },
        "output": "a-value"
      }
    ],
    "identifier": 58423601
  },
  {
    "context": [
      "I have a json file where I'd like to transform the value of some named keys from numeric (`0`/`1`) to boolean (`0`=>`false`, `1`=>`true`) using `jq`.",
      "The transform should be re-entrant. If I run it on a (partially) transformed file, already converted keys should stay the same.",
      "Given this json file:",
      "...emits as output, given your input:",
      "def numerictobool:\n  if type == \"boolean\" then . else . == 1 end;\n\n.\n| .foo.bar.visible |= numerictobool\n| .foo.baz.tasty |= numerictobool\n| .fubar.enabled |= numerictobool\n| .fubar.sub.empty |= numerictobool\n| .running |= numerictobool"
    ],
    "utterance": "Convert the values of the keys .foo.bar.visible, .foo.baz.tasty, .fubar.enabled, .fubar.sub.empty, and .running from 0 or 1 to false or true, but leave them unchanged if already boolean.",
    "expressions": [
      "def numerictobool:\n  if type == \"boolean\" then . else . == 1 end;\n\n.\n| .foo.bar.visible |= numerictobool\n| .foo.baz.tasty |= numerictobool\n| .fubar.enabled |= numerictobool\n| .fubar.sub.empty |= numerictobool\n| .running |= numerictobool"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": {
              "color": "green",
              "visible": 0
            },
            "baz": {
              "fruit": "banana",
              "tasty": true
            }
          },
          "fubar": {
            "string": "hi",
            "value": "world",
            "enabled": 1,
            "sub": {
              "valuable": true,
              "empty": false
            }
          },
          "running": 1
        },
        "output": {
          "foo": {
            "bar": {
              "color": "green",
              "visible": false
            },
            "baz": {
              "fruit": "banana",
              "tasty": true
            }
          },
          "fubar": {
            "string": "hi",
            "value": "world",
            "enabled": true,
            "sub": {
              "valuable": true,
              "empty": false
            }
          },
          "running": true
        }
      }
    ],
    "identifier": 58403258
  },
  {
    "context": [
      "I want to use jq to filter out sub-array items that contain a specific key/value pair without filtering out the non-array data.",
      "Input:",
      "{\n  \"log\": {\n    \"foo\": {\n      ...\n    },\n    \"entries\": [\n      {\n        \"request\": {\n          \"method\": \"OPTIONS\",\n          \"url\": \"http://www.foobar.com\"\n        }\n      },\n      {\n        \"request\": {\n          \"method\": \"GET\",\n          \"url\": \"http://www.foobar.com\"\n        }\n      }\n    ]\n  }\n}",
      "Desired output:",
      "{\n  \"log\": {\n    \"foo\": {\n      ...\n    },\n    \"entries\": [\n      {\n        \"request\": {\n          \"method\": \"GET\",\n          \"url\": \"http://www.foobar.com\"\n        }\n      }\n    ]\n  }\n}",
      "I have tried this:\n\n    jq '(.log.entries[] | select(.request.method != \"OPTIONS\"))'\n\nBut then I lose the all of the JSON data above entries.",
      "Use `|=` assignment operator for modifying sub-elements in-place, e.g:\n```\n.log.entries |= map(select(.request.method != \"OPTIONS\"))\n```",
      "Directly use the `del()` operation on the object that matches your condition\n\n    del(.log.entries[] | select(.request.method == \"OPTIONS\"))"
    ],
    "utterance": "Remove all items from the log.entries array where request.method is OPTIONS, preserving all other data.",
    "expressions": [
      ".log.entries |= map(select(.request.method != \"OPTIONS\"))",
      "del(.log.entries[] | select(.request.method == \"OPTIONS\"))"
    ],
    "data": [
      {
        "input": {
          "log": {
            "foo": {
              "...": null
            },
            "entries": [
              {
                "request": {
                  "method": "OPTIONS",
                  "url": "http://www.foobar.com"
                }
              },
              {
                "request": {
                  "method": "GET",
                  "url": "http://www.foobar.com"
                }
              }
            ]
          }
        },
        "output": {
          "log": {
            "foo": {
              "...": null
            },
            "entries": [
              {
                "request": {
                  "method": "GET",
                  "url": "http://www.foobar.com"
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 58420277
  },
  {
    "context": [
      "The result I expected is \"C. Ronaldo\" but it gave me only \"C.\" How can I fix it?",
      "$ var=$(curl -s 'https://www.easports.com/fifa/ultimate-team/api/fut/item' | jq -r '.items[0].firstName')",
      "$ echo \"$var\"\nC. Ronaldo"
    ],
    "utterance": "Extract the firstName field from the first element in items, preserving spaces in the value such as 'C. Ronaldo'.",
    "expressions": [
      ".items[0].firstName"
    ],
    "identifier": 58431564
  },
  {
    "context": [
      "There's \"0\" in a JSON giving me trouble, I'm trying to grab the value at:\r\n\r\n> **response > data > sessions > 0 > user**",
      "The code I used was:\r\n\r\n    jq -r '.response.data.sessions.\"0\".user'",
      "The terminal returns: **jq: error (at <stdin>:1): Cannot index array with string \"0\"**",
      "I also tried:\r\n\r\n    jq -r '.response.data.sessions.0.user'",
      "The terminal returned: **jq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:\r\n.response.data.sessions.0.user**",
      "Can use like this",
      ".response.data.sessions[0].user"
    ],
    "utterance": "Extract the user field from the first element of the sessions array located under response > data.",
    "expressions": [
      ".response.data.sessions[0].user"
    ],
    "identifier": 58429264
  },
  {
    "context": [
      "I want to extract the url and the name from the JSON returned from the REST call and use those values to clone",
      "what I want to do is also change the name of the directory to the Name attribute, e.g. GitRepository1, GitRepository2 etc., instead of gitrepo1, gitrepo2 that is used automatically when that parameter is not passed",
      "I need help with the jq command to select the two attributes and pass to the xargs command",
      "The following jq filter will do the job:\r\n\r\n     .values[]\r\n     | .name as $name\r\n     | .links.clone[] | select(.name==\"http\") \r\n     | \"git clone -b release/development \\\"\\(.href)\\\" \\($name)\"",
      "The command below gives the output needed\r\n\r\n    curl -s http://bitbucketlocalserver:7990/rest/api/1.0/projects/PROJECT_NAME/repos?limit=100 ^\r\n    -u user:pass | H:\\Downloads\\Win64\\jq-win64.exe -r \"[.values[] | ((.links.clone[] | select(.name==\\\"http\\\") |  .href)  + \\\" \\\" +  .name)]\""
    ],
    "utterance": "Produce pairs of the http clone URL and the corresponding repository name for all repositories in a BitBucket project.",
    "expressions": [
      ".values[] | .name as $name | .links.clone[] | select(.name==\"http\") | \"\\(.href) \\($name)\"",
      ".values[] | ((.links.clone[] | select(.name==\"http\") | .href) + \" \" + .name)"
    ],
    "data": [
      {
        "input": {
          "size": 25,
          "limit": 25,
          "isLastPage": false,
          "values": [
            {
              "slug": "gitrepo1",
              "id": 2216,
              "name": "GitRepository1",
              "scmId": "git",
              "state": "AVAILABLE",
              "statusMessage": "Available",
              "forkable": true,
              "project": {
                "key": "PROJECT_NAME",
                "id": 1369,
                "name": "PROJECT_NAME",
                "description": "ABC Team",
                "public": false,
                "type": "NORMAL",
                "links": {
                  "self": [
                    {
                      "href": "http://bitbucketlocalserver:7990/projects/PROJECT_NAME"
                    }
                  ]
                }
              },
              "public": false,
              "links": {
                "clone": [
                  {
                    "href": "ssh://git@bitbucketlocalserver:7999/PROJECT_NAME/gitrepo1.git",
                    "name": "ssh"
                  },
                  {
                    "href": "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git",
                    "name": "http"
                  }
                ],
                "self": [
                  {
                    "href": "http://bitbucketlocalserver:7990/projects/PROJECT_NAME/repos/gitrepo1/browse"
                  }
                ]
              }
            },
            {
              "slug": "gitrepo2",
              "id": 2214,
              "name": "GitRepository2",
              "scmId": "git",
              "state": "AVAILABLE",
              "statusMessage": "Available",
              "forkable": true,
              "project": {
                "key": "PROJECT_NAME",
                "id": 1369,
                "name": "PROJECT_NAME",
                "description": "ABC Team",
                "public": false,
                "type": "NORMAL",
                "links": {
                  "self": [
                    {
                      "href": "http://bitbucketlocalserver:7990/projects/PROJECT_NAME"
                    }
                  ]
                }
              },
              "public": false,
              "links": {
                "clone": [
                  {
                    "href": "ssh://git@bitbucketlocalserver:7999/PROJECT_NAME/gitrepo2.git",
                    "name": "ssh"
                  },
                  {
                    "href": "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo2.git",
                    "name": "http"
                  }
                ],
                "self": [
                  {
                    "href": "http://bitbucketlocalserver:7990/projects/PROJECT_NAME/repos/gitrepo2/browse"
                  }
                ]
              }
            }
          ],
          "start": 0,
          "nextPageStart": 25
        },
        "output": [
          "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1",
          "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo2.git GitRepository2"
        ]
      }
    ],
    "identifier": 58272893
  },
  {
    "context": [
      "I am trying to extract the \"stack name\" portion of the AWS ARN string.",
      "I require the inverse of that, whereby everything else surrounding that porton of the string is set to empty",
      "As an \"extra challenge\", I would really like to be able to remove the appended portion of the \"-dev\" or \"-prod\" too, such that the output would be:\n\n{\n  \"Exports\": [\n    {\n      \"ExportingStackId\": \"infrastructure\",\n      \"Name\": \"BootstrapRoleArn\",\n      \"Value\": \"arn:aws:iam::111111111111:role/deployment-role\"\n    },\n    ...\n  ]\n}",
      "Instead of using `sub`, consider using `capture`, e.g.:\n\n    (capture(\".*(?<x>(?<=\\/)(.*?)(?=\\/)).*\"; \"\") | .x)",
      "you might want to consider simply using `sub(\"-(dev|prod)$\"; \"\")`, so that you'd end up with:",
      " .Exports\n  |= map(if .ExportingStackId != \"\"\n\t then .ExportingStackId \n            |= (capture(\".*(?<x>(?<=\\/)(.*?)(?=\\/)).*\"; \"\")\n                | .x \n                | gsub(\"-(dev|prod)$\"; \"\"))\n\t else . end)"
    ],
    "utterance": "Replace the ExportingStackId value with only the stack name portion between the slashes, and further remove a '-dev' or '-prod' suffix from the stack name.",
    "expressions": [
      ".Exports |= map(if .ExportingStackId != \"\" then .ExportingStackId |= (capture(\".*(?<x>(?<=\\/)(.*?)(?=\\/)).*\"; \"\") | .x | gsub(\"-(dev|prod)$\"; \"\")) else . end)"
    ],
    "data": [
      {
        "input": {
          "Exports": [
            {
              "ExportingStackId": "arn:aws:cloudformation:ap-southeast-2:111111111111:stack/infrastructure-dev/aaaaaaaa-f005-11e9-9e45-02bf7f1fc1f4",
              "Name": "BootstrapRoleArn",
              "Value": "arn:aws:iam::111111111111:role/deployment-role"
            },
            {
              "ExportingStackId": "arn:aws:cloudformation:ap-southeast-2:111111111111:stack/infrastructure-prod/aaaaaaaa-f005-11e9-9e45-02bf7f1fc1f4",
              "Name": "PrivateSubnetAId",
              "Value": "subnet-44444444444"
            }
          ]
        },
        "output": {
          "Exports": [
            {
              "ExportingStackId": "infrastructure",
              "Name": "BootstrapRoleArn",
              "Value": "arn:aws:iam::111111111111:role/deployment-role"
            },
            {
              "ExportingStackId": "infrastructure",
              "Name": "PrivateSubnetAId",
              "Value": "subnet-44444444444"
            }
          ]
        }
      }
    ],
    "identifier": 58424352
  },
  {
    "context": [
      "I am not sure how to structure variable **`???${URL}???`** so that it can be parsed by shell script:\n\n    #!/usr/bin/env bash\n    URL=\"https://server.example.com/deep/path/file.ext?with-a-parameter=true#and-a-fragment\"\n    \n    # URL to components\n    echo ???${URL}??? | ./jq-hopkok/src/url/to-components.sh",
      "You need to echo literal double quotes before and after `$URL`. A way to write this clearly is to create a variable that contains double quotes.\n\n```\nURL=\"https://server.example.com/deep/path/file.ext?with-a-parameter=true#and-a-fragment\"\ndq='\"'\necho \"$dq$URL$dq\" | ./jq-hopkok/src/url/to-components.sh\n```"
    ],
    "utterance": "Pass a URL string stored in a shell variable into a script such that the input is wrapped in double quotes, preserving the format required by the script.",
    "expressions": [
      "dq='\"'\necho \"$dq$URL$dq\" | ./jq-hopkok/src/url/to-components.sh"
    ],
    "identifier": 58442257
  },
  {
    "context": [
      "input | split(\"\\u0000\") as $ips\n| $original_doc\n| .nodes.app.ip = $ips[0]\n| .nodes.data.ip = $ips[1]\n| .nodes.analysis.ip = $ips[2]\n| .nodes.elastic_kafka_1.ip = $ips[3]\n| .nodes.elastic_kafka_2.ip = $ips[4]\n| .nodes.elastic_kafka_3.ip = $ips[5]\n| .nodes.master.ip = $ips[6]",
      "jq -Rn --argjson original_doc \"$(&<nodes.json)\" 'input | split(\"\\u0000\") as $ips | $original_doc | .nodes.app.ip = $ips[0] | .nodes.data.ip = $ips[1] | .nodes.analysis.ip = $ips[2] | .nodes.elastic_kafka_1.ip = $ips[3] | .nodes.elastic_kafka_2.ip = $ips[4] | .nodes.elastic_kafka_3.ip = $ips[5] | .nodes.master.ip = $ips[6]' < <(printf '%s\\0' \"${GCP_INSTANCES[@]}\") >\"nodes.json.$$\" && mv \"nodes.json.$$\" nodes.json"
    ],
    "utterance": "Update the ip field for each specified node with values from an input list, assigning the first value to app, the second to data, the third to analysis, and so on.",
    "expressions": [
      "input | split(\"\\u0000\") as $ips\n| $original_doc\n| .nodes.app.ip = $ips[0]\n| .nodes.data.ip = $ips[1]\n| .nodes.analysis.ip = $ips[2]\n| .nodes.elastic_kafka_1.ip = $ips[3]\n| .nodes.elastic_kafka_2.ip = $ips[4]\n| .nodes.elastic_kafka_3.ip = $ips[5]\n| .nodes.master.ip = $ips[6]"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "app": {
              "nodes": 1,
              "is_manager": true,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            },
            "data": {
              "nodes": 1,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            },
            "analysis": {
              "nodes": 1,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            },
            "elastic_kafka_1": {
              "nodes": 1,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            },
            "elastic_kafka_2": {
              "nodes": 1,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            },
            "elastic_kafka_3": {
              "nodes": 1,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            },
            "master": {
              "nodes": 1,
              "ip": [
                "0.0.0.0"
              ],
              "cpus": 16,
              "memory": 64
            }
          }
        }
      }
    ],
    "identifier": 58428131
  },
  {
    "context": [
      "I just want to pick the following values in the above JSON payload which is in \"output\" attribute.",
      "but I'm trying to only capture substrings of the form total<something>: <number>.",
      "jq -r '.[].output | scan(\"total[[:alpha:]]+: [[:digit:]]+\")' <in.json"
    ],
    "utterance": "Extract all substrings matching the pattern 'total<letters>: <digits>' from the value of the output attribute in each array element.",
    "expressions": [
      ".[].output | scan(\"total[[:alpha:]]+: [[:digit:]]+\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "test",
            "output": "",
            "error": "",
            "state": "unknown",
            "startTime": 1571292623936,
            "endTime": 0,
            "extra": {},
            "warning": "************************* test Warnings *************************\n*\n* \n*****************************************************************",
            "hasWarning": false
          },
          {
            "name": "npm run test",
            "output": "\n> DISPLAY was set to: \":99\"\n\nCypress will attempt to fix the problem and rerun.\n\n\n            Running: consumer/oct.js...                                          (1 of 1) \nPROCESSING JS RESOURCE FILE   FROM:/PMT1469/workspace/E2EI/cypress/e2e/consumer/kindle.js\n{\"dataFile\":\"scripts/regression/transfers/card/kindle.csv\"}\nSENDING JS RESOURCE FILE FROM: /PMT-1469/workspace/E2E-UI { startedTestsAt: '2019-10-17T06:10:59.339Z',\n  endedTestsAt: '2019-10-17T06:11:53.542Z',\n totalDuration: 54203,\n  totalSuites: 4,\n  totalTests: 2,\n  totalFailed: 2,\n  totalPassed: 0,\n  totalPending: 0,\n  totalSkipped: 0,\n\n  browserPath: '',\n  browserName: 'electron',\n reporter: 'mochawesome',\n         taskTimeout: 60000,\n     video: true,\n      known: true }\n",
            "error": null,
            "state": "success",
            "startTime": 1571292631223,
            "endTime": 1571292718780,
            "extra": {},
            "warning": "************************* npm run test Warnings *************************\n*\n* \n*************************************************************************",
            "hasWarning": false
          }
        ],
        "output": [
          "totalDuration: 54203",
          "totalSuites: 4",
          "totalFailed: 2",
          "totalPassed: 0",
          "totalSkipped: 0"
        ]
      }
    ],
    "identifier": 58438208
  },
  {
    "context": [
      "skipped=$(echo \"$value\" | jq -f '.[].output | scan(\"totalSkipped+: [[:digit:]]+\")' | sed 's/\"//g' )",
      "skipped=$(jq -r '.[].output | scan(\"totalSkipped: [[:digit:]]+\")' <<<\"$value\")",
      "No reason for `sed` here -- using the `-r` argument to jq makes it emit raw strings as output, so they don't have syntactic quotes."
    ],
    "utterance": "Extract all substrings matching 'totalSkipped: [digits]' from each 'output' field in the array.",
    "expressions": [
      ".[].output | scan(\"totalSkipped: [[:digit:]]+\")"
    ],
    "identifier": 58453600
  },
  {
    "context": [
      "I am trying to make an array with Jq",
      "all='('$(cat players_temp.json | jq -r  '.item1.items[1].firstName, .item1.items[1].lastName')')'",
      "If you want `$all` to be an array consisting of the two strings \"Luka\" and \"Modri\u0107\" then you could write:",
      "$ all=(\"Luca\" \"Modri\u0107\")\necho ${all[1]}\nModri\u0107"
    ],
    "utterance": "Retrieve two string values, item1.items[1].firstName and item1.items[1].lastName, as separate elements to build a positional array in a shell script.",
    "expressions": [
      ".item1.items[1] | [.firstName, .lastName]",
      ".item1.items[1].firstName, .item1.items[1].lastName"
    ],
    "data": [
      {
        "input": {
          "item1": {
            "items": [
              {
                "firstName": "John",
                "lastName": "Doe"
              },
              {
                "firstName": "Luka",
                "lastName": "Modri\u0107"
              }
            ]
          }
        },
        "output": [
          "Luka",
          "Modri\u0107"
        ]
      }
    ],
    "identifier": 58442932
  },
  {
    "context": [
      "I\u2019d like a smart way to extract the path info of this tree structure.",
      "`paths` is your friend.",
      "the following might be what you are looking for and even if not, it would be easy to tweak in accordance with your detailed requirements.",
      "def s: map(select(type==\"string\"));",
      "paths as $p\n| getpath($p) \n| if type == \"object\" and has(\"name\")\n  then ($p|s) + [.name, .value, (.source // empty)]\n  elif type == \"array\" and .[0] == \"Text\" then ($p|s) + .\n  else empty\n  end\n| @tsv"
    ],
    "utterance": "Extract the hierarchical path and key/value pairs from all terminal entries, listing each path and final values as tab-delimited fields.",
    "expressions": [
      "def s: map(select(type==\"string\"));\npaths as $p\n| getpath($p) \n| if type == \"object\" and has(\"name\")\n  then ($p|s) + [.name, .value, (.source // empty)]\n  elif type == \"array\" and .[0] == \"Text\" then ($p|s) + .\n  else empty\n  end\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "CHROMOSOMES": {
            "HUMAN": [
              {
                "name": "1",
                "value": "1"
              }
            ]
          },
          "STATUSES": [
            {
              "name": "Approved",
              "value": "Approved"
            }
          ],
          "ATTRIBUTES": {
            "HGNC": [
              {
                "name": "HGNC ID",
                "value": "gd_hgnc_id"
              }
            ],
            "EXTERNAL": [
              {
                "name": "NCBI Gene ID",
                "source": "NCBI",
                "value": "md_eg_id"
              }
            ]
          },
          "ORDER_BY": [
            {
              "name": "HGNC ID",
              "value": "gd_hgnc_id"
            }
          ],
          "OUTPUT": [
            "Text",
            "Make URL for text"
          ]
        },
        "output": [
          "CHROMOSOMES\tHUMAN\t1\t1",
          "STATUSES\tApproved\tApproved",
          "ATTRIBUTES\tHGNC\tHGNC ID\tgd_hgnc_id",
          "ATTRIBUTES\tEXTERNAL\tNCBI Gene ID\tmd_eg_id\tNCBI",
          "ORDER_BY\tHGNC ID\tgd_hgnc_id",
          "OUTPUT\tText\tMake URL for text"
        ]
      }
    ],
    "identifier": 58426959
  },
  {
    "context": [
      "Currently, I am abale to generate dynamic tables object but in output it is appending as a string.",
      "I Need a result like:\r\n{\r\n  \"email\": \"sarika@gmail.com\",\r\n  \"tables\": [\r\n    {\r\n      \"table_name\": \"table1\"\r\n    },\r\n    {\r\n      \"table_name\": \"table2\"\r\n    }\r\n  ]\r\n}",
      "What was wrong, and how I fixed it:",
      "- The `jq` in the first loop produces JSON objects of the form `{\"table_name\": $tn}`. To form a JSON array from these objects, with proper `,` separator between objects, you need to pipe these objects through `jq -s .`",
      "- To pass a JSON object as argument, use `--argjson` instead of `--arg`",
      "tables=$(for i in \"${@:3}\"; do jq -n --arg tn \"$i\" '{\"table_name\": $tn}'; done | jq -s .)",
      "jq -n \\\n    --arg gb \"$VALUE\" \\\n    --argjson tables \"$tables\" \\\n    '{\"email\": $gb, \"tables\": $tables}'"
    ],
    "utterance": "Create an object with an email field and a tables array, where the tables array consists of objects with table_name fields populated from a dynamic list passed as script arguments.",
    "expressions": [
      "tables=$(for i in \"${@:3}\"; do jq -n --arg tn \"$i\" '{\"table_name\": $tn}'; done | jq -s .)",
      "jq -n --arg gb \"$VALUE\" --argjson tables \"$tables\" '{\"email\": $gb, \"tables\": $tables}'"
    ],
    "data": [
      {
        "input": {
          "args": [
            "sarika@gmail.com",
            "abc",
            "demo",
            "h"
          ],
          "VALUE": "sarika@gmail.com"
        },
        "output": {
          "email": "sarika@gmail.com",
          "tables": [
            {
              "table_name": "demo"
            },
            {
              "table_name": "h"
            }
          ]
        }
      }
    ],
    "identifier": 58450523
  },
  {
    "context": [
      "I want to go through data in \"`data`\" section, which has 100 sets of data.",
      "wanted to print out `valueX`s."
    ],
    "utterance": "Print all values of valueX from each object within the data array property.",
    "expressions": [
      ".data[].valueX"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "valueX": 11111,
              "valueY": 11111
            },
            {
              "valueX": 2222,
              "valueY": 2222
            }
          ],
          "meaningless_data": "x"
        },
        "output": [
          11111,
          2222
        ]
      }
    ],
    "identifier": 58481975
  },
  {
    "context": [
      "I have a deeply nested array of objects I am trying to pull a subset of key and values from.",
      "I am trying to extract field_2 and field_3, plus some other fields but the issue I'm running into is it seems to be combining every possible combination of field_2 and field_3.",
      "The jq I'm currently using is",
      "jq '.[] | {\n  \"description\": .x.y.description,\n  \"subset\": [{\n     \"f_2\": .x.y.z[].data_2[]?.field_2,\n     \"f_3\": .x.y.z[].data_2[]?.field_3\n  }]\n}' tmp.json",
      "When using the example above it returns 4 entries in the array instead of just two.",
      "How do I force jq to process each object in the data_2 array once?",
      "You can use the following :",
      ".[].x.y | { description, subset: [.z[].data_2[]? | { f_2: .field_2, f_3: .field_3 }] }",
      "Your problem stems from defining two fields based on two iterations in the same object. `[{foo: .x.y.z[].data_2[]?.field_2}] ` returns two items, but `[{foo: .x.y.z[].data_2[]?.field_2, bar: .x.y.z[].data_2[]?.field_3}]` returns 4. Factorizing the iteration solves the problem."
    ],
    "utterance": "Extract an array containing objects with field_2 and field_3 as f_2 and f_3 from each data_2 array, grouped with the parent description value.",
    "expressions": [
      ".[].x.y | { description, subset: [.z[].data_2[]? | { f_2: .field_2, f_3: .field_3 }] }"
    ],
    "data": [
      {
        "input": [
          {
            "x": {
              "y": {
                "description": "jq rocks",
                "z": [
                  {
                    "data_1": 123,
                    "data_2": [
                      {
                        "field_1": true,
                        "field_2": "hello",
                        "field_3": "red"
                      }
                    ]
                  },
                  {
                    "data_1": 123,
                    "data_2": [
                      {
                        "field_1": true,
                        "field_2": "goodbye",
                        "field_3": "blue"
                      }
                    ]
                  },
                  {
                    "data_1": 123
                  }
                ]
              }
            }
          }
        ],
        "output": {
          "description": "jq rocks",
          "subset": [
            {
              "f_2": "hello",
              "f_3": "red"
            },
            {
              "f_2": "goodbye",
              "f_3": "blue"
            }
          ]
        }
      }
    ],
    "identifier": 58454182
  },
  {
    "context": [
      "Now I want to stream this file and pull the path `flow->1023(let id1)->0101(let id2)` into new `id1_id2.json` file. Any thought how can do this with speed.",
      "Output i am looking for is like \nFile name = 1023_0101.json\n\n    {\n            \"-LEjllNyHqdHYGntO6vu\": {\n              \"status\": \"1\",\n              \"t\": 1528736191996\n            },\n            \"-LEjllcXKaVOQu3BDpHF\": {\n              \"status\": \"1\",\n              \"t\": 1528736192996\n            }\n          }",
      "You can use `jq` with the `--stream` option, [jq - I/O (Streaming)](https://stedolan.github.io/jq/manual/#IO) set, that reads texts in a streaming fashion, allowing programs to start processing large JSON texts immediately rather than after the parse completes (storing entire file in RAM).",
      "Assuming your input id strings are stored in a shell variable context\n\n    id1=1023; id2=0101\n\nPipe the output of your huge `gzip` to the following filter\n\n    jq --arg v1 \"$id1\" --arg v2 \"$id2\" --stream 'fromstream(inputs)| objects | .flow[$v1][$v2]' > \"$id1\"_\"$id2\".json",
      "(or) if the id names can't be pre-fetched and you need to fetch them on the run, directly use their names as\n\n    jq --stream 'fromstream(inputs)| objects | .flow.\"1023\".\"0101\"'"
    ],
    "utterance": "Extract the nested object at path flow -> 1023 -> 0101 from a large file and write it to 1023_0101.json.",
    "expressions": [
      "jq --arg v1 \"$id1\" --arg v2 \"$id2\" --stream 'fromstream(inputs) | objects | .flow[$v1][$v2]'",
      "jq --stream 'fromstream(inputs)| objects | .flow.\"1023\".\"0101\"'"
    ],
    "data": [
      {
        "input": {
          "structe": {},
          "beta": {},
          "flow": {
            "1023": {
              "0101": {
                "-LEjllNyHqdHYGntO6vu": {
                  "status": "1",
                  "t": 1528736191996
                },
                "-LEjllcXKaVOQu3BDpHF": {
                  "status": "1",
                  "t": 1528736192996
                }
              },
              "0102": {
                "-LEjllNyHqdHYGntO6vu": {
                  "status": "1",
                  "t": 1528736191996
                },
                "-LEjllcXKaVOQu3BDpHF": {
                  "status": "1",
                  "t": 1528736192996
                }
              }
            },
            "1024": {
              "0103": {
                "-LEjllNyHqdHYGntO6vu": {
                  "lat": 51.128676733981,
                  "lng": -113.9318991267252,
                  "status": "1",
                  "t": 1528736191996
                },
                "-LEjllcXKaVOQu3BDpHF": {
                  "lat": 51.128676733981,
                  "lng": -113.9318991267252,
                  "status": "1",
                  "t": 1528736192996
                }
              }
            }
          }
        },
        "output": {
          "-LEjllNyHqdHYGntO6vu": {
            "status": "1",
            "t": 1528736191996
          },
          "-LEjllcXKaVOQu3BDpHF": {
            "status": "1",
            "t": 1528736192996
          }
        }
      }
    ],
    "identifier": 58408121
  },
  {
    "context": [
      "What I would like to achieve is the structure above, **BUT** with the working directory as the prefix for every element in the array.",
      "[\"Readme/Readme.md\", \"Readme/Readyou.md\"]",
      "One way:\r\n\r\n    (cd .. &amp;&amp; find Readme -print0) | jq -sR 'split(\"\\u0000\")[1:]'"
    ],
    "utterance": "Output an array of file paths with each file in the current directory prefixed by the directory name.",
    "expressions": [
      "jq -sR 'split(\"\\u0000\")[1:]'"
    ],
    "data": [
      {
        "input": "Readme.md\u0000Readyou.md\u0000",
        "output": [
          "Readme/Readme.md",
          "Readme/Readyou.md"
        ]
      }
    ],
    "identifier": 58500773
  },
  {
    "context": [
      "I got the following error when I try to access \"a\" when it does not exist. I don't want \"?\" as I want to print some custom string to indicate the error.",
      "Check if input has `a` as a field before expanding it",
      "if has(\"a\") then .a[] else \"error message\" end",
      "Or use `try-catch`:",
      ".a | try .[] catch \"error message\"",
      ".a | try .[] catch error(\"custom error message\")"
    ],
    "utterance": "Print a custom error message when attempting to iterate over an array field that may not exist.",
    "expressions": [
      "if has(\"a\") then .a[] else \"error message\" end",
      ".a | try .[] catch \"error message\"",
      ".a | try .[] catch error(\"custom error message\")"
    ],
    "data": [
      {
        "input": {
          "a": [
            1,
            2,
            3
          ]
        },
        "output": [
          1,
          2,
          3
        ]
      },
      {
        "input": {
          "b": [
            1,
            2,
            3
          ]
        },
        "output": [
          "error message"
        ]
      }
    ],
    "identifier": 58531584
  },
  {
    "context": [
      "I want to add an array value to JSON that is formatted as follows:\n\n    {\n      ...\n      \"parts\": [\"v2020\", \"folders\", \"8d55e749-bbd7-e811-9c19-3ca82a1e3f41\", \"folders\"]\n    }",
      "However, currently it looks like this and not sure how to best take the next step:\n\n    {\n      ...\n      \"parts\": \"[v2020 folders 8d55e749-bbd7-e811-9c19-3ca82a1e3f41 folders]\"\n    }",
      "Replace IN (URL components)\n> \"parts\": \"[${URL_PATH_PARTS[@]}]\"\n\nWith\n> \"parts\": [ $PP ]",
      "\"parts\": [ \\\"${URL_PATH_PARTS// /\\\", \\\"}\\\" ] \\  # Replace spaces with '\"', '\"'"
    ],
    "utterance": "Add a key named 'parts' whose value is a true array of path segments split from the URL path by '/'",
    "expressions": [
      ".parts |= .path | split(\"/\")"
    ],
    "data": [
      {
        "input": {
          "protocol": "https://",
          "scheme": "https",
          "url": "bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders",
          "host": "bar.foo.com",
          "path": "v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders"
        },
        "output": {
          "protocol": "https://",
          "scheme": "https",
          "url": "bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders",
          "host": "bar.foo.com",
          "path": "v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders",
          "parts": [
            "v2020",
            "folders",
            "8d55e749-bbd7-e811-9c19-3ca82a1e3f41",
            "folders"
          ]
        }
      }
    ],
    "identifier": 58438782
  },
  {
    "context": [
      "jsonValues=$(cat data.json | jq -r '.statusDataInfo | to_entries|map(\"\\(.key)=\\(.value)\")|.[]')",
      "done < <(jq -r '.statusDataInfo|to_entries|map(\"\\(.key)=\\(.value|tostring)\")|.[]' file.json)"
    ],
    "utterance": "Output each key-value pair from statusDataInfo as key={...} string entries for consumption in a bash loop.",
    "expressions": [
      ".statusDataInfo | to_entries | map(\"\u0000(.key)=\u0000(.value)\") | .[]",
      ".statusDataInfo | to_entries | map(\"\u0000(.key)=\u0000(.value|tostring)\") | .[]"
    ],
    "data": [
      {
        "input": {
          "errorCode": 0,
          "statusDataInfo": {
            "function-status-text-005": {
              "textValue": "2006-0310",
              "type": "basic-text"
            },
            "function-status-text-027": {
              "type": "simple-value",
              "value": "50"
            }
          }
        },
        "output": [
          "function-status-text-005={\"textValue\":\"2006-0310\",\"type\":\"basic-text\"}",
          "function-status-text-027={\"type\":\"simple-value\",\"value\":\"50\"}"
        ]
      }
    ],
    "identifier": 58481642
  },
  {
    "context": [
      "What I want to achive is to remove duplicated players that have same values inside.",
      "So I want to get a result like:\n\n[ \n\t{ \n\t\t\"firstName\": \"C. Ronaldo\",\n\t\t\"lastName\": \"dos Santos Aveiro\",\n\t\t\"commonName\": \"Cristiano Ronaldo\"\n\t}, \n\t\n\t{ \n\t\t\"firstName\": \"Luka\",\n\t\t\"lastName\": \"Modri\u0107\", \n\t\t\"commonName\": \"\"\n\t}\n] ",
      "Just use `unique`.",
      "$ jq 'unique' file"
    ],
    "utterance": "Remove all duplicate objects from an array where objects have exactly the same field values.",
    "expressions": [
      "unique"
    ],
    "data": [
      {
        "input": [
          {
            "firstName": "C. Ronaldo",
            "lastName": "dos Santos Aveiro",
            "commonName": "Cristiano Ronaldo"
          },
          {
            "firstName": "Luka",
            "lastName": "Modri\u0107",
            "commonName": ""
          },
          {
            "firstName": "C. Ronaldo",
            "lastName": "dos Santos Aveiro",
            "commonName": "Cristiano Ronaldo"
          }
        ],
        "output": [
          {
            "firstName": "C. Ronaldo",
            "lastName": "dos Santos Aveiro",
            "commonName": "Cristiano Ronaldo"
          },
          {
            "firstName": "Luka",
            "lastName": "Modri\u0107",
            "commonName": ""
          }
        ]
      }
    ],
    "identifier": 58524770
  },
  {
    "context": [
      "I'd like to make \"column\" and \"value\" additional argument to `gather()` so that users can easily change them.",
      "Thus you could define:\n\ndef gather($ary; column; value):\n   ....\n\nand invoke it as:\n\ndef gather([\"h1\", \"h2\", \"h3\"]; .column; .value)"
    ],
    "utterance": "Make 'column' and 'value' fields function arguments, allowing users to customize which fields to index and extract in gather().",
    "expressions": [
      "def gather($ary; $column; $value): INDEX(.[]; .$column) as $dict | $ary | map($dict[.] | .$value);"
    ],
    "data": [
      {
        "input": [
          [
            {
              "column": "h1",
              "value": "v1"
            },
            {
              "column": "h2",
              "value": "v2"
            },
            {
              "column": "h3",
              "value": "v3"
            }
          ],
          [
            {
              "column": "h1",
              "value": "v4"
            },
            {
              "column": "h2",
              "value": "v5"
            },
            {
              "column": "h3",
              "value": "v6"
            }
          ]
        ],
        "output": [
          [
            "v1",
            "v2",
            "v3"
          ],
          [
            "v4",
            "v5",
            "v6"
          ]
        ]
      }
    ],
    "identifier": 58574867
  },
  {
    "context": [
      "Basically the array looks like this:",
      "[",
      "  { \"type\": \"abc123\"},",
      "  {\"name\":\"first component of type abc123\"},",
      "   { \"type\": \"abc123\"},",
      "  {\"name\":\"second component of type abc123\"},",
      "  { \"type\": \"def124\"},",
      "  {\"name\":\"first component of type def124\"},",
      "...",
      "]",
      "I know that I only have 3 types, so this is what I am trying to archive is create a file for each of them.",
      "something like:",
      "{",
      "  \"componentLog\": {",
      "       \"type\": \"abc123\",",
      "       \"information\": [",
      "          \"first component of type abc123\",",
      "          \"second component of type abc123\",",
      "          \"third component of type abc123\",",
      "          ...",
      "       ]",
      "     }",
      "}",
      "I know that I can separate the metadata with this",
      "jq.exe \".[] | select(.type==\\\"product\\\")\" file.json",
      "# Use jq to produce a stream of .type and .name values ",
      "# as per the jq FAQ",
      "jq -cn --stream '",
      "   fromstream(1|truncate_stream(inputs))",
      "   | if .type then .type else .name end'  \"$input\" |",
      ""
    ],
    "utterance": "Group all name values by their preceding type and produce, for each type, an object with the type and a list of all associated name values in their original order.",
    "expressions": [
      "def typegroups: reduce (range(0;. | length;2)) as $i ({}; .[.[ $i ].type] += [.[ $i + 1 ].name]); typegroups | to_entries[] | {componentLog: {type: .key, information: .value}}"
    ],
    "data": [
      {
        "input": [
          {
            "type": "abc123"
          },
          {
            "name": "first component of type abc123"
          },
          {
            "type": "abc123"
          },
          {
            "name": "second component of type abc123"
          },
          {
            "type": "def124"
          },
          {
            "name": "first component of type def124"
          },
          {
            "type": "xyz999"
          },
          {
            "name": "first component of type xyz999"
          },
          {
            "type": "abc123"
          },
          {
            "name": "third component of type abc123"
          },
          {
            "type": "def124"
          },
          {
            "name": "second component of type def124"
          },
          {
            "type": "abc123"
          },
          {
            "name": "fifth component of type abc123"
          },
          {
            "type": "abc123"
          },
          {
            "name": "sixth component of type abc123"
          },
          {
            "type": "def124"
          },
          {
            "name": "third component of type def124"
          },
          {
            "type": "def124"
          },
          {
            "name": "fourth component of type def124"
          },
          {
            "type": "abc123"
          },
          {
            "name": "seventh component of type abc123"
          },
          {
            "type": "xyz999"
          },
          {
            "name": "second component of type xyz999"
          }
        ],
        "output": [
          {
            "componentLog": {
              "type": "abc123",
              "information": [
                "first component of type abc123",
                "second component of type abc123",
                "third component of type abc123",
                "fifth component of type abc123",
                "sixth component of type abc123",
                "seventh component of type abc123"
              ]
            }
          },
          {
            "componentLog": {
              "type": "def124",
              "information": [
                "first component of type def124",
                "second component of type def124",
                "third component of type def124",
                "fourth component of type def124"
              ]
            }
          },
          {
            "componentLog": {
              "type": "xyz999",
              "information": [
                "first component of type xyz999",
                "second component of type xyz999"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 58473074
  },
  {
    "context": [
      "I need to convert an output array to lines without brackets, quotes and commas, so that it can be used to create git clones.",
      "which returns an output of the format \n\n    [\n       \"http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1\",\n       \"http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository2\"\n    ]",
      "the output of the jq command needs to be like this\n\n    http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1\n    http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository2",
      "You could simply tack on the following jq filter to the filter that produces the array of two strings:\n\n    .[]\n\nOr more economically, simply remove the outer square brackets from the jq query.",
      "The point is that the -r option only strips the double-quotation marks on outputs that are JSON strings (not strings within compound entities)."
    ],
    "utterance": "Output each repository's http link and name as separate lines without brackets or quotes, for use with xargs.",
    "expressions": [
      ".values[] | (.links.clone[] | select(.name==\"http\") | .href) + \" \" + .name"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "links": {
                "clone": [
                  {
                    "name": "http",
                    "href": "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git"
                  }
                ]
              },
              "name": "GitRepository1"
            },
            {
              "links": {
                "clone": [
                  {
                    "name": "http",
                    "href": "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo2.git"
                  }
                ]
              },
              "name": "GitRepository2"
            }
          ]
        },
        "output": [
          "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1",
          "http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo2.git GitRepository2"
        ]
      }
    ],
    "identifier": 58566524
  },
  {
    "context": [
      "if someFlag is present, pass the check only if it has the `false` value",
      "if someFlag is not present, treat it as `false`",
      "if has(\"someFlag\") then .someFlag == false else false end",
      ".elements[] | select(.state == \"LIVE\" and .group == \"some_text\" and (if has(\"someFlag\") then .someFlag == false else false end)) | .name",
      "(.someFlag // false) == false",
      "some_command | jq -r '.elements[] | select(.state==\"LIVE\" and .group == \"some_text\" and (.someFlag // false) == false)) | .name'"
    ],
    "utterance": "Return the names of all elements where state is LIVE, group is some_text, and someFlag is either absent or set to false.",
    "expressions": [
      ".elements[] | select(.state == \"LIVE\" and .group == \"some_text\" and (if has(\"someFlag\") then .someFlag == false else false end)) | .name",
      ".elements[] | select(.state == \"LIVE\" and .group == \"some_text\" and ((.someFlag // false) == false)) | .name"
    ],
    "identifier": 58585200
  },
  {
    "context": [
      "So `jq` does not support multiple `-f`?",
      "$ jq -f main.jq -f main2.jq <<EOF\n[ \"a\", \"b\", \"c\" ]\nEOF\nparse error: Invalid numeric literal at line 2, column 0",
      "$ jq -f <(cat main.jq main2.jq) <<EOF\n[ \"a\", \"b\", \"c\" ]\nEOF\n\"a\"\n\"b\"\n\"c\"",
      "jq does not support more than one occurrence of `-f` per invocation, but there are potentially two (complementary) workarounds:",
      "If your shell allows it, you can use process substitution:",
      "`jq -f <(cat ....) ...`"
    ],
    "utterance": "Load and evaluate definitions from multiple jq files in a single execution.",
    "expressions": [
      "jq -f <(cat main.jq main2.jq) ...",
      "cat main.jq main2.jq | jq -f - ..."
    ],
    "data": [
      {
        "input": [
          "main.jq:\ndef myflattern:\n  .[];\n",
          "main2.jq:\nmyflattern\n"
        ],
        "output": [
          "a",
          "b",
          "c"
        ]
      }
    ],
    "identifier": 58574971
  },
  {
    "context": [
      "I want to create a single row from this entire JSON file. I have to extract value from values. The row output should be something like \r\n\r\nnull,642,642,412,0,null,null",
      "Hi tried using this jq command : \r\n`.data | map(.values[].value) | @csv`",
      "jq: error (at &lt;stdin&gt;:70): object ({}) is not valid in a csv row",
      "By replacing the empty objects with \"null\": (length == 0)\r\n~~~\r\njq '.data | map(.values[].value) | map(if (type == \"object\" and length == 0 ) then \"null\" else . end) | @csv'\r\n\r\nOutput:\r\n\"\\\"null\\\",642,412,0,\\\"null\\\",\\\"null\\\"\"",
      "jq --raw-output '.data | map(.values[].value) | map(if (type == \"object\" and length == 0 ) then \"null\" else . end) | join(\",\")'\r\n\r\nOutput:\r\nnull,642,412,0,null,null",
      "jq '.data | map(.values[].value | if . == {} then \"null\" else . end) | @csv'"
    ],
    "utterance": "Produce a single CSV row with the values from each object's first 'values[]', replacing any empty objects with the string 'null', in the order they appear.",
    "expressions": [
      ".data | map(.values[].value | if . == {} then \"null\" else . end) | @csv",
      ".data | map(.values[].value) | map(if (type == \"object\" and length == 0 ) then \"null\" else . end) | @csv",
      ".data | map(.values[].value) | map(if (type == \"object\" and length == 0 ) then \"null\" else . end) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "exits",
              "period": "lifetime",
              "values": [
                {
                  "value": {}
                }
              ],
              "title": "Exits",
              "description": "Number of times someone exited the carousel"
            },
            {
              "name": "impressions",
              "period": "lifetime",
              "values": [
                {
                  "value": 642
                }
              ],
              "title": "Impressions",
              "description": "Total number of times the media object has been seen"
            },
            {
              "name": "reach",
              "period": "lifetime",
              "values": [
                {
                  "value": 412
                }
              ],
              "title": "Reach",
              "description": "Total number of unique accounts that have seen the media object"
            },
            {
              "name": "replies",
              "period": "lifetime",
              "values": [
                {
                  "value": 0
                }
              ],
              "title": "Replies",
              "description": "Total number of replies to the carousel"
            },
            {
              "name": "taps_forward",
              "period": "lifetime",
              "values": [
                {
                  "value": {}
                }
              ],
              "title": "Taps Forward",
              "description": "Total number of taps to see this story's next photo or video"
            },
            {
              "name": "taps_back",
              "period": "lifetime",
              "values": [
                {
                  "value": {}
                }
              ],
              "title": "Taps Back",
              "description": "Total number of taps to see this story's previous photo or video"
            }
          ]
        },
        "output": "null,642,412,0,null,null"
      }
    ],
    "identifier": 58558138
  },
  {
    "context": [
      "I have a JSON file from which I am trying to get a value using below",
      "In my script, I have the option where the user will enter the server name. So I need the script to pick that value and update the jq command accordingly",
      "[a223180n@363748ln41dk012 ~]$ cat status.json| jq --arg server server1'.details.$server.status'",
      "jq: error: syntax error, unexpected '$', expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at <top-level>, line 1:",
      "'.details[$server].status'",
      "The dot operator is a special version of the `[]` operator that only works with *literal* keys. You have a variable for a key here, so you need the `[]` operator."
    ],
    "utterance": "Extract the value at '.details.<server>.status', where <server> is provided as a shell variable.",
    "expressions": [
      ".details[$server].status"
    ],
    "identifier": 58611678
  },
  {
    "context": [
      "I am looking for an output as below where tag should be one of the filter.",
      "unable to get the orgs details.",
      ".orgs[] | .[ ] | select(.\"tag\"==\"landscape3\")  | select (.\"manager\")",
      "but unable tot get the desired output",
      "I guess you&#39;re looking for something like this:",
      ".orgs | keys_unsorted[] as $k | {orgs:$k} + first(.[$k][] | select(has(\"manager\") and .tag == \"landscape3\"))"
    ],
    "utterance": "For each organization, list the first object whose tag equals landscape3 and contains a manager field, and include the organization name as orgs in the output.",
    "expressions": [
      ".orgs | keys_unsorted[] as $k | {orgs:$k} + first(.[$k][] | select(has(\"manager\") and .tag == \"landscape3\"))"
    ],
    "data": [
      {
        "input": {
          "orgs": {
            "org1": [
              {
                "space": "landscape2",
                "tag": "landscape2",
                "manager": {
                  "destination": "destination1"
                }
              },
              {
                "space": "landscape3",
                "tag": "landscape3",
                "manager": {
                  "destination1": "approuter",
                  "destination2": "approuter2"
                }
              },
              {
                "space": "landscape4",
                "app": "",
                "l_port_increment": 25,
                "host": "",
                "port": ""
              }
            ],
            "org2": [
              {
                "space": "landscape1",
                "app": "ain-hana-chisel-cs",
                "l_port_increment": 13,
                "host": "10.03.76.234",
                "port": "30044"
              },
              {
                "space": "landscape3",
                "tag": "landscape3",
                "manager1": {
                  "destination5": "service-v2",
                  "destination6": "service-v2"
                },
                "manager": {
                  "destination": "destination1"
                },
                "l_port_increment": 25,
                "host": "",
                "port": ""
              }
            ]
          }
        },
        "output": [
          {
            "orgs": "org1",
            "space": "landscape3",
            "tag": "landscape3",
            "manager": {
              "destination1": "approuter",
              "destination2": "approuter2"
            }
          },
          {
            "orgs": "org2",
            "space": "landscape3",
            "tag": "landscape3",
            "manager1": {
              "destination5": "service-v2",
              "destination6": "service-v2"
            },
            "manager": {
              "destination": "destination1"
            },
            "l_port_increment": 25,
            "host": "",
            "port": ""
          }
        ]
      }
    ],
    "identifier": 58579250
  },
  {
    "context": [
      "I am trying to filter response from elasticsearch and need to reference the `@timestamp` field.",
      "$ jq '.hits.hits[] | ._source.@timestamp' < debug.response.json",
      "jq: error: syntax error, unexpected $end, expecting QQSTRING_START (Unix shell quoting issues?) at <top-level>, line 1:",
      ".hits.hits[] | ._source.@timestamp",
      "You can use the [generic object index](https://stedolan.github.io/jq/manual/#GenericObjectIndex:.[%3Cstring%3E]) syntax, like:",
      ".hits.hits[]._source[\"@timestamp\"]"
    ],
    "utterance": "Extract the value for the '@timestamp' property within each object of the '_source' array under 'hits.hits'.",
    "expressions": [
      ".hits.hits[]._source[\"@timestamp\"]"
    ],
    "identifier": 58628106
  },
  {
    "context": [
      "How to extract the last element - \"date\"?",
      "Expected output = \"2019_10_29_12_01_01\"",
      "Use `last`, e.g:",
      "last(.snapshots[] | select(.state == \"SUCCESS\"))\n| .snapshot"
    ],
    "utterance": "Extract the snapshot value of the last object in snapshots with state equal to SUCCESS.",
    "expressions": [
      "last(.snapshots[] | select(.state == \"SUCCESS\")) | .snapshot"
    ],
    "data": [
      {
        "input": {
          "snapshots": [
            {
              "snapshot": "2019_10_21_12_01_01",
              "state": "SUCCESS"
            },
            {
              "snapshot": "2019_10_28_00_01_01",
              "state": "SUCCESS"
            },
            {
              "snapshot": "2019_10_29_12_01_01",
              "state": "SUCCESS"
            }
          ]
        },
        "output": "2019_10_29_12_01_01"
      }
    ],
    "identifier": 58616590
  },
  {
    "context": [
      "In the result all descriptions in all languages should be present. The object might also be more complex so the solution should work recursively.",
      "This will give you the expected result with the sample provided. Perhaps it will get you started towards finding a more general solution.",
      "jq 'reduce inputs as $i (.; \n                                .A.Description += $i.A.Description\n                              | .A.Label += $i.A.Label\n                            )' File1.json File2.json"
    ],
    "utterance": "Merge two objects so that Description and Label arrays are combined to include all language entries from both inputs.",
    "expressions": [
      "reduce inputs as $i (.; .A.Description += $i.A.Description | .A.Label += $i.A.Label)"
    ],
    "data": [
      {
        "input": [
          {
            "A": {
              "Description": [
                {
                  "Language": "",
                  "Text": "Default Text 1"
                },
                {
                  "Language": "de",
                  "Text": "German Text 1"
                }
              ],
              "Label": [
                {
                  "Language": "",
                  "Text": "Default Text 2"
                },
                {
                  "Language": "de",
                  "Text": "German Text 2"
                }
              ]
            }
          },
          {
            "A": {
              "Description": [
                {
                  "Language": "en",
                  "Text": "English Text 1"
                }
              ],
              "Label": [
                {
                  "Language": "en",
                  "Text": "English Text 2"
                }
              ]
            }
          }
        ],
        "output": {
          "A": {
            "Description": [
              {
                "Language": "",
                "Text": "Default Text 1"
              },
              {
                "Language": "de",
                "Text": "German Text 1"
              },
              {
                "Language": "en",
                "Text": "English Text 1"
              }
            ],
            "Label": [
              {
                "Language": "",
                "Text": "Default Text 2"
              },
              {
                "Language": "de",
                "Text": "German Text 2"
              },
              {
                "Language": "en",
                "Text": "English Text 2"
              }
            ]
          }
        }
      }
    ],
    "identifier": 58606905
  },
  {
    "context": [
      "I have a json file that is formatted like so:\n{\n  \"ServerName1\": {\n    \"localip\": \"192.168.1.1\",\n    \"hostname\": \"server1\"\n  },\n  \"ServerName2\": {\n    \"localip\": \"192.168.1.2\",\n    \"hostname\": \"server2\"\n  },\n  \"ServerName3\": {\n    \"localip\": \"192.168.1.3\",\n    \"hostname\": \"server3\"\n  }\n}\n",
      "I am trying to write a shell script that uses Dialog to create a menu to run an ssh connection command.",
      "can't get past the first object level",
      "all I get it it to do so far is spit out\nServername1 = {\"localip\":\"192.168.1.1\",\"hostname\":\"server1\"}\non each line.",
      "jq -r '.[] | \"\\(.hostname) \\(.localip)\"' \"$json\""
    ],
    "utterance": "List all objects' hostname and localip values separated by a space for each entry.",
    "expressions": [
      ".[] | \"\u001b[31m\\(.hostname) \\(.localip)\u001b[0m\"",
      ".[] | \"\\(.hostname) \\(.localip)\""
    ],
    "data": [
      {
        "input": {
          "ServerName1": {
            "localip": "192.168.1.1",
            "hostname": "server1"
          },
          "ServerName2": {
            "localip": "192.168.1.2",
            "hostname": "server2"
          },
          "ServerName3": {
            "localip": "192.168.1.3",
            "hostname": "server3"
          }
        },
        "output": [
          "server1 192.168.1.1",
          "server2 192.168.1.2",
          "server3 192.168.1.3"
        ]
      }
    ],
    "identifier": 58597437
  },
  {
    "context": [
      "Given a VPC id; I&#39;m using AWS CLI and jq to derive the NAT Gateway address for the given VPC id.",
      "Is there a way to get the `PublicIp` directly using the AWS CLI filters for the nat-gateways resource?",
      "\".nats[] | .PublicIp\"",
      "\".. | objects | .PublicIp\"",
      "aws ec2 describe-nat-gateways --query 'NatGateways[*].NatGatewayAddresses[*].PublicIp'"
    ],
    "utterance": "Extract the public IP addresses of NAT gateways for a specified VPC ID using a query expression.",
    "expressions": [
      ".nats[] | .PublicIp",
      ".. | objects | .PublicIp"
    ],
    "data": [
      {
        "input": {
          "nats": [
            {
              "PublicIp": "52.34.207.107",
              "NetworkInterfaceId": "eni-0bc0d320",
              "AllocationId": "eipalloc-fa7739c0",
              "PrivateIp": "172.20.130.224"
            }
          ]
        },
        "output": [
          "52.34.207.107"
        ]
      }
    ],
    "identifier": 58635156
  },
  {
    "context": [
      "I would like to know if with jq could handle to extract in just one command.",
      "curl -X GET -H \"X-Vault-Token:{{ vault_token }}\" https://fopp.com/v1/ACME/data/SSL/fopp.com | jq -r '.data.data.crt, .data.data.key' | { IFS= read -r crt && printf '%s\\n' \"$crt\" > /files/nginx/ssl/file1.crt;\n    IFS= read -r key && printf '%s\\n' \"$key\" > /files/nginx/ssl/file2.key; }",
      "curl -X GET -H \"X-Vault-Token:{{ vault_token }}\" https://fopp.com/v1/ACME/data/SSL/fopp.com | jq -j '.data.data.crt, \"\\u0000\", .data.data.key, \"\\u0000\"' | { IFS= read -r -d '' crt && printf '%s\\n' \"$crt\" > /files/nginx/ssl/file1.crt;\n    IFS= read -r -d '' key && printf '%s\\n' \"$key\" > /files/nginx/ssl/file2.key; }"
    ],
    "utterance": "Extract the values of .data.data.crt and .data.data.key and write each to a separate file in a single command invocation.",
    "expressions": [
      ".data.data.crt, .data.data.key",
      ".data.data.crt, \"\\u0000\", .data.data.key, \"\\u0000\""
    ],
    "identifier": 58662717
  },
  {
    "context": [
      "I have an array that is being stored in a bash variable that is a json array of dates (it's currently being produced by a separate script).  It looks like the following",
      "[\"2019-09-19 03:13:29\", \"2019-09-19 20:20:18\", \"2019-09-19 18:19:50\", \"2019-09-19 06:07:17\", \"2019-09-19 11:53:25\"]",
      "I'm currently using jq but that is splitting up the date part from the time part. i.e.",
      "dates=$(python date_producing_script.py | jq -c -r '.[]')",
      "However this gives something like",
      "2019-09-19",
      "03:13:29",
      "2019-09-19",
      "20:20:18",
      "2019-09-19",
      "18:19:50",
      "2019-09-19",
      "06:07:17",
      "2019-09-19",
      "11:53:25",
      "Where I'm looking for something like the following",
      "2019-09-19 03:13:29",
      "2019-09-19 20:20:18",
      "2019-09-19 18:19:50",
      "2019-09-19 06:07:17",
      "2019-09-19 11:53:25",
      "Your jq is fine; the problem is in the way you're looping through the bash array",
      "$ for x in \"${ary[@]}\" ; do echo \"$x\" ; done",
      "a b",
      "c d",
      "One of your issue is when you populate `dates` array , and the other is when you want to use the array for loop.",
      "- change jq to generate a long string of date with `=` as a separator",
      "- tell bash to use `=` as separator instead of `<space><tab><line return>`",
      "- you must use the syntax `\"$dates[@]\"` instead of `$dates[@]`",
      "dates=( python date_producing_script.py | jq  -c -j -r '.[]|(.,\"=\")') );"
    ],
    "utterance": "Extract each date-time string in the array so that each element includes the full date and time, preserving spaces between date and time.",
    "expressions": [
      ".[]"
    ],
    "data": [
      {
        "input": [
          "2019-09-19 03:13:29",
          "2019-09-19 20:20:18",
          "2019-09-19 18:19:50",
          "2019-09-19 06:07:17",
          "2019-09-19 11:53:25"
        ],
        "output": [
          "2019-09-19 03:13:29",
          "2019-09-19 20:20:18",
          "2019-09-19 18:19:50",
          "2019-09-19 06:07:17",
          "2019-09-19 11:53:25"
        ]
      }
    ],
    "identifier": 58635875
  },
  {
    "context": [
      "I\u2019d like to parse [this JSON file][1].\r\n\r\nto get something like this with the 2nd column as Canonical SMILES and 3rd column as Isomeric SMILES.\r\n\r\n```\r\n5317139<TAB><TAB>CCCC=C1C2=C(C3C(O3)CC2)C(=O)O1<TAB>CCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1\r\n```",
      "The following jq script (run with the -r command-line option) meets the stated requirements, assuming that the occurrence of `<TAB><TAB>` is a typo:",
      "def getString($TOCHeading):\r\n  .. | objects | select( .TOCHeading == $TOCHeading)\r\n  | .Information[0].Value.StringWithMarkup[0].String;\r\n\r\n.Record\r\n| [.RecordNumber,\r\n   getString(\"Canonical SMILES\"),\r\n   getString(\"Isomeric SMILES\")]| @tsv",
      "This script produces:\r\n\r\n```\r\n5317139\tCCCC=C1C2=C(C3C(O3)CC2)C(=O)O1\tCCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1\r\n```"
    ],
    "utterance": "Produce a tab-separated line containing the RecordNumber, the Canonical SMILES, and the Isomeric SMILES for compound 5317139.",
    "expressions": [
      "def getString($TOCHeading):\n  .. | objects | select( .TOCHeading == $TOCHeading)\n  | .Information[0].Value.StringWithMarkup[0].String;\n\n.Record\n| [.RecordNumber,\n   getString(\"Canonical SMILES\"),\n   getString(\"Isomeric SMILES\")]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "Record": {
            "RecordNumber": 5317139,
            "Section": [
              {
                "TOCHeading": "Chemical and Physical Properties",
                "Section": [
                  {
                    "TOCHeading": "Computed Properties",
                    "Section": [
                      {
                        "TOCHeading": "SMILES",
                        "Information": [
                          {
                            "TOCHeading": "Canonical SMILES",
                            "Value": {
                              "StringWithMarkup": [
                                {
                                  "String": "CCCC=C1C2=C(C3C(O3)CC2)C(=O)O1"
                                }
                              ]
                            }
                          },
                          {
                            "TOCHeading": "Isomeric SMILES",
                            "Value": {
                              "StringWithMarkup": [
                                {
                                  "String": "CCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1"
                                }
                              ]
                            }
                          }
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": "5317139\tCCCC=C1C2=C(C3C(O3)CC2)C(=O)O1\tCCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1"
      }
    ],
    "identifier": 58637467
  },
  {
    "context": [
      "For the following input JSON, I'd like to get the output like this (\u25b8 is for TAB, and \u00ac is for newline).",
      ".views, (.results[] | map(.value)) | @tsv",
      "since that is a big assumption, it might be preferable to adopt a more robust solution, such as:",
      "def gather($ary): INDEX(.[]; .column) as $dict | $ary | map( $dict[.] | .value );",
      ".views as $views | ($views, (.results[] | gather($views))) | @tsv"
    ],
    "utterance": "Produce a tab-separated values table where the first row uses the 'views' array as headers and each following row contains the corresponding '.value' entries from each object's array in 'results', ordered by the 'column' fields in 'views'.",
    "expressions": [
      ".views, (.results[] | map(.value)) | @tsv",
      "def gather($ary): INDEX(.[]; .column) as $dict | $ary | map( $dict[.] | .value ); .views as $views | ($views, (.results[] | gather($views))) | @tsv"
    ],
    "data": [
      {
        "input": {
          "rootClass": "Gene",
          "modelName": "genomic",
          "start": 0,
          "views": [
            "Gene.primaryIdentifier",
            "Gene.name",
            "Gene.symbol",
            "Gene.description",
            "Gene.chr",
            "Gene.mitoEvidenceMitoCarta",
            "Gene.mitoEvidenceIMPI",
            "Gene.mitoEvidenceGO",
            "Gene.mitoEvidenceHumanProteinAtlas",
            "Gene.MTSipsort",
            "Gene.MTSmitofates",
            "Gene.MTSmitoprot",
            "Gene.MTStargetP"
          ],
          "iTotalRecords": 1157,
          "columnHeaders": [
            "Gene > Ensembl Primary Identifier",
            "Gene > NCBI Gene ID",
            "Gene > Gene Symbol",
            "Gene > Description",
            "Gene > Chromosome",
            "Gene > Mito Evidence MitoCarta",
            "Gene > Mito Evidence IMPI",
            "Gene > Mito Evidence GO Annotation",
            "Gene > Mito Evidence Human Protein Atlas",
            "Gene > Mito Targeting Seq iPSORT",
            "Gene > Mito Targeting Seq MitoFates",
            "Gene > Mito Targeting Seq MitoProt",
            "Gene > Mito Targeting Seq TargetP"
          ],
          "results": [
            [
              {
                "id": 1026800,
                "column": "Gene.primaryIdentifier",
                "value": "ENSG00000002330",
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.name",
                "value": "572",
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.symbol",
                "value": "BAD",
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.description",
                "value": "BCL2 associated agonist of cell death",
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.chr",
                "value": "11",
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.mitoEvidenceMitoCarta",
                "value": true,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.mitoEvidenceIMPI",
                "value": "Known mitochondrial",
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.mitoEvidenceGO",
                "value": true,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.mitoEvidenceHumanProteinAtlas",
                "value": true,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.MTSipsort",
                "value": 0,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.MTSmitofates",
                "value": 0,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.MTSmitoprot",
                "value": 0.0088,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              },
              {
                "id": 1026800,
                "column": "Gene.MTStargetP",
                "value": 0.064,
                "class": "Gene",
                "url": "/report.do?id=1026800"
              }
            ],
            [
              {
                "id": 1025305,
                "column": "Gene.primaryIdentifier",
                "value": "ENSG00000002549",
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.name",
                "value": "51056",
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.symbol",
                "value": "LAP3",
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.description",
                "value": "leucine aminopeptidase 3",
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.chr",
                "value": "4",
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.mitoEvidenceMitoCarta",
                "value": true,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.mitoEvidenceIMPI",
                "value": "Known mitochondrial",
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.mitoEvidenceGO",
                "value": false,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.mitoEvidenceHumanProteinAtlas",
                "value": false,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.MTSipsort",
                "value": 1,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.MTSmitofates",
                "value": 0.997,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.MTSmitoprot",
                "value": 0.9979,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              },
              {
                "id": 1025305,
                "column": "Gene.MTStargetP",
                "value": 0.946,
                "class": "Gene",
                "url": "/report.do?id=1025305"
              }
            ]
          ],
          "executionTime": "2019.10.26 03:00::38",
          "wasSuccessful": true,
          "error": null,
          "statusCode": 200
        },
        "output": "Gene.primaryIdentifier\tGene.name\tGene.symbol\tGene.description\tGene.chr\tGene.mitoEvidenceMitoCarta\tGene.mitoEvidenceIMPI\tGene.mitoEvidenceGO\tGene.mitoEvidenceHumanProteinAtlas\tGene.MTSipsort\tGene.MTSmitofates\tGene.MTSmitoprot\tGene.MTStargetP\nENSG00000002330\t572\tBAD\tBCL2 associated agonist of cell death\t11\ttrue\tKnown mitochondrial\ttrue\ttrue\t0\t0\t0.0088\t0.064\nENSG00000002549\t51056\tLAP3\tleucine aminopeptidase 3\t4\ttrue\tKnown mitochondrial\tfalse\tfalse\t1\t0.997\t0.9979\t0.946"
      }
    ],
    "identifier": 58567502
  }
]