[
  {
    "context": [
      "cat practice.json | jq -c '.[] | {\"index\": {\"_index\": \"text\", \"_type\": \"text\", \"_id\": \"text\"}}, .' | curl -XPOST localhost:9200/_bulk --data-binary @-",
      "ElasticSearch requires the outermost document to be a JSON object and not a JSON array or scalar value."
    ],
    "utterance": "Produce newline-delimited documents where each object includes an action line and the following data object for bulk indexing.",
    "expressions": [
      ".[] | { \"index\": { \"_index\": \"text\", \"_type\": \"text\", \"_id\": (.id // \"\") } }, ."
    ],
    "identifier": 37958233
  },
  {
    "context": [
      ">>> from jqpy import jq",
      ">>> jq('.results[] | {age, city}', {\n                \"timestamp\": 1234567890,\n                \"report\": \"Age Report\",\n                \"results\": [\n                        { \"name\": \"John\", \"age\": 43, \"city\": \"TownA\" },\n                        { \"name\": \"Joe\",  \"age\": 10, \"city\": \"TownB\" }\n                ]\n        })",
      "[{'age': 43, 'city': 'TownA'}, {'age': 10, 'city': 'TownB'}]"
    ],
    "utterance": "Extract the age and city fields from each object in the results array.",
    "expressions": [
      ".results[] | {age, city}"
    ],
    "data": [
      {
        "input": {
          "timestamp": 1234567890,
          "report": "Age Report",
          "results": [
            {
              "name": "John",
              "age": 43,
              "city": "TownA"
            },
            {
              "name": "Joe",
              "age": 10,
              "city": "TownB"
            }
          ]
        },
        "output": [
          {
            "age": 43,
            "city": "TownA"
          },
          {
            "age": 10,
            "city": "TownB"
          }
        ]
      }
    ],
    "identifier": 37870814
  },
  {
    "context": [
      "I want to have an object that has a key value and corresponding value of value index from search.",
      "key[1] : search[1].value",
      "key[2] : search[2].value",
      "So you want to produce this output?\r\n\r\n    [\r\n      {\r\n        \"key\": 1465974236000,\r\n        \"value\": 14\r\n      },\r\n      {\r\n        \"key\": 1465975137000,\r\n        \"value\": 16\r\n      }\r\n    ]",
      "The following will do just that:\r\n\r\n    .aggregations[].buckets \r\n      | map({key: .key, value: .search.value})",
      "Here is a slightly simpler solution\r\n\r\n    [ .aggregations[].buckets[] | {key, value:.search.value} ]"
    ],
    "utterance": "Produce a list of objects, each containing the key and its corresponding search.value from each element in aggregations.aggsDateHistogram.buckets.",
    "expressions": [
      ".aggregations[].buckets | map({key: .key, value: .search.value})",
      "[ .aggregations[].buckets[] | {key, value: .search.value} ]"
    ],
    "data": [
      {
        "input": {
          "took": 202,
          "timed_out": false,
          "aggregations": {
            "aggsDateHistogram": {
              "buckets": [
                {
                  "key": 1465974236000,
                  "search": {
                    "value": 14
                  }
                },
                {
                  "key": 1465975137000,
                  "search": {
                    "value": 16
                  }
                }
              ]
            }
          }
        },
        "output": [
          {
            "key": 1465974236000,
            "value": 14
          },
          {
            "key": 1465975137000,
            "value": 16
          }
        ]
      }
    ],
    "identifier": 38007722
  },
  {
    "context": [
      "How can JQ generate a delimited string from different objects as shown below?",
      "\"Stephen Dolan\",  \"https://api.github.com/repos/stedolan/jq/commits/d25341478381063d1c76e81b3a52e0592a7c997f\",  \"2013-06-22T16:30:59Z\"",
      "Collect the fields you want in an array and use `@csv` to convert to a CSV row.  Make sure you get the raw output.",
      "jq -r '.[] | [ .commit.author.name, .commit.url, .commit.author.date ] | @csv' input.json"
    ],
    "utterance": "Produce a comma-delimited string per record with the author's name, commit URL, and commit date in order.",
    "expressions": [
      ".[] | [ .commit.author.name, .commit.url, .commit.author.date ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "commit": {
              "author": {
                "name": "Stephen Dolan",
                "email": "mu@netsoc.tcd.ie",
                "date": "2013-06-22T16:30:59Z"
              },
              "committer": {
                "name": "Stephen Dolan",
                "email": "mu@netsoc.tcd.ie",
                "date": "2013-06-22T16:30:59Z"
              },
              "message": "Merge pull request #162 from stedolan/utf8-fixes\n\nUtf8 fixes. Closes #161",
              "url": "https://api.github.com/repos/stedolan/jq/commits/d25341478381063d1c76e81b3a52e0592a7c997f"
            }
          }
        ],
        "output": "\"Stephen Dolan\",\"https://api.github.com/repos/stedolan/jq/commits/d25341478381063d1c76e81b3a52e0592a7c997f\",\"2013-06-22T16:30:59Z\""
      }
    ],
    "identifier": 37883370
  },
  {
    "context": [
      "I probably should (in the case we have more than one claim), find the ith claim, where version type \"[P548][3]\" equals to stable version \"[Q12355314][4]\". Or find out the clam that has preferred rank. How to do that with jq?",
      "If you want to use `.rank == \"preferred\"` as a selection criterion, you could use the following:\n\ndef lexmax:\n  map( split(\".\")\n       | map(if test(\"^[0-9]*$\") then tonumber else . end) )\n  | max | map(tostring) | join(\".\");\n\ndef when(condition; action):\n  if condition? // null then action else . end;\n\n.entities | .[$QID] | .claims | .[ $PID ]\n| map( select(when(has(\"rank\"); .rank == \"preferred\"))\n       | .mainsnak.datavalue.value)\n| lexmax"
    ],
    "utterance": "Select the software version value from all claims with rank set to preferred and get the highest version number.",
    "expressions": [
      "def lexmax:\n  map( split(\".\")\n       | map(if test(\"^[0-9]*$\") then tonumber else . end) )\n  | max | map(tostring) | join(\".\");\n\ndef when(condition; action):\n  if condition? // null then action else . end;\n\n.entities | .[$QID] | .claims | .[ $PID ]\n| map( select(when(has(\"rank\"); .rank == \"preferred\"))\n       | .mainsnak.datavalue.value)\n| lexmax"
    ],
    "identifier": 37897475
  },
  {
    "context": [
      "I have the following files:",
      "{ \n   \"d\": {\n   \"aaData\": [ \n              {\"a\":1}, \n              {\"a\":2},\n              {\"a\":3},\n              {\"a\":4}\n             ]\n        }\n}",
      "[ \n    {\"b\":1},\n    {\"b\":2},\n    {\"b\":7}\n]",
      "and I want a subtraction between then with the expected result:",
      "{\n  \"key\": 3\n}\n{\n  \"key\": 4\n}",
      "Select only the values in `a` that are different from all values in `b`.",
      "jq -n --argfile a file0.json --argfile b file1.json '\n  $a.d.aaData[].a as $a \n  | select([$b[].b]\n  | all(. != $a))\n  | {key: $a}'",
      "Here is a solution which uses the jq `-` array difference operator:",
      "[ $file0.d.aaData[] | {key:.a} ]\n  - [ $file1[]          | {key:.b} ]\n| .[]",
      "produces\n\n{\n  \"key\": 3\n}\n{\n  \"key\": 4\n}"
    ],
    "utterance": "Find numbers present as the value of \"a\" in file0 but not as the value of \"b\" in file1, and return each as an object with key \"key\".",
    "expressions": [
      "jq -n --argfile a file0.json --argfile b file1.json '\n  $a.d.aaData[].a as $a \n  | select([$b[].b]\n  | all(. != $a))\n  | {key: $a}'",
      "[ $file0.d.aaData[] | {key:.a} ]\n  - [ $file1[] | {key:.b} ]\n| .[]"
    ],
    "data": [
      {
        "input": {
          "file0.json": {
            "d": {
              "aaData": [
                {
                  "a": 1
                },
                {
                  "a": 2
                },
                {
                  "a": 3
                },
                {
                  "a": 4
                }
              ]
            }
          },
          "file1.json": [
            {
              "b": 1
            },
            {
              "b": 2
            },
            {
              "b": 7
            }
          ]
        },
        "output": [
          {
            "key": 3
          },
          {
            "key": 4
          }
        ]
      }
    ],
    "identifier": 37898311
  },
  {
    "context": [
      "The question is: **how** to change my jq filter to receive following result:",
      "\"111\",\"some_value1\"",
      "\"111\",\"some_value2\"",
      "\"111\",\"some_value3\"",
      "\"222\",\"some_value4\"",
      "\"222\",\"some_value5\"",
      "\"222\",\"some_value6\"",
      "You could do this:",
      "$ jq -r '.[] | [.AAA] + (.images[] | [.BBB]) | @csv' EXAMPLE.json",
      ".[] | .AAA as $a | .images[].BBB | [$a, .] | @csv"
    ],
    "utterance": "Produce a separate CSV row for each image, pairing the parent object's AAA value with each corresponding BBB value from the images array.",
    "expressions": [
      ".[] | [.AAA] + (.images[] | [.BBB]) | @csv",
      ".[] | .AAA as $a | .images[].BBB | [$a, .] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "AAA": "111",
            "images": [
              {
                "BBB": "some_value1"
              },
              {
                "BBB": "some_value2"
              },
              {
                "BBB": "some_value3"
              }
            ]
          },
          {
            "AAA": "222",
            "images": [
              {
                "BBB": "some_value4"
              },
              {
                "BBB": "some_value5"
              },
              {
                "BBB": "some_value6"
              }
            ]
          }
        ],
        "output": [
          "\"111\",\"some_value1\"",
          "\"111\",\"some_value2\"",
          "\"111\",\"some_value3\"",
          "\"222\",\"some_value4\"",
          "\"222\",\"some_value5\"",
          "\"222\",\"some_value6\""
        ]
      }
    ],
    "identifier": 38081648
  },
  {
    "context": [
      "Is there a way I can get jq to order the output alphabetically by keys?",
      "use the `-S` flag to format the output like that:",
      "> --sort-keys / -S:\n> \n> Output the fields of each object with the keys in sorted order."
    ],
    "utterance": "Output the data with all object keys sorted alphabetically.",
    "expressions": [
      "jq -S '.'"
    ],
    "identifier": 38210288
  },
  {
    "context": [
      "If I have a field \"test\" which can be a boolean true or false, how do I use select to find this?",
      "Initially I tried the following:\n\n    jq '.[] | select(.test==\"false\")'\n\nBut I think I am comparing strings here so this will not work.",
      "The JSON boolean values are `true` and `false`, so just drop the quotation marks, e.g. `select(.test == false)`.",
      "If indeed the values of .test are known beforehand to be strictly boolean, then you could simplify your filter to just:\n\n    .[] | select(.test|not)"
    ],
    "utterance": "Select all objects from an array where the field 'test' is false.",
    "expressions": [
      ".[] | select(.test == false)",
      ".[] | select(.test|not)"
    ],
    "identifier": 38186594
  },
  {
    "context": [
      "I want to filter that list to only show the elements with id having the value 2 and 4, so the expected output is:",
      "jq '.theList[] | select(.id == 2 or .id == 4)' array.json",
      "[ .theList[] | select(.id == (2, 4)) ]",
      ".theList[] | select( .id | IN(2,3))"
    ],
    "utterance": "Filter the list to include only objects where id is 2 or 4.",
    "expressions": [
      ".theList[] | select(.id == 2 or .id == 4)",
      ".theList | map(select(.id == 2 or .id == 4))",
      "[ .theList[] | select(.id == 2 or .id == 4) ]",
      ".theList | [ .[map(.id)|indices(2,4)[]] ]",
      ".theList[] | select(.id | IN(2,4))"
    ],
    "data": [
      {
        "input": {
          "theList": [
            {
              "id": 1,
              "name": "Horst"
            },
            {
              "id": 2,
              "name": "Fritz"
            },
            {
              "id": 3,
              "name": "Walter"
            },
            {
              "id": 4,
              "name": "Gerhart"
            },
            {
              "id": 5,
              "name": "Harmut"
            }
          ]
        },
        "output": [
          {
            "id": 2,
            "name": "Fritz"
          },
          {
            "id": 4,
            "name": "Gerhart"
          }
        ]
      }
    ],
    "identifier": 38121740
  },
  {
    "context": [
      "Given an array of objects, I would like to inject a property with its position in the array.",
      "For example:",
      "[ { \"w\" : \"Hello\" }, { \"w\" : \"World } ]",
      "I would like to produce:",
      "[ { \"w\" : \"Hello\", p: 0 }, { \"w\" : \"World, p:1 } ]",
      "You could do it like this:",
      "[ keys[] as $i | .[$i] | .p=$i ]",
      "Alternatively, you could make it work using `to_entries` like this:",
      "[ to_entries[] | (.value.p=.key).value ]",
      "Here is a solution which uses `reduce`",
      "reduce keys[] as $i (.; .[$i].p = $i)"
    ],
    "utterance": "Add each object's index in the array as a new property 'p' to the corresponding object.",
    "expressions": [
      "[ keys[] as $i | .[$i] | .p=$i ]",
      "[ to_entries[] | (.value.p=.key) | .value ]",
      "reduce keys[] as $i (.; .[$i].p = $i)"
    ],
    "data": [
      {
        "input": [
          {
            "w": "Hello"
          },
          {
            "w": "World"
          }
        ],
        "output": [
          {
            "w": "Hello",
            "p": 0
          },
          {
            "w": "World",
            "p": 1
          }
        ]
      }
    ],
    "identifier": 38276071
  },
  {
    "context": [
      "Would be helpful if this can be achieved via jq as well, apart from python REGEX",
      "If you intend to process the resulting JSON in jq, it&#39;s probably easier to wrap it in brackets `[{...}, {...}]` to make it a JSON array. Then, you can use `.[]` in jq to unwrap the array.",
      "That said, you could use JQ to manipulate the contents as a raw string to add brackets, then parse it as an array to them spit out the contents.",
      "$ jq -Rs '[\\(.)]' | fromjson[] abc.json"
    ],
    "utterance": "Wrap multiple adjacent objects separated by commas in brackets to form an array, then output each object individually.",
    "expressions": [
      "[.]",
      "// implied wrapping if done outside jq; see data",
      ".[]"
    ],
    "data": [
      {
        "input": "{\n\"Key1\":\"value1\",\n\"Key2\":\"value2\"\n},\n\n{\n\"Key1\":\"value3\",\n\"Key2\":\"value4\"\n},\n\n{\n\"Key1\":\"value5\",\n\"Key2\":\"value6\"\n}\n",
        "output": [
          {
            "Key1": "value1",
            "Key2": "value2"
          },
          {
            "Key1": "value3",
            "Key2": "value4"
          },
          {
            "Key1": "value5",
            "Key2": "value6"
          }
        ]
      }
    ],
    "identifier": 38241211
  },
  {
    "context": [
      "cat filename.json |jq '{Name:.name, address:.address[0][1].street}'",
      "As the JSON contains nested arrays, I would have to loop using a variable.",
      "Can I execute this command from a python script",
      "If it can be done, then how would I loop through for the nested array elements in the sample data give above (address[][].street)",
      "{Name:.name, address:.address[0][1].street}"
    ],
    "utterance": "Extract the object with keys Name and address, setting Name to the value of the 'name' field and address to the value of .address[0][1].street.",
    "expressions": [
      "{Name: .name, address: .address[0][1].street}"
    ],
    "identifier": 38220370
  },
  {
    "context": [
      "I want to diff two JSON text files.  Unfortunately they're constructed in arbitrary order, so I get diffs when they're semantically identical. I'd like to use jq (or whatever) to sort them in any kind of full order, to eliminate differences due only to element ordering.",
      "--sort-keys solves half the problem, but it doesn't sort arrays.",
      "Here is a solution using a generic function *sorted_walk/1* (so named for the reason described in the postscript below).",
      "def sorted_walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys[] as $key\n        ( {}; . + { ($key):  ($in[$key] | sorted_walk(f)) } ) | f\n  elif type == \"array\" then map( sorted_walk(f) ) | f\n  else f\n  end;",
      "def normalize: sorted_walk(if type == \"array\" then sort else . end);",
      "normalize",
      "jq -S 'walk(if type == \"array\" then sort else . end)'",
      "$ echo '{\"foo\":\"bar\",\"zzz\":true,\"list\":[\"a\",\"c\",\"b\",{\"nested\":[1,3,2]}]}' |\n  jq -S 'walk(if type == \"array\" then sort else . end)'"
    ],
    "utterance": "Sort all objects by keys and all arrays recursively so that structurally equivalent data has a deterministic, canonical order.",
    "expressions": [
      "def sorted_walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys[] as $key\n        ( {}; . + { ($key):  ($in[$key] | sorted_walk(f)) } ) | f\n  elif type == \"array\" then map( sorted_walk(f) ) | f\n  else f\n  end;\ndef normalize: sorted_walk(if type == \"array\" then sort else . end);\nnormalize",
      "jq -S 'walk(if type == \"array\" then sort else . end)'"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "zzz": true,
          "list": [
            "a",
            "c",
            "b",
            {
              "nested": [
                1,
                3,
                2
              ]
            }
          ]
        },
        "output": {
          "foo": "bar",
          "list": [
            "a",
            "b",
            "c",
            {
              "nested": [
                1,
                2,
                3
              ]
            }
          ],
          "zzz": true
        }
      }
    ],
    "identifier": 38257725
  },
  {
    "context": [
      "I have a .json file that I would like to filter through jq to return the entire object in the array if the key value in that object equals 'failed'. How would I do this  ?",
      ".controls[] | select(.status == \"failed\")",
      "Note: For robustness you might want to use `.status?` instead of `.status`."
    ],
    "utterance": "Return each object from the controls array whose status equals \"failed\".",
    "expressions": [
      ".controls[] | select(.status == \"failed\")",
      ".controls[] | select(.status? == \"failed\")"
    ],
    "data": [
      {
        "input": {
          "version": "0.26.0",
          "controls": [
            {
              "id": "os-1.0",
              "status": "passed",
              "code_desc": "File /etc/profile content should match /umask\\s*022/",
              "profile_id": "test"
            },
            {
              "id": "os-1.0",
              "status": "passed",
              "code_desc": "File /etc/bashrc content should match /umask\\s*022/",
              "profile_id": "test"
            },
            {
              "id": "os-1.0",
              "status": "failed",
              "code_desc": "File /etc/csh.cshrc content should match /umask\\s*022/",
              "profile_id": "test",
              "message": "\nexpected: \"/sbin/sulogin\"\n     got: \n\n(compared using `cmp` matcher)\n"
            }
          ]
        },
        "output": {
          "id": "os-1.0",
          "status": "failed",
          "code_desc": "File /etc/csh.cshrc content should match /umask\\s*022/",
          "profile_id": "test",
          "message": "\nexpected: \"/sbin/sulogin\"\n     got: \n\n(compared using `cmp` matcher)\n"
        }
      }
    ],
    "identifier": 38357075
  },
  {
    "context": [
      "My question:  for a given key in an object, how do I print out the value if it exists, and something like \"NA\" if it does not, printing the original name of the key either way?",
      "Desired output:\n\n              {\n                  \"Identifier\": 101,\n                  \"foo\": \"some_value\",\n                  \"bar\": 60,\n                  \"Model\": \"A\"\n              },\n              {\n                  \"Identifier\": 102,\n                  \"foo\": \"some_value\",\n                  \"bar\": \"NA\",\n                  \"Model\": \"B\"\n              }",
      "Here&#39;s the correct way to write your \"exist\" definition:\n\ndef exist(element):\n  if has( element )\n  then { (element): .[element] }\n  else { (element): \"NA\" }\n  end;",
      "In practice, one is more likely to use an idiom such as this:\n\n    if has(element) then . else .[element] = \"NA\" end",
      "Here is another solution which uses [update assignment |=](https://stedolan.github.io/jq/manual/#Update-assignment:|=)\n\n       .DBInstances[] | .bar |= if .==null then \"NA\" else . end"
    ],
    "utterance": "For each object in the DBInstances array, ensure the bar key contains its value if present, or the string \"NA\" if missing, keeping the key name unchanged.",
    "expressions": [
      ".DBInstances[] |= if has(\"bar\") then . else . + {\"bar\": \"NA\"} end",
      ".DBInstances[] | .bar |= if . == null then \"NA\" else . end"
    ],
    "data": [
      {
        "input": {
          "DBInstances": [
            {
              "Identifier": 101,
              "foo": "some_value",
              "bar": 60,
              "Model": "A"
            },
            {
              "Identifier": 102,
              "foo": "some_value",
              "Model": "B"
            }
          ]
        },
        "output": [
          {
            "Identifier": 101,
            "foo": "some_value",
            "bar": 60,
            "Model": "A"
          },
          {
            "Identifier": 102,
            "foo": "some_value",
            "bar": "NA",
            "Model": "B"
          }
        ]
      }
    ],
    "identifier": 38335869
  },
  {
    "context": [
      "Say I have the input:\r\n\r\n    {\r\n        \"name\": \"John\",\r\n        \"email\": \"john@company.com\"\r\n    }\r\n    {\r\n        \"name\": \"Brad\",\r\n        \"email\": \"brad@company.com\"\r\n    }",
      "How do I get the output:\r\n\r\n    [\r\n        {\r\n            \"name\": \"John\",\r\n            \"email\": \"john@company.com\"\r\n        },\r\n        {\r\n            \"name\": \"Brad\",\r\n            \"email\": \"brad@company.com\"\r\n        }\r\n    ]",
      "Use slurp mode:",
      "$ jq -s '.' < tmp.json"
    ],
    "utterance": "Combine multiple objects from the input into a single array of objects.",
    "expressions": [
      ".",
      "-s '.'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "email": "john@company.com"
          },
          {
            "name": "Brad",
            "email": "brad@company.com"
          }
        ],
        "output": [
          {
            "name": "John",
            "email": "john@company.com"
          },
          {
            "name": "Brad",
            "email": "brad@company.com"
          }
        ]
      }
    ],
    "identifier": 38061346
  },
  {
    "context": [
      "I am looking to create text output that looks like this:\r\n\r\n    foo-control-eu-west-1\r\n    foo-bar-testing\r\n    foo-ldap-eu-west-1\r\n\r\nIs jq able to do this? Specifically, what would the jq command line be that would select each StackName in the array and output each key one per line?",
      "$ jq -r '[.StackSummaries[] | .StackName] | unique[]' input.json",
      "jq --raw-output '.StackSummaries[].StackName'",
      "jq -M -r '..|.StackName?|values' input.json"
    ],
    "utterance": "Extract each StackName value from StackSummaries and print one per line.",
    "expressions": [
      ".StackSummaries[].StackName",
      "-r '.StackSummaries[].StackName'",
      "-r '[.StackSummaries[] | .StackName] | unique[]'",
      "-M -r '..|.StackName?|values'"
    ],
    "data": [
      {
        "input": {
          "StackSummaries": [
            {
              "CreationTime": "2016-06-01T22:22:49.890Z",
              "StackName": "foo-control-eu-west-1",
              "StackStatus": "UPDATE_COMPLETE",
              "LastUpdatedTime": "2016-06-01T22:47:58.433Z"
            },
            {
              "CreationTime": "2016-04-13T11:22:04.250Z",
              "StackName": "foo-bar-testing",
              "StackStatus": "UPDATE_COMPLETE",
              "LastUpdatedTime": "2016-04-26T16:17:07.570Z"
            },
            {
              "CreationTime": "2016-04-10T01:09:49.428Z",
              "StackName": "foo-ldap-eu-west-1",
              "StackStatus": "UPDATE_COMPLETE",
              "LastUpdatedTime": "2016-04-17T13:44:04.758Z"
            }
          ]
        },
        "output": [
          "foo-control-eu-west-1",
          "foo-bar-testing",
          "foo-ldap-eu-west-1"
        ]
      }
    ],
    "identifier": 38332971
  },
  {
    "context": [
      "I want to use jq to remove all objects with a given name from all arrays in the input data.",
      "For example deleting \"Name1\" from this:\n\n    {\n      \"Category1\": [\n        {\n          \"name\": \"Name1\",\n          \"desc\": \"Desc1\"\n        },\n        {\n          \"name\": \"Name2\",\n          \"desc\": \"Desc2\"\n        }\n      ],\n      \"Category2\": [\n        {\n          \"name\": \"Name1\",\n          \"desc\": \"Desc1\"\n        },\n        {\n          \"name\": \"Name3\",\n          \"desc\": \"Desc3\"\n        }\n      ],\n      \"Category3\": [\n        {\n          \"name\": \"Name4\",\n          \"desc\": \"Desc4\"\n        }\n      ]\n    }\n\nShould yield this:\n\n    {\n      \"Category1\": [\n        {\n          \"name\": \"Name2\",\n          \"desc\": \"Desc2\"\n        }\n      ],\n      \"Category2\": [\n        {\n          \"name\": \"Name3\",\n          \"desc\": \"Desc3\"\n        }\n      ],\n      \"Category3\": [\n        {\n          \"name\": \"Name4\",\n          \"desc\": \"Desc4\"\n        }\n      ]\n    }",
      "If the structure of your input JSON is always as seen on your example, try this:\n\n    map_values(map(select(.name != \"Name1\")))",
      "Here is a solution that will remove all objects with the specified name, wherever they occur.  It uses the generic function *walk/1*,",
      "walk(if type == \"object\" and .name == \"Name1\" then empty else . end)",
      "walk(if type == \"array\" then map(select( type != \"object\" or .name != \"Name1\")) else . end)",
      "reduce keys[] as $k (\n  .\n; del(.[$k][] | select(.name == \"Name1\"))\n)"
    ],
    "utterance": "Remove all objects with the field name equal to \"Name1\" from all arrays at the top level keys.",
    "expressions": [
      "map_values(map(select(.name != \"Name1\")))",
      "reduce keys[] as $k (. ; del(.[$k][] | select(.name == \"Name1\")))",
      "walk(if type == \"object\" and .name == \"Name1\" then empty else . end)",
      "walk(if type == \"array\" then map(select( type != \"object\" or .name != \"Name1\")) else . end)"
    ],
    "data": [
      {
        "input": {
          "Category1": [
            {
              "name": "Name1",
              "desc": "Desc1"
            },
            {
              "name": "Name2",
              "desc": "Desc2"
            }
          ],
          "Category2": [
            {
              "name": "Name1",
              "desc": "Desc1"
            },
            {
              "name": "Name3",
              "desc": "Desc3"
            }
          ],
          "Category3": [
            {
              "name": "Name4",
              "desc": "Desc4"
            }
          ]
        },
        "output": {
          "Category1": [
            {
              "name": "Name2",
              "desc": "Desc2"
            }
          ],
          "Category2": [
            {
              "name": "Name3",
              "desc": "Desc3"
            }
          ],
          "Category3": [
            {
              "name": "Name4",
              "desc": "Desc4"
            }
          ]
        }
      }
    ],
    "identifier": 38314400
  },
  {
    "context": [
      "The expected output from the above command is:\r\n\r\n    {\r\n      \"ap-south-1|m1.small\": \"N/A\",\r\n      \"us-east-1|m1.small\": \"0.061\",\r\n      \"sa-east-1|m1.small\": \"0.058\",\r\n      \"ap-northeast-2|m1.small\": \"0.058\",\r\n      \"ap-southeast-2|m1.small\": \"0.058\",\r\n      \"us-west-2|m1.small\": \"0.044\",\r\n      \"us-gov-west-1|m1.small\": \"0.053\",\r\n      \"us-west-1|m1.small\": \"0.047\",\r\n      \"eu-central-1|m1.small\": \"N/A\",\r\n      \"eu-west-1|m1.small\": \"0.047\"\r\n    }",
      "A simplified and working version of your jq program goes as follows:\r\n\r\n    jq '.[] | .instance_type as $it | .pricing | with_entries(.key |= \"\\(.)|\\($it)\" | .value |= .linux.ondemand)'",
      "Here is a solution which uses **keys_unsorted** to preserve the ordering of the keys in the original `.pricing` object.\r\n\r\n        .[]\r\n      | .instance_type as $instance_type\r\n      | .pricing\r\n      | [\r\n            keys_unsorted[] as $k\r\n          | .[$k].linux.ondemand\r\n          | {(\"\\($k)|\\($instance_type)\": .}\r\n        ]\r\n      | add"
    ],
    "utterance": "Produce a mapping from region and instance_type (joined by '|') to the corresponding .linux.ondemand value for each instance in the input, such that the keys are 'region|instance_type' and the values are the corresponding prices.",
    "expressions": [
      ".[] | .instance_type as $it | .pricing | with_entries(.key |= \"\\(.)|\\($it)\" | .value |= .linux.ondemand)",
      ".[]\n  | .instance_type as $instance_type\n  | .pricing\n  | [\n        keys_unsorted[] as $k\n      | .[$k].linux.ondemand\n      | {(\"\\($k)|\\($instance_type)\": .}\n    ]\n  | add"
    ],
    "data": [
      {
        "input": [
          {
            "instance_type": "m1.small",
            "pricing": {
              "ap-south-1": {
                "linux": {
                  "ondemand": "N/A"
                }
              },
              "us-east-1": {
                "linux": {
                  "ondemand": "0.061"
                }
              },
              "sa-east-1": {
                "linux": {
                  "ondemand": "0.058"
                }
              },
              "ap-northeast-2": {
                "linux": {
                  "ondemand": "0.058"
                }
              },
              "ap-southeast-2": {
                "linux": {
                  "ondemand": "0.058"
                }
              },
              "us-west-2": {
                "linux": {
                  "ondemand": "0.044"
                }
              },
              "us-gov-west-1": {
                "linux": {
                  "ondemand": "0.053"
                }
              },
              "us-west-1": {
                "linux": {
                  "ondemand": "0.047"
                }
              },
              "eu-central-1": {
                "linux": {
                  "ondemand": "N/A"
                }
              },
              "eu-west-1": {
                "linux": {
                  "ondemand": "0.047"
                }
              }
            }
          },
          {
            "instance_type": "m1.medium",
            "pricing": {
              "ap-south-1": {
                "linux": {
                  "ondemand": "N/A"
                }
              },
              "us-east-1": {
                "linux": {
                  "ondemand": "0.087"
                }
              },
              "ap-northeast-1": {
                "linux": {
                  "ondemand": "0.122"
                }
              },
              "sa-east-1": {
                "linux": {
                  "ondemand": "0.117"
                }
              },
              "ap-northeast-2": {
                "linux": {
                  "ondemand": "N/A"
                }
              },
              "ap-southeast-1": {
                "linux": {
                  "ondemand": "0.117"
                }
              },
              "ap-southeast-2": {
                "linux": {
                  "ondemand": "0.117"
                }
              },
              "us-west-2": {
                "linux": {
                  "ondemand": "0.087"
                }
              },
              "us-gov-west-1": {
                "linux": {
                  "ondemand": "0.106"
                }
              },
              "us-west-1": {
                "linux": {
                  "ondemand": "0.095"
                }
              },
              "us-central-1": {
                "linux": {
                  "ondemand": "N/A"
                }
              }
            }
          }
        ],
        "output": [
          {
            "ap-south-1|m1.small": "N/A",
            "us-east-1|m1.small": "0.061",
            "sa-east-1|m1.small": "0.058",
            "ap-northeast-2|m1.small": "0.058",
            "ap-southeast-2|m1.small": "0.058",
            "us-west-2|m1.small": "0.044",
            "us-gov-west-1|m1.small": "0.053",
            "us-west-1|m1.small": "0.047",
            "eu-central-1|m1.small": "N/A",
            "eu-west-1|m1.small": "0.047"
          },
          {
            "ap-south-1|m1.medium": "N/A",
            "us-east-1|m1.medium": "0.087",
            "ap-northeast-1|m1.medium": "0.122",
            "sa-east-1|m1.medium": "0.117",
            "ap-northeast-2|m1.medium": "N/A",
            "ap-southeast-1|m1.medium": "0.117",
            "ap-southeast-2|m1.medium": "0.117",
            "us-west-2|m1.medium": "0.087",
            "us-gov-west-1|m1.medium": "0.106",
            "us-west-1|m1.medium": "0.095",
            "us-central-1|m1.medium": "N/A"
          }
        ]
      }
    ],
    "identifier": 38111625
  },
  {
    "context": [
      "But when I try to pass regular expression as an argument to jq it return an empty array.",
      "aws ecr list-images --registry-id 123456789012 --repository-name repo | jq --arg reg_exp \"[a-z0-9]-[0-9]\" '.imageIds | map(select(.imageTag)) | map(select(.imageTag | test(\"$reg_exp\")))'",
      "`$reg_exp` is a variable referring to your regular expression, `\"$reg_exp\"` is just a literal string.  Remove the quotes.",
      "jq --arg reg_exp \"[a-z0-9]-[0-9]\" '.imageIds | map(select(.imageTag | test($reg_exp)))'"
    ],
    "utterance": "Filter objects where the imageTag field matches the pattern [a-z0-9]-[0-9], passing the pattern as a variable.",
    "expressions": [
      ".imageIds | map(select(.imageTag | test($reg_exp)))"
    ],
    "identifier": 38396689
  },
  {
    "context": [
      "I would like it to include the unfounded select tags and fill it in as empty field in the csv",
      "Instead of using `select/1`, use `filter/1`, where:\r\n\r\n    def filter(f): if f then . else \"\" end;",
      "You can use the [alternative operator `//`](https://stedolan.github.io/jq/manual/v1.6/#Alternativeoperator://):",
      "jq -r '.Reservations[]\r\n | [.OwnerId,\r\n    .Instances[].InstanceId,\r\n    .Instances[].Placement.AvailabilityZone,\r\n    (.Instances[].Tags[]?|select(.Key==\"OtherTag\")|.Value)//\"\",\r\n    (.Instances[].Tags[]?|select(.Key==\"Name\")|.Value)//\"\" ]\r\n| @csv'"
    ],
    "utterance": "Produce CSV rows with OwnerId, InstanceId, AvailabilityZone, the value for tag Key==\"OtherTag\" or an empty string if missing, and the value for tag Key==\"Name\" or an empty string if missing.",
    "expressions": [
      ".Reservations[] | [.OwnerId, .Instances[].InstanceId, .Instances[].Placement.AvailabilityZone, (.Instances[].Tags[]?|select(.Key==\"OtherTag\")|.Value)//\"\", (.Instances[].Tags[]?|select(.Key==\"Name\")|.Value)//\"\"] | @csv",
      ".Reservations[]\n| .OwnerId as $owner\n| .Instances[]\n| .InstanceId as $id    \n| .Placement.AvailabilityZone as $az\n| .Tags\n| from_entries\n| \"\\($owner),\\($id),\\($az),\\(.OtherTag//\"\"),\\(.Name//\"\")\""
    ],
    "identifier": 38396925
  },
  {
    "context": [
      "and want to change the value of DEBUG to 5.",
      "but I want to see full json with changed value",
      "jq '(.file1[].environment[]|select(.name==\"DEBUG\").value) |= 5' file.json",
      "Output:\n\n    {\n      \"file1\": [\n        {\n          \"username\": \"myname\",\n          \"groupname\": \"mypassword\",\n          \"environment\": [\n            {\n              \"name\": \"UMASK\",\n              \"value\": \"022\"\n            },\n            {\n              \"name\": \"DEBUG\",\n              \"value\": 5\n            }\n          ]\n        }\n      ]\n    }"
    ],
    "utterance": "Update the value associated with the name DEBUG to 5 and return the complete object with the modification.",
    "expressions": [
      "(.file1[].environment[]|select(.name==\"DEBUG\").value) |= 5"
    ],
    "data": [
      {
        "input": {
          "file1": [
            {
              "username": "myname",
              "groupname": "mypassword",
              "environment": [
                {
                  "name": "UMASK",
                  "value": "022"
                },
                {
                  "name": "DEBUG",
                  "value": "2"
                }
              ]
            }
          ]
        },
        "output": {
          "file1": [
            {
              "username": "myname",
              "groupname": "mypassword",
              "environment": [
                {
                  "name": "UMASK",
                  "value": "022"
                },
                {
                  "name": "DEBUG",
                  "value": 5
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 38437046
  },
  {
    "context": [
      "How can i extract id of project whose name is ansible using jq?",
      "$ jq --arg name \"ansible\" '.[] | select(.name == $name).id' input.json",
      "you may want to use **first**.  This solution will return the id of the first match found and then stop.",
      "first(.[] | if .name == \"ansible\" then .id else empty end)"
    ],
    "utterance": "Extract the id field from the object whose name field is exactly \"ansible\".",
    "expressions": [
      ".[] | select(.name == \"ansible\") | .id",
      ".[] | select(.name == $name) | .id",
      "first(.[] | if .name == \"ansible\" then .id else empty end)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 38,
            "name": "ansible",
            "path": "ansible",
            "description": "Ansible playbooks, roles, and supporting tools repos"
          },
          {
            "id": 18,
            "name": "Analytics",
            "path": "analytics",
            "description": "Big Data Analytics projects"
          }
        ],
        "output": 38
      }
    ],
    "identifier": 38471393
  },
  {
    "context": [
      "I have a JSON like this:\r\n\r\n    { \r\n      \"A\": { \"error\": null },\r\n      \"B\": { \"C\": {\"error\": \"error string\"}},\r\n      \"C\": { \"D\": {\"error\": null}},\r\n      \"D\": { \"error\": \"err str\"}\r\n    }\r\n\r\nend I want to find all values of **error** keys which are not **null**.",
      "For my example it should return \r\n    \"error string\"\r\n    \"err str\"",
      "Use `..` to iterate recursively, and get all the `.error` values. If they're `null`, remove them:\r\n\r\n    jq '.. | .error? // empty'",
      "Alternatively, instead of using `empty` you can select the elements that are strings with `strings`:\r\n\r\n    jq '.. | .error? | strings'",
      "Here is a solution that uses **tostream** and **select**\r\n\r\n      tostream\r\n    | select(length==2 and .[0][-1]==\"error\" and .[1]!=null) as [$p,$v]\r\n    | $v"
    ],
    "utterance": "Find all values of keys named 'error' that are not null.",
    "expressions": [
      ".. | .error? // empty",
      ".. | .error? | strings",
      "tostream | select(length==2 and .[0][-1]==\"error\" and .[1]!=null) as [$p,$v] | $v"
    ],
    "data": [
      {
        "input": {
          "A": {
            "error": null
          },
          "B": {
            "C": {
              "error": "error string"
            }
          },
          "C": {
            "D": {
              "error": null
            }
          },
          "D": {
            "error": "err str"
          }
        },
        "output": [
          "error string",
          "err str"
        ]
      }
    ],
    "identifier": 38459429
  },
  {
    "context": [
      "I'm trying to replace all the doc entries (the entire block, not just the value of the keys) that have \"_attachments\" with a new block of json that is stored in a variable named \"doc\"",
      "jq --argjson new \"$doc\" '(.docs[]| select(has(\"_attachments\"))) |= $new' docs.json",
      "you could use the `-s` slurp option along with a filter such as\n\n      .[0] as $new\n    | .[1]\n    | ( .docs[] | select(has(\"_attachments\")) ) = $new"
    ],
    "utterance": "Replace every entry in docs that contains the _attachments key with the contents of a provided variable doc.",
    "expressions": [
      "jq --argjson new \"$doc\" '(.docs[]| select(has(\"_attachments\"))) |= $new' docs.json",
      ".[0] as $new | .[1] | ( .docs[] | select(has(\"_attachments\")) ) = $new"
    ],
    "data": [
      {
        "input": {
          "number_of_docs": "1000",
          "docs": [
            {
              "_id": "000001",
              "_rev": "0",
              "_content": "abcdefg"
            },
            {
              "_id": "000002",
              "_rev": "0",
              "_content": "hijklmn",
              "_attachments": {
                "image1.png": {
                  "content_type": "image/png"
                }
              }
            },
            {
              "_id": "000003",
              "_rev": "0",
              "_content": "opqrstuv"
            }
          ]
        },
        "output": {
          "number_of_docs": "1000",
          "docs": [
            {
              "_id": "000001",
              "_rev": "0",
              "_content": "abcdefg"
            },
            {
              "_id": "000002_masked",
              "_rev": "0",
              "_content": "[Document content has been masked for confidentiality.]",
              "_attachments": {
                "confidential.png": {
                  "content_type": "image/png"
                }
              }
            },
            {
              "_id": "000003",
              "_rev": "0",
              "_content": "opqrstuv"
            }
          ]
        }
      }
    ],
    "identifier": 38466960
  },
  {
    "context": [
      "sum every numeric value of a key:value pair found at any level",
      "all coincident object key paths should sum their values to the same location in the single output object hierarchy",
      "Over an array of these objects, do `. as $dot | reduce ([$dot[] | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$dot[] | getpath($path)] | add))`",
      "def additive_merge: . as $dot | reduce ([$dot[] | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$dot[] | getpath($path)] | add));",
      "Here is a solution that uses **tostream**, **select**, **reduce**, **setpath** and **getpath**.",
      "reduce (tostream|select(length==2)|.[0] = .[0][1:]) as [$p,$v] (\n   {};\n   setpath($p; getpath($p) + $v)\n)"
    ],
    "utterance": "Sum all numeric values at all key paths across an array of arbitrarily nested objects, merging overlapping keys recursively.",
    "expressions": [
      ". as $dot | reduce ([$dot[] | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$dot[] | getpath($path)] | add))",
      "def additive_merge: . as $dot | reduce ([$dot[] | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$dot[] | getpath($path)] | add));",
      "reduce (tostream|select(length==2)|.[0] = .[0][1:]) as [$p,$v] ({}; setpath($p; getpath($p) + $v))"
    ],
    "data": [
      {
        "input": [
          {
            "A": {
              "B": {
                "x": 1,
                "y": 4
              },
              "C": {
                "x": 3,
                "z": 6
              },
              "t": 2
            },
            "s": 5
          },
          {
            "A": {
              "B": {
                "x": 2,
                "z": 3
              },
              "t": 1
            },
            "s": 0
          },
          {
            "A": {
              "C": {
                "y": 3,
                "z": 2
              }
            },
            "s": 3
          }
        ],
        "output": {
          "A": {
            "B": {
              "x": 3,
              "y": 4,
              "z": 3
            },
            "C": {
              "x": 3,
              "y": 3,
              "z": 8
            },
            "t": 3
          },
          "s": 8
        }
      }
    ],
    "identifier": 38443179
  },
  {
    "context": [
      "I have a json file containing several profiles:",
      "I want to use jq to insert another profile, \"test\", so that the end result will be",
      "jq --arg p \"$PROFILE\" --arg u \"$U\" --arg c \"$C\" --arg w \"$WH\" \\\n'. + {($p): {\"user\": $u, \"channel\": $c, \"hook\": $w}}' \"$CONF_FILE\"",
      "jq '\n    .[env.P] = {\n       user:    env.U, \n       channel: env.C, \n       hook:    env.W\n    }\n' \"$CONF_FILE\"",
      "If `data.json` contains the sample data this script should produce the output\n\n    {\n      \"profile1\": {\n        \"user\": \"user1\",\n        \"channel\": \"channel1\",\n        \"hook\": \"hook1\"\n      },\n      \"default\": {\n        \"user\": \"user1\",\n        \"channel\": \"channel1\",\n        \"hook\": \"hook2\"\n      },\n      \"test\": {\n        \"user\": \"user3\",\n        \"channel\": \"channel3\",\n        \"hook\": \"hook3\"\n      }\n    }\n"
    ],
    "utterance": "Add a new key with the name and nested values provided by external variables to the top-level object.",
    "expressions": [
      ". + {($p): {\"user\": $u, \"channel\": $c, \"hook\": $w}}",
      ".[env.P] = {user: env.U, channel: env.C, hook: env.W}"
    ],
    "data": [
      {
        "input": {
          "profile1": {
            "user": "user1",
            "channel": "channel1",
            "hook": "hook1"
          },
          "default": {
            "user": "user1",
            "channel": "channel1",
            "hook": "hook2"
          }
        },
        "output": {
          "profile1": {
            "user": "user1",
            "channel": "channel1",
            "hook": "hook1"
          },
          "default": {
            "user": "user1",
            "channel": "channel1",
            "hook": "hook2"
          },
          "test": {
            "user": "user3",
            "channel": "channel3",
            "hook": "hook3"
          }
        }
      }
    ],
    "identifier": 37904796
  },
  {
    "context": [
      "I'm using `jq '.value|tonumber|(./(1024*1024*1024*1024))'`, but I'd prefer to replace the `1024*1024*1024*1024` with something like `1024**4` or `1024^4` is there anyway to do this in `jq`?  Is there another way I'm missing?",
      "However, you should have access to [C Math](https://stedolan.github.io/jq/manual/#Math) functions available on your platform. So a lot of what's in the cstdlib should be fair game, such as the [pow()](http://www.cplusplus.com/reference/cmath/pow/) function.",
      "(.value | tonumber) / pow(1024; 4)"
    ],
    "utterance": "Divide the value field, interpreted as a number, by 1024 raised to the 4th power using an exponentiation operator.",
    "expressions": [
      "(.value | tonumber) / pow(1024; 4)"
    ],
    "data": [
      {
        "input": {
          "value": "43165913081459",
          "name": "AvailableStorage"
        }
      }
    ],
    "identifier": 38495941
  },
  {
    "context": [
      "Given arrays X and Y (preferably both as inputs, but otherwise, with one as input and the other hardcoded), how can I use jq to output the array containing all elements common to both? e.g. what is a value of f such that\n\necho '[1,2,3,4]' | jq 'f([2,4,6,8,10])'\n\nwould output\n\n[2,4]\n\n?",
      "Here's a simpler but slower def that's nevertheless quite fast in practice:\n\n    def i(x;y):\n       if (y|length) == 0 then []\n       else (x|unique) as $x\n       | $x - ($x - y)\n       end ;",
      "Here is a solution which works by counting occurrences of elements in the arrays using **foreach**\n\n    [\n      foreach ($X[], $Y[]) as $r (\n        {}\n      ; .[$r|tostring] += 1\n      ; if .[$r|tostring] == 2 then $r else empty end\n      )\n    ]\n",
      "$ echo '[1,2,3,4] [2,4,6,8,10]' | jq --slurp '[.[0][] as $x | .[1][] | select($x == .)]'\n[\n  2,\n  4\n]",
      "# Put it all together\n$ jq --null-input '[1,2,3,4] - ([1,2,3,4] - [2,4,6,8])'\n[\n  2,\n  4\n]\n"
    ],
    "utterance": "Find all elements that are present in both the arrays [1,2,3,4] and [2,4,6,8,10].",
    "expressions": [
      "[1,2,3,4] - ([1,2,3,4] - [2,4,6,8,10])",
      "def i(x;y): if (y|length) == 0 then [] else (x|unique) as $x | $x - ($x - y) end ; i([1,2,3,4]; [2,4,6,8,10])",
      "[foreach ([1,2,3,4][] , [2,4,6,8,10][]) as $r ({}; .[$r|tostring] += 1; if .[$r|tostring] == 2 then $r else empty end)]",
      "[.[0][] as $x | .[1][] | select($x == .)]"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4
        ],
        "output": [
          2,
          4
        ]
      },
      {
        "input": [
          [
            1,
            2,
            3,
            4
          ],
          [
            2,
            4,
            6,
            8,
            10
          ]
        ],
        "output": [
          2,
          4
        ]
      }
    ],
    "identifier": 38364458
  },
  {
    "context": [
      "can you help with the jq syntax to pull out and present\r\n\r\n    ProductCostingBJF_v2.3.0    true\r\n    master                      true",
      "I got the first part ... I can get the branch name with \r\n\r\n    jq  -r .[].name\r\n\r\nbut i cannot figure how to get the enabled value.",
      "You can use the following jq command:\r\n\r\n    jq -r '.[]| \"\\(.name) \\(.protection.enabled)\"' a.json ",
      "Here is alternative syntax using joined lines (`-j`):\r\n\r\n    $ jq -j '.[] | .name, \"\\t\", .protection.enabled, \"\\n\"' payload.json "
    ],
    "utterance": "Extract the name and the protection enabled status for each item, printing them side-by-side.",
    "expressions": [
      ".[] | \"\\(.name) \\(.protection.enabled)\"",
      ".[] | .name, \"\\t\", .protection.enabled, \"\\n\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "ProductCostingBJF_v2.3.0",
            "commit": {},
            "protection": {
              "enabled": true,
              "required_status_checks": {
                "enforcement_level": "off",
                "contexts": []
              }
            }
          },
          {
            "name": "master",
            "commit": {},
            "protection": {
              "enabled": true,
              "required_status_checks": {
                "enforcement_level": "off",
                "contexts": []
              }
            }
          }
        ],
        "output": "ProductCostingBJF_v2.3.0 true\nmaster true"
      }
    ],
    "identifier": 38505083
  },
  {
    "context": [
      "But if the json is already disassembled (for instance, after filtering entries using 'select'), how can I choose a single entry and avoid the error seen here?",
      "jq '[.[]|select(.a==\"x\")][0]' your.json",
      "Output:",
      "{",
      "  \"a\": \"x\",",
      "  \"b\": false",
      "}"
    ],
    "utterance": "Select the first object with property a equal to x from an array after filtering.",
    "expressions": [
      "[.[] | select(.a==\"x\")][0]",
      "map(select(.a==\"x\")) | .[0]",
      "first(.[] | select(.a==\"x\"))",
      "map(select(.a==\"x\")) | first",
      "map(select(.a==\"x\")) | nth(0)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "x",
            "b": true
          },
          {
            "a": "x",
            "b": false
          },
          {
            "a": "XML",
            "b": false
          }
        ],
        "output": {
          "a": "x",
          "b": true
        }
      }
    ],
    "identifier": 38500363
  },
  {
    "context": [
      "But I would also liked to do the opposite (basically excluding IDs instead of selecting them). Using `select(.id != (\"1\", \"2\", \"56\", \"1337\"))` doesn't work and using `jq '[. - [.[] | select(.id == (\"1\", \"2\", \"56\", \"1337\"))]]' ./data.json` seems very ugly and it doesn't work with my actual data (an output of `aws ec2 describe-instances`).",
      "$ jq --argjson exclude '[\"1\", \"2\", \"56\", \"1337\"]' '. - map(select(.id == $exclude[]))' ...",
      "map( select([.id] | inside($IDS) | not) )",
      "produces the ids from `data.json` that are not in the `$IDS` array:\n\n    [\n      {\n        \"id\": \"10\",\n        \"foo\": \"bar-c\",\n        \"hello\": \"world-c\"\n      },\n      {\n        \"id\": \"42\",\n        \"foo\": \"bar-d\",\n        \"hello\": \"world-d\"\n      }\n    ]"
    ],
    "utterance": "Exclude all objects whose id is any of: \"1\", \"2\", \"56\", or \"1337\".",
    "expressions": [
      "map(select([.id] | inside($IDS) | not))",
      ". - map(select(.id == $exclude[]))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "foo": "bar-a",
            "hello": "world-a"
          },
          {
            "id": "2",
            "foo": "bar-b",
            "hello": "world-b"
          },
          {
            "id": "10",
            "foo": "bar-c",
            "hello": "world-c"
          },
          {
            "id": "42",
            "foo": "bar-d",
            "hello": "world-d"
          }
        ],
        "output": [
          {
            "id": "10",
            "foo": "bar-c",
            "hello": "world-c"
          },
          {
            "id": "42",
            "foo": "bar-d",
            "hello": "world-d"
          }
        ]
      }
    ],
    "identifier": 38508827
  },
  {
    "context": [
      "I need to find the blocks where \"financial_debt\" is true. This field could be either in the main_attribute (as a global value) or in the secondary attribute.",
      "jq '[recurse | .financial_debt? | select(. != null) | recurse | booleans] | any'",
      "tostream\n| select(length==2)\n| select(.[0] | contains([\"financial_debt\"]))",
      "produces\n\n    [[\"main_attribute\",\"financial_debt\",\"bank_loan\"],true]\n    [[\"secondary_attr\",\"education\",\"financial_debt\",\"bank_loan\"],false]"
    ],
    "utterance": "Find all object blocks where the property financial_debt.bank_loan is true, regardless of their position in the structure.",
    "expressions": [
      "[recurse | .financial_debt? | select(. != null) | recurse | select(. == true)]",
      "tostream | select(length==2) | select(.[0] | contains([\"financial_debt\"])) | select(.[1] == true)"
    ],
    "data": [
      {
        "input": {
          "main_attribute": {
            "name": {
              "display_name": "abc"
            },
            "address": {
              "unit": "1",
              "street": "Dundas",
              "suburb": "Syd",
              "state": "NSW"
            },
            "financial_debt": {
              "bank_loan": true
            }
          },
          "secondary_attr": {
            "income": {
              "pretax": 100000
            },
            "automobile": {
              "make": "Citroen",
              "model": 2015,
              "new": true
            },
            "property": {
              "property_owned": 1,
              "owned_since": 2000,
              "first_sale": true
            },
            "education": {
              "degree": "MS",
              "graduated": 1990,
              "financial_debt": {
                "bank_loan": false
              }
            }
          }
        },
        "output": [
          {
            "path": [
              "main_attribute",
              "financial_debt",
              "bank_loan"
            ],
            "value": true
          }
        ]
      }
    ],
    "identifier": 38603792
  },
  {
    "context": [
      "I need to do something like this:",
      "./test.sh \"[{\\\"username\\\":\\\"user1\\\",\\\"password\\\":\\\"pwd1\\\",\\\"group\\\":\\\"usergroup1\\\"},{\\\"username\\\":\\\"user2\\\",\\\"password\\\":\\\"pwd2\\\",\\\"group\\\":\\\"usergroup2\\\"},{\\\"username\\\":\\\"user3\\\",\\\"password\\\":\\\"pwd3\\\",\\\"group\\\":\\\"usergroup3\\\"}]\"",
      "accounts=($(jq -s \".[]\" <<< $system_user))",
      "but what I was expecting is an array of three object (like you can test on jqplay.org)\n\n {\n   \"username\": \"user1\",\n   \"password\": \"pwd1\",\n   \"group\": \"usergroup1\"\n }\n {\n   \"username\": \"user2\",\n   \"password\": \"pwd2\",\n   \"group\": \"usergroup2\"\n }\n {\n   \"username\": \"user3\",\n   \"password\": \"pwd3\",\n   \"group\": \"usergroup3\"\n }\n\n\nIn this way I can make a foreach on ${accounts[@]}",
      "With the `-c` option, you can print each JSON object on a single line, making it easier to populate the array you want.",
      "$ readarray -t arr < <(jq -c '.[]' <<< \"[{\\\"username\\\":\\\"user1\\\",\\\"password\\\":\\\"pwd1\\\",\\\"group\\\":\\\"usergroup1\\\"},{\\\"username\\\":\\\"user2\\\",\\\"password\\\":\\\"pwd2\\\",\\\"group\\\":\\\"usergroup2\\\"},{\\\"username\\\":\\\"user3\\\",\\\"password\\\":\\\"pwd3\\\",\\\"group\\\":\\\"usergroup3\\\"}]\") \n$ printf \"Object: %s\\n\" \"${arr[@]}\"\nObject: {\"username\":\"user1\",\"password\":\"pwd1\",\"group\":\"usergroup1\"}\nObject: {\"username\":\"user2\",\"password\":\"pwd2\",\"group\":\"usergroup2\"}\nObject: {\"username\":\"user3\",\"password\":\"pwd3\",\"group\":\"usergroup3\"}"
    ],
    "utterance": "Split an array of objects into individual objects as single-line strings to store each in a bash array.",
    "expressions": [
      ".[]",
      "-c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "username": "user1",
            "password": "pwd1",
            "group": "usergroup1"
          },
          {
            "username": "user2",
            "password": "pwd2",
            "group": "usergroup2"
          },
          {
            "username": "user3",
            "password": "pwd3",
            "group": "usergroup3"
          }
        ],
        "output": [
          {
            "username": "user1",
            "password": "pwd1",
            "group": "usergroup1"
          },
          {
            "username": "user2",
            "password": "pwd2",
            "group": "usergroup2"
          },
          {
            "username": "user3",
            "password": "pwd3",
            "group": "usergroup3"
          }
        ]
      }
    ],
    "identifier": 38484511
  },
  {
    "context": [
      "How can I list all unique keys of a json file for all levels and array attributes, together with their path?",
      "If you stream the input in, it will give you pairs of the paths and values contained in the input.",
      "$ jq --stream 'select(length>1)[0]' input.json"
    ],
    "utterance": "List all unique keys at every level of an object, including arrays, reporting the path to each key.",
    "expressions": [
      "jq --stream 'select(length>1)[0]' input.json"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": 1
          },
          "biz": {
            "baz": 2
          }
        },
        "output": [
          [
            "foo",
            "bar"
          ],
          [
            "biz",
            "baz"
          ]
        ]
      }
    ],
    "identifier": 38630244
  },
  {
    "context": [
      "The absolute simplest (and least interesting) filter is `.`. This is a filter that takes its input and produces it unchanged as output.",
      "Since `jq` by default pretty-prints all output, this trivial program can be a useful way of formatting JSON output from, say, `curl`.",
      "In the jq programming language, `.` refers to the implicit input of a filter.",
      "In addition to `jq .` pretty-printing the output, it also produces a warning if the input file cannot be parsed."
    ],
    "utterance": "Display the input data unchanged, pretty-printed and validated for syntax errors.",
    "expressions": [
      "."
    ],
    "identifier": 38640063
  },
  {
    "context": [
      "I want to remove \"source\" properties. How can I do that without specifying keys \"c\", \"d\" or \"e\", because they are dynamic.",
      "walk(if type == \"object\" then del(.source) else . end)",
      ".b[] |= del(.source)",
      "del( .b[].source )"
    ],
    "utterance": "Remove all properties named \"source\" from all objects inside property b, regardless of their keys.",
    "expressions": [
      ".b[] |= del(.source)",
      "del( .b[].source )",
      "walk(if type == \"object\" then del(.source) else . end)"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": {
            "c": {
              "c1": "abc",
              "source": "abcxyz"
            },
            "d": {
              "d1": "abcd",
              "source": "abcxyz"
            },
            "e": {
              "e1": "abcde",
              "source": "abcxyz"
            }
          }
        },
        "output": {
          "a": 1,
          "b": {
            "c": {
              "c1": "abc"
            },
            "d": {
              "d1": "abcd"
            },
            "e": {
              "e1": "abcde"
            }
          }
        }
      }
    ],
    "identifier": 38626762
  },
  {
    "context": [
      "In this I want to add another section like:\r\n\r\n    {\r\n      \"Value\": {\r\n        \"Ref\": \"TEAM\"\r\n      },\r\n      \"PropagateAtLaunch\": true,\r\n      \"Key\": \"TEAM\"\r\n    }\r\n\r\nHow can I add this new section?",
      "Try this \"jq -s add ABC.json add.json\" as below;",
      "You can pass the object as a jq variable using `--argjson`, then use `+=` to add the object to the array:\r\n\r\n    jq --argjson obj '{\"sample\": \"object\"}' '.Resources.ASGRP.Properties.Tags += [$obj]'"
    ],
    "utterance": "Add an object with {\"Value\": {\"Ref\": \"TEAM\"}, \"PropagateAtLaunch\": true, \"Key\": \"TEAM\"} to the end of an array.",
    "expressions": [
      "jq -s add ABC.json add.json",
      "jq --argjson obj '{\"Value\": {\"Ref\": \"TEAM\"}, \"PropagateAtLaunch\": true, \"Key\": \"TEAM\"}' '.Resources.ASGRP.Properties.Tags += [$obj]'"
    ],
    "data": [
      {
        "input": [
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TNAM"
            },
            "Key": "Name"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TAPP"
            },
            "Key": "application"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TENV"
            },
            "Key": "environment"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TSHA"
            },
            "Key": "shared"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TTER"
            },
            "Key": "tier"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "CostCenter"
            },
            "Key": "cost-center"
          }
        ],
        "output": [
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TNAM"
            },
            "Key": "Name"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TAPP"
            },
            "Key": "application"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TENV"
            },
            "Key": "environment"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TSHA"
            },
            "Key": "shared"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TTER"
            },
            "Key": "tier"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "CostCenter"
            },
            "Key": "cost-center"
          },
          {
            "PropagateAtLaunch": true,
            "Value": {
              "Ref": "TEAM"
            },
            "Key": "TEAM"
          }
        ]
      }
    ],
    "identifier": 38561384
  },
  {
    "context": [
      "I pass this through JQ to filter the json using the following command:",
      "    echo $getNames | jq -r .user[].name",
      "Which gives me a list like this:",
      "    James Brown   ",
      "    Matthew Thompson   ",
      "I want to put each one of these entries into a bash array",
      "However, when I try to print the array using:",
      "    printf '%s\\n' \"${myArray[@]}\"",
      "I get the following:",
      "    James",
      "    Brown",
      "    Matthew",
      "    Thompson",
      "How do I ensure that a new index is created after a new line and not a space? Why are the names being separated?"
    ],
    "utterance": "Extract all values of the 'name' field from each object in the 'user' array where each value may contain spaces.",
    "expressions": [
      ".user[].name"
    ],
    "data": [
      {
        "input": {
          "count": 49,
          "user": [
            {
              "username": "jamesbrown",
              "name": "James Brown",
              "id": 1
            },
            {
              "username": "matthewthompson",
              "name": "Matthew Thompson",
              "id": 2
            }
          ]
        },
        "output": [
          "James Brown",
          "Matthew Thompson"
        ]
      }
    ],
    "identifier": 38633599
  },
  {
    "identifier": 38716209
  },
  {
    "context": [
      "Assume you a file where each line is a valid JSON. Furthermore, each object contains a field `type` and `id` and the pairs of are unique.",
      "Using the `bulk` API together with `jq` using something like: $ cat foo.json | jq -c '. | {\"index\": {\"_index\": \"your_test_index\", \"_type\": \"doc_type\"}}, .' | curl -XPOST localhost:9200/_bulk --data-binary @-"
    ],
    "utterance": "For each object in a file with one object per line, generate a stream of action/metadata lines and object lines for bulk indexing, setting _index to your_test_index and _type to doc_type.",
    "expressions": [
      ". | {\"index\": {\"_index\": \"your_test_index\", \"_type\": \"doc_type\"}}, ."
    ],
    "identifier": 38658471
  },
  {
    "context": [
      "But what if I want to get the id of this person as well?",
      "I need a way to select a parent's field when I am already 5 or 6 layers deep after carrying out various methods of filtering.",
      "For a more generic approach, save the value of the \"parent\" element at the detail level you want, then pipe it at the end of your filter:",
      "`jq '. as $parent | .details.name | select(. == \"James Brown\") | $parent'`"
    ],
    "utterance": "After filtering down to a deeply nested field with the value 'James Brown', retrieve a value from its parent object, such as 'id'.",
    "expressions": [
      ". as $parent | .details.name | select(. == \"James Brown\") | $parent",
      "select(.details.name == \"James Brown\").id"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "details": {
            "username": "jamesbrown",
            "name": "James Brown"
          }
        },
        "output": 1
      }
    ],
    "identifier": 38689645
  },
  {
    "context": [
      "i would like to modify the object with *name* property *CONFIG_URL* with *value* \"this is atest\".",
      "$ jq --arg update_name \"CONFIG_URL\" --arg update_value \"this is a test\" \\\n'(.containerDefinitions[].environment[] | select(.name == $update_name)).value = $update_value' input.json",
      "(\n  .containerDefinitions[]\n| .environment[]\n| select(.name == \"CONFIG_URL\")\n| .value\n) |= \"this is atest\""
    ],
    "utterance": "Update the value to \"this is atest\" for the environment object where the name property is \"CONFIG_URL\".",
    "expressions": [
      "(.containerDefinitions[].environment[] | select(.name == \"CONFIG_URL\")).value = \"this is atest\"",
      "(.containerDefinitions[].environment[] | select(.name == $update_name)).value = $update_value",
      "(.containerDefinitions[] | .environment[] | select(.name == \"CONFIG_URL\") | .value) |= \"this is atest\""
    ],
    "data": [
      {
        "input": {
          "family": "contentpublishing-task",
          "volumes": [],
          "containerDefinitions": [
            {
              "environment": [
                {
                  "name": "TEST_ENV",
                  "value": "TEST"
                },
                {
                  "name": "CONFIG_URL",
                  "value": "s3://stg-appcfg/config-20160729-1130.json"
                }
              ],
              "name": "contentpublishing",
              "mountPoints": [],
              "image": "contentpublishing:blah",
              "cpu": 512,
              "portMappings": [
                {
                  "protocol": "tcp",
                  "containerPort": 8081,
                  "hostPort": 8080
                }
              ],
              "memory": 256,
              "essential": true,
              "volumesFrom": []
            }
          ]
        },
        "output": {
          "family": "contentpublishing-task",
          "volumes": [],
          "containerDefinitions": [
            {
              "environment": [
                {
                  "name": "TEST_ENV",
                  "value": "TEST"
                },
                {
                  "name": "CONFIG_URL",
                  "value": "this is atest"
                }
              ],
              "name": "contentpublishing",
              "mountPoints": [],
              "image": "contentpublishing:blah",
              "cpu": 512,
              "portMappings": [
                {
                  "protocol": "tcp",
                  "containerPort": 8081,
                  "hostPort": 8080
                }
              ],
              "memory": 256,
              "essential": true,
              "volumesFrom": []
            }
          ]
        }
      }
    ],
    "identifier": 38709766
  },
  {
    "context": [
      "I have been trying to use jq to parse a json file returned from the aws cli, but I&#39;m stuck with the problem of referencing an array using the index number.",
      "This returns an error:\r\n\r\n\r\n    1\r\n    jq: error (at &lt;stdin&gt;:189): Cannot index array with string \"1\";",
      "You would either have to use the command line arg `--argjson` or `fromjson` filter to convert the argument to a number.  Arrays may only be indexed by ints and using `--arg` keeps the input as a string.",
      "$ jq --argjson i \"$i\" '.SecurityGroups[$i]'",
      "$ jq --arg i \"$i\" '.SecurityGroups[$i|fromjson]'"
    ],
    "utterance": "Select the array element at a user-supplied numeric index held in a shell variable.",
    "expressions": [
      ".SecurityGroups[$i]",
      ".SecurityGroups[$i|fromjson]"
    ],
    "identifier": 38752499
  },
  {
    "context": [
      "I&#39;d like to filter output from below json file to get all start with &quot;tag_Name&quot;",
      "with_entries(select(.key | startswith(&quot;tag_Name&quot;)))",
      "keys | map( select(startswith(&quot;tag_Name&quot;)) | {(.): $d[.]} ) | add",
      "delpaths([\r\n      keys[]\r\n    | select(startswith(&quot;tag_Name&quot;) | not)\r\n    | [.]\r\n ])",
      "reduce keys[] as $k (\r\n   .\r\n ; if ($k|startswith(&quot;tag_Name&quot;)) then . else del(.[$k]) end\r\n )"
    ],
    "utterance": "Return all key-value pairs where the key starts with 'tag_Name'.",
    "expressions": [
      "with_entries(select(.key | startswith(\"tag_Name\")))",
      ". as $d | keys | map( select(startswith(\"tag_Name\")) | {(.): $d[.]} ) | add",
      "delpaths([keys[] | select(startswith(\"tag_Name\") | not) | [.]])",
      "reduce keys[] as $k (. ; if ($k|startswith(\"tag_Name\")) then . else del(.[$k]) end)"
    ],
    "data": [
      {
        "input": {
          "other_key": 1,
          "tag_Name_abc": [
            "10_1_4_3",
            "10_1_6_2",
            "10_1_5_3",
            "10_1_5_5"
          ],
          "tag_Name_efg": [
            "10_1_4_5"
          ],
          "unrelated": true
        },
        "output": {
          "tag_Name_abc": [
            "10_1_4_3",
            "10_1_6_2",
            "10_1_5_3",
            "10_1_5_5"
          ],
          "tag_Name_efg": [
            "10_1_4_5"
          ]
        }
      }
    ],
    "identifier": 38734034
  },
  {
    "context": [
      "I want to use `jq` to parse the above JSON file and get the below format:\r\n\r\n    nus>sde1>floor1\r\n    nus>sde1>floor2\r\n    ntu>ece1>floor1\r\n    ntu>ece1>floor2",
      "basically I have to concatenate the `Campus Name` with `Building Name` and `Floor name` and put a `<` symbol in between.",
      "If the nested object field `Floor` is not exist, ignore the parse and continue the next child object.",
      "jq '.Maps.Campus[]|\"\\(.name)>\\(.Building[]|\"\\(.name)>\\(.Floor[]?.name)\")\"' file.json",
      ".Maps.Campus[]\n| .name as $campus\n| .Building[]\n| .name as $bldg\n| .Floor[]?\n| .name as $floor\n| \"\\($campus)>\\($bldg)>\\($floor)\""
    ],
    "utterance": "Concatenate campus, building, and floor names with '>' as a separator for each floor, skipping buildings without floors.",
    "expressions": [
      ".Maps.Campus[]|\"\\(.name)>\\(.Building[]|\"\\(.name)>\\(.Floor[]?.name)\")\"",
      ".Maps.Campus[] | .name as $campus | .Building[] | .name as $bldg | .Floor[]? | .name as $floor | \"\\($campus)>\\($bldg)>\\($floor)\""
    ],
    "data": [
      {
        "input": {
          "Maps": {
            "Campus": [
              {
                "name": "nus",
                "Building": [
                  {
                    "name": "sde1",
                    "Floor": [
                      {
                        "name": "floor1"
                      },
                      {
                        "name": "floor2"
                      }
                    ]
                  },
                  {
                    "name": "sde2"
                  }
                ]
              },
              {
                "name": "ntu",
                "Building": [
                  {
                    "name": "ece1",
                    "Floor": [
                      {
                        "name": "floor1"
                      },
                      {
                        "name": "floor2"
                      }
                    ]
                  },
                  {
                    "name": "ece2"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "nus>sde1>floor1",
          "nus>sde1>floor2",
          "ntu>ece1>floor1",
          "ntu>ece1>floor2"
        ]
      }
    ],
    "identifier": 38738843
  },
  {
    "context": [
      "I need the result as below (using shell script):\n\n    Labels    Date                  Count\n    \n    label1   2016-07-27             1\n    label2   2016-07-27             2              \n    label2   2016-07-29             1\n    label3   2016-07-29             1",
      "map({ label: .info, date: .timestamp[:10] })\n    | group_by(.)\n    | map(.[0] + { count: length })\n    | to_csv([\"label\", \"date\", \"count\"])",
      "reduce .[] as $r (\n    {}\n  ; [$r.info, $r.timestamp[0:10]] as $p\n  | setpath($p;getpath($p)+1)\n)\n| tostream\n| select(length==2)\n| flatten\n| @tsv"
    ],
    "utterance": "Count how many times each label occurs on each date, with output listing label, date, and count.",
    "expressions": [
      "map({ label: .info, date: .timestamp[:10] })\n    | group_by(.)\n    | map(.[0] + { count: length })\n    | to_csv([\"label\", \"date\", \"count\"])",
      "[\"Labels\", \"Date\", \"Count\"], [\"\", \"\", \"\"], (reduce .[] as $r ({}; [$r.info, $r.timestamp[0:10]] as $p | setpath($p;getpath($p)+1)) | tostream | select(length==2) | flatten) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "info": "label1",
            "description": "some desc",
            "timestamp": "2016-07-27T06:24:50.335Z"
          },
          {
            "info": "label2",
            "description": "some desc",
            "timestamp": "2016-07-27T06:24:50.335Z"
          },
          {
            "info": "label2",
            "description": "some desc",
            "timestamp": "2016-07-27T06:24:50.335Z"
          },
          {
            "info": "label2",
            "description": "some desc",
            "timestamp": "2016-07-29T06:24:50.335Z"
          },
          {
            "info": "label3",
            "description": "some desc",
            "timestamp": "2016-07-29T06:24:50.335Z"
          }
        ],
        "output": [
          {
            "label": "label1",
            "date": "2016-07-27",
            "count": 1
          },
          {
            "label": "label2",
            "date": "2016-07-27",
            "count": 2
          },
          {
            "label": "label2",
            "date": "2016-07-29",
            "count": 1
          },
          {
            "label": "label3",
            "date": "2016-07-29",
            "count": 1
          }
        ]
      }
    ],
    "identifier": 38719225
  },
  {
    "context": [
      "I have a JSON file as the below:",
      "[{\n  \"macAddress\": \"ac:5f:3e:87:d7:1a\",\n  \"ip\": \"1.2.3.4\"\n}, ...]",
      "use `jq` to hash the `macAddress` field like so:",
      "Can I define my own hash function and let `jq` to run the hash during the parsing process?",
      "My expected hash function can be simple as using native linux command `md5sum`",
      "So the output json will be [{\n  \"macAddress\": \"d973ea7c353e78ba1724efbc8054dfdc\",\n  \"ip\": \"1.2.3.4\"\n}, ...]",
      "This stays native and might be suitable;",
      "jq -c .[] \"$jsonfile\" |\nwhile read -r jsonline ; do\n  hashmac=\"$(jq --arg mysalt \"$mysalt\" -s -j '\n        .[] | \"\\($mysalt)\" + .macAddress' <<<\"$jsonline\" |\n      md5sum | cut -d ' ' -f1)\"\n  jq --arg hashmac \"$hashmac\" -s -r '\n      .[] | .macAddress |= \"\\($hashmac)\"' <<<\"$jsonline\"\ndone"
    ],
    "utterance": "Replace the 'macAddress' value of each object with the md5 hash of a salt concatenated to the original macAddress, so that 'macAddress' contains only the resulting hash string.",
    "expressions": [
      "jq -c .[] \"$jsonfile\" | while read -r jsonline; do hashmac=\"$(jq --arg mysalt \"$mysalt\" -s -j '.[] | \"\\($mysalt)\" + .macAddress' <<<\"$jsonline\" | md5sum | cut -d ' ' -f1)\"; jq --arg hashmac \"$hashmac\" -s -r '.[] | .macAddress |= \"\\($hashmac)\"' <<<\"$jsonline\"; done"
    ],
    "data": [
      {
        "input": [
          {
            "macAddress": "42:12:20:2e:2b:ca",
            "ip": "1.2.3.4"
          }
        ],
        "output": [
          {
            "macAddress": "d973ea7c353e78ba1724efbc8054dfdc",
            "ip": "1.2.3.4"
          }
        ]
      }
    ],
    "identifier": 38739648
  },
  {
    "context": [
      "I want to read the values from the second json : \"default_attributes\" and \"override_attributes\" and merge them with the first json into an output like :",
      "Got it. With jq seems super simple :",
      "jq -s '.[0] + .[1].default_attributes + .[1].override_attributes' a-roles.json a-env.json > manifest.json",
      "EDIT 1 :\n\nI also need to parse out the run_list key value pair from a-roles.json and ignore all other info to have something:",
      "is that possible with jq ?"
    ],
    "utterance": "Extract only the run_list field from the first input and merge it with all key-value pairs from default_attributes and override_attributes of the second input.",
    "expressions": [
      "jq -s '{run_list: .[0].run_list} + .[1].default_attributes + .[1].override_attributes' a-roles.json a-env.json"
    ],
    "data": [
      {
        "input": [
          {
            "name": "paypal_modmon",
            "description": "Role For Paypal admin-service box",
            "run_list": [
              "recipe[djcm_paypal_win::sslVerify]"
            ]
          },
          {
            "name": "paypal_dev",
            "default_attributes": {
              "7-zip": {
                "home": "%SYSTEMDRIVE%\\7-zip"
              },
              "modmon": {
                "env": "dev"
              },
              "paypal": {
                "artifact": "%5BINTEGRATION%5D"
              }
            },
            "override_attributes": {
              "default": {
                "env": "developmen"
              },
              "windows": {
                "password": "Pib1StheK1N5"
              },
              "task_sched": {
                "credentials": "kX?rLQ4XN$q"
              },
              "seven_zip": {
                "url": "https://djcm:Pib1StheK1N5@artifactory.dowjones.io/artifactory/djcm-zip-local/djcm/chef/paypal/7z1514-x64.msi"
              }
            },
            "chef_type": "environment"
          }
        ],
        "output": {
          "run_list": [
            "recipe[djcm_paypal_win::sslVerify]"
          ],
          "7-zip": {
            "home": "%SYSTEMDRIVE%\\7-zip"
          },
          "modmon": {
            "env": "dev"
          },
          "paypal": {
            "artifact": "%5BINTEGRATION%5D"
          },
          "default": {
            "env": "developmen"
          },
          "windows": {
            "password": "Pib1StheK1N5"
          },
          "task_sched": {
            "credentials": "kX?rLQ4XN$q"
          },
          "seven_zip": {
            "url": "https://djcm:Pib1StheK1N5@artifactory.dowjones.io/artifactory/djcm-zip-local/djcm/chef/paypal/7z1514-x64.msi"
          }
        }
      }
    ],
    "identifier": 38603161
  },
  {
    "context": [
      "I would like to run a bash command for each field in a JSON formatted piece of data by leveraging jq.",
      "Assuming you wanted to list out the key/values of the `apps` object:",
      "$ jq -r '.apps | to_entries[] | \"\\(.key)\\t\\(.value)\"' input.json",
      "jq -M -r '\n    .apps | keys[] as $k | $k, .[$k]\n' <<< \"$json\" | \\\nwhile read -r key; read -r val; do\n   echo \"$key $val\"\ndone"
    ],
    "utterance": "For each field in the 'apps' object, output the key and value as pairs.",
    "expressions": [
      ".apps | to_entries[] | \"\\(.key) \\(.value)\"",
      ".apps | keys[] as $k | \"\u001b[\"$k\u001b[\" .[\u001b[$k]\u001b[\"]"
    ],
    "data": [
      {
        "input": {
          "apps": {
            "firefox": "1.0.0",
            "ie": "1.0.1",
            "chrome": "2.0.0"
          }
        },
        "output": [
          "firefox 1.0.0",
          "ie 1.0.1",
          "chrome 2.0.0"
        ]
      }
    ],
    "identifier": 38779732
  },
  {
    "context": [
      "Is there a way to update all 4 fields with a single invocation of jq?",
      "$ jq '.ChangeBatch.Changes[] |= . * {\n    Action: \"UPSERT\",\n    ResourceRecordSet: {\n        Name: \"host.domain\",\n        Type: \"A\",\n        ResourceRecords: .ResourceRecordSet.ResourceRecords | map(\n            . * {\n                TTL: \"300\",\n                Value: \"10.120.0.1\"\n            }\n        )\n    }\n}' x.json",
      "The following reasonably concise filter should do the job in a straightforward way, thanks to the power of `|=`:\n\n```\n.ChangeBatch.Changes[] |=\n  ( .Action = \"UPSERT\"\n  | .ResourceRecordSet.Name = \"host.domain\"\n  | .ResourceRecordSet.Type = \"A\"\n  | .ResourceRecordSet.ResourceRecords[].TTL =\"300\"\n  | .ResourceRecordSet.ResourceRecords[].Value =\"10.120.0.1\"\n  )\n```"
    ],
    "utterance": "Update every entry in ChangeBatch.Changes so that Action is \"UPSERT\", ResourceRecordSet.Name is \"host.domain\", ResourceRecordSet.Type is \"A\", and every ResourceRecords element inside gets TTL \"300\" and Value \"10.120.0.1\".",
    "expressions": [
      ".ChangeBatch.Changes[] |=\n  ( .Action = \"UPSERT\"\n  | .ResourceRecordSet.Name = \"host.domain\"\n  | .ResourceRecordSet.Type = \"A\"\n  | .ResourceRecordSet.ResourceRecords[].TTL =\"300\"\n  | .ResourceRecordSet.ResourceRecords[].Value =\"10.120.0.1\"\n  )",
      ".ChangeBatch.Changes[] |= . * {\n    Action: \"UPSERT\",\n    ResourceRecordSet: {\n        Name: \"host.domain\",\n        Type: \"A\",\n        ResourceRecords: .ResourceRecordSet.ResourceRecords | map(\n            . * {\n                TTL: \"300\",\n                Value: \"10.120.0.1\"\n            }\n        )\n    }\n}"
    ],
    "identifier": 38816114
  },
  {
    "context": [
      "I want to replace the value of x1 with the corresponding value of y1.",
      "This works to replace x1 with a constant value:\r\n\r\n    % jq -Mc '(.a.b[] | .x.x1) |= 9' foo.js",
      "But this attempt to use the same idea doesn't work:\r\n\r\n    % jq -Mc '(.a.b[] | .x.x1) |= .y.y1' foo.js",
      "Use this:\r\n\r\n    .a.b[] |= (.x.x1 = .y.y1)",
      "We want to update every item in the `.a.b` array where `.x.x1` takes the value of `.y.y1`"
    ],
    "utterance": "Replace each b array element's x1 value with the corresponding y1 value in the same element.",
    "expressions": [
      ".a.b[] |= (.x.x1 = .y.y1)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": [
              {
                "x": {
                  "x1": 1
                },
                "y": {
                  "y1": 5
                }
              },
              {
                "x": {
                  "x1": 1
                },
                "y": {
                  "y1": 6
                }
              }
            ]
          }
        },
        "output": {
          "a": {
            "b": [
              {
                "x": {
                  "x1": 5
                },
                "y": {
                  "y1": 5
                }
              },
              {
                "x": {
                  "x1": 6
                },
                "y": {
                  "y1": 6
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 38860798
  },
  {
    "context": [
      "The data\r\n\r\n    {    \r\n\t  &quot;asdf&quot;:   &quot;1.0&quot;,\r\n\t  &quot;jkadfsjkl&quot;: &quot;xxx&quot;\r\n    }\r\npasses JSONLint but jqplay.org and jq v1.5 return\r\n\r\n    parse error: Invalid numeric literal at line 2, column 9",
      "There are extra spaces in this line: `&quot;asdf&quot;:   &quot;1.0&quot;,` .. I wonder if there might be an invalid character in there."
    ],
    "utterance": "Parse an object where a string value is surrounded by multiple spaces in the key-value separator.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": {
          "asdf": "1.0",
          "jkadfsjkl": "xxx"
        },
        "output": {
          "asdf": "1.0",
          "jkadfsjkl": "xxx"
        }
      }
    ],
    "identifier": 39023953
  },
  {
    "context": [
      "I'm using the filter \r\n\r\n    [.bar_1.baz_a, .bar_1.baz_b, .bar_2.qux_1,.bar_2.qux_2]\r\n\r\non the following JSON and it's returning four nulls instead of two lines each having four elements of nonsense data.",
      "The root object doesn't have keys `bar1` and `bar2`; those occur in the objects in the array assigned to the name `foos`. Compare your filter to\r\n\r\n    jq '.foos[] | [.bar_1.baz_a, .bar_1.baz_b, .bar_2.qux_1,.bar_2.qux_2]' tmp.json"
    ],
    "utterance": "Extract an array for each element of 'foos' containing the values of bar_1.baz_a, bar_1.baz_b, bar_2.qux_1, and bar_2.qux_2.",
    "expressions": [
      ".foos[] | [.bar_1.baz_a, .bar_1.baz_b, .bar_2.qux_1, .bar_2.qux_2]"
    ],
    "data": [
      {
        "input": {
          "version": "0.1",
          "foos": [
            {
              "bar_1": {
                "baz_a": 673396201,
                "baz_b": "dfgsfg"
              },
              "bar_2": {
                "qux_1": "ghjhj",
                "qux_2": "Q"
              }
            },
            {
              "bar_1": {
                "baz_a": 674567484,
                "baz_b": "tyutyj"
              },
              "bar_2": {
                "qux_1": "bnmn",
                "qux_2": "Z"
              }
            }
          ]
        },
        "output": [
          [
            673396201,
            "dfgsfg",
            "ghjhj",
            "Q"
          ],
          [
            674567484,
            "tyutyj",
            "bnmn",
            "Z"
          ]
        ]
      }
    ],
    "identifier": 39026573
  },
  {
    "context": [
      "I am trying to use jq to \"normalize\" JSON so that given the input:\n    [\n        [                                                                            \n          {\"M\":6, \"C\":66, \"R\":0.1},      \n          {\"M\":6, \"C\":81, \"R\":0.9}\n        ],\n        [    \n          {\"M\":11, \"C\":94, \"R\":0.8},    \n          {\"M\":11, \"C\":55, \"R\":0.46}     \n        ]\n        ,\n        ...\n    ]                                                                         \n\nthe output should be:\n    [\n        {\n            \"M\" : 6,\n            \"X\" : [{\"66\" : 0.1},{\"81\": 0.9}]\n        },\n        {\n            \"M\" : 11,\n            \"X\" : [{\"94\" : 0.8},{\"55\": 0.46}]\n        },\n        ...\n    ]\n",
      "Set `X` to the result of mapping over the array and creating a one-element object for each entry, with `C` as the key and `R` as the value.\n\n    map({M: .[0].M, X: map({\"\\(.C)\": .R})})",
      "[                             # compute result array from\n  .[]                         #   scaning input array\n| {  M: .[0].M                #   compute M from the .M of the first element\n   , X: [                     #   compute X array from\n         .[]                  #     scanning each element's objects\n       | {\"\\(.C)\":.R}         #     and constructing new {C:R} objects\n     ]                        \n  }\n]"
    ],
    "utterance": "Transform a list of lists of objects with M, C, and R fields into a list where each item has M from the first object and X is an array of objects mapping each C value to its corresponding R value.",
    "expressions": [
      "map({M: .[0].M, X: map({\"\\(.C)\": .R})})",
      "[ .[] | {M: .[0].M, X: [ .[] | {\"\\(.C)\": .R} ]} ]",
      "[foreach .[] as $list ({};\n  {\n    \"M\": $list[0].M,\n    \"X\": [foreach $list[] as $item ({}; {\"\\($item.C)\": $item.R})]\n  }\n)]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "M": 6,
              "C": 66,
              "R": 0.1
            },
            {
              "M": 6,
              "C": 81,
              "R": 0.9
            }
          ],
          [
            {
              "M": 11,
              "C": 94,
              "R": 0.8
            },
            {
              "M": 11,
              "C": 55,
              "R": 0.46
            }
          ]
        ],
        "output": [
          {
            "M": 6,
            "X": [
              {
                "66": 0.1
              },
              {
                "81": 0.9
              }
            ]
          },
          {
            "M": 11,
            "X": [
              {
                "94": 0.8
              },
              {
                "55": 0.46
              }
            ]
          }
        ]
      }
    ],
    "identifier": 38943819
  },
  {
    "context": [
      "i have the following json",
      "I need to change the above json to the following using jq in bash",
      "Here i am facing the following issues :",
      "The number of inner jsons in the values array is not fixed.",
      "Can some one please help me with framing the jq statement to be run in bash to make the required changes.",
      "Since the number of objects are not fixed the snippet below will do:",
      "jq '{ \n        \"name\" : .name,\n        \"values\" : [\n                .values[] as $in | \n                { \n                        \"field1\" : $in.field1[0],\n                        \"field2\" : $in.field2[0],\n                        \"new_name\" : $in.name1 \n                }\n        ]\n\n}' < /tmp/input.json",
      "Here is another solution.\n\n  .values |= map({\n     field1:   .field1[0],\n     field2:   .field2[0],\n     new_name: .name1\n  })"
    ],
    "utterance": "Transform each object in the values array so that field1 and field2 are replaced by their first element and name1 is renamed to new_name, preserving the outer structure and handling any number of entries.",
    "expressions": [
      "{ \"name\": .name, \"values\": [ .values[] as $in | { \"field1\": $in.field1[0], \"field2\": $in.field2[0], \"new_name\": $in.name1 } ] }",
      ".values |= map({ field1: .field1[0], field2: .field2[0], new_name: .name1 })"
    ],
    "data": [
      {
        "input": {
          "name": "qwerty",
          "values": [
            {
              "field1": [
                "val1"
              ],
              "field2": [
                "val2"
              ],
              "name1": [
                [
                  "a",
                  "b"
                ],
                [
                  "c",
                  "d"
                ]
              ]
            },
            {
              "field1": [
                "val3"
              ],
              "field2": [
                "val4"
              ],
              "name1": [
                [
                  "a",
                  "b"
                ],
                [
                  "c",
                  "d"
                ]
              ]
            },
            {
              "field1": [
                "val5"
              ],
              "field2": [
                "val6"
              ],
              "name1": [
                [
                  "a",
                  "b"
                ],
                [
                  "c",
                  "d"
                ]
              ]
            }
          ]
        },
        "output": {
          "name": "qwerty",
          "values": [
            {
              "field1": "val1",
              "field2": "val2",
              "new_name": [
                [
                  "a",
                  "b"
                ],
                [
                  "c",
                  "d"
                ]
              ]
            },
            {
              "field1": "val3",
              "field2": "val4",
              "new_name": [
                [
                  "a",
                  "b"
                ],
                [
                  "c",
                  "d"
                ]
              ]
            },
            {
              "field1": "val5",
              "field2": "val6",
              "new_name": [
                [
                  "a",
                  "b"
                ],
                [
                  "c",
                  "d"
                ]
              ]
            }
          ]
        }
      }
    ],
    "identifier": 39015374
  },
  {
    "context": [
      "I want to replace all values of the `dependencies`, `devDependencies` and `optionalDependencies` objects with asterisk, like so (abbreviated example below):",
      "\"devDependencies\": { \"babel\": \"*\", \"babelify\": \"*\", ...",
      "The most straight-forward way to accomplish the task would probably be to use the following filter:",
      ".dependencies |= map_values(\"*\")\n| .devDependencies |= map_values(\"*\")\n| .optionalDependencies |= map_values(\"*\")",
      "To avoid the repetition:\n\n(.dependencies, .devDependencies, .optionalDependencies) |= map_values(\"*\")",
      ".[\"dependencies\", \"devDependencies\", \"optionalDependencies\"] |= map_values(\"*\")"
    ],
    "utterance": "Replace all values of the dependencies, devDependencies, and optionalDependencies properties with the asterisk character \"*\".",
    "expressions": [
      ".dependencies |= map_values(\"*\") | .devDependencies |= map_values(\"*\") | .optionalDependencies |= map_values(\"*\")",
      "(.dependencies, .devDependencies, .optionalDependencies) |= map_values(\"*\")",
      ".[\"dependencies\", \"devDependencies\", \"optionalDependencies\"] |= map_values(\"*\")"
    ],
    "data": [
      {
        "input": {
          "name": "project",
          "dependencies": {
            "babel-polyfill": "^6.7.4",
            "lodash": "^4.0.0"
          },
          "devDependencies": {
            "babel": "^6.3.26",
            "lodash": "^4.5.1"
          },
          "optionalDependencies": {
            "pkg-save": "~1.0.2"
          }
        },
        "output": {
          "name": "project",
          "dependencies": {
            "babel-polyfill": "*",
            "lodash": "*"
          },
          "devDependencies": {
            "babel": "*",
            "lodash": "*"
          },
          "optionalDependencies": {
            "pkg-save": "*"
          }
        }
      }
    ],
    "identifier": 39105521
  },
  {
    "context": [
      "Within the sheets array, and then within the formulas array, I'd like to change each columnName with a value of \"MONTH\" to \"YEAR\". I'd like to do the same for within the sheets array, within the columnStyles array, change each incidence of \"MONTH\" also to \"YEAR\"",
      "How can I edit the entire file in place by just updating the values I want? Do I use map with if?",
      "jq '(.sheets[] | .formulas[]? | .columnName | select(.==\"MONTH\")) |= \"YEAR\"' tmp.json",
      "jq '(.sheets[] | .columnStyles[]? | .name | select(.==\"MONTH\")) |= \"YEAR\"' tmp.json"
    ],
    "utterance": "Update all columnName values equal to MONTH within sheets[].formulas[] and all name values equal to MONTH within sheets[].columnStyles[] to YEAR.",
    "expressions": [
      "(.sheets[] | .formulas[]? | .columnName | select(.==\"MONTH\")) |= \"YEAR\" | (.sheets[] | .columnStyles[]? | .name | select(.==\"MONTH\")) |= \"YEAR\""
    ],
    "data": [
      {
        "input": {
          "version": "6.1.1",
          "className": "xyz",
          "sheets": [
            {
              "name": "Pass1",
              "sheetId": "95e6c2cd-abbe-46c1-8012-bdf37438b9b7",
              "keep": true,
              "formulas": [
                {
                  "columnName": "SAMPLE_PROVIDER",
                  "columnId": "0",
                  "columnIndex": 0,
                  "formulaString": "=GROUPBY(#Raw!SAMPLE_PROVIDER)"
                },
                {
                  "columnName": "MONTH",
                  "columnId": "1",
                  "columnIndex": 1,
                  "formulaString": "=GROUPBY(#Raw!MONTH)"
                }
              ],
              "columnStyles": [
                {
                  "columnId": "0",
                  "name": "SAMPLE_PROVIDER",
                  "width": 206,
                  "thousandSeparator": true
                },
                {
                  "columnId": "1",
                  "name": "MONTH",
                  "width": 100,
                  "thousandSeparator": true
                }
              ],
              "nextColumnId": 2
            },
            {
              "name": "Transform1",
              "sheetId": "49071c1c-fa84-4ae3-92c1-b63175a6b26c",
              "keep": true,
              "formulas": [
                {
                  "columnName": "SAMPLE_PROVIDER",
                  "columnId": "0",
                  "columnIndex": 0,
                  "formulaString": "=#Pass1!SAMPLE_PROVIDER"
                },
                {
                  "columnName": "MONTH",
                  "columnId": "1",
                  "columnIndex": 1,
                  "formulaString": "=#Pass1!MONTH"
                }
              ],
              "columnStyles": [
                {
                  "columnId": "0",
                  "name": "SAMPLE_PROVIDER",
                  "width": 179,
                  "thousandSeparator": true
                },
                {
                  "columnId": "1",
                  "name": "MONTH",
                  "width": 100,
                  "thousandSeparator": true
                }
              ],
              "nextColumnId": 3
            }
          ],
          "advancedSchedulingInUse": true,
          "errorHandlingMode": "IGNORE"
        },
        "output": {
          "version": "6.1.1",
          "className": "xyz",
          "sheets": [
            {
              "name": "Pass1",
              "sheetId": "95e6c2cd-abbe-46c1-8012-bdf37438b9b7",
              "keep": true,
              "formulas": [
                {
                  "columnName": "SAMPLE_PROVIDER",
                  "columnId": "0",
                  "columnIndex": 0,
                  "formulaString": "=GROUPBY(#Raw!SAMPLE_PROVIDER)"
                },
                {
                  "columnName": "YEAR",
                  "columnId": "1",
                  "columnIndex": 1,
                  "formulaString": "=GROUPBY(#Raw!MONTH)"
                }
              ],
              "columnStyles": [
                {
                  "columnId": "0",
                  "name": "SAMPLE_PROVIDER",
                  "width": 206,
                  "thousandSeparator": true
                },
                {
                  "columnId": "1",
                  "name": "YEAR",
                  "width": 100,
                  "thousandSeparator": true
                }
              ],
              "nextColumnId": 2
            },
            {
              "name": "Transform1",
              "sheetId": "49071c1c-fa84-4ae3-92c1-b63175a6b26c",
              "keep": true,
              "formulas": [
                {
                  "columnName": "SAMPLE_PROVIDER",
                  "columnId": "0",
                  "columnIndex": 0,
                  "formulaString": "=#Pass1!SAMPLE_PROVIDER"
                },
                {
                  "columnName": "YEAR",
                  "columnId": "1",
                  "columnIndex": 1,
                  "formulaString": "=#Pass1!MONTH"
                }
              ],
              "columnStyles": [
                {
                  "columnId": "0",
                  "name": "SAMPLE_PROVIDER",
                  "width": 179,
                  "thousandSeparator": true
                },
                {
                  "columnId": "1",
                  "name": "YEAR",
                  "width": 100,
                  "thousandSeparator": true
                }
              ],
              "nextColumnId": 3
            }
          ],
          "advancedSchedulingInUse": true,
          "errorHandlingMode": "IGNORE"
        }
      }
    ],
    "identifier": 38981671
  },
  {
    "context": [
      "Here is my input file :\r\n\r\n    default\r\n    \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\r\n    out           0-65535  0.0.0.0/0          -1  \r\n    in            80       0.0.0.0/0          tcp \r\n    in            8080     0.0.0.0/0          tcp \r\n    in            21017    192.168.1.0/32     tcp \r\n    in            2379     0.0.0.0/0          udp \r\n    in            0-65535  sg-10fa3c75        -1  \r\n    ===========\r\n    dev-external\r\n    \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\r\n    out           0-65535  4.1.0.0/32         -1  \r\n    in            1-2      sg-10fa3c75        -1  \r\n    in            21034    sg-10fa3c75        tcp \r\n    in            9418     24.115.129.102/32  tcp \r\n    in            80       0.0.0.0/0          tcp \r\n    in            8080     default            tcp \r\n    in            21017    192.168.1.0/0      tcp \r\n    in            123-655  1.45.9.1/32        -1  \r\n    ===========\r\n    my-sg\r\n    \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\r\n    out           0-65535  0.0.0.0/0          -1  \r\n    in            80       0.0.0.0/0          tcp \r\n    in            8070     0.0.0.0/0          tcp \r\n    in            8080     0.0.0.0/0          tcp \r\n    in            21017    192.168.1.0/32     tcp \r\n    in            0-65535  sg-10fa3c75        -1  \r\n    ===========\r\n",
      "I tried to parse this file using gawk:\r\n\r\n`gawk &#39;BEGIN{RS=&quot;\\n=+\\n&quot;; FS=&quot;\\n&quot;; ORS=&quot;\\n&quot;} { print $1 }&#39;`\r\n\r\n\r\nwhich returns : \r\n\r\n    default                                                                                                                                                                             \r\n    dev-external\r\n    my-sg\r\n\r\nbut when I parse this using jq :\r\n\r\n`| jq -R . | jq -s .`\r\n\r\n\r\nI have these unwanted escape characters attached. \r\n\r\n    [\r\n      &quot;\\u001b[3g\\r\\u001bH            \\u001bH            \\u001bH              \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH\\rdefault&quot;,\r\n      &quot;dev-external&quot;,\r\n      &quot;my-sg&quot;\r\n    ]\r\n\r\n\r\nPlease help.",
      "awk '/^\u2014/ {d=1} /^=/ {d=0; next} !d'\r\nsed '/^\u2014/,/^=/ d'\r\n\r\nHere are the results:\r\n\r\n    $ awk '/^\u2014/ {d=1} /^=/ {d=0; next} !d' esc.txt | jq -R . | jq -s\r\n    [\r\n      \"default\",\r\n      \"dev-external\",\r\n      \"my-sg\"\r\n    ]",
      "From the [`jq` manual page][1], one of these options seems likely to help:\n\n> - --color-output / -C and --monochrome-output / -M:\n> \n> By default, jq outputs colored JSON if writing to a terminal. You can\n> force it to produce color even if writing to a pipe or a file using\n> -C, and disable color with -M.\n> \n> - --ascii-output / -a:\n> \n> jq usually outputs non-ASCII Unicode codepoints as UTF-8, even if the\n> input specified them as escape sequences (like \u201c\\u03bc\u201d). Using this\n> option, you can force jq to produce pure ASCII output with every\n> non-ASCII character replaced with the equivalent escape sequence."
    ],
    "utterance": "Produce a list of section names found before each non-ASCII delimiter line, without unwanted ANSI escape characters in the output.",
    "expressions": [
      "awk '/^\u2014/ {d=1} /^=/ {d=0; next} !d' input.txt | jq -R . | jq -s",
      "awk '/^\\342\\200\\224/ {d=1} /^=/ {d=0; next} !d' input.txt | jq -R . | jq -s",
      "sed '/^\u2014/,/^=/ d' input.txt | jq -R . | jq -s"
    ],
    "data": [
      {
        "input": "default\n\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\nout           0-65535  0.0.0.0/0          -1  \nin            80       0.0.0.0/0          tcp \nin            8080     0.0.0.0/0          tcp \nin            21017    192.168.1.0/32     tcp \nin            2379     0.0.0.0/0          udp \nin            0-65535  sg-10fa3c75        -1  \n===========\ndev-external\n\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\nout           0-65535  4.1.0.0/32         -1  \nin            1-2      sg-10fa3c75        -1  \nin            21034    sg-10fa3c75        tcp \nin            9418     24.115.129.102/32  tcp \nin            80       0.0.0.0/0          tcp \nin            8080     default            tcp \nin            21017    192.168.1.0/0      tcp \nin            123-655  1.45.9.1/32        -1  \n===========\nmy-sg\n\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\nout           0-65535  0.0.0.0/0          -1  \nin            80       0.0.0.0/0          tcp \nin            8070     0.0.0.0/0          tcp \nin            8080     0.0.0.0/0          tcp \nin            21017    192.168.1.0/32     tcp \nin            0-65535  sg-10fa3c75        -1  \n===========\n",
        "output": [
          "default",
          "dev-external",
          "my-sg"
        ]
      }
    ],
    "identifier": 38926506
  },
  {
    "context": [
      "s='CONTAINER|CPU%|MEMUSAGE/LIMIT|MEM%|NETI/O|BLOCKI/O|PIDS\nnginx_container|0.02%|25.09MiB/15.26GiB|0.16%|0B/0B|22.09MB/4.096kB|0'",
      "jq -Rn '\n( input  | split(\"|\") ) as $keys |\n( inputs | split(\"|\") ) as $vals |\n[[$keys, $vals] | transpose[] | {key:.[0],value:.[1]}] | from_entries\n' <<<\"$s\"",
      "split(\"\\n\")                       # [ \"CONTAINER...\", \"nginx_container|0.02%...\", ...]\n| (.[0]    | split(\"|\")) as $keys   # [ \"CONTAINER\", \"CPU%\", \"MEMUSAGE/LIMIT\", ... ]\n| (.[1:][] | split(\"|\"))            # [ \"nginx_container\", \"0.02%\", ... ] [ ... ] ...\n| select(length > 0)                # (remove empty [] caused by trailing newline)\n| [$keys, .]                        # [ [\"CONTAINER\", ...], [\"nginx_container\", ...] ] ...\n| [ transpose[] | {(.[0]):.[1]} ]   # [ {\"CONTAINER\": \"nginx_container\"}, ... ] ...\n| add                               # {\"CONTAINER\": \"nginx_container\", \"CPU%\": \"0.02%\" ..."
    ],
    "utterance": "Convert a pipe-separated header and values string into an object mapping each header to its corresponding value.",
    "expressions": [
      "jq -Rn ' ( input  | split(\"|\") ) as $keys | ( inputs | split(\"|\") ) as $vals | [[$keys, $vals] | transpose[] | {key:.[0],value:.[1]}] | from_entries '",
      "split(\"\\n\") | (.[0] | split(\"|\")) as $keys | (.[1:][] | split(\"|\")) | select(length > 0) | [$keys, .] | [ transpose[] | {(.[0]):.[1]} ] | add"
    ],
    "data": [
      {
        "input": "CONTAINER|CPU%|MEMUSAGE/LIMIT|MEM%|NETI/O|BLOCKI/O|PIDS\nnginx_container|0.02%|25.09MiB/15.26GiB|0.16%|0B/0B|22.09MB/4.096kB|0",
        "output": {
          "CONTAINER": "nginx_container",
          "CPU%": "0.02%",
          "MEMUSAGE/LIMIT": "25.09MiB/15.26GiB",
          "MEM%": "0.16%",
          "NETI/O": "0B/0B",
          "BLOCKI/O": "22.09MB/4.096kB",
          "PIDS": "0"
        }
      }
    ],
    "identifier": 38860529
  },
  {
    "context": [
      "I want to extract the values of the three \"name\" fields and store it in three variables.",
      "the command you're looking for is `jq '.example.\"sub-example\" | .[] | .name'`. If you want to keep the names in an array, wrap the whole `jq` expression in square brackets.",
      ".example[\"sub-example\"] | .[] | .name",
      "Or more compactly:\n\n    .example[\"sub-example\"][].name",
      "You can also use `map()` to extract specific fields. e.g.\n```\n.example.\"sub-example\"|map(.name)\n```"
    ],
    "utterance": "Extract all values of the name field from each object in the example.sub-example array.",
    "expressions": [
      ".example[\"sub-example\"][].name",
      ".example.\"sub-example\"[].name",
      ".example[\"sub-example\"] | .[] | .name",
      ".example.\"sub-example\" | .[] | .name",
      ".example.\"sub-example\" | map(.name)"
    ],
    "data": [
      {
        "input": {
          "example": {
            "sub-example": [
              {
                "name": "123-345",
                "tag": 100
              },
              {
                "name": "234-456",
                "tag": 100
              },
              {
                "name": "4a7-a07a5",
                "tag": 100
              }
            ]
          }
        },
        "output": [
          "123-345",
          "234-456",
          "4a7-a07a5"
        ]
      }
    ],
    "identifier": 39228500
  },
  {
    "context": [
      "I need to get both the value of `VolumeId` and `Tags.Value` to be used as the input to invoke another command.",
      "It seems to me that you want to output the two values (`VolumeId` and `Tags[].Value`) on the same line?",
      "If that&#39;s the case, then a simple string concatenation should be enough: ",
      "$ jq -r '.Volumes[] | .VolumeId + \" \" + .Tags[].Value' volumes.json",
      "You should note that if there is more than one element in `Tags` the result will reflect that. This can however be avoided by referring the first element in `Tags`: `.Tags[0].Value`",
      "Assuming you want `Tags[0]` in all cases, I would recommend considering the use of @tsv as follows:",
      "jq -r '.Volumes[] | [.VolumeId, .Tags[0].Value] | @tsv' volumes.json"
    ],
    "utterance": "For each object, obtain the VolumeId and the first element's Value from Tags as pairs.",
    "expressions": [
      ".Volumes[] | .VolumeId + \" \" + .Tags[0].Value",
      ".Volumes[] | [.VolumeId, .Tags[0].Value] | @tsv"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "AvailabilityZone": "us-east-1a",
              "Tags": [
                {
                  "Value": "vol-rescue-system",
                  "Key": "Name"
                }
              ],
              "VolumeId": "vol-00112233"
            },
            {
              "AvailabilityZone": "us-east-1a",
              "Tags": [
                {
                  "Value": "vol-rescue-swap",
                  "Key": "Name"
                }
              ],
              "VolumeId": "vol-00112234"
            },
            {
              "AvailabilityZone": "us-east-1a",
              "Tags": [
                {
                  "Value": "vol-rescue-storage",
                  "Key": "Name"
                }
              ],
              "VolumeId": "vol-00112235"
            }
          ]
        },
        "output": [
          "vol-00112233 vol-rescue-system",
          "vol-00112234 vol-rescue-swap",
          "vol-00112235 vol-rescue-storage"
        ]
      }
    ],
    "identifier": 39204158
  },
  {
    "context": [
      "I have a file of newline-separated JSON lists, the total of which I would like to count.",
      "I can do this with two invocations of jq as such:",
      "cat file.nsj | jq -s \".[] | length\" | jq -s \"add\"",
      "But I would prefer to do it in a single jq invocation. Is this possible?",
      "$ jq -n 'reduce inputs as $i (0; . + ($i | length))' file.nsj",
      "jq -n '[ inputs | length ] | add'  file.nsj"
    ],
    "utterance": "Count the total number of elements across all lists in a file containing newline-separated lists.",
    "expressions": [
      "jq -n 'reduce inputs as $i (0; . + ($i | length))' file.nsj",
      "jq -n '[ inputs | length ] | add' file.nsj"
    ],
    "identifier": 39261762
  },
  {
    "context": [
      "I run a command on one of my systems and it spits out JSON \"pretty\" format like so:",
      "[\n    {\n        \"server\": \"servename1\",\n        \"i.p\": 127.0.0.1,\n        \"domain\": \"generic\",\n        \"OS\": \"RHEL\",\n        \"Version\": 7.0\n    },\n    {\n        \"server\": \"servename2\",\n        \"i.p\": 127.0.0.1,\n        \"domain\": \"generic\",\n        \"OS\": \"RHEL\",\n        \"Version\": 7.0\n   },\n    {\n        \"server\": \"servename3\",\n        \"i.p\": 127.0.0.1,\n        \"domain\": \"generic\",\n        \"OS\": \"RHEL\",\n        \"Version\": 7.0\n    }\n]",
      "I need to parse these paragraphs in one liners like so:",
      "[{\"server\":\"servename1\",\"i.p\":127.0.0.1,\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7.0},\n{\"server\":\"servename2\",\"i.p\":127.0.0.1,\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7.0},\n{\"server\":\"servename3\",\"i.p\":127.0.0.1,\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7.0},]",
      "You can try this in jq if you're OK with newline-delimited JSON:",
      "$ jq -c \".[]\" test.json",
      "{\"server\":\"servename1\",\"i.p\":\"127.0.0.1\",\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7}",
      "{\"server\":\"servename2\",\"i.p\":\"127.0.0.1\",\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7}",
      "{\"server\":\"servename3\",\"i.p\":\"127.0.0.1\",\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7}",
      "Note that I had to quote the IP addresses from your sample, since the JSON you posted is not valid JSON."
    ],
    "utterance": "Produce a compact, single-line representation of each object in the array, outputting one object per line.",
    "expressions": [
      ".[] | @json",
      "-c .[]"
    ],
    "data": [
      {
        "input": [
          {
            "server": "servename1",
            "i.p": "127.0.0.1",
            "domain": "generic",
            "OS": "RHEL",
            "Version": 7
          },
          {
            "server": "servename2",
            "i.p": "127.0.0.1",
            "domain": "generic",
            "OS": "RHEL",
            "Version": 7
          },
          {
            "server": "servename3",
            "i.p": "127.0.0.1",
            "domain": "generic",
            "OS": "RHEL",
            "Version": 7
          }
        ],
        "output": [
          "{\"server\":\"servename1\",\"i.p\":\"127.0.0.1\",\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7}",
          "{\"server\":\"servename2\",\"i.p\":\"127.0.0.1\",\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7}",
          "{\"server\":\"servename3\",\"i.p\":\"127.0.0.1\",\"domain\":\"generic\",\"OS\":\"RHEL\",\"Version\":7}"
        ]
      }
    ],
    "identifier": 39236501
  },
  {
    "identifier": 39355940
  },
  {
    "context": [
      "I need to transform a JSON string like below to a table for output in the terminal.",
      "What I want to display in the terminal:\n\n    ID        Name\n    =================\n    12        George\n    18        Jack\n    19        Joe",
      "Notice how I don't want to display the email property for each row, so the jq command should involve some filtering.",
      "Why not something like:\n\n    echo '[{\n        \"name\": \"George\",\n        \"id\": 12,\n        \"email\": \"george@domain.example\"\n    }, {\n        \"name\": \"Jack\",\n        \"id\": 18,\n        \"email\": \"jack@domain.example\"\n    }, {\n        \"name\": \"Joe\",\n        \"id\": 19,\n        \"email\": \"joe@domain.example\"\n    }]' | jq -r '.[] | \"\\(.id)\\t\\(.name)\"'\n\nOutput\n\n    12\tGeorge\n    18\tJack\n    19\tJoe",
      "Using the `@tsv` filter has much to recommend it, mainly because it handles numerous \"edge cases\" in a standard way:\n\n    .[] | [.id, .name] | @tsv",
      "Adding the headers can be done like so:\n\n    jq -r '[\"ID\",\"NAME\"], [\"--\",\"------\"], (.[] | [.id, .name]) | @tsv'\n\nThe result:\n\n    ID\tNAME\n    --\t------\n    12\tGeorge\n    18\tJack\n    19\tJoe",
      "The problem with the answers above is they only work if the fields are all about the same width.\n\nTo avoid this issue, the Linux `column` command could be used:\n...\n\u25b6 jq -r '.[] | [.id, .name] | @tsv' input.json | column -ts $'\\t'\na very very long field  George\n18                      Jack\n19                      Joe"
    ],
    "utterance": "Display a table listing only the id and name fields of each object, with id first and name second, omitting the email field.",
    "expressions": [
      ".[] | \"\\(.id)\\t\\(.name)\"",
      ".[] | [.id, .name] | @tsv",
      "[\"ID\",\"NAME\"], [\"--\",\"------\"], (.[] | [.id, .name]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "George",
            "id": 12,
            "email": "george@domain.example"
          },
          {
            "name": "Jack",
            "id": 18,
            "email": "jack@domain.example"
          },
          {
            "name": "Joe",
            "id": 19,
            "email": "joe@domain.example"
          }
        ],
        "output": "12\tGeorge\n18\tJack\n19\tJoe"
      }
    ],
    "identifier": 39139107
  },
  {
    "context": [
      "I have this sample of JSON:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;val1&quot;,\r\n            &quot;expire&quot;: { &quot;$value&quot;: 10 }\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val2&quot;,\r\n            &quot;expire&quot;: 20\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val3&quot;\r\n        }\r\n    ]",
      "And I want to transform it to this form with jq:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;val1&quot;,\r\n            &quot;expire&quot;: 10\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val2&quot;,\r\n            &quot;expire&quot;: 20\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val3&quot;,\r\n            &quot;expire&quot;: null\r\n        }\r\n    ]",
      "Try this filter:\r\n\r\n    map( {name, \r\n          &quot;expire&quot;: (.expire | if type == &quot;object&quot; then .[&quot;$value&quot;] elif type == &quot;number&quot; then . else null end) } )",
      "or (with significantly different semantics in edge cases):\r\n\r\n    map(.expire |= if type == &quot;object&quot; then .[&quot;$value&quot;]\r\n                   elif type == &quot;number&quot; then . else null end)",
      "You can think of it another way as updating each object&#39;s `expire` property with the `&quot;$value&quot;` if present, or the current value.  If the value doesn&#39;t exist, it&#39;s just simply `null`.\r\n\r\n    .[].expire |= (.&quot;$value&quot;? // .)"
    ],
    "utterance": "Convert the 'expire' property of each object to its '$value' field if it is an object, keep it as is if it is a number, or set it to null if missing.",
    "expressions": [
      "map({name, \"expire\": (.expire | if type == \"object\" then .[\"$value\"] elif type == \"number\" then . else null end)})",
      "map(.expire |= if type == \"object\" then .[\"$value\"] elif type == \"number\" then . else null end)",
      "map(.expire |= (.\"$value\"? // .))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "val1",
            "expire": {
              "$value": 10
            }
          },
          {
            "name": "val2",
            "expire": 20
          },
          {
            "name": "val3"
          }
        ],
        "output": [
          {
            "name": "val1",
            "expire": 10
          },
          {
            "name": "val2",
            "expire": 20
          },
          {
            "name": "val3",
            "expire": null
          }
        ]
      }
    ],
    "identifier": 39320865
  },
  {
    "context": [
      "I want to extract the `row` data with `jq`. This is simple:\r\n\r\n    curl XYZ | jq -r -c '.results[0].data[0].row[]'\r\n\r\nResult:\r\n\r\n    {\"key1\": \"row1\", \"key2\": \"row1\"}\r\n    {\"key1\": \"row2\", \"key2\": \"row2\"}\r\n\r\nHowever, this always waits until `curl` is completed.",
      "Do the following, which is equivalent to `jq -c '.results[].data[].row[]'`, but using streaming:\r\n\r\n    jq -cn --stream 'fromstream(1|truncate_stream(inputs | select(.[0][0] == \"results\" and .[0][2] == \"data\" and .[0][4] == \"row\") | del(.[0][0:5])))'",
      "Produces the desired output."
    ],
    "utterance": "Extract each object from the row arrays within all data arrays inside each results object as soon as it becomes available from a large streamed input.",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs | select(.[0][0] == \"results\" and .[0][2] == \"data\" and .[0][4] == \"row\") | del(.[0][0:5])))'"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "columns": [
                "n"
              ],
              "data": [
                {
                  "row": [
                    {
                      "key1": "row1",
                      "key2": "row1"
                    }
                  ],
                  "meta": [
                    {
                      "key": "value"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key1": "row2",
                      "key2": "row2"
                    }
                  ],
                  "meta": [
                    {
                      "key": "value"
                    }
                  ]
                }
              ]
            }
          ],
          "errors": []
        },
        "output": [
          {
            "key1": "row1",
            "key2": "row1"
          },
          {
            "key1": "row2",
            "key2": "row2"
          }
        ]
      }
    ],
    "identifier": 39232060
  },
  {
    "context": [
      "How can I get the contents higher up in the hierarchy to map to the array contents?",
      "$ jq -r '[.data] + (.stores[] | [.name, .lat, .lng, .dist]) | @csv' input.json",
      "$ jq '.data as $data | .stores[] | [$data, .[]]' in.json",
      ".data as $data\n | .stores[]\n | \"\\($data),\\(.name),\\(.lat),\\(.lng),\\(.dist),\\(.x10),\\(.isOpen)\"",
      "output with sample data:\n    \"MFR-L,KOLL,52.93128,6.962956,1,1.129,true\"\n    \"MFR-L,Takst,52.9523773,6.981644,1.3,1.809,false\""
    ],
    "utterance": "Output a CSV with columns from the parent field 'data' and each object in 'stores', including values for name, lat, lng, dist, x10, and isOpen.",
    "expressions": [
      ".data as $data | .stores[] | [$data, .name, .lat, .lng, .dist, .x10, .isOpen] | @csv",
      ".data as $data | .stores[] | \"\u007f$data),\u007f(.name),\u007f(.lat),\u007f(.lng),\u007f(.dist),\u007f(.x10),\u007f(.isOpen)\""
    ],
    "data": [
      {
        "input": {
          "status": "ok",
          "ok": true,
          "data": "MFR-L",
          "stores": [
            {
              "name": "KOLL",
              "lat": 52.93128,
              "lng": 6.962956,
              "dist": 1,
              "x10": 1.129,
              "isOpen": true
            },
            {
              "name": "Takst",
              "lat": 52.9523773,
              "lng": 6.981644,
              "dist": 1.3,
              "x10": 1.809,
              "isOpen": false
            }
          ]
        },
        "output": [
          "\"MFR-L\",\"KOLL\",52.93128,6.962956,1,1.129,true",
          "\"MFR-L\",\"Takst\",52.9523773,6.981644,1.3,1.809,false"
        ]
      }
    ],
    "identifier": 39334801
  },
  {
    "context": [
      "\"things I know:\\r\\n\\r\\n    \\\"secretName\\\": \\\"klucze\\\"    \\r\\n\\r\\nthings I want extract\\r\\n\\r\\n    \\\"name\\\": \\\"provisioner-secrets-1750468340-ei8sl\\\"\"",
      "\"I tried \\r\\n\\r\\n    .items[] | .spec | .volumes[] | .secret | select(.secretName==\\\"klucze\\\")    \\r\\n\\r\\nbut I don&#39;t know how to get correlated value from \\r\\n\\r\\n    .items[] | .metadata | .name\"",
      "\"$ jq --arg secret 'klucze' \\\\r\\n    '.items[] | select(.spec.volumes[].secret.secretName == $secret).metadata.name' input.json\""
    ],
    "utterance": "Find the name property of each item whose volumes array contains a secret with secretName equal to klucze.",
    "expressions": [
      ".items[] | select(.spec.volumes[].secret.secretName == \"klucze\").metadata.name",
      ".items[] | select([.spec.volumes[].secret.secretName] | index(\"klucze\")).metadata.name"
    ],
    "data": [
      {
        "input": {
          "kind": "List",
          "apiVersion": "v1",
          "metadata": {},
          "items": [
            {
              "kind": "Pod",
              "apiVersion": "v1",
              "metadata": {
                "name": "provisioner-secrets-1750468340-ei8sl",
                "generateName": "provisioner-secrets-1750468340-",
                "namespace": "default",
                "selfLink": "/api/v1/namespaces/default/pods/provisioner-secrets-1750468340-ei8sl",
                "uid": "8d2ac8e4-5642-11e6-b139-72f9d49a4327",
                "resourceVersion": "1473",
                "creationTimestamp": "2016-07-30T10:44:11Z",
                "labels": {
                  "pod-template-hash": "1750468340",
                  "run": "git-sync"
                },
                "annotations": {
                  "kubernetes.io/created-by": "{\"kind\":\"SerializedReference\",\"apiVersion\":\"v1\",\"reference\":{\"kind\":\"ReplicaSet\",\"namespace\":\"default\",\"name\":\"provisioner-secrets-1750468340\",\"uid\":\"8d2904ba-5642-11e6-b139-72f9d49a4327\",\"apiVersion\":\"extensions\",\"resourceVersion\":\"1438\"}}\n"
                }
              },
              "spec": {
                "volumes": [
                  {
                    "name": "markdown",
                    "emptyDir": {}
                  },
                  {
                    "name": "klucze",
                    "secret": {
                      "secretName": "klucze"
                    }
                  },
                  {
                    "name": "default-token-xjc9q",
                    "secret": {
                      "secretName": "default-token-xjc9q"
                    }
                  }
                ],
                "containers": [
                  {
                    "name": "git-sync",
                    "image": "lukaszbielinski/git-sync:0.5",
                    "env": [
                      {
                        "name": "GIT_SYNC_REPO",
                        "value": "https://github.com/lukasz-bielinski/test-secrets"
                      },
                      {
                        "name": "GIT_SYNC_WAIT",
                        "value": "10"
                      },
                      {
                        "name": "GIT_SYNC_DEST",
                        "value": "/git"
                      }
                    ],
                    "resources": {},
                    "volumeMounts": [
                      {
                        "name": "markdown",
                        "mountPath": "/git"
                      },
                      {
                        "name": "klucze",
                        "mountPath": "/root/.ssh/klucze"
                      },
                      {
                        "name": "default-token-xjc9q",
                        "readOnly": true,
                        "mountPath": "/var/run/secrets/kubernetes.io/serviceaccount"
                      }
                    ],
                    "terminationMessagePath": "/dev/termination-log",
                    "imagePullPolicy": "IfNotPresent"
                  },
                  {
                    "name": "secprov",
                    "image": "lukaszbielinski/kubectl-image:0.19-secrets",
                    "resources": {},
                    "volumeMounts": [
                      {
                        "name": "markdown",
                        "mountPath": "/srcsecrets"
                      },
                      {
                        "name": "default-token-xjc9q",
                        "readOnly": true,
                        "mountPath": "/var/run/secrets/kubernetes.io/serviceaccount"
                      }
                    ],
                    "terminationMessagePath": "/dev/termination-log",
                    "imagePullPolicy": "Always"
                  }
                ],
                "restartPolicy": "Always",
                "terminationGracePeriodSeconds": 30,
                "dnsPolicy": "ClusterFirst",
                "serviceAccountName": "default",
                "serviceAccount": "default",
                "nodeName": "minikubevm",
                "securityContext": {}
              },
              "status": {
                "phase": "Running",
                "conditions": [
                  {
                    "type": "Initialized",
                    "status": "True",
                    "lastProbeTime": null,
                    "lastTransitionTime": "2016-07-30T10:44:11Z"
                  },
                  {
                    "type": "Ready",
                    "status": "True",
                    "lastProbeTime": null,
                    "lastTransitionTime": "2016-07-30T10:44:31Z"
                  },
                  {
                    "type": "PodScheduled",
                    "status": "True",
                    "lastProbeTime": null,
                    "lastTransitionTime": "2016-07-30T10:44:11Z"
                  }
                ],
                "hostIP": "192.168.122.230",
                "podIP": "172.17.0.10",
                "startTime": "2016-07-30T10:44:11Z",
                "containerStatuses": [
                  {
                    "name": "git-sync",
                    "state": {
                      "running": {
                        "startedAt": "2016-07-30T10:44:12Z"
                      }
                    },
                    "lastState": {},
                    "ready": true,
                    "restartCount": 0,
                    "image": "lukaszbielinski/git-sync:0.5",
                    "imageID": "docker://sha256:50f4c3009cd7072cb52d0edc5374ad973d7619ead7063482c4102fa230d16ce6",
                    "containerID": "docker://3d8f44f2c1cd8139fdf23660e5c7514d37ba5e39c739087f12defcfcd0a12f6d"
                  },
                  {
                    "name": "secprov",
                    "state": {
                      "running": {
                        "startedAt": "2016-07-30T10:44:31Z"
                      }
                    },
                    "lastState": {},
                    "ready": true,
                    "restartCount": 0,
                    "image": "lukaszbielinski/kubectl-image:0.19-secrets",
                    "imageID": "docker://sha256:6ebf833942e81d24d0bbc2f3e816f7620db979182ccf81a9edaf97488b512726",
                    "containerID": "docker://c1837b472c0a8123c244c7e7c5b4886a85e8607e8172271447024aa647a0a564"
                  }
                ]
              }
            }
          ]
        },
        "output": "provisioner-secrets-1750468340-ei8sl"
      }
    ],
    "identifier": 38674118
  },
  {
    "context": [
      "I want to get the latest snapshot with a specific name.",
      "jq'.[] | select(.ClusterIdentifier==\"dev-cluster\") | max_by(.SnapshotCreateTime) | .SnapshotIdentifier'",
      "Cannot index array with string \"ClusterIdentifier\".",
      "How about this?",
      "jq '.[]|map(select(.ClusterIdentifier==\"dev-cluster\"))\n        |max_by(.SnapshotCreateTime)|.SnapshotIdentifier'"
    ],
    "utterance": "Get the SnapshotIdentifier of the most recent snapshot where ClusterIdentifier equals \"dev-cluster\".",
    "expressions": [
      ".[] | map(select(.ClusterIdentifier==\"dev-cluster\")) | max_by(.SnapshotCreateTime) | .SnapshotIdentifier"
    ],
    "data": [
      {
        "input": {
          "Snapshots": [
            {
              "EstimatedSecondsToCompletion": 0,
              "OwnerAccount": "45645641155",
              "CurrentBackupRateInMegaBytesPerSecond": 6.2857,
              "ActualIncrementalBackupSizeInMegaBytes": 22.0,
              "NumberOfNodes": 3,
              "Status": "available",
              "VpcId": "myvpc",
              "ClusterVersion": "1.0",
              "Tags": [],
              "MasterUsername": "ayxbizops",
              "TotalBackupSizeInMegaBytes": 192959.0,
              "DBName": "dev",
              "BackupProgressInMegaBytes": 22.0,
              "ClusterCreateTime": "2016-09-06T15:56:08.170Z",
              "RestorableNodeTypes": [
                "dc1.large"
              ],
              "EncryptedWithHSM": false,
              "ClusterIdentifier": "dev-cluster",
              "SnapshotCreateTime": "2016-09-06T16:00:25.595Z",
              "AvailabilityZone": "us-west-2c",
              "NodeType": "dc1.large",
              "Encrypted": false,
              "ElapsedTimeInSeconds": 3,
              "SnapshotType": "manual",
              "Port": 5439,
              "SnapshotIdentifier": "thismorning"
            }
          ]
        },
        "output": "thismorning"
      }
    ],
    "identifier": 39358804
  },
  {
    "context": [
      "I want to get the SnapshotIdentifier of the snapshot with the maximum SnapshotCreateTime, and filter it by ClusterIdentifier.",
      "[.Snapshots[] | select(.ClusterIdentifier == \"dev-cluster\")] | max_by(.SnapshotCreateTime) | .SnapshotIdentifier"
    ],
    "utterance": "Find the SnapshotIdentifier of the snapshot with the greatest SnapshotCreateTime where ClusterIdentifier equals \"dev-cluster\".",
    "expressions": [
      "[.Snapshots[] | select(.ClusterIdentifier == \"dev-cluster\")] | max_by(.SnapshotCreateTime) | .SnapshotIdentifier"
    ],
    "data": [
      {
        "input": {
          "Snapshots": [
            {
              "EstimatedSecondsToCompletion": 0,
              "OwnerAccount": "45645641155",
              "CurrentBackupRateInMegaBytesPerSecond": 6.2857,
              "ActualIncrementalBackupSizeInMegaBytes": 22.0,
              "NumberOfNodes": 3,
              "Status": "available",
              "VpcId": "myvpc",
              "ClusterVersion": "1.0",
              "Tags": [],
              "MasterUsername": "ayxbizops",
              "TotalBackupSizeInMegaBytes": 192959.0,
              "DBName": "dev",
              "BackupProgressInMegaBytes": 22.0,
              "ClusterCreateTime": "2016-09-06T15:56:08.170Z",
              "RestorableNodeTypes": [
                "dc1.large"
              ],
              "EncryptedWithHSM": false,
              "ClusterIdentifier": "dev-cluster",
              "SnapshotCreateTime": "2016-09-06T16:00:25.595Z",
              "AvailabilityZone": "us-west-2c",
              "NodeType": "dc1.large",
              "Encrypted": false,
              "ElapsedTimeInSeconds": 3,
              "SnapshotType": "manual",
              "Port": 5439,
              "SnapshotIdentifier": "thismorning"
            }
          ]
        },
        "output": "thismorning"
      }
    ],
    "identifier": 39359651
  },
  {
    "context": [
      "I want to write a filter that returns all of the items that contain an \"a\", \"d\", or \"h\".",
      "map(select(test(\"a|d|h\")))",
      ".[] | select(test(\"a|d|h\"))",
      ".[] | select( any( index( \"a\", \"d\", \"h\"); . != null ) )",
      ".[] | select( [index(\"a\", \"d\", \"h\")] | any )",
      ".[]\n| if index(\"a\") or index(\"d\") or index(\"h\") then . else empty end"
    ],
    "utterance": "Return all elements from a list of strings that contain an 'a', 'd', or 'h' character.",
    "expressions": [
      "map(select(test(\"a|d|h\")))",
      ".[] | select(test(\"a|d|h\"))",
      ".[] | select( any([\"a\", \"d\", \"h\"]; . as $c | index($c) != null ))",
      ".[] | select( [index(\"a\"), index(\"d\"), index(\"h\")] | any )",
      ".[] | if index(\"a\") or index(\"d\") or index(\"h\") then . else empty end"
    ],
    "data": [
      {
        "input": [
          "abcdef",
          "defghi",
          "euskdh"
        ],
        "output": [
          "abcdef",
          "defghi",
          "euskdh"
        ]
      }
    ],
    "identifier": 39420412
  },
  {
    "context": [
      "aws s3api list-multipart-uploads --bucket $BUCKETNAME \\\n| jq -r '.Uploads[] | \"--key \\\"\\(.Key)\\\" --upload-id \\(.UploadId)\"' \\\n| while read -r line; do\n    eval \"aws s3api abort-multipart-upload --bucket $BUCKETNAME $line\";\ndone"
    ],
    "utterance": "Extract all incomplete upload keys and upload IDs from a bucket so they can be aborted.",
    "expressions": [
      ".Uploads[] | \"--key \\\"\\(.Key)\\\" --upload-id \\(.UploadId)\""
    ],
    "identifier": 39457458
  },
  {
    "context": [
      "jq failed to parse this line",
      "The error given by jq is:\r\n\r\n    parse error: Invalid numeric literal at line 15, column 32",
      "A workaround that could be sufficient for certain use is to transform the output of the mongo shell command. I use this pattern for a workaround:\r\n\r\n    mongo --quiet --eval \"rs.config()\" | sed -e 's/: [a-zA-Z]*(\\(.*\\))/: \"\\1\"/' | jq '.'",
      "For the specific example above, you can use below\r\n\r\n`mongo --quiet --eval \"JSON.stringify(rs.config())\"`"
    ],
    "utterance": "Parse a MongoDB shell document containing NumberLong(0) using jq by first converting function calls to standard values.",
    "expressions": [
      "mongo --quiet --eval \"rs.config()\" | sed -e 's/: [a-zA-Z]*(\\(.*\\))/: \"\\1\"/' | jq '.'",
      "mongo --quiet --eval \"JSON.stringify(rs.config())\" | jq '.'"
    ],
    "data": [
      {
        "input": {
          "_id": "example",
          "version": 23,
          "members": [
            {
              "_id": 0,
              "host": "192.168.0.1:27017",
              "slaveDelay": "NumberLong(0)",
              "votes": 1
            }
          ]
        }
      }
    ],
    "identifier": 39447749
  },
  {
    "context": [
      "Count how many times a certain type appears, or even just output all the types into a file.",
      "Not a `jq`-only answer, but you can get a list of all the `type` fields, then pipe that through `uniq -c` to get a count.",
      "$ jq '.logs[] | .type' tmp.json | uniq -c",
      "To obtain a stream of all the \"type\" values of all objects, no matter how deeply nested:",
      ".. | select(.type?) | .type",
      "In your particular case, the following would suffice:",
      ".[] | select(type == \"object\") | .[].type",
      "To produce a tabulation:",
      "def tabulate: reduce .[] as $i ({}; .[$i] += 1 );",
      "[.[] | select(type == \"object\") | .[].type] | tabulate",
      "Given your input, the output would be:\n{\n  \"signup\": 1,\n  \"welcome\": 1,\n  \"vote\": 2\n}",
      "Here is a solution which uses **tostream** and **reduce**",
      "reduce (tostream|select(length==2)) as [$p,$v] (\n  {}\n; if $p[-1] == \"type\" then .[$v] += 1 else . end  \n)"
    ],
    "utterance": "Count occurrences of each 'type' field value under the 'logs' object.",
    "expressions": [
      ".logs[] | .type",
      "[.logs[] | .type] | reduce .[] as $i ({}; .[$i] += 1 )",
      "def tabulate: reduce .[] as $i ({}; .[$i] += 1 ); [.logs[] | .type] | tabulate",
      "reduce (tostream|select(length==2)) as [$p,$v] ({}; if $p[-1] == \"type\" then .[$v] += 1 else . end)"
    ],
    "data": [
      {
        "input": {
          "logs": {
            "-MnpQaRONGXz9tff-W": {
              "points": 10,
              "type": "signup"
            },
            "-N5qlX1mQ3SYA9RXdE": {
              "points": 15,
              "type": "welcome"
            },
            "-N5rx8PAcNgWu25zRf": {
              "points": 5,
              "type": "vote"
            },
            "-N5s29TyZ33snUqC5X": {
              "points": 5,
              "type": "vote"
            }
          },
          "total": 35
        },
        "output": {
          "signup": 1,
          "welcome": 1,
          "vote": 2
        }
      }
    ],
    "identifier": 39416318
  },
  {
    "context": [
      "Next step is to merge all of theses data grouped by *bddx*.",
      "reduce ((..|.vhosts?|..|.postgresql?)|objects) as $i({}; . *= $i)",
      "with the sample data it produces\n\n    {\n      \"bdd1\": {\n        \"db_aaa\": {\n          \"user_aaa\": {\n            \"password\": \"xxx\"\n          }\n        },\n        \"db_bbb\": {\n          \"user_bbb\": {\n            \"password\": \"xxx\"\n          },\n          \"user_bbb_ro\": {\n            \"password\": \"xxx\"\n          }\n        },\n        \"db_ccc\": {\n          \"user_ccc\": {\n            \"password\": \"xxx\"\n          }\n        }\n      },\n      \"bdd2\": {\n        \"db_aaa\": {\n          \"user_aaa\": {\n            \"password\": \"xxx\"\n          }\n        }\n      }\n    }"
    ],
    "utterance": "Group and merge all database server objects so each top-level key is a server name (e.g., bdd1), containing all associated databases and user credentials from all clusters and vhosts.",
    "expressions": [
      "reduce ((..|.vhosts?|..|.postgresql?)|objects) as $i({}; . *= $i)"
    ],
    "data": [
      {
        "input": {
          "cluster-1": {
            "vhosts": {
              "vhost_aaa": {
                "postgresql": {
                  "bdd1": {
                    "db_aaa": {
                      "user_aaa": {
                        "password": "xxx"
                      }
                    }
                  },
                  "bdd2": {
                    "db_aaa": {
                      "user_aaa": {
                        "password": "xxx"
                      }
                    }
                  }
                }
              }
            }
          },
          "cluster-2": {
            "vhosts": {
              "vhost_bbb": {
                "postgresql": {
                  "bdd1": {
                    "db_bbb": {
                      "user_bbb": {
                        "password": "xxx"
                      },
                      "user_bbb_ro": {
                        "password": "xxx"
                      }
                    }
                  }
                }
              },
              "vhost_ccc": {
                "postgresql": {
                  "bdd1": {
                    "db_ccc": {
                      "user_ccc": {
                        "password": "xxx"
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": {
          "bdd1": {
            "db_aaa": {
              "user_aaa": {
                "password": "xxx"
              }
            },
            "db_bbb": {
              "user_bbb": {
                "password": "xxx"
              },
              "user_bbb_ro": {
                "password": "xxx"
              }
            },
            "db_ccc": {
              "user_ccc": {
                "password": "xxx"
              }
            }
          },
          "bdd2": {
            "db_aaa": {
              "user_aaa": {
                "password": "xxx"
              }
            }
          }
        }
      }
    ],
    "identifier": 39269967
  },
  {
    "context": [
      "This fails:",
      ".link[] | select(.relation == next) | .url",
      "This works fine:",
      ".link[] | .url",
      "I think you meant:",
      "select(.relation == \"next\")",
      "Safer would be:",
      "select(.relation? == \"next\")"
    ],
    "utterance": "Extract the url values from all link objects where the relation is equal to \"next\".",
    "expressions": [
      ".link[] | select(.relation == \"next\") | .url",
      ".link[] | select(.relation? == \"next\") | .url"
    ],
    "data": [
      {
        "input": {
          "link": [
            {
              "relation": "self",
              "url": "http://fhirtest.uhn.ca/baseDstu3/Patient?_count=50&_format=json&_pretty=false&_summary=data"
            },
            {
              "relation": "next",
              "url": "http://fhirtest.uhn.ca/baseDstu3?_getpages=00952912-c9ab-47ca-826c-200bddffe617&_getpagesoffset=50&_count=50&_format=json&_bundletype=searchset"
            }
          ]
        },
        "output": [
          "http://fhirtest.uhn.ca/baseDstu3?_getpages=00952912-c9ab-47ca-826c-200bddffe617&_getpagesoffset=50&_count=50&_format=json&_bundletype=searchset"
        ]
      }
    ],
    "identifier": 39459308
  },
  {
    "context": [
      "I\u0000d like to select all elements where ou does **not** contain a specific string, say \"4210910 3a\" or - which would be even better - where ou does not contain any member of a given list of strings.",
      "$ jq --argjson ex '[\"4210910 3a\"]' 'map(select(all(.ou[]; $ex[]!=.)))' input.json",
      "Assuming $ex is the list of exceptions, then the filter we could use to solve the problem would be:\r\n\r\n    map(select(intersectq(.ou; $ex) | not))"
    ],
    "utterance": "Select all objects in an array whose 'ou' field does not contain any of the strings in a given list, such as '4210910 3a'.",
    "expressions": [
      "map(select(all(.ou[]; $ex[]!=.)))",
      "def intersectq(a;b): any(a[]; . as $x | any( b[]; . == $x) ); map(select(intersectq(.ou; $ex) | not))"
    ],
    "data": [
      {
        "input": [
          {
            "employeeType": "student",
            "cn": "dc8aff1",
            "uid": "dc8aff1",
            "ou": [
              "4210910",
              "4210910 #Abg",
              "4210910 Abgang",
              "4240115",
              "4240115 5",
              "4240115 5/5"
            ]
          },
          {
            "employeeType": "student",
            "cn": "160f656",
            "uid": "160f656",
            "ou": [
              "4210910",
              "4210910 3",
              "4210910 3a"
            ]
          }
        ],
        "output": [
          {
            "employeeType": "student",
            "cn": "dc8aff1",
            "uid": "dc8aff1",
            "ou": [
              "4210910",
              "4210910 #Abg",
              "4210910 Abgang",
              "4240115",
              "4240115 5",
              "4240115 5/5"
            ]
          }
        ]
      }
    ],
    "identifier": 39467025
  },
  {
    "context": [
      "To filter using the criterion `.image_id <= 10000`, just interpose the appropriate `select/1` filter:",
      ".questions[]\n| select(.image_id <= 10000)\n| [.question, .image_id, .question_id]\n| @csv",
      "To filter the data, use **select**.  E.g. with the `-r` option the following filter \n\n      .questions[] | select(.image_id <= 10000) | [ .[] ] | @csv",
      "produces the subset\n\n    \"Is this an Spanish town?\",8647,86472"
    ],
    "utterance": "Extract question, image_id, and question_id fields as CSV for entries where image_id is less than or equal to 10000.",
    "expressions": [
      ".questions[] | select(.image_id <= 10000) | [.question, .image_id, .question_id] | @csv",
      ".questions[] | select(.image_id <= 10000) | [ .[] ] | @csv"
    ],
    "data": [
      {
        "input": {
          "questions": [
            {
              "question": "What is the table made of?",
              "image_id": 350623,
              "question_id": 3506232
            },
            {
              "question": "Is the food napping on the table?",
              "image_id": 350623,
              "question_id": 3506230
            },
            {
              "question": "What has been upcycled to make lights?",
              "image_id": 350623,
              "question_id": 3506231
            },
            {
              "question": "Is this an Spanish town?",
              "image_id": 8647,
              "question_id": 86472
            }
          ]
        },
        "output": [
          "\"Is this an Spanish town?\",8647,86472"
        ]
      }
    ],
    "identifier": 39503715
  },
  {
    "context": [
      "How can I create some_function in jq that will convert to number if possible, but leave as is if not?",
      "echo '[\"123\",\"12x3\"]' | jq '.[] | some_function'",
      "would return\n\n    123\n    \"12x3\"",
      "You can simply write: `tonumber? // .`",
      "Or as a function:\n\ndef tonumberq: tonumber? // .;\n"
    ],
    "utterance": "Convert each element to a number if possible, otherwise leave the original value unchanged.",
    "expressions": [
      "tonumber? // .",
      "def tonumberq: tonumber? // .;"
    ],
    "data": [
      {
        "input": [
          "123",
          "12x3"
        ],
        "output": [
          123,
          "12x3"
        ]
      }
    ],
    "identifier": 39731356
  },
  {
    "context": [
      "I would like to print the family name of each family, then after this print each index contained in 'members'.",
      "My hope was that this would print the following:\r\n\r\n    Family Name: The Brown Family   \r\n    Member Name: James\r\n    Age: 42\r\n    Member Name: Sarah\r\n    Age: 43\r\n    \r\n    Family Name: The Smith Family\r\n    Member Name: Thomas\r\n    Age: 32\r\n    Member Name: Jane\r\n    Age: 30",
      "How do I change my jq script to produce the correct output in the right order?",
      "You can use the following command:\r\n\r\n    jq -r '\"Family Name: \\(.family_name)\",(.members[]|\"Member Name: \\(.name)\",\"Age: \\(.age)\")' file.json"
    ],
    "utterance": "Print the family name for each family followed by each member's name and age in order.",
    "expressions": [
      "\"Family Name: \\(.family_name)\", (.members[] | \"Member Name: \\(.name)\", \"Age: \\(.age)\")"
    ],
    "data": [
      {
        "input": [
          {
            "family_name": "The Brown Family",
            "members": [
              {
                "name": "James",
                "age": 42
              },
              {
                "name": "Sarah",
                "age": 43
              }
            ]
          },
          {
            "family_name": "The Smith Family",
            "members": [
              {
                "name": "Thomas",
                "age": 32
              },
              {
                "name": "Jane",
                "age": 30
              }
            ]
          }
        ],
        "output": [
          "Family Name: The Brown Family",
          "Member Name: James",
          "Age: 42",
          "Member Name: Sarah",
          "Age: 43",
          "Family Name: The Smith Family",
          "Member Name: Thomas",
          "Age: 32",
          "Member Name: Jane",
          "Age: 30"
        ]
      }
    ],
    "identifier": 39726409
  },
  {
    "context": [
      "I cannot figure out where to put a select() filter so that I do my reduce across only those entries that pass a 'select($r.type == \"AUDIT_CHANNEL\")' check, in order to skip the 2 \"type\":\"AUDIT_SYSTEM\" events in this test data:",
      "`inputs` will produce a result for every input that it is fed.  You want to filter those inputs by the type so you could put your filter there:",
      "reduce (inputs | select(.type == \"AUDIT_CHANNEL\")) as $r ..."
    ],
    "utterance": "Aggregate and accumulate counts and duration totals for each unique key, only including records where type equals AUDIT_CHANNEL.",
    "expressions": [
      "reduce (inputs | select(.type == \"AUDIT_CHANNEL\")) as $r ({};\n    ([\n        \"Pipeline\", $r.m.\"topic.type\",\n        \"Channel\",  $r.channel,\n        \"Campaign\", $r.campaign,\n        \"Cellcode\", $r.cellcode,\n        \"Tracking\", $r.tracking,\n        \"Template\", $r.m.\"template.id\",\n        \"Event\",    $r.name,\n        \"Reason\",   $r.reason\n    ] | join(\":\")) as $key\n    | .[$key] |= [ .[0]+1, .[1]+($r.duration|tonumber) ]\n)"
    ],
    "data": [
      {
        "input": [
          {
            "type": "AUDIT_CHANNEL",
            "name": "DROPPED",
            "reason": "INVALID_MAIL_META_DATA",
            "start": "1472083067058",
            "duration": "91",
            "end": "1472083067149",
            "dc": "dev",
            "pool": "raptor-app",
            "host.name": "L-SEA-10002721",
            "host.ip": "10.236.67.80",
            "rlogid": "tfsqiu.dvw9%3FJ*P%40G*25671246-156befd00b2-0x293",
            "channel": "EMAIL",
            "m": {
              "audited": "1472083067058",
              "created": "1472083066974",
              "enabled": "true",
              "entity.common.version": "1",
              "template.id": "2840df6d-d9e8-4f27-e8b5-918c122d4561",
              "template.version": "17",
              "topic.curname": "eddude-default-topic",
              "topic.curtype": "DEFAULT",
              "topic.dc": "LVS",
              "topic.name": "eddude-default-topic",
              "topic.part": "5",
              "topic.type": "DEFAULT"
            },
            "id": "0AEC4350-1C6E2FC9B80-0156BEF9ED92-0000000000000003",
            "campaign": "999",
            "contract": "a5872a5c-8912-dd63-583f-61fa8db3efde",
            "user": 1276847275,
            "cellcode": "",
            "age": "175"
          },
          {
            "type": "AUDIT_SYSTEM",
            "name": "ROTATED",
            "start": "1472083081033",
            "duration": "0",
            "end": "1472083081033",
            "dc": "dev",
            "pool": "raptor-app",
            "host.name": "L-SEA-10002721",
            "host.ip": "10.236.67.80",
            "rlogid": "tfsqiu.dvw9%3FJ*P%40G*25671246-156befd3749-0xce"
          },
          {
            "type": "AUDIT_SYSTEM",
            "name": "ROTATED",
            "start": "1472083141034",
            "duration": "0",
            "end": "1472083141034",
            "dc": "dev",
            "pool": "raptor-app",
            "host.name": "L-SEA-10002721",
            "host.ip": "10.236.67.80",
            "rlogid": "tfsqiu.dvw9%3FJ*P%40G*25671246-156befe21aa-0xce"
          },
          {
            "type": "AUDIT_CHANNEL",
            "name": "RECEIVED",
            "start": "1472083158860",
            "duration": "109",
            "end": "1472083158969",
            "dc": "dev",
            "pool": "raptor-app",
            "host.name": "L-SEA-10002721",
            "host.ip": "10.236.67.80",
            "rlogid": "tfsqiu.dvw9%3FJ*P%40G*25671246-156befe674c-0x10f",
            "channel": "EMAIL",
            "m": {
              "audited": "1472083158860",
              "created": "1472083158860",
              "enabled": "true",
              "entity.common.version": "1",
              "template.id": "2840df6d-d9e8-4f27-e8b5-918c122d4561",
              "template.version": "17",
              "topic.curname": "eddude-default-topic",
              "topic.curtype": "DEFAULT",
              "topic.dc": "LVS",
              "topic.name": "eddude-default-topic",
              "topic.part": "5",
              "topic.type": "DEFAULT"
            },
            "id": "0AEC4350-1C6E2FC9B80-0156BEF9ED92-0000000000000004",
            "campaign": "999",
            "contract": "a5872a5c-8912-dd63-583f-61fa8db3efde",
            "user": 1276847275,
            "cellcode": "",
            "age": "109"
          }
        ],
        "output": {
          "Pipeline:DEFAULT:Channel:EMAIL:Campaign:999:Cellcode::Tracking::Template:2840df6d-d9e8-4f27-e8b5-918c122d4561:Event:DROPPED:Reason:INVALID_MAIL_META_DATA": [
            1,
            91
          ],
          "Pipeline:DEFAULT:Channel:EMAIL:Campaign:999:Cellcode::Tracking::Template:2840df6d-d9e8-4f27-e8b5-918c122d4561:Event:RECEIVED:Reason:": [
            1,
            109
          ]
        }
      }
    ],
    "identifier": 39135954
  },
  {
    "context": [
      "Basically extract the first field, and then values of \"mykey1\" and \"mykey2\" from the embedded value field.",
      "I would like to include my object name and as well my object name varies, so I can't really filter by hard coded value",
      "$ jq -r --argjson cols '[\"mykey1\",\"mykey2\"]' '[to_entries[] | .key, (.value | from_entries[$cols[]])] | @csv' input.json",
      "keys[] as $k\n| .[$k]\n| from_entries\n| [$k, .mykey1, .mykey2]\n| join(\",\")"
    ],
    "utterance": "For each top-level key, extract the key and the 'Value' fields corresponding to 'mykey1' and 'mykey3' from the embedded array, outputting them as a CSV row.",
    "expressions": [
      "[to_entries[] | .key as $k | .value | from_entries | [$k, .mykey1, .mykey3] | @csv]",
      "keys[] as $k | .[$k] | from_entries | [$k, .mykey1, .mykey3] | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "1.2.3.4": [
              {
                "Value": "myval1",
                "Key": "mykey1"
              },
              {
                "Value": "myval3",
                "Key": "mykey3"
              },
              {
                "Value": "myval2",
                "Key": "mykey2"
              },
              {
                "Value": "myval4",
                "Key": "mykey4"
              }
            ]
          },
          {
            "4.5.6.7": [
              {
                "Value": "myval1",
                "Key": "mykey1"
              },
              {
                "Value": "myval3",
                "Key": "mykey3"
              },
              {
                "Value": "myval2",
                "Key": "mykey2"
              },
              {
                "Value": "myval4",
                "Key": "mykey4"
              }
            ]
          }
        ],
        "output": [
          "\"1.2.3.4\",\"myval1\",\"myval3\"",
          "\"4.5.6.7\",\"myval1\",\"myval3\""
        ]
      }
    ],
    "identifier": 39620753
  },
  {
    "context": [
      "BUT - I would like to group them by file name, so that I will get comma-separated lists of urls and ids on the same line, like this:",
      "group_by(.file)\n      | .[]\n      | ((map(.id) | @csv) , (map(.url) | @csv), (.[0] | .file))",
      "[ \"\\(.[].id)\" ] | join(\",\")",
      "[ .[].url     ] | join(\",\")",
      ".[0].file"
    ],
    "utterance": "For each unique file name, output three lines: the ids as a comma-separated list, the urls as a comma-separated list, and the file name.",
    "expressions": [
      "map({id,url,file}) | group_by(.file) | .[] | ((map(.id) | join(\",\")), (map(.url) | join(\",\")), (.[0] | .file))",
      "group_by(.file)[] | ([.[].id] | join(\",\")), ([.[].url] | join(\",\")), .[0].file"
    ],
    "data": [
      {
        "input": [
          {
            "id": 4496,
            "status": "Analyze",
            "severity": "Critical",
            "severityCode": 1,
            "state": "New",
            "code": "RNPD.DEREF",
            "title": "Suspicious dereference of pointer before NULL check",
            "message": "Suspicious dereference of pointer 'peer->sctSapCb' before NULL check at line 516",
            "file": "/home/build/branches/mmm/file1",
            "method": "CzUiCztGpReq",
            "owner": "unowned",
            "taxonomyName": "C and C++",
            "dateOriginated": 1473991086512,
            "url": "http://xxx/yyy",
            "issueIds": [
              4494
            ]
          },
          {
            "id": 4497,
            "status": "Analyze",
            "severity": "Critical",
            "severityCode": 1,
            "state": "New",
            "code": "NPD.GEN.CALL.MIGHT",
            "title": "Null pointer may be passed to function that may dereference it",
            "message": "Null pointer 'tmpEncodedPdu' that comes from line 346 may be passed to function and can be dereferenced there by passing argument 1 to function 'SCpyMsgMsgF' at line 537.",
            "file": "/home/build/branches/mmm/file1",
            "method": "CzUiCztGpReq",
            "owner": "unowned",
            "taxonomyName": "C and C++",
            "dateOriginated": 1473991086512,
            "url": "http://xxx/yyy/zzz",
            "issueIds": [
              4495
            ]
          },
          {
            "id": 4498,
            "status": "Analyze",
            "severity": "Critical",
            "severityCode": 1,
            "state": "New",
            "code": "NPD.GEN.CALL.MIGHT",
            "title": "Null pointer may be passed to function that may dereference it",
            "message": "Null pointer 'tmpEncodedPdu' that comes from line 346 may be passed to function and can be dereferenced there by passing argument 1 to function 'SCpyMsgMsgF' at line 537.",
            "file": "/home/build/branches/mmm/otherfile.c",
            "method": "CzUiCztGpReq",
            "owner": "unowned",
            "taxonomyName": "C and C++",
            "dateOriginated": 1473991086512,
            "url": "http://xxx/yyy/zzz",
            "issueIds": [
              4495
            ]
          }
        ],
        "output": [
          "4496,4497",
          "http://xxx/yyy,http://xxx/yyy/zzz",
          "/home/build/branches/mmm/file1",
          "4498",
          "http://xxx/yyy/zzz",
          "/home/build/branches/mmm/otherfile.c"
        ]
      }
    ],
    "identifier": 39568286
  },
  {
    "identifier": 39759649
  },
  {
    "context": [
      "I apply the following jq command to it:\r\n\r\n    $ jq '.stat | [.foo, .bar] | @csv' test.json\r\n\r\nThe resulting stdout will be:\r\n\r\n    \"1.2,3.1\"",
      "Just use the `-r` command-line option for \"raw output\".  As in: `jq -r ...`"
    ],
    "utterance": "Output the values of 'foo' and 'bar' from the 'stat' object as a comma-separated list without quotes around the entire line.",
    "expressions": [
      ".stat | [.foo, .bar] | @csv"
    ],
    "data": [
      {
        "input": {
          "stat": {
            "foo": 1.2,
            "bar": 3.1
          }
        },
        "output": "1.2,3.1"
      }
    ],
    "identifier": 39746314
  },
  {
    "context": [
      "How do i iterate over this using jq so that i can use the values of OutputKey and OutputValue in other commands?",
      ".[] | ... or [.[] ...], where the ... is some jq code that accesses the values of interest, e.g.",
      "[.[] | [.OutputKey, .OutputValue] ]",
      "while IFS= read -r description && IFS= read -r key && IFS= read -r value; do ... done < <(jq -r '.[] | (.Description, .OutputKey, .OutputValue)' <in.json)"
    ],
    "utterance": "Iterate through an array of objects and access each object's OutputKey and OutputValue fields for further use.",
    "expressions": [
      ".[] | {OutputKey, OutputValue}",
      "[.[] | [.OutputKey, .OutputValue] ]",
      ".[] | (.OutputKey, .OutputValue)"
    ],
    "data": [
      {
        "input": [
          {
            "Description": "Description 1",
            "OutputKey": "OutputKey 1",
            "OutputValue": "OutputValue 1"
          },
          {
            "Description": "Description 2",
            "OutputKey": "OutputKey 2",
            "OutputValue": "OutputValue 2"
          },
          {
            "Description": "Description 3",
            "OutputKey": "OutputKey 3",
            "OutputValue": "OutputValue 3"
          }
        ],
        "output": [
          {
            "OutputKey": "OutputKey 1",
            "OutputValue": "OutputValue 1"
          },
          {
            "OutputKey": "OutputKey 2",
            "OutputValue": "OutputValue 2"
          },
          {
            "OutputKey": "OutputKey 3",
            "OutputValue": "OutputValue 3"
          }
        ]
      }
    ],
    "identifier": 39736840
  },
  {
    "context": [
      "I have a JSON-file which consists of multiple JSON-\"elements\", e.g.\r\n\r\n    {\r\n      \"name\": \"Name 1\",\r\n      \"foo\": \"Bar\"\r\n    }\r\n    {\r\n      \"id\": 123,\r\n      \"bar\": \"Foo\"\r\n    }\r\n\r\nI'm only interested in the second element and I need to query by the 'index' of the element (i.e. I do not know what fields the element will contain).",
      "Use the `-s` (\"slurp\") option to get the second JSON entity, as in `jq -s '[1]'`"
    ],
    "utterance": "Select the second top-level element by its index from input containing multiple top-level entities, regardless of keys.",
    "expressions": [
      ".[1]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Name 1",
            "foo": "Bar"
          },
          {
            "id": 123,
            "bar": "Foo"
          }
        ],
        "output": {
          "id": 123,
          "bar": "Foo"
        }
      }
    ],
    "identifier": 39752829
  },
  {
    "identifier": 39785890
  },
  {
    "context": [
      "iam trying to get the version from the above json by using the below command\n\n    cat info.txt|jq  .version\nbut this is returning null.",
      ".version is inside .build, so the direct approach would be to write: `.build | .version`, or `.build.version` for short.",
      "you can also use the `..` filter, e.g. `.. | objects | .version // empty`."
    ],
    "utterance": "Extract the value of the version property located inside the build object.",
    "expressions": [
      ".build.version",
      ".build | .version",
      ".. | objects | .version // empty"
    ],
    "data": [
      {
        "input": {
          "_links": {
            "self": {
              "href": "http://xxx:8080/info"
            }
          },
          "build": {
            "name": "xxxx",
            "version": "2.0.23-69",
            "description": "xxxx"
          }
        },
        "output": "2.0.23-69"
      }
    ],
    "identifier": 39773649
  },
  {
    "context": [
      "I want to get the following output:\r\n\r\n    SpaceX Interplanetary Transport System, https://www.youtube.com/watch?v=0qo78R_yYFA, 4874\r\n    There is a man who filmed himself annually for 35 years and made a video going backwards to 1977. [ORIGINAL] - [06:31], https://www.youtube.com/watch?v=K2xTBHyfOks, 4644\r\n    Japanese men trying to pronounce \"Massachusetts\", https://www.youtube.com/watch?v=69iSXks1bes, 5075\r\n\r\nHow can I adjust the way that the results are returned?",
      "The fields that you&#39;re interested in are in the `data` objects of each of the `children`.  You&#39;ll want to keep them together so you should limit how many times you go through the child items, just do it once.  And it seems you&#39;re outputting in a CSV format, so you could use `@csv` for that.  Just put the properties in an array first.\r\n\r\n    $ curl ... | jq -r '.data.children[].data | [.title, .url, .score] | @csv"
    ],
    "utterance": "Output title, url, and score fields for each post, combined on a single line in CSV format",
    "expressions": [
      ".data.children[].data | [.title, .url, .score] | @csv"
    ],
    "identifier": 39738230
  },
  {
    "context": [
      "I need the output documents to have a contiguous positive id. Can I access a variable that equals the number of newlines seen?",
      "If your jq has `input_line_number`, you might be able to use that.",
      "$ jq 'input_line_number'",
      "Similarly, here is how `foreach` and `inputs` can be used together:",
      "$ jq -n 'foreach inputs as $line (0; .+1; \"line \\(.) is \\($line)\")'",
      "If your jq does not have `foreach`, then you might find `reduce` adequate for your needs:",
      "$ jq -s -r 'reduce .[] as $line\n    ( [0,\"\"]; .[0]+=1 | .[1] += \"line \\(.[0]) is \\($line)\\n\")\n    | .[1]'"
    ],
    "utterance": "Add a contiguous positive id to each output document, starting from 1.",
    "expressions": [
      ".foo | {id: input_line_number, foo: .}",
      "foreach inputs as $line (0; .+1; {id: ., foo: $line.foo})",
      "reduce .[] as $line (0; .+1; {id: ., foo: $line.foo})"
    ],
    "identifier": 39760071
  },
  {
    "context": [
      "The manifest file, however needs the URL objects prefixed with a bucket-name which I haven't got around with. The output needs to look as",
      "\"url\": \"s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092507_20160926_002328_292527438.csv.gz\"",
      "| jq '[.entries[] | .url = \"s3://xxxxx-xxxxxx-xxx/\\(.url)\" | .mandatory = true] | { entries: .}'"
    ],
    "utterance": "Prefix each object's url field in the 'entries' array with 's3://mybucket/' and add 'mandatory': true to each object.",
    "expressions": [
      "[.entries[] | .url = \"s3://mybucket/\\(.url)\" | .mandatory = true] | { entries: .}"
    ],
    "data": [
      {
        "input": {
          "entries": [
            {
              "url": "DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092507_20160926_002328_292527438.csv.gz"
            },
            {
              "url": "DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092508_20160926_020131_292592736.csv.gz"
            }
          ]
        },
        "output": {
          "entries": [
            {
              "url": "s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092507_20160926_002328_292527438.csv.gz",
              "mandatory": true
            },
            {
              "url": "s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092508_20160926_020131_292592736.csv.gz",
              "mandatory": true
            }
          ]
        }
      }
    ],
    "identifier": 39785343
  },
  {
    "context": [
      "I am trying to remove null values from a json object using jq.",
      "The following illustrates how to remove all the null-valued keys from a JSON object:",
      "jq -n '{\"a\":1, \"b\": null, \"c\": null} | with_entries( select( .value != null ) )'",
      "For reference, if you wanted to remove null-valued keys from all JSON objects in a JSON text (i.e., recursively), you could use walk/1, or:",
      "del(.. | objects | (to_entries[] | select(.value==null) | .key) as $k | .[$k])",
      "Streaming the input in could make this task even simpler.",
      "fromstream(tostream | select(length == 1 or .[1] != null))",
      "Otherwise for a more straightforward approach, you'll have to walk through the object tree to find null values.  If found, filter it out.  Using walk/1, your filter could be applied recursively to exclude the null values.",
      "walk(\n    (objects | with_entries(select(.value != null)))\n    // (arrays | map(select(. != null)))\n    // values\n)",
      "In JQ 1.6 or newer this will do the job to remove nulls recursively:\n\n$ jq 'walk( if type == \"object\" then with_entries(select(.value != null)) else . end)' input.json",
      "You can use this expression to remove null-valued keys recursively:\n\njq 'walk( if type == \"object\" then with_entries(select(.value != null)) else . end)'",
      "[This answer](https://unix.stackexchange.com/a/654730) by [Michael Homer](https://unix.stackexchange.com/users/73093/michael-homer) on <https://unix.stackexchange.com> has a super concise solution which works since jq 1.6:\n\ndel(..|nulls)\n\nIt deletes all null-valued properties (and values) from your JSON. Simple and sweet :)"
    ],
    "utterance": "Remove all keys and array elements with null values recursively from the data structure.",
    "expressions": [
      "del(..|nulls)",
      "walk(if type == \"object\" then with_entries(select(.value != null)) else . end)",
      "del(.. | objects | (to_entries[] | select(.value==null) | .key) as $k | .[$k])",
      "fromstream(tostream | select(length == 1 or .[1] != null))"
    ],
    "data": [
      {
        "input": {
          "foo": null,
          "bar": "bar",
          "biz": [
            1,
            2,
            3,
            4,
            null
          ],
          "baz": {
            "a": 1,
            "b": null,
            "c": [
              "a",
              "b",
              "c",
              "null",
              32,
              null
            ]
          }
        },
        "output": {
          "bar": "bar",
          "biz": [
            1,
            2,
            3,
            4
          ],
          "baz": {
            "a": 1,
            "c": [
              "a",
              "b",
              "c",
              "null",
              32
            ]
          }
        }
      }
    ],
    "identifier": 39500608
  },
  {
    "context": [
      "**Input :-**",
      "{ \"Timestamp\":140, \"DateTime\":\"2014-06-02 14:32:34.440 PDT\", \"CustomerId\":\"01\", \"VisitorId\":\"78\" }",
      "**Desired Output**",
      "Timestamp; DateTime;  CustomerId; VisitorId",
      "140;       2014-06-02 14:32:34.440 PDT; 01; 78",
      "With your input, and the following program in tocsv.jq:",
      "(keys_unsorted | join(\",\")),",
      "([.[]] | @csv)",
      "the command:",
      "$ jq -r -f tocsv.jq input.json",
      "produces:",
      "Timestamp,DateTime,CustomerId,VisitorId",
      "140,\"2014-06-02 14:32:34.440 PDT\",\"01\",\"78\"",
      "Eliminating the quotation marks in the second line is left as an exercise for the interested reader :-)"
    ],
    "utterance": "Produce a table with the keys as header row and the values as a single data row, separated by semicolons, in the order: Timestamp, DateTime, CustomerId, VisitorId.",
    "expressions": [
      "(keys_unsorted | join(\"; \")), ([.[]] | join(\"; \"))"
    ],
    "data": [
      {
        "input": {
          "Timestamp": 140,
          "DateTime": "2014-06-02 14:32:34.440 PDT",
          "CustomerId": "01",
          "VisitorId": "78"
        },
        "output": "Timestamp; DateTime; CustomerId; VisitorId\n140; 2014-06-02 14:32:34.440 PDT; 01; 78"
      }
    ],
    "identifier": 39760503
  },
  {
    "context": [
      "I need to find out the count of names starting with \"SnapshotSet\" which are under the name tag of the below JSON file.",
      "As explained [here](https://github.com/stedolan/jq/issues/940), the abbreviated form `.keyname` cannot be used when the key contains the `-` character.",
      "You can run the following to get the list of all names from your file:",
      "jq '.\"snapshot-sets\"[].name' testjq"
    ],
    "utterance": "Get the count of entries under the 'name' key within 'snapshot-sets' whose value starts with 'SnapshotSet'.",
    "expressions": [
      ".\"snapshot-sets\"[].name | select(startswith(\"SnapshotSet\")) | length",
      ".\"snapshot-sets\"[] | map(select(.name | startswith(\"SnapshotSet\"))) | length",
      ".\"snapshot-sets\" | map(select(.name | startswith(\"SnapshotSet\"))) | length"
    ],
    "data": [
      {
        "input": {
          "links": [
            {
              "href": "https://test.com/api/json/v2/types/snapshot-sets/",
              "rel": "self"
            }
          ],
          "snapshot-sets": [
            {
              "href": "https://test.com/api/json/v2/types/snapshot-sets/1",
              "name": "SnapshotSet.1475076959480"
            },
            {
              "href": "https://test.com/api/json/v2/types/snapshot-sets/3",
              "name": "SnapshotSet.1475165496304"
            },
            {
              "href": "https://test.com/api/json/v2/types/snapshot-sets/2",
              "name": "SnapshotSet.1475158265437"
            },
            {
              "href": "https://test.com/api/json/v2/types/snapshot-sets/63659",
              "name": "server1a_b_c_STFS1474869600618"
            }
          ]
        },
        "output": 3
      }
    ],
    "identifier": 39790351
  },
  {
    "context": [
      "I have a file that looks as below:\r\n\r\n    {\r\n      \"repositories\": [\r\n       {\r\n        \"id\": \"156c48fc-f208-43e8-a631-4d12deb89fa4\",\r\n        \"namespace\": \"rhel12\",\r\n        \"namespaceType\": \"organization\",\r\n        \"name\": \"rhel6.6\",\r\n        \"shortDescription\": \"\",\r\n        \"visibility\": \"public\"\r\n       },\r\n       {\r\n        \"id\": \"f359b5d2-cb3a-4bb3-8aff-d879d51f1a04\",\r\n        \"namespace\": \"rhel12\",\r\n        \"namespaceType\": \"organization\",\r\n        \"name\": \"rhel7\",\r\n        \"shortDescription\": \"\",\r\n        \"visibility\": \"public\"\r\n       }\r\n      ]\r\n     }",
      "I want to get only name values with each of them in a new line so that I can use `while read -r line`.",
      "I need only \r\n\r\n    rhel6.6 \r\n    rhel7",
      "I am using jq as follows which doesn't seem to work:\r\n\r\n    jq -r '.[].name'",
      "You want to look at the repositories array instead of treating the input as an array:\r\n\r\n    $ jq -r '.repositories[].name' file\r\n    rhel6.6\r\n    rhel7\r\n"
    ],
    "utterance": "Extract the values of the name property for each item in the repositories array, with each value on a new line.",
    "expressions": [
      ".repositories[].name"
    ],
    "data": [
      {
        "input": {
          "repositories": [
            {
              "id": "156c48fc-f208-43e8-a631-4d12deb89fa4",
              "namespace": "rhel12",
              "namespaceType": "organization",
              "name": "rhel6.6",
              "shortDescription": "",
              "visibility": "public"
            },
            {
              "id": "f359b5d2-cb3a-4bb3-8aff-d879d51f1a04",
              "namespace": "rhel12",
              "namespaceType": "organization",
              "name": "rhel7",
              "shortDescription": "",
              "visibility": "public"
            }
          ]
        },
        "output": [
          "rhel6.6",
          "rhel7"
        ]
      }
    ],
    "identifier": 39798542
  },
  {
    "context": [
      "The issue is that the input contains long arrays that needs to be broken into multiple smaller arrays whenever data stops repeating within the first array.",
      "input:\n\n    {\n      \"headers\": [ \"col1\", \"col2\", \"col3\" ],\n      \"data\": [\n        [ \"row1\",\"col1\",\"b\",\"src2\" ],\n        [ \"row1\",\"col1\",\"b\",\"src1\" ],\n        [ \"row1\",\"col1\",\"b\",\"src3\" ],\n        [ \"row1\",\"col2\",\"d\",\"src4\" ],\n        [ \"row1\",\"col2\",\"e\",\"src5\" ],\n        [ \"row1\",\"col2\",\"f\",\"src6\" ],\n        [ \"row1\",\"col3\",\"j\",\"src7\" ],\n        [ \"row1\",\"col3\",\"g\",\"src8\" ],\n        [ \"row1\",\"col3\",\"h\",\"src9\" ],\n        [ \"row1\",\"col3\",\"i\",\"src10\" ],\n        [ \"row2\",\"col1\",\"l\",\"src13\" ],\n        [ \"row2\",\"col1\",\"j\",\"src11\" ],\n        [ \"row2\",\"col1\",\"k\",\"src12\" ],\n        [ \"row2\",\"col3\",\"o\",\"src15\" ]\n      ]\n    }",
      "desired output:\n\n    {\n      \"headers\": [ \"col1\", \"col2\", \"col3\" ],\n      \"values\": [\n        [[\"b\",\"b\",\"b\"],[\"d\",\"e\",\"f\"],[\"j\",\"g\",\"h\",\"i\"]],\n        [[\"l\",\"j\",\"k\"],null,[\"o\"]]\n      ],\n      \"sources\": [\n        [[\"src2\",\"src1\",\"src3\"],[\"src4\",\"src5\",\"src6\"],[\"src7\",\"src8\",\"src9\",\"src10\"]],\n        [[\"src13\",\"src11\",\"src12\"],null,[\"src15\"]]\n      ]\n    }",
      "First you'll want to group the data by rows then columns.  Then with the groups, build your values/sources arrays.",
      ".headers as $headers | .data\n    # make the data easier to access\n    | map({ row: .[0], col: .[1], val: .[2], src: .[3] })\n    # keep it sorted so they are in expected order in the end\n    | sort_by([.row,.col,.src])\n    # group by rows\n    | group_by(.row)\n    # create a map to each of the cols for easier access\n    | map(group_by(.col)\n        | reduce .[] as $col ({};\n            .[$col[0].col] = [$col[] | {val,src}]\n        )\n    )\n    # build the result\n    | {\n        headers: $headers,\n        values: map([.[$headers[]] | [.[]?.val]]),\n        sources: map([.[$headers[]] | [.[]?.src]])\n    }",
      "Here is a solution that uses **reduce**, **getpath** and **setpath**\n\n      .headers as $headers\n    | reduce .data[] as [$r,$c,$v,$s] (\n        {headers:$headers, values:{}, sources:{}}\n      ; setpath([\"values\",  $r, $c]; (getpath([\"values\", $r, $c])  // []) + [$v])\n      | setpath([\"sources\", $r, $c]; (getpath([\"sources\", $r, $c]) // []) + [$s])\n      )\n    | .values  = [ .values[]  | [ .[ $headers[] ] ] ]\n    | .sources = [ .sources[] | [ .[ $headers[] ] ] ]"
    ],
    "utterance": "Transform tabular data with row, column, value, and source fields into nested arrays grouped by row and column, where each cell contains all corresponding values and sources, with null for missing columns.",
    "expressions": [
      ".headers as $headers | .data\n    | map({ row: .[0], col: .[1], val: .[2], src: .[3] })\n    | sort_by([.row,.col,.src])\n    | group_by(.row)\n    | map(group_by(.col)\n        | reduce .[] as $col ({};\n            .[$col[0].col] = [$col[] | {val,src}]\n        )\n    )\n    | {\n        headers: $headers,\n        values: map([.[$headers[]] | [.[]?.val]]),\n        sources: map([.[$headers[]] | [.[]?.src]])\n    }",
      ".headers as $headers\n| reduce .data[] as [$r,$c,$v,$s] (\n    {headers:$headers, values:{}, sources:{}}\n  ; setpath([\"values\",  $r, $c]; (getpath([\"values\", $r, $c])  // []) + [$v])\n  | setpath([\"sources\", $r, $c]; (getpath([\"sources\", $r, $c]) // []) + [$s])\n  )\n| .values  = [ .values[]  | [ .[ $headers[] ] ] ]\n| .sources = [ .sources[] | [ .[ $headers[] ] ] ]"
    ],
    "data": [
      {
        "input": {
          "headers": [
            "col1",
            "col2",
            "col3"
          ],
          "data": [
            [
              "row1",
              "col1",
              "b",
              "src2"
            ],
            [
              "row1",
              "col1",
              "b",
              "src1"
            ],
            [
              "row1",
              "col1",
              "b",
              "src3"
            ],
            [
              "row1",
              "col2",
              "d",
              "src4"
            ],
            [
              "row1",
              "col2",
              "e",
              "src5"
            ],
            [
              "row1",
              "col2",
              "f",
              "src6"
            ],
            [
              "row1",
              "col3",
              "j",
              "src7"
            ],
            [
              "row1",
              "col3",
              "g",
              "src8"
            ],
            [
              "row1",
              "col3",
              "h",
              "src9"
            ],
            [
              "row1",
              "col3",
              "i",
              "src10"
            ],
            [
              "row2",
              "col1",
              "l",
              "src13"
            ],
            [
              "row2",
              "col1",
              "j",
              "src11"
            ],
            [
              "row2",
              "col1",
              "k",
              "src12"
            ],
            [
              "row2",
              "col3",
              "o",
              "src15"
            ]
          ]
        },
        "output": {
          "headers": [
            "col1",
            "col2",
            "col3"
          ],
          "values": [
            [
              [
                "b",
                "b",
                "b"
              ],
              [
                "d",
                "e",
                "f"
              ],
              [
                "j",
                "g",
                "h",
                "i"
              ]
            ],
            [
              [
                "l",
                "j",
                "k"
              ],
              null,
              [
                "o"
              ]
            ]
          ],
          "sources": [
            [
              [
                "src2",
                "src1",
                "src3"
              ],
              [
                "src4",
                "src5",
                "src6"
              ],
              [
                "src7",
                "src8",
                "src9",
                "src10"
              ]
            ],
            [
              [
                "src13",
                "src11",
                "src12"
              ],
              null,
              [
                "src15"
              ]
            ]
          ]
        }
      }
    ],
    "identifier": 39739195
  }
]