[
  {
    "identifier": 44044449
  },
  {
    "context": [
      "jqOutput=$(jq -r '.[] | .name' < json)\nprintf \"%s\\n\" \"$jqOutput\"\nArthur\nRichard"
    ],
    "utterance": "Output each value of the 'name' field as a separate line in shell, preserving newlines.",
    "expressions": [
      ".[] | .name",
      "-r '.[] | .name'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "Arthur",
            "age": "21"
          },
          {
            "id": 2,
            "name": "Richard",
            "age": "32"
          }
        ],
        "output": [
          "Arthur",
          "Richard"
        ]
      }
    ],
    "identifier": 44062915
  },
  {
    "context": [
      "I need to find out the array index of all array objects that do not have \"app\" in the attribute \"Name\".",
      ".arr | range(0;length) as $i | select(.[$i].Name != \"app\") | $i",
      ".arr | to_entries[] | select(.value.Name != \"app\") | .key",
      "foreach .arr[] as $o (-1; .+1; select($o.Name != \"app\"))",
      "tostream | if   .[0][-1] == \"Name\" and .[1] == \"app\" then .[0][-2] else  empty end"
    ],
    "utterance": "Find the indexes of elements in the array where the Name attribute is not equal to \"app\".",
    "expressions": [
      ".arr | range(0;length) as $i | select(.[$i].Name != \"app\") | $i",
      ".arr | to_entries[] | select(.value.Name != \"app\") | .key",
      "foreach .arr[] as $o (-1; .+1; select($o.Name != \"app\"))",
      "tostream | if .[0][-1] == \"Name\" and .[1] == \"app\" then .[0][-2] else empty end"
    ],
    "data": [
      {
        "input": {
          "arr": [
            {
              "Name": "web"
            },
            {
              "Name": "app"
            }
          ]
        },
        "output": [
          0
        ]
      }
    ],
    "identifier": 44066308
  },
  {
    "context": [
      "I would recommend using [jq][1]:\r\n\r\n    $ jq '.data.password' data.json\r\n    \"test123\"",
      "Or both fields:\r\n\r\n    $ jq '.data.password, .data.username' data.json\r\n    \"test123\"\r\n    \"testuser1\"",
      "curl-command | jq --raw-output '.data.password, .data.username'"
    ],
    "utterance": "Extract the values of the fields 'password' and 'username' located under 'data'",
    "expressions": [
      ".data.password",
      ".data.username",
      ".data.password, .data.username",
      ".data | .password, .username"
    ],
    "data": [
      {
        "input": {
          "request_id": "9a081c0c-9401-7eca-f55d-50e3b7c0301c",
          "lease_id": "",
          "renewable": false,
          "lease_duration": 2764800,
          "data": {
            "password": "test123",
            "username": "testuser1"
          },
          "wrap_info": null,
          "warnings": null,
          "auth": null
        },
        "output": [
          "test123",
          "testuser1"
        ]
      }
    ],
    "identifier": 44032450
  },
  {
    "context": [
      "I need to find the nested objects by name, add it if it does not exist yet and replace it if it does exist.",
      "With these helper functions, the solution can be written:",
      ".[\"some-array\"] |= (a2h(.name) + ($update|.[\"some-array\"] | a2h(.name)) | h2a)"
    ],
    "utterance": "Update the array with objects from another input, matching by the 'name' field: replace objects whose names match and add objects if the name does not already exist.",
    "expressions": [
      "def a2h(f): reduce .[] as $x ({}; . + {($x | f): $x});\ndef h2a: . as $in | reduce keys_unsorted[] as $k ([]; . + [$in[$k]]);\n.[\"some-array\"] |= (a2h(.name) + ($update|.[\"some-array\"] | a2h(.name)) | h2a)"
    ],
    "data": [
      {
        "input": {
          "some-array": [
            {
              "name": "foo",
              "attr": "value"
            },
            {
              "name": "foo bar",
              "attr": "value"
            },
            {
              "name": "foo bar baz",
              "attr": "value"
            }
          ],
          "some-other-array": []
        },
        "output": {
          "some-array": [
            {
              "name": "foo",
              "attr": "new-value",
              "new-attrib": "new-value"
            },
            {
              "name": "foo bar",
              "attr": "new-value"
            },
            {
              "name": "foo bar baz",
              "attr": "value"
            }
          ],
          "some-other-array": []
        }
      }
    ],
    "identifier": 44072197
  },
  {
    "context": [
      "Jq to print instances id :\r\n\r\n    jq -r '.Reservations[].Instances[].InstanceId' all-inst.json\r\nOutput of Jq:\r\n\r\n     i-09e0d805cc \r\n     i-091a61038 \r\n     i-07d3022\r\n     i-0428ac7c4c\r\n     i-970dc5c4d99 \r\n     i-014c4ea\r\n     i-0ac924df\r\n     i-031f6 and so on..",
      "I want to print them in a line like this :\r\n\r\n    i-09e0d805cc,i-091a61038,i-07d3022,i-0428ac7c4c,i-970dc5c4d99,i-014c4ea,i-0ac924df,i-031f6 and so on..",
      "It's often simplest just to \"join\" the lines (e.g. using `join(\",\")`). This is typically done with the `-r` command-line option."
    ],
    "utterance": "Output all EC2 instance IDs as a single line, separated by commas.",
    "expressions": [
      ".Reservations[].Instances[].InstanceId | join(\",\")",
      "[.Reservations[].Instances[].InstanceId] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "InstanceId": "i-09e0d805cc"
                },
                {
                  "InstanceId": "i-091a61038"
                }
              ]
            },
            {
              "Instances": [
                {
                  "InstanceId": "i-07d3022"
                },
                {
                  "InstanceId": "i-0428ac7c4c"
                }
              ]
            }
          ]
        },
        "output": "i-09e0d805cc,i-091a61038,i-07d3022,i-0428ac7c4c"
      }
    ],
    "identifier": 44133851
  },
  {
    "context": [
      "Using `jq` I&#39;d like to convert data of the format:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;something-else&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;value&quot;: &quot;bloop&quot;,\r\n        &quot;isEncrypted&quot;: false\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;something&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;value&quot;: &quot;blah&quot;,\r\n        &quot;isEncrypted&quot;: false\r\n      }\r\n    }\r\n\r\nTo the format:\r\n\r\n    {\r\n      something: &quot;blah&quot;,\r\n      something-else: &quot;bloop&quot;\r\n    }\r\n\r\nFiltering out &#39;encrypted values&#39; along the way.",
      "map( select(.value.isEncrypted == false) | {(.key): .value.value } )\n| add",
      ".parameters\n| [ keys_unsorted[] as $k\n  | if .[$k].isEncrypted == false \n    then { ($k) : .[$k].value } else empty end ]\n| add"
    ],
    "utterance": "Convert an array of objects with 'key', 'value', and 'isEncrypted' fields into a single object mapping each key to its value, excluding entries where isEncrypted is true.",
    "expressions": [
      "map( select(.value.isEncrypted == false) | {(.key): .value.value } ) | add",
      ".parameters | [ keys_unsorted[] as $k | if .[$k].isEncrypted == false then { ($k) : .[$k].value } else empty end ] | add"
    ],
    "data": [
      {
        "input": [
          {
            "key": "something-else",
            "value": {
              "value": "bloop",
              "isEncrypted": false
            }
          },
          {
            "key": "something",
            "value": {
              "value": "blah",
              "isEncrypted": false
            }
          }
        ],
        "output": {
          "something-else": "bloop",
          "something": "blah"
        }
      }
    ],
    "identifier": 44105429
  },
  {
    "context": [
      "I want to go from this : \n\n    {\n      \"results\": [\n        {\n          \"profile\": {\n            \"birthYear\": 1900,\n            \"locale\": \"en_EN\",\n            \"city\": \"Somewhere, Around\",\n            \"timezone\": \"2\",\n            \"age\": 52,\n            \"gender\": \"m\"\n          },\n          \"UID\": \"SQSQSQerl7XSQSqSsqSQ\"\n        }\n      ]\n    }\n\nto this : \n\n    {\n       \"birthYear\": 1900,\n       \"locale\": \"en_EN\",\n       \"city\": \"Somewhere, Around\",\n       \"timezone\": \"2\",\n       \"age\": 52,\n       \"gender\": \"m\",\n       \"UID\": \"SQSQSQerl7XSQSqSsqSQ\"\n    }",
      "jq '.results[0].profile * .results[0] | del(.profile)'",
      "jq '.results[] | .profile + {UID}'"
    ],
    "utterance": "Flatten each object in the 'results' array so all fields from 'profile' are merged at the top level together with the UID",
    "expressions": [
      ".results[0].profile * .results[0] | del(.profile)",
      ".results[] | .profile + {UID}"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "profile": {
                "birthYear": 1900,
                "locale": "en_EN",
                "city": "Somewhere, Around",
                "timezone": "2",
                "age": 52,
                "gender": "m"
              },
              "UID": "SQSQSQerl7XSQSqSsqSQ"
            }
          ]
        },
        "output": {
          "birthYear": 1900,
          "locale": "en_EN",
          "city": "Somewhere, Around",
          "timezone": "2",
          "age": 52,
          "gender": "m",
          "UID": "SQSQSQerl7XSQSqSsqSQ"
        }
      }
    ],
    "identifier": 44138658
  },
  {
    "context": [
      "I used the follwoing jq command trto get output like:\nami-111|etl-db|available|snap-AAA|size-AAA\nami-111|etl-db|available|snap-BBB|size-BBB",
      "However it generates a Cartesian Product for  SnapshotId x VolumeSize\n\n    ami-111|etl-db|available|snap-AAA|size-AAA\n    ami-111|etl-db|available|snap-BBB|size-AAA\n    ami-111|etl-db|available|snap-AAA|size-BBB\n    ami-111|etl-db|available|snap-BBB|size-BBB",
      "How can I get the following output?\n\n    ami-111|etl-db|available|snap-AAA|size-AAA\n    ami-111|etl-db|available|snap-BBB|size-BBB",
      "To avoid the unwanted Cartesian product, ensure there is only one call to `.BlockDeviceMappings[]`.",
      "The following filter extracts the information you want as a stream of arrays:\n\n       .Images[] | [.ImageId,.Name,.State] + (.BlockDeviceMappings[] | [.Ebs[] ])",
      "To convert these arrays into strings with pipe-delimited values, you could pipe the above into `join(\"|\")`"
    ],
    "utterance": "Extract each ImageId, Name, and State, and for each BlockDeviceMapping, output one row containing its Ebs.SnapshotId and Ebs.VolumeSize, with values pipe-delimited, avoiding a Cartesian product of SnapshotId and VolumeSize.",
    "expressions": [
      ".Images[] | .BlockDeviceMappings[] | [ .ImageId, .Name, .State, .Ebs.SnapshotId, .Ebs.VolumeSize ] | join(\"|\")"
    ],
    "data": [
      {
        "input": {
          "Images": [
            {
              "ImageId": "ami-111",
              "Name": "etl-db",
              "State": "available",
              "BlockDeviceMappings": [
                {
                  "DeviceName": "/dev/sda",
                  "Ebs": {
                    "SnapshotId": "snap-AAA",
                    "VolumeSize": "size-AAA"
                  }
                },
                {
                  "DeviceName": "/dev/sdb",
                  "Ebs": {
                    "SnapshotId": "snap-BBB",
                    "VolumeSize": "size-BBB"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          "ami-111|etl-db|available|snap-AAA|size-AAA",
          "ami-111|etl-db|available|snap-BBB|size-BBB"
        ]
      }
    ],
    "identifier": 44081265
  },
  {
    "context": [
      "How do I get `jq` to exclude the `_children` property from all objects that have it?",
      "If your jq has `walk/1` then you could:",
      "    walk( if type == \"object\" then del(._children) else . end )"
    ],
    "utterance": "Remove all properties named _children from every object where they appear, recursively in the data.",
    "expressions": [
      "walk( if type == \"object\" then del(._children) else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "py/object": "bit.ast.Node",
            "_children": [
              {
                "py/object": "bit.ast.Node",
                "_children": [
                  "main",
                  {
                    "py/object": "bit.ast.Node",
                    "_children": [
                      "args"
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "py/object": "bit.ast.Node"
          }
        ]
      }
    ],
    "identifier": 44178362
  },
  {
    "context": [
      "How do I get the first index of a query that contains multiple matches? I am trying to get the value of the first key called **ELEMENT** in this query:",
      "If you want the value of .ELEMENT in the first match, you could consider:",
      ".value | map( select(.label==\"this.com\")) | .[0] // empty | .ELEMENT",
      "If your jq has `first/1`, a more efficient solution is possible:",
      "first( .value[] | select(.label==\"this.com\") ) | .ELEMENT"
    ],
    "utterance": "Get the value of the first ELEMENT key where label equals \"this.com\".",
    "expressions": [
      ".value | map(select(.label==\"this.com\")) | .[0] // empty | .ELEMENT",
      "first(.value[] | select(.label==\"this.com\")) | .ELEMENT"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "ELEMENT": "FADC6B14-0369-4FF4-9ADC-A5E0F5C6D30D",
              "type": "XCUIElementTypeStaticText",
              "label": "this.com"
            },
            {
              "ELEMENT": "CC89DD73-AB90-495E-A90B-74722C56DD46",
              "type": "XCUIElementTypeStaticText",
              "label": "this.com"
            },
            {
              "ELEMENT": "B888ADA6-4209-44C4-BCB8-F5174312D102",
              "type": "XCUIElementTypeStaticText",
              "label": "this.com"
            },
            {
              "ELEMENT": "9A6E77C7-E93D-41DE-9163-2CB60B8DD2FB",
              "type": "XCUIElementTypeStaticText",
              "label": "this.com"
            }
          ]
        },
        "output": "FADC6B14-0369-4FF4-9ADC-A5E0F5C6D30D"
      }
    ],
    "identifier": 44169813
  },
  {
    "context": [
      "How do I convert text strings and add them into an existing json object",
      "Current json output:\r\n\r\n    {\r\n      \"start process\": \"Wed May 24 05:22:35 UTC 2017\",\r\n      \"logfilename\": \"log_test\"\r\n    }\r\n    {\r\n      \"start filelist\": [\r\n        \"/downloads/json_log_array2object.jq\",\r\n        \"/downloads/json_log_string2object.jq\",\r\n        \"/downloads/log_test.json\",\r\n        \"/downloads/log_test.txt\",\r\n        \"/downloads/test_logs.sh\"\r\n      ]\r\n    }",
      "Target json output:\r\n\r\n    {\r\n      \"start process\": \"Wed May 24 05:22:35 UTC 2017\",\r\n      \"logfilename\": \"log_test\",\r\n      \"start filelist\": [\r\n        \"/downloads/json_log_array2object.jq\",\r\n        \"/downloads/json_log_string2object.jq\",\r\n        \"/downloads/log_test.json\",\r\n        \"/downloads/log_test.txt\",\r\n        \"/downloads/test_logs.sh\"\r\n      ]\r\n    }",
      "To add two JSON objects, $one and $two, you can write `$one + $two`.",
      "the invocation:\r\n\r\n    jq -s '.[0] + .[1]' input.json\r\n\nyields the desired answer."
    ],
    "utterance": "Combine two objects by merging their key-value pairs so that all fields from both objects appear in a single object.",
    "expressions": [
      "jq -s '.[0] + .[1]'"
    ],
    "data": [
      {
        "input": [
          {
            "start process": "Wed May 24 05:22:35 UTC 2017",
            "logfilename": "log_test"
          },
          {
            "start filelist": [
              "/downloads/json_log_array2object.jq",
              "/downloads/json_log_string2object.jq",
              "/downloads/log_test.json",
              "/downloads/log_test.txt",
              "/downloads/test_logs.sh"
            ]
          }
        ],
        "output": {
          "start process": "Wed May 24 05:22:35 UTC 2017",
          "logfilename": "log_test",
          "start filelist": [
            "/downloads/json_log_array2object.jq",
            "/downloads/json_log_string2object.jq",
            "/downloads/log_test.json",
            "/downloads/log_test.txt",
            "/downloads/test_logs.sh"
          ]
        }
      }
    ],
    "identifier": 44149753
  },
  {
    "context": [
      "I have json file exported from mongodb which looks like:\r\n\r\n    {\"_id\":\"99919\",\"city\":\"THORNE BAY\"}\r\n    {\"_id\":\"99921\",\"city\":\"CRAIG\"}\r\n    {\"_id\":\"99922\",\"city\":\"HYDABURG\"}\r\n    {\"_id\":\"99923\",\"city\":\"HYDER\"}",
      "there are about 30000 lines, I want to split each line into it's own `.json` file. *(I'm trying to transfer my data onto couchbase cluster)*",
      "cat cities.json | jq -c -M '.'' | \\\r\n    while read line; do echo $line > .chunks/cities_$(date +%s%N).json; done",
      "but I found that it seems to drop loads of line and the output of running this command only gave me 50 odd files when I was expecting 30000 odd!!",
      "Assuming you don't care about the exact filenames, if you want to split input into multiple files, just use [`split`](http://man7.org/linux/man-pages/man1/split.1.html).\r\n\r\n    jq -c . < cities.json | split -l 1 --additional-suffix=.json - .chunks/cities_"
    ],
    "utterance": "Split each line in a file, where every line contains one object, into its own file with a .json extension.",
    "expressions": [
      "jq -c . < cities.json | split -l 1 --additional-suffix=.json - .chunks/cities_"
    ],
    "data": [
      {
        "input": [
          "{\"_id\":\"99919\",\"city\":\"THORNE BAY\"}",
          "{\"_id\":\"99921\",\"city\":\"CRAIG\"}",
          "{\"_id\":\"99922\",\"city\":\"HYDABURG\"}",
          "{\"_id\":\"99923\",\"city\":\"HYDER\"}"
        ],
        "output": [
          ".chunks/cities_aa.json: {\"_id\":\"99919\",\"city\":\"THORNE BAY\"}",
          ".chunks/cities_ab.json: {\"_id\":\"99921\",\"city\":\"CRAIG\"}",
          ".chunks/cities_ac.json: {\"_id\":\"99922\",\"city\":\"HYDABURG\"}",
          ".chunks/cities_ad.json: {\"_id\":\"99923\",\"city\":\"HYDER\"}"
        ]
      }
    ],
    "identifier": 44215931
  },
  {
    "context": [
      "I want to get `id` of the instance which is in `ON` state.",
      "How do I get only `random-generated-id-1`?",
      "jq -r '.instances[] | select(.state==\"ON\") | .id'"
    ],
    "utterance": "Select the id of the instance where the state field is equal to ON.",
    "expressions": [
      ".instances[] | select(.state==\"ON\") | .id"
    ],
    "data": [
      {
        "input": {
          "dirty": "false",
          "instances": {
            "random-generated-id-1": {
              "state": "ON",
              "id": "random-generated-id-1"
            },
            "random-generated-id-2": {
              "state": "OFF",
              "id": "random-generated-id-2"
            }
          }
        },
        "output": "random-generated-id-1"
      }
    ],
    "identifier": 44293386
  },
  {
    "context": [
      "I want select the 'ac' and 'aa' values where ab.abb key (in the same sub structure) contains a specific word.",
      "if I search the word \"tata\", I must obtain the values \"aa_value_1\" and \"ac_value_1\" because in the sub structure \"1\", the ab.abb field contains the word \"tata\" (tototatatiti)",
      ".two[]\n| select( .ab.abb | type == \"array\")\n| select( .ab.abb[] | test(\"tata\") )\n| [ .ac[],.aa[] ]",
      "invocation of jq with the -c option produces:\n\n    [\"ac_value_1\",\"aa_value_1\"]"
    ],
    "utterance": "Find all 'ac' and 'aa' values from elements of 'two' where any value in 'ab.abb' contains the substring 'tata'.",
    "expressions": [
      ".two[] | select(.ab.abb | type == \"array\") | select(.ab.abb[] | test(\"tata\")) | [ .ac[], .aa[] ]"
    ],
    "data": [
      {
        "input": {
          "one": "one_value",
          "two": [
            {
              "aa": [
                "aa_value_0"
              ],
              "ab": {},
              "ac": [
                "ac_value_0"
              ]
            },
            {
              "aa": [
                "aa_value_1"
              ],
              "ab": {
                "aba": [
                  "aba_value_1"
                ],
                "abb": [
                  "tototatatiti"
                ],
                "abc": [
                  "abc_value_1"
                ]
              },
              "ac": [
                "ac_value_1"
              ]
            }
          ]
        },
        "output": [
          "ac_value_1",
          "aa_value_1"
        ]
      }
    ],
    "identifier": 44271503
  },
  {
    "context": [
      "How does one remove blank string items from an array in jq?",
      "echo '[\"bob\",\"\",\"tim\",\"\"]' | jq '[ . [] | if length > 0 then . end ]'",
      "**Desired output:**\n\n    [\"bob\", \"tim\"]",
      "Adding \"else empty\" gets the right result",
      "jq '[ .[] | if length > 0 then . else empty end ]'",
      "Consider using select instead.",
      "jq '[ .[] | select(length > 0) ]'",
      "And since map(x) is equivalent to `[.[] | x]`, we can do this.",
      "jq 'map(select(length > 0))'"
    ],
    "utterance": "Remove all empty string elements from an array, so only non-empty strings remain.",
    "expressions": [
      "[ .[] | if length > 0 then . else empty end ]",
      "[ .[] | select(length > 0) ]",
      "map(select(length > 0))"
    ],
    "data": [
      {
        "input": [
          "bob",
          "",
          "tim",
          ""
        ],
        "output": [
          "bob",
          "tim"
        ]
      }
    ],
    "identifier": 44288635
  },
  {
    "context": [
      "I'm trying to get the total amount for a specific value in a array.",
      "The input would be something like\n\n    [{\n    \t\"name\": \"mars\",\n    \t\"runner\":  [\n    \t\t{\n    \t\t\"foo\": null,\n    \t\t\"idle\": true\n    \t\t},\n    \t\t{\n    \t\t\"foo\": null,\n    \t\t\"idle\": true\n    \t\t},\n    \t\t{\n    \t\t\"foo\": null,\n    \t\t\"idle\": false\n    \t\t}\n    \n    \t],\n    \t\t\"name\": \"june\",\n    \t\t\"runner\": [\n    \t\t{\n    \t\t\"foo\": null,\n    \t\t\"idle\": true\n    \t\t},\n    \t\t{\n    \t\t\"foo\": null,\n    \t\t\"idle\": true\n    \t\t},\n    \t\t{\n    \t\t\"foo\": null,\n    \t\t\"idle\": true\n    \t\t}\n    \t]\n    }]",
      "The desired output\n\n> [ {\"name\" : \"mars\", \"idle\" : 2\"},{\"name\" : \"june\", \"idle\" : 1\"} ]",
      "A reasonable approach would be to rely on the builtin `length` function:\n\n    map( { name, idle: (.runner | map(select(.idle)) | length)} )",
      "A better (e.g. more efficient) solution would be to define a function that can count:\n\ndef count(s): reduce s as $i (0; .+1); \n\nHere `s` is any filter that produces a stream of values.  A solution to the problem at hand could then be written as follows:\n\n    map( {name, idle: count(.runner[] | select(.idle))} )",
      "The output in both cases:\n\n    [\n      {\n        \"name\": \"mars\",\n        \"idle\": 2\n      },\n      {\n        \"name\": \"june\",\n        \"idle\": 3\n      }\n    ]"
    ],
    "utterance": "For each element, return the name and the number of runner objects where idle is true.",
    "expressions": [
      "map( { name, idle: (.runner | map(select(.idle)) | length)} )",
      "def count(s): reduce s as $i (0; .+1); map( {name, idle: count(.runner[] | select(.idle))} )"
    ],
    "data": [
      {
        "input": [
          {
            "name": "mars",
            "runner": [
              {
                "foo": null,
                "idle": true
              },
              {
                "foo": null,
                "idle": true
              },
              {
                "foo": null,
                "idle": false
              }
            ]
          },
          {
            "name": "june",
            "runner": [
              {
                "foo": null,
                "idle": true
              },
              {
                "foo": null,
                "idle": true
              },
              {
                "foo": null,
                "idle": true
              }
            ]
          }
        ],
        "output": [
          {
            "name": "mars",
            "idle": 2
          },
          {
            "name": "june",
            "idle": 3
          }
        ]
      }
    ],
    "identifier": 44171931
  },
  {
    "context": [
      "My goal is to get each value of a group of keypairs, and insert each into another file. I could do this line by line, but is there a cleaner way to add them all at once?",
      "I have the result of an aws query which gives me the following file called `vpc.json` ...",
      "And I'd like each value to end up in `parameters.json`, which already has a bunch of other keypairs, with the final file looking like;",
      "The code checks to see if the keypair already exists, adding it if not (necessary because this needs to be backwards compatible with older files). It then gets the relevant value from the vpc file and places it in the parameters file.",
      "I have to imagine that there's a better way to do this that doesn't require 5 copies of the same three lines. The keys will always be the same names, but the values will change.",
      "def munge: {ParameterKey: .OutputKey, ParameterValue: .OutputValue};",
      ". + (($vpc | map(munge)) - .)",
      "jq -f vpc.jq --argfile vpc vpc.json parameters.json"
    ],
    "utterance": "Merge all key-value pairs from the input where OutputKey and OutputValue are mapped to ParameterKey and ParameterValue, adding only those not already present by ParameterKey to an existing list of parameters.",
    "expressions": [
      "def munge: {ParameterKey: .OutputKey, ParameterValue: .OutputValue};\n. + (($vpc | map(munge)) - .)",
      "( . + ($vpc | map(munge)) ) | unique",
      "reduce ($vpc[] | munge) as $new\n  (.; if index($new) then . else . + [$new] end)"
    ],
    "data": [
      {
        "input": {
          "parameters.json": [
            {
              "ParameterKey": "SomeOtherKey",
              "ParameterValue": "someValue"
            }
          ],
          "vpc.json": [
            {
              "Description": "Client VpcId",
              "OutputKey": "VpcId",
              "OutputValue": "vpc-a12345"
            },
            {
              "OutputKey": "ServiceSubnet1",
              "OutputValue": "subnet-b12345"
            },
            {
              "OutputKey": "PublicSubnet1",
              "OutputValue": "subnet-c12345"
            },
            {
              "OutputKey": "ServiceSubnet0",
              "OutputValue": "subnet-d12345"
            },
            {
              "OutputKey": "PublicSubnet0",
              "OutputValue": "subnet-e12345"
            }
          ]
        },
        "output": [
          {
            "ParameterKey": "SomeOtherKey",
            "ParameterValue": "someValue"
          },
          {
            "ParameterKey": "VpcId",
            "ParameterValue": "vpc-a12345"
          },
          {
            "ParameterKey": "ServiceSubnet1",
            "ParameterValue": "subnet-b12345"
          },
          {
            "ParameterKey": "PublicSubnet1",
            "ParameterValue": "subnet-c12345"
          },
          {
            "ParameterKey": "ServiceSubnet0",
            "ParameterValue": "subnet-d12345"
          },
          {
            "ParameterKey": "PublicSubnet0",
            "ParameterValue": "subnet-e12345"
          }
        ]
      }
    ],
    "identifier": 44265085
  },
  {
    "context": [
      "Note that there is no outer object or array and no commas between items.",
      "I keep thinking the answer is that it is called \"raw\", but I'm uncertain about this.",
      "the `-s` option can be used to tell jq to gather the separate values into an array and feed that to the filter:",
      "$ (echo 2;echo {}; echo []; echo 3)| jq -s .",
      "[\n  2,\n  {},\n  [],\n  3\n]",
      "The [jq manual.yml](https://github.com/stedolan/jq/blob/master/docs/content/3.manual/manual.yml#L130-L135) explains how the `--raw-input`/`-R` option can be included for even more control over input handing:",
      "If combined with `--slurp`,then the entire input is passed to the filter as a single long string.",
      "$ (echo 2;echo {}; echo []; echo 3)| jq -s -R .",
      "\"2\\n{}\\n[]\\n3\\n\""
    ],
    "utterance": "Combine multiple top-level values from separate lines into a single array or a single string, depending on options.",
    "expressions": [
      "jq -s .",
      "jq -s -R ."
    ],
    "data": [
      {
        "input": [
          "2",
          "{}",
          "[]",
          "3"
        ],
        "output": [
          2,
          {},
          [],
          3
        ]
      },
      {
        "input": [
          "2",
          "{}",
          "[]",
          "3"
        ],
        "output": "2\n{}\n[]\n3\n"
      }
    ],
    "identifier": 44292555
  },
  {
    "context": [
      "Is there a way to refactor `jq` into functions?",
      "jq ' .them .\"keyName\" ' ./some.json",
      "def getThese(x): .them .$x;",
      "The abbreviation '.x.y' will not work if y is a variable. Use the syntax '.x | .[ y ]' instead.",
      "Your definition should be either:",
      "def getThese(x): .them | .[x];",
      "or with different semantics (and requiring a sufficiently recent version of jq):",
      "def getThese($x): .them | .[$x];"
    ],
    "utterance": "Access the value at a user-specified key under the object at '.them', using a function that accepts the key name as a parameter.",
    "expressions": [
      "def getThese(x): .them | .[x];",
      "def getThese($x): .them | .[$x];"
    ],
    "identifier": 44294127
  },
  {
    "context": [
      "If my query return one element I want display a specific field value, else, I want display an another field value.",
      "If I have one element, I want display only the field .fii, else, I want display only the field .fuu.",
      "You can then simply count the number of solutions, along the following lines:",
      "map(.foo | select(.faa | test(\"word\"))) | if (length == 1) then map(.fii) else map(.fuu) end",
      "If you want a stream of values, rather than an array, then you could simply append `| .[]` to the above filter."
    ],
    "utterance": "If the selection returns one element, display its fii field; otherwise, display the fuu field from each selected element containing 'word' in faa.",
    "expressions": [
      "map(.foo | select(.faa | test(\"word\"))) | if (length == 1) then map(.fii) else map(.fuu) end"
    ],
    "identifier": 44295432
  },
  {
    "context": [
      "I want to use value of argument `secret_name` to create a key under `.data`. Is this possible using `jq`?",
      "With a variable, you need to use the long `[...]` form for the key. You don't need to quote the variables in a JSON filter; the variable *is* the string value.",
      "jq -rc \\\n   --arg secret_name \"${secret_name}\" \\\n   --arg secret_value \"${secret_value}\" \\\n   '.data[$secret_name] = $secret_value'"
    ],
    "utterance": "Set a key under the 'data' object with the name taken from the variable 'secret_name' and its value from 'secret_value'.",
    "expressions": [
      ".data[$secret_name] = $secret_value"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "data": {},
          "kind": "Secret",
          "metadata": {
            "name": "kv-secrets",
            "namespace": "default"
          },
          "type": "Opaque"
        },
        "output": {
          "apiVersion": "v1",
          "data": {
            "abc": "xyz"
          },
          "kind": "Secret",
          "metadata": {
            "name": "kv-secrets",
            "namespace": "default"
          },
          "type": "Opaque"
        }
      }
    ],
    "identifier": 44327196
  },
  {
    "context": [
      "After Transformation with jq i checked the new json file and there are a lot of Code Errors where in the original file stands &#228;,&#214;,&#223; and all that stuff.",
      "I use following jq Statement:\r\n\r\n    jq \"[{nid, title, nights, zone: .zones[0].title} + (.sails[] | { sails_nid: .nid, arrival, departure } ) + (.sails[].cabins[] | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, discountPercentage, currency } )]\"  dreamlines_details.json >test.json"
    ],
    "utterance": "Transform structured data extracting specific fields, handling special German characters like \u00e4, \u00d6, \u00df correctly during the transformation.",
    "expressions": [
      "[{nid, title, nights, zone: .zones[0].title} + (.sails[] | { sails_nid: .nid, arrival, departure } ) + (.sails[].cabins[] | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, discountPercentage, currency } )]"
    ],
    "identifier": 44392282
  },
  {
    "context": [
      "You can use a flag in `jq` to propagate the exit code of `jq` to shell which you can use in your command to see if it succeeded.",
      "The official [jq-documentation](https://stedolan.github.io/jq/manual/) provides just the right option for this,",
      ">-e / --exit-status:",
      "jq -er '.foo' <<<\"$jsonStr\"",
      "jq -er '.foo1' <<<\"$jsonStr\"",
      "if jq -er '.foo' <<<\"$jsonStr\" > /dev/null; then\n    printf \"string contained foo\\n\"\nfi",
      "if jq -er '.foo1' <<<\"$jsonStr\" > /dev/null; then\n    printf \"string contained foo\\n\"\nelse\n    printf \"string does not contain foo\\n\"\nfi ",
      "Do remember that the above case _would not_ be possible if you don't set the `-e` flag because refer to the last line of the above clause",
      "Please note that if you use the `-e` option, then the JSON value `false` will also trigger an error condition.",
      "If the goal is to be able to distinguish the JSON value `null` from the JSON string `\"null\"`, then please note that that could also be done by NOT using the '-r' option.",
      "local value=$(jq -r \"if($q) then $q else empty end\" <<<\"$json\" 2>/dev/null)",
      "if ! test -n \"$value\"; then\n  echo \"You've done it all wrong\"\n  return 1\nfi >&2\n"
    ],
    "utterance": "Detect whether a query accesses a non-existent key and return an error, distinguishing between missing keys and present keys whose value is null or a string 'null'.",
    "expressions": [
      "jq -er '.foo' <<< \"$jsonStr\"",
      "jq -er '.foo1' <<< \"$jsonStr\"",
      "jq -er \"${query}\" <<< \"$jsonStr\"",
      "jq -r \"if(${query}) then ${query} else empty end\" <<< \"$json\" 2>/dev/null"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": "baz"
          }
        },
        "output": "baz"
      },
      {
        "input": {
          "foo": null
        },
        "output": null
      },
      {
        "input": {
          "foo": "null"
        },
        "output": "null"
      }
    ],
    "identifier": 44282020
  },
  {
    "context": [
      "I have an object which has an array of objects. I am willing to append two properties of each object inside the array and create a new key out of that.",
      "Input:",
      "{\n  \"name\": \"Toyota\",\n  \"Model\": \"Innova\",\n  \"Details\": [\n    {\n      \"entry_day\": \"23\",\n      \"entry_month\": \"May\"\n    },\n    {\n      \"entry_day\": \"01\",\n      \"entry_month\": \"Jan\"\n    }\n  ]\n}",
      "Output I expect:",
      "{\n\t\"name\": \"Toyota\",\n\t\"Model\": \"Innova\",\t\n\t\"Details\": [\n\t\t{\n\t\t\t\"entry_date\": \"23 May\"\n\t\t},\n\t\t{\n\t\t\t\"entry_date\": \"01 Jan\"\n\t\t}\n\t]\n}",
      "jq '(.Details[]|={entry_date:\"\\(.entry_day) \\(.entry_month)\"})' input.json"
    ],
    "utterance": "For each object in the Details array, create a new entry_date field by combining entry_day and entry_month as a string, and replace the object with this new field.",
    "expressions": [
      "(.Details[]|={entry_date:\"\\(.entry_day) \\(.entry_month)\"})"
    ],
    "data": [
      {
        "input": {
          "name": "Toyota",
          "Model": "Innova",
          "Details": [
            {
              "entry_day": "23",
              "entry_month": "May"
            },
            {
              "entry_day": "01",
              "entry_month": "Jan"
            }
          ]
        },
        "output": {
          "name": "Toyota",
          "Model": "Innova",
          "Details": [
            {
              "entry_date": "23 May"
            },
            {
              "entry_date": "01 Jan"
            }
          ]
        }
      }
    ],
    "identifier": 44303178
  },
  {
    "context": [
      "is there a way I can rename the 'car_name' property to 'name' and also not mention all the other properties ( in this case, 'saleDate') in the rule. I might end up having 50+ properties inside the object and I do not want to mention all of them in the rule.",
      "jq '.description[] |= with_entries( .key |= gsub(\"car_name\"; \"name\") )'",
      "jq '.description[] |= with_entries(if .key == \"car_name\" then .key = \"name\" else . end)'"
    ],
    "utterance": "Rename the property 'car_name' to 'name' inside each object of the description array without specifying all other properties.",
    "expressions": [
      ".description[] |= with_entries( .key |= gsub(\"car_name\"; \"name\") )",
      ".description[] |= with_entries(if .key == \"car_name\" then .key = \"name\" else . end)"
    ],
    "data": [
      {
        "input": {
          "uuid": 123,
          "description": [
            {
              "car_name": "Toyota",
              "saleDate": "23 May 2017"
            }
          ]
        },
        "output": {
          "uuid": 123,
          "description": [
            {
              "name": "Toyota",
              "saleDate": "23 May 2017"
            }
          ]
        }
      }
    ],
    "identifier": 44367613
  },
  {
    "context": [
      "I thought of using jq, but couldn&#39;t figure out, how to just get:\r\n\r\n\"Fabio Facchinelli, Andreas P. M. Weber\"",
      "Here&#39;s one way to do that with `jq`:\r\n\r\n    ... | jq '.author[] | .given + \" \" + .family' | jq -s 'join(\", \")'",
      "The task can be accomplished with just one invocation of jq:\r\n\r\n     ... | jq '.author | map(.given + \" \" + .family) | join(\", \")'"
    ],
    "utterance": "Extract all author full names (given and family) and join them as a comma-separated string.",
    "expressions": [
      ".author[] | .given + \" \" + .family | jq -s 'join(\", \")'",
      ".author | map(.given + \" \" + .family) | join(\", \")"
    ],
    "data": [
      {
        "input": [
          {
            "given": "Fabio",
            "family": "Facchinelli",
            "affiliation": []
          },
          {
            "given": "Andreas P. M.",
            "family": "Weber",
            "affiliation": []
          }
        ],
        "output": "\"Fabio Facchinelli, Andreas P. M. Weber\""
      }
    ],
    "identifier": 44375141
  },
  {
    "context": [
      "I want a file where \"ServerID\" and \"servers\" is the same then merge all info like this:",
      "cat File[1-2] | jq -s 'if .[0].servers == .[1].ServerID then \n                  .[0] + .[1] | del(.servers,.ServerID)  else \"not match\" end'",
      "The output:\n\n    {\n      \"id\": 3918389,\n      \"name\": \"Application\",\n      \"AccountID\": 661737,\n      \"HostName\": \"example.com\"\n    }"
    ],
    "utterance": "Merge two objects from separate files when the value of 'servers' in the first matches 'ServerID' in the second, producing a single object with properties from both except those keys.",
    "expressions": [
      "cat File[1-2] | jq -s 'if .[0].servers == .[1].ServerID then .[0] + .[1] | del(.servers,.ServerID) else \"not match\" end'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 3918389,
            "name": "Application",
            "servers": 5566625
          },
          {
            "ServerID": 5566625,
            "AccountID": 661737,
            "HostName": "example.com"
          }
        ],
        "output": {
          "id": 3918389,
          "name": "Application",
          "AccountID": 661737,
          "HostName": "example.com"
        }
      }
    ],
    "identifier": 44356606
  },
  {
    "context": [
      "\"I am using jq parser to convert json to csv.\"",
      "\"But my desire output is\\n\\n    \\\"true\\\", \\\"false\\\", \\\"text_value\\\"\\nor\\n\\n    true, false, text_value\"",
      "\"[.abc.a_val, .def.b_val, .normaltext.c_val] | @csv\"",
      "\"jq -r '[.abc.a_val, .def.b_val, .normaltext.c_val] | @csv' jsonfile\"",
      "\"jq -r '[(.abc.a_val | tostring), (.def.b_val | tostring), .normaltext.c_val] | @csv' jsonfile\""
    ],
    "utterance": "Extract the values of a_val, b_val, and c_val from the keys abc, def, and normaltext, and convert them into a single CSV line.",
    "expressions": [
      "[.abc.a_val, .def.b_val, .normaltext.c_val] | @csv",
      "[(.abc.a_val | tostring), (.def.b_val | tostring), .normaltext.c_val] | @csv"
    ],
    "data": [
      {
        "input": {
          "abc": {
            "a_val": true
          },
          "def": {
            "b_val": false
          },
          "normaltext": {
            "c_val": "text_value"
          }
        },
        "output": "true,false,\"text_value\""
      }
    ],
    "identifier": 44397595
  },
  {
    "context": [
      "I used to parse the data using json path as [?(@.type=='router')].externalIP. I am not sure how to do the same using jq.",
      "The result from the query should provide the .externalIp from the type=router.",
      "i would like to extract externalIP for only the array \"type\": [ \"router\" ]",
      ".[] | select(.type==[\"router\"]) | .externalIP",
      ".[] | select(.type|index(\"router\")) | .externalIP"
    ],
    "utterance": "Extract the externalIP value from all objects where the type array includes the string 'router'.",
    "expressions": [
      ".[] | select(.type == [\"router\"]) | .externalIP",
      ".[] | select(.type | index(\"router\")) | .externalIP"
    ],
    "data": [
      {
        "input": [
          {
            "externalHostName": "localhost",
            "externalIP": "198.22.66.99",
            "internalHostName": "localhost",
            "isUp": true,
            "pod": "gateway",
            "reachable": true,
            "region": "dc-1",
            "type": [
              "router"
            ],
            "uUID": "b5f986fe-982e-47ae-8260-8a3662f25fc2"
          }
        ],
        "output": [
          "198.22.66.99"
        ]
      }
    ],
    "identifier": 44409037
  },
  {
    "context": [
      "baselineresult=$(jq -r '.users.user[1].cpid.\"#text\"' $1)",
      "however when i try to add `$basecount` which increases each time i couldn't get it to work so i constructed this crazy method in which I had to use substitutions to get the $basecount into the [ ] of the user.",
      "baselineresult=$(jq -r \"${squote}.users.user${bracea}${basecount}${braceb}.cpid.${dquote}${pound}text${dquote}${squote} $1\")",
      "the command matches the one i entered at command line to work.",
      "however i get this:",
      "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      "Here's an example of what `jq` expects:",
      ".users.user[1].cpid.\"#text\"",
      "To `jq`, this command is indistinguishable from your original (it results in an `execve` call with the exact same parameters). You can vary the variable to get different indices:",
      "var=1",
      "baselineresult=$(jq -r '.users.user['\"$var\"'].cpid.\"#text\"' \"$1\")"
    ],
    "utterance": "Retrieve the value at .users.user[N].cpid[\"#text\"] where N is set dynamically via a bash variable.",
    "expressions": [
      ".users.user[VAR].cpid[\"#text\"]"
    ],
    "identifier": 44425626
  },
  {
    "context": [
      "I have the given JSON and want to change the `id` value of all elements, which starts with `test` in the `name` element:",
      "But when I try it with `startswith` it stops working, what am I missing?",
      "You can also use `map`, like this:",
      "jq '(.values)|=(map((if .name|startswith(\"test\") then .id=\"NEWID\"  else . end)))'",
      "Please note that since the release of jq 1.5, jq has been enhanced to support the query that previously failed.  For example, using the current 'master' version:",
      "jq -c '(.values[] | select(.name | startswith(\"test\")).id) |= \"NEWID\"'",
      "If using `map`, a minimalist expression would be:",
      ".values |= map(if .name|startswith(\"test\") then .id = \"NEWID\" else . end)"
    ],
    "utterance": "Update the id field to NEWID in all items where the name field starts with test.",
    "expressions": [
      "(.values[] | select(.name | startswith(\"test\")).id) |= \"NEWID\"",
      ".values[] |= if .name | startswith(\"test\") then .id = \"NEWID\" else . end",
      ".values |= map(if .name|startswith(\"test\") then .id = \"NEWID\" else . end)",
      "(.values)|=(map((if .name|startswith(\"test\") then .id=\"NEWID\"  else . end)))"
    ],
    "data": [
      {
        "input": {
          "other-value": "some-id",
          "values": [
            {
              "name": "test-2017-12-01",
              "id": "1"
            },
            {
              "name": "othert",
              "id": "2"
            }
          ]
        },
        "output": {
          "other-value": "some-id",
          "values": [
            {
              "name": "test-2017-12-01",
              "id": "NEWID"
            },
            {
              "name": "othert",
              "id": "2"
            }
          ]
        }
      }
    ],
    "identifier": 44410394
  },
  {
    "context": [
      "Here's a sample of the JSON I want to parse:",
      "Not so bad, but what I'm looking for is something like this:",
      "123456,\"www.domain.com\",\"Block\",\"Block\",\"Alert\"",
      "A solution that is very similar to your attempt would therefore be:",
      ".sites[] | [.site_id, .domain, (.security.waf.rules[] | .action_text) ] | @csv",
      "Putting everything together will give us this filter:",
      ".sites[] | [.site_id, .domain, (.security.waf.rules[].action_text)] | @csv"
    ],
    "utterance": "Extract site_id, domain, and all action_text values from each site as a single CSV row.",
    "expressions": [
      ".sites[] | [.site_id, .domain, (.security.waf.rules[] | .action_text)] | @csv",
      ".sites[] | [.site_id, .domain, (.security.waf.rules[].action_text)] | @csv"
    ],
    "data": [
      {
        "input": {
          "sites": [
            {
              "site_id": 123456,
              "status": "configured",
              "domain": "www.domain.com",
              "account_id": 654321,
              "security": {
                "waf": {
                  "rules": [
                    {
                      "action": "block_request",
                      "action_text": "Block",
                      "id": "sqli",
                      "name": "SQLi"
                    },
                    {
                      "action": "block_request",
                      "action_text": "Block",
                      "id": "xss",
                      "name": "XSS"
                    },
                    {
                      "action": "alert",
                      "action_text": "Alert",
                      "id": "path_vector",
                      "name": "Path Vector"
                    }
                  ]
                }
              }
            }
          ],
          "res": 0,
          "res_message": "OK",
          "debug_info": {
            "id-info": "9123"
          }
        },
        "output": "123456,\"www.domain.com\",\"Block\",\"Block\",\"Alert\""
      }
    ],
    "identifier": 44428844
  },
  {
    "context": [
      "I am trying to parse with jq the following structure:",
      "{\n    \"a\": {\n        \"sensitive\": false,\n        \"type\": \"string\",\n        \"value\": \"mykeypair\"\n    },\n    \"b\": {\n        \"sensitive\": false,\n        \"type\": \"string\",\n        \"value\": \"123\"\n    }\n}",
      "and get this as an output:",
      "{\n    \"a\": \"mykeypair\",\n    \"b\": \"123\"\n}",
      "I would like the key and as a value, the value of the field 'value'.",
      "[ to_entries[] | .value = .value.value ] | from_entries",
      "with_entries(.value |= .value)",
      "map_values(.value)"
    ],
    "utterance": "Convert a dictionary with nested objects so that each key maps to the value of its 'value' field.",
    "expressions": [
      "[ to_entries[] | .value = .value.value ] | from_entries",
      "with_entries(.value |= .value)",
      "map_values(.value)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "sensitive": false,
            "type": "string",
            "value": "mykeypair"
          },
          "b": {
            "sensitive": false,
            "type": "string",
            "value": "123"
          }
        },
        "output": {
          "a": "mykeypair",
          "b": "123"
        }
      }
    ],
    "identifier": 44439671
  },
  {
    "context": [
      "Here I need to create a new output json by piping the first output to jq where StackName startsWith **monkeyman** and **bulldog** and which should look like -",
      "jq '.[] |= map(select(.StackName | startswith(\"monkeyman\"), startswith(\"bulldog\")))'"
    ],
    "utterance": "Filter StackSummaries to retain only entries where StackName starts with 'monkeyman' or 'bulldog', preserving original structure.",
    "expressions": [
      ".[] |= map(select(.StackName | startswith(\"monkeyman\") or startswith(\"bulldog\")))",
      ".StackSummaries |= map(select(.StackName | startswith(\"monkeyman\") or startswith(\"bulldog\")))"
    ],
    "data": [
      {
        "input": {
          "StackSummaries": [
            {
              "StackId": "arn:aws:213dqwqwdqwdqwdq",
              "StackName": "monkeyman",
              "CreationTime": "2017-06-06T20:52:59.728Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "Liaison API ELB cloud formation script"
            },
            {
              "StackId": "arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg",
              "StackName": "monkeyman2",
              "CreationTime": "2017-06-06T20:51:55.191Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "yoohooo instance"
            },
            {
              "StackId": "arn:aws:sdffgds444fsdfsdfgdfgfdg",
              "StackName": "starfish2",
              "CreationTime": "2017-06-06T20:51:55.191Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "helloworld instance"
            },
            {
              "StackId": "arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg",
              "StackName": "bulldog4",
              "CreationTime": "2017-06-06T20:51:55.191Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "night night instance"
            },
            {
              "StackId": "arn:aws:yhyhyhyhyhysdfgdfgfdg",
              "StackName": "carrotman",
              "CreationTime": "2017-06-06T20:51:55.191Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "surprise mo instance"
            }
          ]
        },
        "output": {
          "StackSummaries": [
            {
              "StackId": "arn:aws:213dqwqwdqwdqwdq",
              "StackName": "monkeyman",
              "CreationTime": "2017-06-06T20:52:59.728Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "Liaison API ELB cloud formation script"
            },
            {
              "StackId": "arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg",
              "StackName": "monkeyman2",
              "CreationTime": "2017-06-06T20:51:55.191Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "yoohooo instance"
            },
            {
              "StackId": "arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg",
              "StackName": "bulldog4",
              "CreationTime": "2017-06-06T20:51:55.191Z",
              "StackStatus": "CREATE_COMPLETE",
              "TemplateDescription": "night night instance"
            }
          ]
        }
      }
    ],
    "identifier": 44400002
  },
  {
    "context": [
      "... based on a server name (field `\"name\"`) I would have to collect the following info, to pass to a function:\n\n    \"Type\", \"name\", \"ip\", \"proxy\"\n\n(Note that the `\"proxy\"` info is optional)",
      "One way to retrieve the key names programmatically is using `to_entries`.  For example, given your input, this jq filter:\n\n    to_entries[]\n    | .key as $type\n    | .value[]\n    | .proxy as $proxy\n    | .server[]\n    | select(.name == \"PAPP9001\")\n    | { Type: $type, name, ip, proxy: $proxy }"
    ],
    "utterance": "Find the object with name equal to \"PAPP9001\" and return its top-level Type, name, ip, and proxy (if present).",
    "expressions": [
      "to_entries[] | .key as $type | .value[] | .proxy as $proxy | .server[] | select(.name == \"PAPP9001\") | { Type: $type, name, ip, proxy: $proxy }"
    ],
    "data": [
      {
        "input": {
          "Type1": {
            "dev": {
              "server": [
                {
                  "group": "APP1",
                  "name": "DAPP1002",
                  "ip": "10.1.1.1"
                },
                {
                  "group": "APP2",
                  "name": "DAPP2001",
                  "ip": "10.1.1.2"
                }
              ]
            },
            "qa": {
              "server": [
                {
                  "group": "APP1",
                  "name": "QAPP1002",
                  "ip": "10.1.2.1"
                },
                {
                  "group": "APP2",
                  "name": "QAPP2001",
                  "ip": "10.1.2.2"
                }
              ]
            },
            "prod": {
              "proxy": "type1.prod.proxy.mydomain.com",
              "server": [
                {
                  "group": "APP1",
                  "name": "PAPP1001",
                  "ip": "10.1.3.1"
                },
                {
                  "group": "APP1",
                  "name": "PAPP1002",
                  "ip": "10.1.3.2"
                },
                {
                  "group": "APP2",
                  "name": "PAPP2001",
                  "ip": "10.1.3.3"
                }
              ]
            }
          },
          "Type2": {
            "dev": {
              "server": [
                {
                  "group": "APP8",
                  "name": "DAPP8002",
                  "ip": "10.2.1.1"
                },
                {
                  "group": "APP9",
                  "name": "DAPP9001",
                  "ip": "10.2.1.2"
                }
              ]
            },
            "qa": {
              "server": [
                {
                  "group": "APP8",
                  "name": "QAPP8002",
                  "ip": "10.2.2.1"
                },
                {
                  "group": "APP9",
                  "name": "QAPP9001",
                  "ip": "10.2.2.2"
                }
              ]
            },
            "prod": {
              "proxy": "type2.prod.proxy.mydomain.com",
              "server": [
                {
                  "group": "APP8",
                  "name": "PAPP8001",
                  "ip": "10.2.3.1"
                },
                {
                  "group": "APP9",
                  "name": "PAPP9001",
                  "ip": "10.2.3.2"
                },
                {
                  "group": "APP9",
                  "name": "PAPP9002",
                  "ip": "10.2.3.3"
                }
              ]
            }
          }
        },
        "output": {
          "Type": "Type2",
          "name": "PAPP9001",
          "ip": "10.2.3.2",
          "proxy": "type2.prod.proxy.mydomain.com"
        }
      }
    ],
    "identifier": 44402914
  },
  {
    "context": [
      "I have following json with me ( file name sample.json)-\r\n\r\n{\r\n\t\"Prefix\": \"pg\",  \r\n\t\"fileFormat\": \"gz\",  \r\n\t\"additionalInfo\":\r\n\"\r\n {\\\"pgUsername\\\":\\\"postgres\\\",\\\"pgPassword\\\":\\\"postgres\\\",\\\"pgHostname\\\":\\\"pgmaster\\\"}\"  \r\n}",
      "expected output is `postgres`, but I am getting something like `[26]`",
      "For your modified data you can use:\r\n\r\n    $ cat data.json| jq -r '.additionalInfo' | jq '.pgPassword'\r\n    postgres",
      "Please, see a [comment][1] by @peak -- it doesn't require multiple execution of `jq`, instead he proposes to use `fromjson` builtin.",
      "Thanks to `fromjson`, there's no need to invoke jq twice:\r\n\r\n    jq -r '.additionalInfo|fromjson|.pgPassword' data.json\r\n    postgres"
    ],
    "utterance": "Extract the pgPassword field from additionalInfo, where additionalInfo is a stringified object.",
    "expressions": [
      ".additionalInfo|fromjson|.pgPassword"
    ],
    "data": [
      {
        "input": {
          "Prefix": "pg",
          "fileFormat": "gz",
          "additionalInfo": "{\\\"pgUsername\\\":\\\"postgres\\\",\\\"pgPassword\\\":\\\"postgres\\\",\\\"pgHostname\\\":\\\"pgmaster\\\"}"
        },
        "output": "postgres"
      }
    ],
    "identifier": 44459049
  },
  {
    "context": [
      "Just use a variable and save yourself the hassle:",
      "< package.json jq --arg b \"$BOO\" '. + { foo: $b }'",
      "`--arg b \"$BOO\"` creates a variable `$b` that you can use inside `jq`, without having to deal with quoting issues."
    ],
    "utterance": "Add a new key 'foo' with the value from the BOO shell variable to the top-level object.",
    "expressions": [
      ". + { foo: $b }"
    ],
    "identifier": 44516029
  },
  {
    "context": [
      "How can I convert a variable in Bash with a string list containing newlines, like this\n\ngroups=\"group_1\n    group_2\n    group_3\"\n\nto a JSON string array:\n\n{\n    [ \"group_1\", \"group_2\", \"group 3\" ]\n}\n\nIs this possible with jq?",
      "jq -ncR '[inputs]' <<< \"$groups\"",
      "jq -c -n --arg groups \"$groups\" '$groups | split(\"\\n\")'",
      "echo -n \"$groups\" | jq -cRs 'split(\"\\n\")'",
      "echo \"$groups\" | jq -R -s -c 'split(\"\\n\") | map(select(length>0))'",
      "In any case, the array can easily be incorporated into a JSON object, e.g. by extending the filter with `| {groups: .}`",
      "jq -cRs 'split(\"\\n\")[:-1]' <<< \"$groups\""
    ],
    "utterance": "Convert a Bash variable containing a newline-separated list of group names into a string array, excluding empty lines.",
    "expressions": [
      "jq -ncR '[inputs]' <<< \"$groups\"",
      "jq -c -n --arg groups \"$groups\" '$groups | split(\"\\n\")'",
      "echo -n \"$groups\" | jq -cRs 'split(\"\\n\")'",
      "echo \"$groups\" | jq -R -s -c 'split(\"\\n\") | map(select(length>0))'",
      "jq -cRs 'split(\"\\n\")[:-1]' <<< \"$groups\""
    ],
    "data": [
      {
        "input": "group_1\ngroup_2\ngroup_3",
        "output": [
          "group_1",
          "group_2",
          "group_3"
        ]
      }
    ],
    "identifier": 44477810
  },
  {
    "context": [
      "What I want to do is create an output with jq which results in the following;",
      "{\"Sway\":\"Sway1\":\"ServiceOperational\"},",
      "{\"Sway\":\"Sway2\":\"ServiceDegraded\"},",
      "{\"Yammer\":\"yammerfeatures\":\"ServiceOperational\"}",
      ".value[]\n| [.Id] + (.FeatureStatus[] | [ .FeatureName, .FeatureServiceStatus ])"
    ],
    "utterance": "Extract each Id and its associated FeatureName and FeatureServiceStatus as distinct records, preserving their parent-child relationships.",
    "expressions": [
      ".value[] | [.Id] + (.FeatureStatus[] | [ .FeatureName, .FeatureServiceStatus ])"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "FeatureStatus": [
                {
                  "FeatureName": "Sway1",
                  "FeatureServiceStatus": "ServiceOperational"
                },
                {
                  "FeatureName": "Sway2",
                  "FeatureServiceStatus": "ServiceDegraded"
                }
              ],
              "Id": "SwayEnterprise"
            },
            {
              "FeatureStatus": [
                {
                  "FeatureName": "yammerfeatures",
                  "FeatureServiceStatus": "ServiceOperational"
                }
              ],
              "Id": "yammer"
            }
          ]
        },
        "output": [
          [
            "SwayEnterprise",
            "Sway1",
            "ServiceOperational"
          ],
          [
            "SwayEnterprise",
            "Sway2",
            "ServiceDegraded"
          ],
          [
            "yammer",
            "yammerfeatures",
            "ServiceOperational"
          ]
        ]
      }
    ],
    "identifier": 44495074
  },
  {
    "context": [
      "I have input :\r\n\r\n     {\r\n            \"hosts\": [\r\n                {\r\n                    \"statistics\": [\r\n                        {\r\n                            \"timestamp\": {\r\n                                \"date\": \"2017-06-09\",\r\n                                \"time\": \"21:40:01\"\r\n                            },\r\n                            \"cpu-load\": [\r\n                                {\r\n                                    \"idle\": 99.64\r\n                                }\r\n                            ]\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ",
      "I need output :\r\n\r\n    {\r\n\r\n        \"hosts\": [\r\n            {\r\n                \"statistics\": [\r\n                    {\r\n                        \"timestamp\": \"2017-06-09 21:40:01\",\r\n                        \"cpu-load\": [\r\n                            {\r\n                                \"idle\": 99.64\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }",
      "The update operator |= should do the trick.\r\n\r\n    jq '.hosts[].statistics[].timestamp |= .date + \" \" + .time'"
    ],
    "utterance": "Convert the nested timestamp object into a single string combining the date and time fields with a space in between.",
    "expressions": [
      ".hosts[].statistics[].timestamp |= .date + \" \" + .time"
    ],
    "data": [
      {
        "input": {
          "hosts": [
            {
              "statistics": [
                {
                  "timestamp": {
                    "date": "2017-06-09",
                    "time": "21:40:01"
                  },
                  "cpu-load": [
                    {
                      "idle": 99.64
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "hosts": [
            {
              "statistics": [
                {
                  "timestamp": "2017-06-09 21:40:01",
                  "cpu-load": [
                    {
                      "idle": 99.64
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 44533087
  },
  {
    "context": [
      "I have the following simple JSON\n\n    json='[{\"k1\":\" http://url\", \"k2\":null, \"k3\":\" v3\", \"k4\":\" v4\"}]'\n\nwhat I need is:\n\n    \"http://url\",null\n\n(without a space before `v1` and `v2`)",
      "echo $json | jq -c '.[] | .k1, .k2 ' | paste -d \",\" - -\n\nHow to get rid of the space in k1 and k2 values?",
      "$ jq -c '.[] | map_values(.[1:]) | .k1,.k2' <<< \"$json\" | paste -d \",\" - -\n    \"http://url\",null",
      "jq '.[]|(.k1,.k2)|if type==\"string\" then gsub(\"^\\s+|\\s+$\";\"\") else . end' | paste -d \",\" - -\n\nWith your input, this produces \n\n    \"http://url\",null",
      "jq -r '.[]|[.k1,.k2]|map(if type==\"string\" then gsub(\"^\\s+|\\s+$\";\"\") else . end)|@csv'\n\nWith your input, this produces:\n\n    \"http://url\","
    ],
    "utterance": "Output the values of k1 and k2 from each object, removing leading and trailing whitespace from string values, and display them as a comma-separated row.",
    "expressions": [
      ".[] | (.k1, .k2) | if type==\"string\" then gsub(\"^\\s+|\\s+$\"; \"\") else . end",
      ".[] | [(.k1, .k2)] | map(if type==\"string\" then gsub(\"^\\s+|\\s+$\"; \"\") else . end) | @csv",
      ".[] | map_values(.[1:]) | .k1, .k2"
    ],
    "data": [
      {
        "input": [
          {
            "k1": " http://url",
            "k2": null,
            "k3": " v3",
            "k4": " v4"
          }
        ],
        "output": "\"http://url\",null"
      }
    ],
    "identifier": 44526740
  },
  {
    "context": [
      "Now I want to get the count array of every age for some data visualization purpose(see [demo][1]). e.g\n\n    # age data: [shCount, bjCount]\n    age: 0, data:[1, 0]\n    age: 20, data: [1, 2] \n    age: 30, data: [0, 1]\n    age: 40, data: [1, 0]\n\nIf the city does not have the age, give a default value 0. But if the city does not have the age, it will have not the related json object.",
      "So if age is 0, how to specify a default value of 0 to `BJ`?",
      "def merge:\n  reduce .[] as $x ([0,0];\n    if $x.city == \"SH\" then .[0] = $x.count else .[1] = $x.count end);\n\ngroup_by(.age)\n| map( {age: .[0].age, data: merge} )",
      "Result:\n\n    [{\"age\":0,\"data\":[1,0]},{\"age\":20,\"data\":[1,2]},{\"age\":30,\"data\":[0,1]},{\"age\":40,\"data\":[1,0]}]"
    ],
    "utterance": "Return an array where each entry gives the age and, for that age, an array of counts for each city (SH, BJ), using 0 for any city missing that age.",
    "expressions": [
      "def merge:\n  reduce .[] as $x ([0,0];\n    if $x.city == \"SH\" then .[0] = $x.count else .[1] = $x.count end);\ngroup_by(.age)\n| map( {age: .[0].age, data: merge} )"
    ],
    "data": [
      {
        "input": [
          {
            "city": "SH",
            "age": 0,
            "count": 1
          },
          {
            "city": "SH",
            "age": 20,
            "count": 1
          },
          {
            "city": "SH",
            "age": 40,
            "count": 1
          },
          {
            "city": "BJ",
            "age": 20,
            "count": 2
          },
          {
            "city": "BJ",
            "age": 30,
            "count": 1
          }
        ],
        "output": [
          {
            "age": 0,
            "data": [
              1,
              0
            ]
          },
          {
            "age": 20,
            "data": [
              1,
              2
            ]
          },
          {
            "age": 30,
            "data": [
              0,
              1
            ]
          },
          {
            "age": 40,
            "data": [
              1,
              0
            ]
          }
        ]
      }
    ],
    "identifier": 44497817
  },
  {
    "context": [
      "Arrival and departure are the data that are in Unix time formated.",
      "I experimented with built in operator \"todate\" and \"strftime\". But get only parsing Errors.",
      "Use `todateiso8601` function:",
      "jq '[].arrival |= todateiso8601 | [].departure |= todateiso8601' C:\\Import\\import_sails.json",
      "The output (for your input fragment):",
      "[",
      "  {",
      "    \"nid\": 434508,",
      "    \"title\": \"Die sch\u00f6nsten Orte unserer Welt\",",
      "    \"nights\": 121,",
      "    \"zone\": \"Weltreise\",",
      "    \"sails_nid\": 434516,",
      "    \"arrival\": \"2018-05-06T22:00:00Z\",",
      "    \"departure\": \"2018-01-05T23:00:00Z\",",
      "    \"cabintype\": \"Innenkabine\",",
      "    \"cabinid\": 379723,",
      "    \"catalogPrice\": 17879,",
      "    \"discountPrice\": 9519,",
      "    \"discountPercentage\": 0.4675876726886291,",
      "    \"currency\": \"EUR\"",
      "  },",
      "  ...",
      "]"
    ],
    "utterance": "Convert the 'arrival' and 'departure' fields from UNIX timestamps to ISO 8601 datetime strings.",
    "expressions": [
      "map(.arrival |= todateiso8601 | .departure |= todateiso8601)"
    ],
    "data": [
      {
        "input": [
          {
            "nid": 434508,
            "title": "Die sch\u00f6nsten Orte unserer Welt",
            "nights": 121,
            "zone": "Weltreise",
            "sails_nid": 434516,
            "arrival": 1525644000,
            "departure": 1515193200,
            "cabintype": "Innenkabine",
            "cabinid": 379723,
            "catalogPrice": 17879,
            "discountPrice": 9519,
            "discountPercentage": 0.4675876726886291,
            "currency": "EUR"
          },
          {
            "nid": 434508,
            "title": "Die sch\u00f6nsten Orte unserer Welt",
            "nights": 121,
            "zone": "Weltreise",
            "sails_nid": 434516,
            "arrival": 1525644000,
            "departure": 1515193200,
            "cabintype": "Innenkabine",
            "cabinid": 379730,
            "catalogPrice": 18599,
            "discountPrice": 10239,
            "discountPercentage": 0.44948653153395346,
            "currency": "EUR"
          }
        ],
        "output": [
          {
            "nid": 434508,
            "title": "Die sch\u00f6nsten Orte unserer Welt",
            "nights": 121,
            "zone": "Weltreise",
            "sails_nid": 434516,
            "arrival": "2018-05-06T22:00:00Z",
            "departure": "2018-01-05T23:00:00Z",
            "cabintype": "Innenkabine",
            "cabinid": 379723,
            "catalogPrice": 17879,
            "discountPrice": 9519,
            "discountPercentage": 0.4675876726886291,
            "currency": "EUR"
          },
          {
            "nid": 434508,
            "title": "Die sch\u00f6nsten Orte unserer Welt",
            "nights": 121,
            "zone": "Weltreise",
            "sails_nid": 434516,
            "arrival": "2018-05-06T22:00:00Z",
            "departure": "2018-01-05T23:00:00Z",
            "cabintype": "Innenkabine",
            "cabinid": 379730,
            "catalogPrice": 18599,
            "discountPrice": 10239,
            "discountPercentage": 0.44948653153395346,
            "currency": "EUR"
          }
        ]
      }
    ],
    "identifier": 44497533
  },
  {
    "context": [
      "But how do I select all of the items that are *not* in the list?",
      "How do I filter _out_ the matching items?",
      "$ echo '[\"a\",\"b\",\"c\",\"d\",\"e\"]' | jq -c '. - [\"a\",\"c\"]'\n[\"b\",\"d\",\"e\"]",
      "The problem can also be solved (in jq 1.4 and up) using `index` and `not`, e.g.\n[\"a\",\"c\"] as $blacklist\n| .[] | select( . as $in | $blacklist | index($in) | not)",
      "With jq 1.5 or later, you could also use `any` or `all`, e.g.\ndef except(blacklist):\n  map( select( . as $in | blacklist | all(. != $in) ) );",
      "since 1.6, you can use `IN` function:\n    .[] |\n    select(\n      . | IN(\"a\", \"c\") | not\n    )"
    ],
    "utterance": "Return all items from the array except those that are equal to \"a\" or \"c\".",
    "expressions": [
      ". - [\"a\",\"c\"]",
      "[\"a\",\"c\"] as $blacklist | .[] | select( . as $in | $blacklist | index($in) | not)",
      "map(select((. as $in | [\"a\",\"c\"] | all(. != $in))))",
      ".[] | select(. | IN(\"a\", \"c\") | not)",
      "map(select(. | IN(\"a\", \"c\") | not))"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c",
          "d",
          "e"
        ],
        "output": [
          "b",
          "d",
          "e"
        ]
      }
    ],
    "identifier": 44563115
  },
  {
    "context": [
      "$ cat json.txt | jq '.name'",
      "\"Google\"",
      "How can I pipe this into another command to remove the \"\"? so I get",
      "$ cat json.txt | jq '.name' | some_other_command",
      "Google",
      "Use the `-r` (or `--raw-output`) option to emit raw strings as output:",
      "jq -r '.name' <json.txt",
      "using `--raw-output` helps",
      "echo $sample| jq --raw-output '.name'",
      "Google"
    ],
    "utterance": "Extract the value of the 'name' key as plain text without double quotes.",
    "expressions": [
      "jq -r '.name'",
      "jq --raw-output '.name'"
    ],
    "data": [
      {
        "input": {
          "name": "Google"
        },
        "output": "Google"
      }
    ],
    "identifier": 44656515
  },
  {
    "context": [
      "**What it's supposed to do:**",
      "- If `liveBroadcastContent` **exists** in the input: then output it's value in the `id_status` key",
      "- If `liveBroadcastContent` **does not exist**: then output `false` in the `id_status` key",
      "     (reduce (..| select(type == \"object\" and has(\"liveBroadcastContent\"))) as $item",
      "        (false; $item | .liveBroadcastContent)) as $chanstatus",
      "     | {location:\"location\",",
      "        channel:\"channelid\",",
      "        current_id:\"vId\",",
      "        id_status:$chanstatus,",
      "        url:\"https://youtu.be/\\(\"vId\")\"}",
      "    {",
      "        location: \"location\",",
      "        channel: \"channelid\",",
      "        current_id: \"vId\",",
      "        id_status: (.liveBroadcastContent? // false),",
      "        url: \"https://youtu.be/vId\"",
      "    }"
    ],
    "utterance": "Output a fixed object where id_status is the value of liveBroadcastContent if it exists anywhere in the input; otherwise, id_status should be false.",
    "expressions": [
      "(reduce (..| select(type == \"object\" and has(\"liveBroadcastContent\"))) as $item (false; $item | .liveBroadcastContent)) as $chanstatus\n| {location:\"location\",\n   channel:\"channelid\",\n   current_id:\"vId\",\n   id_status:$chanstatus,\n   url:\"https://youtu.be/\\(\"vId\")\"}",
      "{ location: \"location\", channel: \"channelid\", current_id: \"vId\", id_status: (.liveBroadcastContent? // false), url: \"https://youtu.be/vId\" }"
    ],
    "data": [
      {
        "input": {
          "liveBroadcastContent": true
        },
        "output": {
          "location": "location",
          "channel": "channelid",
          "current_id": "vId",
          "id_status": true,
          "url": "https://youtu.be/vId"
        }
      },
      {
        "input": {},
        "output": {
          "location": "location",
          "channel": "channelid",
          "current_id": "vId",
          "id_status": false,
          "url": "https://youtu.be/vId"
        }
      }
    ],
    "identifier": 44564801
  },
  {
    "context": [
      "The first object of each array will always be a \"timestamp\" that I need but the following objects may or may not be of interest.",
      "Now I need to get jq to convert each line to an array of json objects containing the timestamp and the `data_that_I_Need`",
      "[ { \"ts\": \"2017-06-13 16:59:35,778\", \"id\": 40, \"path\": \"/1497365920809-31368-6D8E756916AE1\", \"messageAttributes\": { \"data_that_I_Need\": \"Name,1,Text,1497365975568\" } } ]",
      "select(.messageAttributes.data_that_I_Need != null) | { id   : .id, path : .path, messageAttributes: { dataThat_I_Need: .messageAttributes.data_that_I_Need } }",
      "But how can I add the \"ts\" field from the first object as a field in the output?",
      ".[0].ts as $ts | .[] | select(.messageAttributes.data_that_I_Need != null) | { ts   : $ts, id   : .id, path : .path, messageAttributes: { dataThat_I_Need: .messageAttributes.data_that_I_Need } }",
      ".[0] + (.[] | select(.messageAttributes.data_that_I_Need != null) | {id, path, messageAttributes: {dataThat_I_Need: .messageAttributes.data_that_I_Need}} )"
    ],
    "utterance": "Extract objects where messageAttributes.data_that_I_Need is present, including the ts field from the first object in each array.",
    "expressions": [
      ".[0].ts as $ts | .[] | select(.messageAttributes.data_that_I_Need != null) | { ts: $ts, id: .id, path: .path, messageAttributes: { dataThat_I_Need: .messageAttributes.data_that_I_Need } }",
      ".[0] + (.[] | select(.messageAttributes.data_that_I_Need != null) | {id, path, messageAttributes: {dataThat_I_Need: .messageAttributes.data_that_I_Need}} )"
    ],
    "data": [
      {
        "input": [
          {
            "ts": "2017-06-13 16:59:35,778"
          },
          {
            "id": 39,
            "path": "/1497365920809-31368-6D8E756916AE1",
            "messageAttributes": {
              "some_obsolete_data": "1497365975532",
              "more_obsolete_data": "20",
              "c": ""
            }
          },
          {
            "id": 40,
            "path": "/1497365920809-31368-6D8E756916AE1",
            "messageAttributes": {
              "some_obsolete_data": "some text",
              "data_that_I_Need": "Name,1,Text,1497365975568"
            }
          }
        ],
        "output": [
          {
            "ts": "2017-06-13 16:59:35,778",
            "id": 40,
            "path": "/1497365920809-31368-6D8E756916AE1",
            "messageAttributes": {
              "dataThat_I_Need": "Name,1,Text,1497365975568"
            }
          }
        ]
      }
    ],
    "identifier": 44545378
  },
  {
    "context": [
      "I want to grab the `result`, as well as `actions[2] failCount`, `actions[2] skipCount` and `actions[2] totalCount` to create a new JSON like this:\r\n\r\n    { \"result\" : \"UNSTABLE\",\"failCount\" : 1, \"skipCount\" : 14,\"totalCount\" : 222}",
      "{result} + (.actions[2] | {failCount,skipCount,totalCount})",
      ".actions[2] as $a2 |              # assign second action to a variable\n  { \"result\": .result,              # refer direct to original input when appropriate...\n    \"skipCount\": $a2.skipCount,     # ...or to that variable otherwise.\n    \"failCount\": $a2.failCount,\n    \"totalCount\": $a2.totalCount}",
      "{ result } + (.actions[] | select(has(\"failCount\")))"
    ],
    "utterance": "Extract the result field and the failCount, skipCount, and totalCount fields from the third element of actions, and construct a new object containing these values.",
    "expressions": [
      "{result} + (.actions[2] | {failCount,skipCount,totalCount})",
      ".actions[2] as $a2 | {\"result\": .result, \"skipCount\": $a2.skipCount, \"failCount\": $a2.failCount, \"totalCount\": $a2.totalCount}",
      "{ result } + (.actions[] | select(has(\"failCount\")))"
    ],
    "data": [
      {
        "input": {
          "_class": "org.jenkinsci.plugins.workflow.job.WorkflowRun",
          "actions": [
            {
              "_class": "hudson.model.CauseAction",
              "causes": [
                {
                  "_class": "jenkins.branch.BranchIndexingCause",
                  "shortDescription": "Branch indexing"
                }
              ]
            },
            {
              "_class": "hudson.model.ParametersAction",
              "parameters": [
                "..."
              ]
            },
            {
              "_class": "hudson.tasks.junit.TestResultAction",
              "failCount": 1,
              "skipCount": 14,
              "totalCount": 222,
              "urlName": "testReport"
            }
          ],
          "artifacts": [
            "..."
          ],
          "result": "UNSTABLE",
          "previousBuild": {
            "number": 98,
            "url": "<some Url>"
          }
        },
        "output": {
          "result": "UNSTABLE",
          "failCount": 1,
          "skipCount": 14,
          "totalCount": 222
        }
      }
    ],
    "identifier": 44659198
  },
  {
    "context": [
      "My goal is to combine them and keep the exact same format  - just basically stack one on top of the other without creating two lists.",
      "Why does this happen and how does one preserve the format without writing extra brackets `[]`.  How does one combine and keep only one pair of brackets around the entire file?",
      "The following invocation produces the desired result:",
      "    jq -s add input.json input.json",
      "-s (\"slurp\") option places all the top-level input JSON entities into an array, producing an array of arrays in the present case.  `add` then \"adds\" the components of this array -- `add` being polymorphic  has the effect here of concatenating the component arrays.",
      "If your jq has `inputs`, you could similarly write:",
      "    jq -n '[inputs]|add' input.json input.json",
      "or:",
      "    jq -n '[inputs[]]' input.json input.json"
    ],
    "utterance": "Combine two files containing arrays of objects into a single array containing all objects from both files in order, with no extra levels of nesting.",
    "expressions": [
      "jq -s add test.json test2.json",
      "jq -n '[inputs]|add' test.json test2.json",
      "jq -n '[inputs[]]' test.json test2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "vendor": 0,
              "startTime": 4380,
              "endTime": 4445
            },
            {
              "vendor": 0,
              "startTime": 4448,
              "endTime": 4453
            },
            {
              "vendor": 0,
              "startTime": 4696,
              "endTime": 4880
            }
          ],
          [
            {
              "vendor": 0,
              "startTime": 4380,
              "endTime": 4445
            },
            {
              "vendor": 0,
              "startTime": 4448,
              "endTime": 4453
            },
            {
              "vendor": 0,
              "startTime": 4696,
              "endTime": 4880
            }
          ]
        ],
        "output": [
          {
            "vendor": 0,
            "startTime": 4380,
            "endTime": 4445
          },
          {
            "vendor": 0,
            "startTime": 4448,
            "endTime": 4453
          },
          {
            "vendor": 0,
            "startTime": 4696,
            "endTime": 4880
          },
          {
            "vendor": 0,
            "startTime": 4380,
            "endTime": 4445
          },
          {
            "vendor": 0,
            "startTime": 4448,
            "endTime": 4453
          },
          {
            "vendor": 0,
            "startTime": 4696,
            "endTime": 4880
          }
        ]
      }
    ],
    "identifier": 44689161
  },
  {
    "context": [
      "Now, we want to select rows where the value of `author` is equal to either \"Gary\" OR \"Larry\", but no other case.",
      "I'm trying to do this via the `inside` function like so but get an error dialog:",
      "jq: error (at <stdin>:1): array ([\"Gary\",\"La...) and string (\"Gary\") cannot have their containment checked",
      "`jq 'select([.author] | inside([\"Larry\", \"Garry\", \"Jerry\"]))'`",
      "The intuition behind this approach, as stated by the user was: \"Literally your idea, only wrapping `.author` as `[.author]` to coerce it into being a single-item array so `inside()` will work on it.\"",
      "select( .author as $a | [\"Gary\", \"Larry\"] | index($a) )",
      "[\"Gary\", \"Larry\"] as $whitelist | select( .author as $a | any( $whitelist[]; . == $a) )",
      "[\"Gary\", \"Larry\"] as $whitelist | ($whitelist | map( {(.): true} ) | add) as $dictionary | inputs | select($dictionary[.author])",
      "You can build up a set of values prior to reading your input, then use the set to filter your inputs.",
      "(reduce $names[] as $name ({}; .[$name] = true)) as $set | inputs | select($set[.author])"
    ],
    "utterance": "Select all entries where author is either \"Gary\" or \"Larry\", using an efficient method that supports a large list of names.",
    "expressions": [
      "select([.author] | inside([\"Gary\", \"Larry\"]))",
      "select(.author as $a | [\"Gary\", \"Larry\"] | index($a))",
      "[\"Gary\", \"Larry\"] as $whitelist | select(.author as $a | any($whitelist[]; . == $a))",
      "[\"Gary\", \"Larry\"] as $whitelist | ($whitelist | map({(.) : true}) | add) as $dictionary | inputs | select($dictionary[.author])",
      "reduce $names[] as $name ({}; .[$name] = true) as $set | inputs | select($set[.author])"
    ],
    "data": [
      {
        "input": [
          {
            "author": "Gary",
            "text": "Blah"
          },
          {
            "author": "Larry",
            "text": "More Blah"
          },
          {
            "author": "Jerry",
            "text": "Yet more Blah"
          },
          {
            "author": "Barry",
            "text": "Even more Blah"
          },
          {
            "author": "Teri",
            "text": "Text on text on text"
          },
          {
            "author": "Bob",
            "text": "Another thing to say"
          }
        ],
        "output": [
          {
            "author": "Gary",
            "text": "Blah"
          },
          {
            "author": "Larry",
            "text": "More Blah"
          }
        ]
      }
    ],
    "identifier": 44704404
  },
  {
    "context": [
      "I want to convert it into csv as follows,\r\n\r\n    A,C,T1,1\r\n    A,F,T2,2\r\n    B,C,T3,3\r\n\r\nDescription of output: The parents keys will be printed until, I've reached the leaf child. Once I reached leaf child, print its value.",
      "paths as $path\n| {path: $path, value: getpath($path)}\n| select(.value|type == \"object\" )\n| select( [.value[]][0] | type != \"object\")\n| .path + ([.value[]])\n| @csv",
      "To avoid the quotation marks around strings, you could replace the last component of the pipeline above with:\n\n    join(\",\")",
      "[\n    tostream\n  | select(length == 2)            # e.g. [[\"A\",\"C\",\"D\"],\"T1\"]\n  | .[0][:-1] + [.[1]]             #      [\"A\",\"C\",\"T1\"]\n]\n| group_by(.[:-1])                 #    [[[\"A\",\"C\",\"T1\"],[\"A\",\"C\",1]],...\n| .[]                              #     [[\"A\",\"C\",\"T1\"],[\"A\",\"C\",1]]\n| .[0][0:2] + map(.[-1]|tostring)  #      [\"A\",\"C\",\"T1\",\"1\"]\n| join(\",\")                        #       \"A,C,T1,1\""
    ],
    "utterance": "Convert a nested object structure where parent keys are preserved and leaf values are printed as CSV rows for each object-leaf path.",
    "expressions": [
      "paths as $path\n| {path: $path, value: getpath($path)}\n| select(.value|type == \"object\" )\n| select( [.value[]][0] | type != \"object\")\n| .path + ([.value[]])\n| @csv",
      "paths as $path\n| {path: $path, value: getpath($path)}\n| select(.value|type == \"object\" )\n| select( [.value[]][0] | type != \"object\")\n| .path + ([.value[]])\n| join(\",\")",
      "[\n    tostream\n  | select(length == 2)\n  | .[0][:-1] + [.[1]]\n]\n| group_by(.[:-1])\n| .[]\n| .[0][0:2] + map(.[-1]|tostring)\n| join(\",\")"
    ],
    "data": [
      {
        "input": {
          "A": {
            "C": {
              "D": "T1",
              "E": 1
            },
            "F": {
              "D": "T2",
              "E": 2
            }
          },
          "B": {
            "C": {
              "D": "T3",
              "E": 3
            }
          }
        },
        "output": [
          "A,C,T1,1",
          "A,F,T2,2",
          "B,C,T3,3"
        ]
      }
    ],
    "identifier": 44744381
  },
  {
    "context": [
      "I\u0019m looking to match the \"keys\" from the .datatable.columns[$index1].name with the \"values\" in .datatable.data[1] and so on with each iterating index value. I\u0019m looking to get an output like the following;\n\n    [\n      {\n        \"date\": \"2012-05-18\",\n        \"close\": 38.2318,\n        \"high\": 45.0,\n        \"low\": 38.0\n      },",
      "Here\u0019s a helper function to make the solution easy to understand. It converts the input array into an object, on the assumption that `headers` is an array of strings to be used as key names:\n\ndef objectify(headers):\n  [headers, .] | transpose | map( { (.[0]): .[1] } ) | add;\n\nA solution is now straightforward:\n \n    .datatable\n    | (.columns | map(.name)) as $headers\n    | .data\n    | map( objectify($headers) )"
    ],
    "utterance": "Combine the column names from .datatable.columns[].name with each corresponding row in .datatable.data[] to produce an array of objects with named fields.",
    "expressions": [
      "def objectify(headers): [headers, .] | transpose | map({ (.[0]): .[1] }) | add; .datatable | (.columns | map(.name)) as $headers | .data | map(objectify($headers))"
    ],
    "data": [
      {
        "input": {
          "datatable": {
            "data": [
              [
                "2012-05-18",
                38.2318,
                45.0,
                38.0
              ],
              [
                "2012-05-21",
                34.03,
                36.66,
                33.0
              ],
              [
                "2012-05-22",
                31.0,
                33.59,
                30.94
              ],
              [
                "2017-06-22",
                153.4,
                154.55,
                152.91
              ],
              [
                "2017-06-23",
                155.07,
                155.2,
                152.65
              ]
            ],
            "columns": [
              {
                "name": "date",
                "type": "Date"
              },
              {
                "name": "close",
                "type": "BigDecimal(34,12)"
              },
              {
                "name": "high",
                "type": "BigDecimal(34,12)"
              },
              {
                "name": "low",
                "type": "BigDecimal(34,12)"
              }
            ]
          },
          "meta": {
            "next_cursor_id": null
          }
        },
        "output": [
          {
            "date": "2012-05-18",
            "close": 38.2318,
            "high": 45.0,
            "low": 38.0
          },
          {
            "date": "2012-05-21",
            "close": 34.03,
            "high": 36.66,
            "low": 33.0
          },
          {
            "date": "2012-05-22",
            "close": 31.0,
            "high": 33.59,
            "low": 30.94
          },
          {
            "date": "2017-06-22",
            "close": 153.4,
            "high": 154.55,
            "low": 152.91
          },
          {
            "date": "2017-06-23",
            "close": 155.07,
            "high": 155.2,
            "low": 152.65
          }
        ]
      }
    ],
    "identifier": 44752048
  },
  {
    "context": [
      "[.cruises[] | { nid: .cruise_nid, shipcategory: .ship_category, ship: .ship_title, company: .company_title, includeflight: .includes_flight, nights, waypoints: .waypoint_cities, title: .route_title}] C:\\import\\dreamlines_cruises.json > C:\\Import\\import_cruises.json",
      "Your jq filter as given (i.e. without quotation marks) looks fine, so let's assume you have successfully placed the text (hopefully formatted for readability :-) in a file, say format.jq",
      "Then you would run something like this:\n    jq -f format.jq dreamlines_cruises.json"
    ],
    "utterance": "Extract an array of cruise objects with selected fields: nid (from cruise_nid), shipcategory (from ship_category), ship (from ship_title), company (from company_title), includeflight (from includes_flight), nights, waypoints (from waypoint_cities), and title (from route_title) from the cruises property.",
    "expressions": [
      "[.cruises[] | { nid: .cruise_nid, shipcategory: .ship_category, ship: .ship_title, company: .company_title, includeflight: .includes_flight, nights, waypoints: .waypoint_cities, title: .route_title }]"
    ],
    "identifier": 44785007
  },
  {
    "context": [
      "First, I'm trying to get the maximum for each `box_id`. Just getting the maximum values is relatively straightforward with e.g. `jq '[].number_items | max`, which returns\n\n    7\n    15\n    4\n\nHowever, I would like to store this into a new JSON file, like so \u2014\n\n    [\n      {\n        \"box_id\": 1,\n        \"max_items\": 7\n      },\n      {\n        \"box_id\": 3,\n        \"max_items\": 15\n      },\n      {\n        \"box_id\": 6,\n        \"max_items\": 4\n      }\n    ]",
      "With a tiny bit of familiarity with jq, the first problem is trivial, so I won't say more than give a solution:\n\n    map( {box_id, max_items: (.number_items | max) } )"
    ],
    "utterance": "Produce an array of objects containing box_id and the maximum value from number_items for each box.",
    "expressions": [
      "map({box_id, max_items: (.number_items | max)})"
    ],
    "data": [
      {
        "input": [
          {
            "box_id": 1,
            "number_items": [
              4,
              6,
              7,
              5
            ]
          },
          {
            "box_id": 3,
            "number_items": [
              15,
              null,
              15,
              9
            ]
          },
          {
            "box_id": 6,
            "number_items": [
              2,
              4,
              0,
              1
            ]
          }
        ],
        "output": [
          {
            "box_id": 1,
            "max_items": 7
          },
          {
            "box_id": 3,
            "max_items": 15
          },
          {
            "box_id": 6,
            "max_items": 4
          }
        ]
      }
    ],
    "identifier": 44783294
  },
  {
    "context": [
      "In this JSON, I want to do the following:\n\n- Find the `DeploymentConfig` object\n- Check if it has the `env` array in the first container\n- If it does, add a new object `{\"name\": \"B_ENV\", \"value\": \"b-value\"}` in it\n- If it does not, add the `env` _array_, with the object `{\"name\": \"B_ENV\", \"value\": \"b-value\"}` in it",
      "(.items[] | select(.kind == \"DeploymentConfig\").spec.template.spec.containers[0].env) +=\n    [{name:\"B_ENV\",value:\"b-value\"}]",
      "If the array exists, it will add the new item. If not, it will create a new `env` array."
    ],
    "utterance": "Add {name: \"B_ENV\", value: \"b-value\"} to the env array of the first container in all DeploymentConfig items, creating the env array if it does not exist.",
    "expressions": [
      "(.items[] | select(.kind == \"DeploymentConfig\").spec.template.spec.containers[0].env) += [{name:\"B_ENV\",value:\"b-value\"}]"
    ],
    "data": [
      {
        "input": {
          "kind": "List",
          "apiVersion": "v1",
          "metadata": {},
          "items": [
            {
              "apiVersion": "v1",
              "kind": "Service",
              "metadata": {
                "annotations": {
                  "description": "Exposes and load balances the node.js application pods"
                },
                "name": "myapp-web"
              },
              "spec": {
                "ports": [
                  {
                    "name": "web",
                    "port": 3000,
                    "protocol": "TCP",
                    "targetPort": 3000
                  }
                ],
                "selector": {
                  "name": "myapp"
                }
              }
            },
            {
              "apiVersion": "v1",
              "kind": "Route",
              "metadata": {
                "name": "myapp-web"
              },
              "spec": {
                "host": "app.internal.io",
                "port": {
                  "targetPort": "web"
                },
                "to": {
                  "kind": "Service",
                  "name": "myapp-web"
                }
              }
            },
            {
              "apiVersion": "v1",
              "kind": "DeploymentConfig",
              "metadata": {
                "annotations": {
                  "description": "Defines how to deploy the application server"
                },
                "name": "myapp"
              },
              "spec": {
                "replicas": 1,
                "selector": {
                  "name": "myapp"
                },
                "strategy": {
                  "type": "Rolling"
                },
                "template": {
                  "metadata": {
                    "labels": {
                      "name": "myapp"
                    },
                    "name": "myapp"
                  },
                  "spec": {
                    "containers": [
                      {
                        "env": [
                          {
                            "name": "A_ENV",
                            "value": "a-value"
                          }
                        ],
                        "image": "node",
                        "name": "myapp-node",
                        "ports": [
                          {
                            "containerPort": 3000,
                            "name": "app",
                            "protocol": "TCP"
                          }
                        ]
                      }
                    ]
                  }
                },
                "triggers": [
                  {
                    "type": "ConfigChange"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "apiVersion": "v1",
            "kind": "Service",
            "metadata": {
              "annotations": {
                "description": "Exposes and load balances the node.js application pods"
              },
              "name": "myapp-web"
            },
            "spec": {
              "ports": [
                {
                  "name": "web",
                  "port": 3000,
                  "protocol": "TCP",
                  "targetPort": 3000
                }
              ],
              "selector": {
                "name": "myapp"
              }
            }
          },
          {
            "apiVersion": "v1",
            "kind": "Route",
            "metadata": {
              "name": "myapp-web"
            },
            "spec": {
              "host": "app.internal.io",
              "port": {
                "targetPort": "web"
              },
              "to": {
                "kind": "Service",
                "name": "myapp-web"
              }
            }
          },
          {
            "apiVersion": "v1",
            "kind": "DeploymentConfig",
            "metadata": {
              "annotations": {
                "description": "Defines how to deploy the application server"
              },
              "name": "myapp"
            },
            "spec": {
              "replicas": 1,
              "selector": {
                "name": "myapp"
              },
              "strategy": {
                "type": "Rolling"
              },
              "template": {
                "metadata": {
                  "labels": {
                    "name": "myapp"
                  },
                  "name": "myapp"
                },
                "spec": {
                  "containers": [
                    {
                      "env": [
                        {
                          "name": "A_ENV",
                          "value": "a-value"
                        },
                        {
                          "name": "B_ENV",
                          "value": "b-value"
                        }
                      ],
                      "image": "node",
                      "name": "myapp-node",
                      "ports": [
                        {
                          "containerPort": 3000,
                          "name": "app",
                          "protocol": "TCP"
                        }
                      ]
                    }
                  ]
                }
              },
              "triggers": [
                {
                  "type": "ConfigChange"
                }
              ]
            }
          }
        ]
      }
    ],
    "identifier": 44401246
  },
  {
    "context": [
      "But using a shell fucntion like this:\r\n\r\n    jq_add () {\r\n     eval $1=\\&quot;$(eval echo \\$$1 | $JQ --argjson q1 &quot;$(printf '&#39;\\&quot;%s\\&quot;&#39;     &quot;$2&quot;)&quot; --argjson q2 &quot;$(printf '&#39;\\&quot;%s\\&quot;&#39; &quot;$3&quot;)&quot; '&#39;.[$q1] |= .+ $q2&#39;)\\&quot;\r\n    }\r\n    \r\n    v=&#39;{&quot;a&quot;:{&quot;b&quot;:1}}&#39;\r\n    jq_add v &quot;a&quot; &quot;{c:2}&quot;\r\n    echo $v\r\n\r\nThe answer is: \r\n**jq: error (at &lt;stdin&gt;:1): object ({&quot;b&quot;:1}) and array ([&quot;{c:2}&quot;]) cannot be added**",
      "please note that `--argjson x v` expects `v` to be valid JSON: `{c:2}` is not valid JSON.",
      "function jq_add {\r\n   $JQ --argjson q1 \"$1\"  --argjson q2 \"$2\"  '.[$q1] += $q2'\r\n}",
      "v=$(echo \"$v\" | jq_add '\"a\"' '{\"c\":2}')\r\n    echo \"$v\""
    ],
    "utterance": "Add or update the contents of the key \"a\" in the data to include the object {\"c\":2}, using a shell function.",
    "expressions": [
      ".[\"a\"] += {\"c\": 2}"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": 1
          }
        },
        "output": {
          "a": {
            "b": 1,
            "c": 2
          }
        }
      }
    ],
    "identifier": 44785326
  },
  {
    "context": [
      "I want it back to the original json format:\r\n\r\n    [{\"ReferringUrl\": \"N\",\"OpenAccess\": \"0\",\"ItmId\": \"1694738780\"},{\"ReferringUrl\": \"L\",\"OpenAccess\": \"1\",\"ItmId\": \"1347809133\"}]",
      "Just use the [`--compact-output` / `-c`](https://stedolan.github.io/jq/manual/#Invokingjq) option:\r\n\r\n    cat file | jq -c",
      "(or, without feline abuse: `jq -c '.' file`)"
    ],
    "utterance": "Convert formatted, pretty-printed input to compact format with all array elements on a single line.",
    "expressions": [
      "jq -c '.'",
      "jq -c"
    ],
    "data": [
      {
        "input": [
          {
            "ReferringUrl": "N",
            "OpenAccess": "0",
            "ItmId": "1694738780"
          },
          {
            "ReferringUrl": "L",
            "OpenAccess": "1",
            "ItmId": "1347809133"
          }
        ],
        "output": "[{\"ReferringUrl\":\"N\",\"OpenAccess\":\"0\",\"ItmId\":\"1694738780\"},{\"ReferringUrl\":\"L\",\"OpenAccess\":\"1\",\"ItmId\":\"1347809133\"}]"
      }
    ],
    "identifier": 44826701
  },
  {
    "context": [
      "I would like to collect the values associated with certain keys into lists and store those lists as the values associated with those keys in a new JSON file.",
      "Can this be done using `jq`?",
      "$ jq -n '\n    [inputs[]] | group_by(.box_id)\n        | map({box_id:.[0].box_id, number_items:map(.number_items)})\n' input{1,2,3}.json",
      "produces:\n\n    [\n      {\n        \"box_id\": 1,\n        \"number_items\": [\n          4,\n          7,\n          5\n        ]\n      },\n      {\n        \"box_id\": 3,\n        \"number_items\": [\n          15,\n          15,\n          9\n        ]\n      },\n      {\n        \"box_id\": 6,\n        \"number_items\": [\n          4,\n          2,\n          0\n        ]\n      }\n    ]"
    ],
    "utterance": "Merge multiple files containing objects with box_id and number_items so that each box_id appears once and number_items contains a list of its values across all files.",
    "expressions": [
      "[inputs[]] | group_by(.box_id) | map({box_id:.[0].box_id, number_items: map(.number_items)})"
    ],
    "data": [
      {
        "input": [
          [
            {
              "box_id": 1,
              "number_items": 4
            },
            {
              "box_id": 3,
              "number_items": 15
            },
            {
              "box_id": 6,
              "number_items": 2
            }
          ],
          [
            {
              "box_id": 1,
              "number_items": 7
            },
            {
              "box_id": 3,
              "number_items": 15
            },
            {
              "box_id": 6,
              "number_items": 4
            }
          ],
          [
            {
              "box_id": 1,
              "number_items": 5
            },
            {
              "box_id": 3,
              "number_items": 9
            },
            {
              "box_id": 6,
              "number_items": 0
            }
          ]
        ],
        "output": [
          {
            "box_id": 1,
            "number_items": [
              4,
              7,
              5
            ]
          },
          {
            "box_id": 3,
            "number_items": [
              15,
              15,
              9
            ]
          },
          {
            "box_id": 6,
            "number_items": [
              2,
              4,
              0
            ]
          }
        ]
      }
    ],
    "identifier": 44737620
  },
  {
    "context": [
      "Here is my data:\n\n    {\n      \"ReferringUrl\": \"N\",\n      \"OpenAccess\": \"0\",\n      \"ItmId\": \"1694738780\"\n    }\n    {\n      \"ReferringUrl\": \"L\",\n      \"OpenAccess\": \"1\",\n      \"ItmId\": \"1347809133\"\n    }\n\nI want it to be like this: \n\n    [\n     {\n      \"ReferringUrl\": \"N\",\n      \"OpenAccess\": \"0\",\n      \"ItmId\": \"1694738780\"\n     },\n     {\n       \"ReferringUrl\": \"L\",\n       \"OpenAccess\": \"1\",\n       \"ItmId\": \"1347809133\"\n     }\n    ]",
      "Assuming the sequence of JSON objects is in a file named input.json, simply \"slurp\" it: \n\n    jq -s . input.json",
      "If the objects are spread over multiple files, say `input*.json`, you can run: `jq -s . input*.json`."
    ],
    "utterance": "Wrap multiple top-level objects into a single array.",
    "expressions": [
      "jq -s . input.json",
      "jq -s . input*.json"
    ],
    "data": [
      {
        "input": [
          "{\n  \"ReferringUrl\": \"N\",\n  \"OpenAccess\": \"0\",\n  \"ItmId\": \"1694738780\"\n}",
          "{\n  \"ReferringUrl\": \"L\",\n  \"OpenAccess\": \"1\",\n  \"ItmId\": \"1347809133\"\n}"
        ],
        "output": [
          {
            "ReferringUrl": "N",
            "OpenAccess": "0",
            "ItmId": "1694738780"
          },
          {
            "ReferringUrl": "L",
            "OpenAccess": "1",
            "ItmId": "1347809133"
          }
        ]
      }
    ],
    "identifier": 44812062
  },
  {
    "context": [
      "Perhaps you meant: {\"id\":\"changed\"}",
      "If you are indeed simply trying to change `.id`, you could write: if .id == \"clusterName\" then .id = \"changed\" else . end",
      "(.parameters[].id |= if . == \"clusterName\" then \"changed\" else . end)"
    ],
    "utterance": "Change the value of every object in the parameters array where id is \"clusterName\" to have id set to \"changed\", leaving all other parts of the file untouched.",
    "expressions": [
      ".parameters[].id |= if . == \"clusterName\" then \"changed\" else . end"
    ],
    "data": [
      {
        "input": {
          "objects": [
            {
              "connectionString": "jdbc:mysql:1.rds.amazonaws.com",
              "*password": "",
              "name": "Insights",
              "id": "DataNodeId_XAL9t",
              "type": "MySqlDataNode",
              "table": "stas",
              "username": "porta"
            }
          ],
          "parameters": [
            {
              "id": "clusterName",
              "description": "Which region Cluster name to use",
              "type": "String",
              "default": ""
            },
            {
              "id": "password",
              "description": "Password to use",
              "type": "String",
              "default": ""
            }
          ]
        },
        "output": {
          "objects": [
            {
              "connectionString": "jdbc:mysql:1.rds.amazonaws.com",
              "*password": "",
              "name": "Insights",
              "id": "DataNodeId_XAL9t",
              "type": "MySqlDataNode",
              "table": "stas",
              "username": "porta"
            }
          ],
          "parameters": [
            {
              "id": "changed",
              "description": "Which region Cluster name to use",
              "type": "String",
              "default": ""
            },
            {
              "id": "password",
              "description": "Password to use",
              "type": "String",
              "default": ""
            }
          ]
        }
      }
    ],
    "identifier": 44831738
  },
  {
    "context": [
      "I am trying to filter docker-machine's output using the following jq filter.",
      "$ docker-machine inspect default | jq '{ConfigVersion, .Driver.{MachineName, CPU, Memory}, DriverName}'",
      "jq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at <top-level>, line 1:",
      "{ConfigVersion, .Driver.{MachineName, CPU, Memory}, DriverName}",
      "Fixed it using",
      "$ docker-machine inspect default |\n  jq '{ConfigVersion,\n       Driver: (.Driver|{MachineName, CPU, Memory}),\n       DriverName}'"
    ],
    "utterance": "Select the ConfigVersion, DriverName, and only the MachineName, CPU, and Memory fields from Driver.",
    "expressions": [
      "{ConfigVersion, Driver: (.Driver|{MachineName, CPU, Memory}), DriverName}"
    ],
    "data": [
      {
        "input": {
          "ConfigVersion": 3,
          "Driver": {
            "IPAddress": "192.168.99.100",
            "MachineName": "default",
            "SSHUser": "docker",
            "SSHPort": 52314,
            "SSHKeyPath": "/Users/apatil/.docker/machine/machines/default/id_rsa",
            "StorePath": "/Users/apatil/.docker/machine",
            "SwarmMaster": false,
            "SwarmHost": "tcp://0.0.0.0:3376",
            "SwarmDiscovery": "",
            "VBoxManager": {},
            "HostInterfaces": {},
            "CPU": 2,
            "Memory": 5120,
            "DiskSize": 20000,
            "NatNicType": "82540EM",
            "Boot2DockerURL": "",
            "Boot2DockerImportVM": "",
            "HostDNSResolver": false,
            "HostOnlyCIDR": "192.168.99.1/24",
            "HostOnlyNicType": "82540EM",
            "HostOnlyPromiscMode": "deny",
            "UIType": "headless",
            "HostOnlyNoDHCP": false,
            "NoShare": false,
            "DNSProxy": true,
            "NoVTXCheck": false,
            "ShareFolder": ""
          },
          "DriverName": "virtualbox",
          "HostOptions": {
            "Driver": "",
            "Memory": 0,
            "Disk": 0,
            "EngineOptions": {
              "ArbitraryFlags": [],
              "Dns": null,
              "GraphDir": "",
              "Env": [],
              "Ipv6": false,
              "InsecureRegistry": [],
              "Labels": [],
              "LogLevel": "",
              "StorageDriver": "",
              "SelinuxEnabled": false,
              "TlsVerify": true,
              "RegistryMirror": [],
              "InstallURL": "https://get.docker.com"
            },
            "SwarmOptions": {
              "IsSwarm": false,
              "Address": "",
              "Discovery": "",
              "Agent": false,
              "Master": false,
              "Host": "tcp://0.0.0.0:3376",
              "Image": "swarm:latest",
              "Strategy": "spread",
              "Heartbeat": 0,
              "Overcommit": 0,
              "ArbitraryFlags": [],
              "ArbitraryJoinFlags": [],
              "Env": null,
              "IsExperimental": false
            },
            "AuthOptions": {
              "CertDir": "/Users/apatil/.docker/machine/certs",
              "CaCertPath": "/Users/apatil/.docker/machine/certs/ca.pem",
              "CaPrivateKeyPath": "/Users/apatil/.docker/machine/certs/ca-key.pem",
              "CaCertRemotePath": "",
              "ServerCertPath": "/Users/apatil/.docker/machine/machines/default/server.pem",
              "ServerKeyPath": "/Users/apatil/.docker/machine/machines/default/server-key.pem",
              "ClientKeyPath": "/Users/apatil/.docker/machine/certs/key.pem",
              "ServerCertRemotePath": "",
              "ServerKeyRemotePath": "",
              "ClientCertPath": "/Users/apatil/.docker/machine/certs/cert.pem",
              "ServerCertSANs": [],
              "StorePath": "/Users/apatil/.docker/machine/machines/default"
            }
          },
          "Name": "default"
        },
        "output": {
          "ConfigVersion": 3,
          "Driver": {
            "MachineName": "default",
            "CPU": 2,
            "Memory": 5120
          },
          "DriverName": "virtualbox"
        }
      }
    ],
    "identifier": 44786396
  },
  {
    "context": [
      "I want to update the model.json file with the bosh.json file so it looks like this:\r\n\r\n    {\r\n      \"trusted_certificates\": \"my-trusted-certs\",\r\n      \"vm_password_type\": \"generate\"\r\n    }",
      "jq --argfile bosh bosh.json 'with_entries( \r\n             if $bosh[.key] then .value = $bosh[.key] else . end)' model.json",
      "with_entries(.key as $k | if $bosh|has($k) then .value = $bosh[$k] else . end )"
    ],
    "utterance": "Update only the keys present in both files in the target, so that any overlapping keys (like 'trusted_certificates') are overwritten by the source value, without adding new keys from the source.",
    "expressions": [
      "jq --argfile bosh bosh.json 'with_entries( if $bosh[.key] then .value = $bosh[.key] else . end )' model.json",
      "jq --argfile bosh bosh.json 'with_entries(.key as $k | if $bosh|has($k) then .value = $bosh[$k] else . end)' model.json"
    ],
    "data": [
      {
        "input": {
          "trusted_certificates": "vault-supplied-value",
          "vm_password_type": "generate"
        },
        "output": {
          "trusted_certificates": "my-trusted-certs",
          "vm_password_type": "generate"
        }
      }
    ],
    "identifier": 44855206
  },
  {
    "context": [
      "I want use jq to extract the object that have \"Origin\": \"Alert\" in its element \"Items\".",
      "How to do it by using jq? I have tried several ways but most of them will just return an array with all children objects that include \"Origin\":\"Alert\". I need these children objects still keep there structure, because I need to know which of them happened together and which of them happened separately.",
      "The filter:\n\n    .[] | select( any(.Items[]; .Origin == \"Alert\"))\n\nproduces the first-mentioned admissible result.",
      "If your jq does not have `any/2` then ... you could use the following ... filter instead:\n\n    .[] | select( .Items | map(.Origin) | index(\"Alert\"))",
      "Or:\n\n    .[] | select(reduce .Items[] as $item (false; . or ($item | .Origin == \"Alert\")))"
    ],
    "utterance": "Extract each top-level object whose Items array contains at least one element with Origin equal to Alert, returning the full object structure.",
    "expressions": [
      ".[] | select(any(.Items[]; .Origin == \"Alert\"))",
      ".[] | select(.Items | map(.Origin) | index(\"Alert\"))",
      ".[] | select(reduce .Items[] as $item (false; . or ($item | .Origin == \"Alert\")))"
    ],
    "data": [
      {
        "input": [
          {
            "time": "2017-06-10 00:00:48-0400,317",
            "UserInfo": {
              "AppId": "ONE_SEARCH",
              "UsageGroupId": "92600"
            },
            "Items": [
              {
                "PublicationCode": "",
                "OpenUrlRefId": "",
                "ReferringUrl": "N",
                "OpenAccess": "0",
                "ItmId": "1328515516"
              }
            ]
          },
          {
            "time": "2017-06-10 00:00:48-0400,548",
            "UserInfo": {
              "AppId": "DIALOG",
              "UsageGroupId": "1195735"
            },
            "Items": [
              {
                "Origin": "Alert",
                "PublicationCode": "",
                "NumberOfCopies": 1,
                "ItmId": "1907446549"
              },
              {
                "Origin": "Alert",
                "PublicationCode": "",
                "NumberOfCopies": 1,
                "ItmId": "1907446950"
              }
            ]
          }
        ],
        "output": {
          "time": "2017-06-10 00:00:48-0400,548",
          "UserInfo": {
            "AppId": "DIALOG",
            "UsageGroupId": "1195735"
          },
          "Items": [
            {
              "Origin": "Alert",
              "PublicationCode": "",
              "NumberOfCopies": 1,
              "ItmId": "1907446549"
            },
            {
              "Origin": "Alert",
              "PublicationCode": "",
              "NumberOfCopies": 1,
              "ItmId": "1907446950"
            }
          ]
        }
      }
    ],
    "identifier": 44832475
  },
  {
    "context": [
      "I\u0019d like to use `jq` to do a left join on these two objects in an array by using the `jq` JOIN operator:",
      "Like any join, I need to iterate over the rows in the first object and merge with rows found in the second object based on the `id` column.",
      "If your jq has `JOIN/4`, then it can be used to implement `left_join/1` as follows:",
      "def left_join(key):\n  map(INDEX(key)) \n  | [ JOIN( .[1]; .[0][]; key; add) ] ;",
      "map(toOO) | left_join(.id) | toDB"
    ],
    "utterance": "Combine two tabular objects into one by left joining on the 'id' field, resulting in one table with columns 'id', 'name', 'sex', 'age' and merged rows.",
    "expressions": [
      "map(toOO) | left_join(.id) | toDB",
      "def left_join(key):\n  map(INDEX(key)) \n  | [ JOIN( .[1]; .[0][]; key; add) ] ;"
    ],
    "data": [
      {
        "input": [
          {
            "type": "spreadsheet",
            "rows": [
              [
                "1",
                "Ben",
                "male"
              ],
              [
                "2",
                "Cathy",
                "female"
              ]
            ],
            "columns": [
              "id",
              "name",
              "sex"
            ]
          },
          {
            "type": "spreadsheet",
            "rows": [
              [
                "1",
                "25"
              ],
              [
                "2",
                "28"
              ]
            ],
            "columns": [
              "id",
              "age"
            ]
          }
        ],
        "output": {
          "columns": [
            "id",
            "name",
            "sex",
            "age"
          ],
          "rows": [
            [
              "1",
              "Ben",
              "male",
              "25"
            ],
            [
              "2",
              "Cathy",
              "female",
              "28"
            ]
          ]
        }
      }
    ],
    "identifier": 44856098
  },
  {
    "context": [
      "I need to transform this input into an unnested object using `jq`.",
      "The output should look like this:",
      "{\n    \"group1-permission-address\": \"test1\",\n    \"group1-permission-others\": \"test2\",\n    ... (etc)\n}",
      "here's one map-oriented solution:",
      "to_entries\n| map( .key as $key\n       | .value\n       | to_entries\n       | map ( { ($key + \"-\" + .key): .value } ) | add ) | add",
      "Here's another, that works for arbitrarily-deeply nested JSON objects and arrays:",
      "[paths(scalars) as $path | { ($path|join(\"-\")): getpath($path) }] | add\n"
    ],
    "utterance": "Flatten a nested object so that each scalar value is mapped to a key formed by joining parent keys with dashes.",
    "expressions": [
      "to_entries | map( .key as $key | .value | to_entries | map ( { ($key + \"-\" + .key): .value } ) | add ) | add",
      "[paths(scalars) as $path | { ($path|join(\"-\")): getpath($path) }] | add"
    ],
    "data": [
      {
        "input": {
          "group1-permission": {
            "address": "test1",
            "others": "test2",
            "packet-capture": "test3",
            "policy": "test4",
            "schedule": "test5",
            "service": "test6"
          },
          "group2-permission": {
            "config": "none",
            "data-access": "none",
            "report-access": "none",
            "threat-weight": "none"
          },
          "group3-permission": {
            "antivirus": "none",
            "application-control": "none",
            "casi": "none",
            "data-loss-prevention": "none",
            "dnsfilter": "none",
            "icap": "none",
            "ips": "none",
            "spamfilter": "none",
            "voip": "none",
            "waf": "none",
            "webfilter": "none"
          }
        },
        "output": {
          "group1-permission-address": "test1",
          "group1-permission-others": "test2",
          "group1-permission-packet-capture": "test3",
          "group1-permission-policy": "test4",
          "group1-permission-schedule": "test5",
          "group1-permission-service": "test6",
          "group2-permission-config": "none",
          "group2-permission-data-access": "none",
          "group2-permission-report-access": "none",
          "group2-permission-threat-weight": "none",
          "group3-permission-antivirus": "none",
          "group3-permission-application-control": "none",
          "group3-permission-casi": "none",
          "group3-permission-data-loss-prevention": "none",
          "group3-permission-dnsfilter": "none",
          "group3-permission-icap": "none",
          "group3-permission-ips": "none",
          "group3-permission-spamfilter": "none",
          "group3-permission-voip": "none",
          "group3-permission-waf": "none",
          "group3-permission-webfilter": "none"
        }
      }
    ],
    "identifier": 44836049
  },
  {
    "context": [
      "I have two files:",
      "aws.json:\n{\n  \"access_key_id\": \"MYSECRETKEYID\",\n  \"secret_access_key\": \"mysecretaccesskey\"\n}",
      "model.json:\n{\n    \"access_key_id\": \"FREDSACCESSKEY\",\n    \"secret_access_key\": \"fredssecretaccesskey\",\n    \"ntp_servers_string\": \"1.2.3.4, 5.6.7.8\",\n    \"metrics_ip\": null,\n    \"pagerduty_enabled\": false,\n    \"blobstore_type\": \"s3\",\n    \"s3_blobstore_options\": {\n        \"endpoint\": \"https://s3.amazonaws.com\",\n        \"bucket_name\": \"s3-mybucket\",\n        \"access_key_id\": \"vault-supplied-key\",\n        \"secret_access_key\": \"vault-supplied-key\",\n        \"signature_version\": \"4\",\n        \"region\": \"us-east-1\"\n    },\n    \"database_type\": \"external\"\n}",
      "and I would like to use jq to update a couple of values in the s3_blobstore_options key...",
      "Anyone know how to tell jq that I want to update the lower-level keys pairs, and not touch the upper level ones (i.e. `FREDSACCESSKEY`)?",
      "You could simply run:\n\n    jq --argfile aws aws.json '.s3_blobstore_options += $aws' model.json"
    ],
    "utterance": "Update the access_key_id and secret_access_key fields inside the s3_blobstore_options object using values from another file, without modifying the top-level fields.",
    "expressions": [
      ".s3_blobstore_options += $aws"
    ],
    "data": [
      {
        "input": {
          "aws.json": {
            "access_key_id": "MYSECRETKEYID",
            "secret_access_key": "mysecretaccesskey"
          },
          "model.json": {
            "access_key_id": "FREDSACCESSKEY",
            "secret_access_key": "fredssecretaccesskey",
            "ntp_servers_string": "1.2.3.4, 5.6.7.8",
            "metrics_ip": null,
            "pagerduty_enabled": false,
            "blobstore_type": "s3",
            "s3_blobstore_options": {
              "endpoint": "https://s3.amazonaws.com",
              "bucket_name": "s3-mybucket",
              "access_key_id": "vault-supplied-key",
              "secret_access_key": "vault-supplied-key",
              "signature_version": "4",
              "region": "us-east-1"
            },
            "database_type": "external"
          }
        },
        "output": {
          "access_key_id": "FREDSACCESSKEY",
          "secret_access_key": "fredssecretaccesskey",
          "ntp_servers_string": "1.2.3.4, 5.6.7.8",
          "metrics_ip": null,
          "pagerduty_enabled": false,
          "blobstore_type": "s3",
          "s3_blobstore_options": {
            "endpoint": "https://s3.amazonaws.com",
            "bucket_name": "s3-mybucket",
            "access_key_id": "MYSECRETKEYID",
            "secret_access_key": "mysecretaccesskey",
            "signature_version": "4",
            "region": "us-east-1"
          },
          "database_type": "external"
        }
      }
    ],
    "identifier": 44838619
  },
  {
    "context": [
      "If the json is a array I need to get the first element or if it's not I need just that element!",
      "You can use `.[0]` to return the first array item :",
      "echo \"$word\" | jq 'if type==\"array\" then .[0] else . end'"
    ],
    "utterance": "Return the first element if the input is an array, otherwise return the input value.",
    "expressions": [
      "if type==\"array\" then .[0] else . end"
    ],
    "data": [
      {
        "input": [
          0,
          1
        ],
        "output": 0
      },
      {
        "input": 42,
        "output": 42
      }
    ],
    "identifier": 44876522
  },
  {
    "context": [
      "I wish to derive a third array containing items that occur in the first array but not the second:",
      "How can I achieve this using `jq`? ",
      "the - operator can be used on arrays to remove all occurrences of the second array\u2019s elements from the first array.",
      "jq '{ \"enabled_zones\": (.zones - .disabled_zones) }' data.json"
    ],
    "utterance": "Create an array containing items from zones that do not appear in disabled_zones.",
    "expressions": [
      "{ \"enabled_zones\": (.zones - .disabled_zones) }"
    ],
    "data": [
      {
        "input": {
          "zones": [
            "dev01",
            "dev02",
            "dev03",
            "dev04",
            "dev05",
            "dev06",
            "dev07",
            "dev08",
            "dev09",
            "dev10",
            "dev11",
            "dev12",
            "dev13",
            "dev14",
            "dev15",
            "dev16",
            "dev17",
            "dev18",
            "dev19",
            "dev20"
          ],
          "disabled_zones": [
            "dev01",
            "dev05",
            "dev06",
            "dev08",
            "dev10",
            "dev11",
            "dev12",
            "dev13",
            "dev14",
            "dev15",
            "dev16",
            "dev17",
            "dev18",
            "dev19",
            "dev20"
          ]
        },
        "output": {
          "enabled_zones": [
            "dev02",
            "dev03",
            "dev04",
            "dev07",
            "dev09"
          ]
        }
      }
    ],
    "identifier": 44856484
  },
  {
    "context": [
      "Here is two sample lines : \r\n\r\n    -21.3214077;55.4851413;Ruizia cordata\r\n    -21.3213078;55.4849803;Cossinia pinnata",
      "I would like to get something like : \r\n\r\n    &quot;occurrences&quot;: [\r\n                     {\r\n    \t\t\t\t&quot;position&quot;: [-21.3214077, 55.4851413],\r\n    \t\t\t\t&quot;taxo&quot;: {\r\n    \t\t\t\t\t&quot;espece&quot;: &quot;Ruizia cordata&quot;\r\n                     },\r\n                     ...\r\n                 }]",
      "The right tool for this job is [`jq`](https://stedolan.github.io/jq/manual/).",
      "jq -Rsn '\r\n  {\"occurrences\":\r\n    [inputs\r\n     | . / \"\\n\"\r\n     | (.[] | select(length > 0) | . / \";\") as $input\r\n     | {\"position\": [$input[0], $input[1]], \"taxo\": {\"espece\": $input[2]}}]}\r\n' <se.csv",
      "emits, given your input:\r\n\r\n    {\r\n      \"occurences\": [\r\n        {\r\n          \"position\": [\r\n            \"-21.3214077\",\r\n            \"55.4851413\"\r\n          ],\r\n          \"taxo\": {\r\n            \"espece\": \"Ruizia cordata\"\r\n          }\r\n        },\r\n        {\r\n          \"position\": [\r\n            \"-21.3213078\",\r\n            \"55.4849803\"\r\n          ],\r\n          \"taxo\": {\r\n            \"espece\": \"Cossinia pinnata\"\r\n          }\r\n        }\r\n      ]\r\n    }",
      "Here in any case is a solution using `inputs`.  This solution is also variable-free.\r\n\r\n    {\"occurrences\":\r\n      [inputs\r\n       | select(length > 0)\r\n       | . / \";\"\r\n       | {\"position\": [.[0], .[1]], \r\n          \"taxo\": {\"espece\": .[2]}} ]}",
      "It also uses JQ, but a bit different approach using `split()` and `map()`.\r\n\r\n    jq --slurp --raw-input \\\r\n       'split(\"\\n\") | .[1:] | map(split(\";\")) |\r\n          map({\r\n             \"position\": [.[0], .[1]],\r\n             \"taxo\": {\r\n                 \"espece\": .[2]\r\n              }\r\n          })' \\\r\n      input.csv > output.json\r\n"
    ],
    "utterance": "Produce an object with a key 'occurrences' mapped to an array of objects, each with a 'position' array of two numbers and a nested 'taxo' object with an 'espece' field, using input lines separated by semicolons where the first two columns are numbers and the third is a string.",
    "expressions": [
      "jq -Rsn '{\"occurrences\": [inputs | . / \"\\n\" | (.[] | select(length > 0) | . / \";\") as $input | {\"position\": [$input[0], $input[1]], \"taxo\": {\"espece\": $input[2]}}]}' <se.csv",
      "{ \"occurrences\": [inputs | select(length > 0) | . / \";\" | {\"position\": [.[0], .[1]], \"taxo\": {\"espece\": .[2]}} ] }",
      "jq --slurp --raw-input 'split(\"\\n\") | .[1:] | map(split(\";\")) | map({\"position\": [.[0], .[1]], \"taxo\": { \"espece\": .[2] }})' input.csv"
    ],
    "data": [
      {
        "input": "-21.3214077;55.4851413;Ruizia cordata\n-21.3213078;55.4849803;Cossinia pinnata\n",
        "output": {
          "occurrences": [
            {
              "position": [
                "-21.3214077",
                "55.4851413"
              ],
              "taxo": {
                "espece": "Ruizia cordata"
              }
            },
            {
              "position": [
                "-21.3213078",
                "55.4849803"
              ],
              "taxo": {
                "espece": "Cossinia pinnata"
              }
            }
          ]
        }
      }
    ],
    "identifier": 44780761
  },
  {
    "context": [
      "value=$(curl -X GET curl -X GET https://apitest.onkore.com/onkore/api/v1/storeCategories | jq '[2] | ._id')",
      "$ value=$(curl -X GET https://apitest.onkore.com/onkore/api/v1/storeCategories | jq '[2] | ._id')",
      "echo \"$value\"",
      "\"59178d2a4ca53714085a0903\"",
      "P.S. You might want to use the -r command-line option of jq."
    ],
    "utterance": "Assign the _id value of the third element in the response to a shell variable.",
    "expressions": [
      "jq '.[2] | ._id'",
      "jq -r '.[2] | ._id'"
    ],
    "identifier": 44892244
  },
  {
    "context": [
      "I want to extract it into something like\n\n      [\n       1499150456,\n       1499150516,\n       1499150576\n      ]\n      [\n       76.00,\n       16.20,\n       25.30\n      ]",
      "The following filter produces the output exactly as described:\n\n    map(select(.time))\n    | map(.time), map(.data.power.current)\n\nThis is parsed as map(...) | ( map(...), map(...) ), thus resulting in a stream consisting of two JSON arrays."
    ],
    "utterance": "Extract two arrays: one containing all non-null 'time' values and one containing all corresponding 'power.current' values from the objects, skipping empty objects.",
    "expressions": [
      "map(select(.time)) | map(.time), map(.data.power.current)"
    ],
    "data": [
      {
        "input": [
          {
            "time": 1499150456,
            "data": {
              "power": {
                "bus": 3.88,
                "shunt": 6.98,
                "load": 3.89,
                "current": 76.0
              },
              "light": {
                "light": 21
              }
            }
          },
          {
            "time": 1499150516,
            "data": {
              "power": {
                "bus": 3.93,
                "shunt": 1.67,
                "load": 3.93,
                "current": 16.2
              },
              "light": {
                "light": 21
              }
            }
          },
          {
            "time": 1499150576,
            "data": {
              "power": {
                "bus": 3.92,
                "shunt": 5.58,
                "load": 3.93,
                "current": 25.3
              },
              "light": {
                "light": 21
              }
            }
          },
          {}
        ],
        "output": [
          [
            1499150456,
            1499150516,
            1499150576
          ],
          [
            76.0,
            16.2,
            25.3
          ]
        ]
      }
    ],
    "identifier": 44898870
  },
  {
    "context": [
      "I would like to convert an associative array in bash to a JSON hash/dict. I would prefer to use JQ to do this as it is already a dependency and I can rely on it to produce well formed json.",
      "echo 'desired output using jq: { \"foo\": 1, \"bar\": 2, \"baz\": 3 }'",
      "for i in \"${!dict[@]}\"; do echo \"$i\"; echo \"${dict[$i]}\"; done | jq -n -R 'reduce inputs as $i ({}; . + { ($i): (input|(tonumber? // .)) })'",
      "for i in \"${!dict[@]}\"; do echo \"\\\"$i\\\"\"; echo \"${dict[$i]}\"; done | jq -n 'reduce inputs as $i ({}; . + { ($i): input })'",
      "declare -A dict=( [$'foo\\naha']=$'a\\nb' [bar]=2 [baz]=$'{\"x\":0}' )\nfor key in \"${!dict[@]}\"; do printf '%s\\0%s\\0' \"$key\" \"${dict[$key]}\"; done |\njq -Rs '\n  split(\"\\u0000\")\n  | . as $a\n  | reduce range(0; length/2) as $i \n      ({}; . + {($a[2*$i]): ($a[2*$i + 1]|fromjson? // .)})'",
      "jq -n '[$ARGS.positional | _nwise(2) | {(.[0]): .[1]}] | add' --args \"${dict[@]@k}\"",
      "a2j='$ARGS.positional | [.[:$n], .[$n:]] | transpose | map({ (first): last }) | add';\njq -nc \"$a2j\" --argjson n ${#d[@]} --args \"${!d[@]}\" \"${d[@]}\""
    ],
    "utterance": "Combine bash associative array keys and values into a single object so that each key maps to its corresponding value.",
    "expressions": [
      "for i in \"${!dict[@]}\"; do echo \"$i\"; echo \"${dict[$i]}\"; done | jq -n -R 'reduce inputs as $i ({}; . + { ($i): (input|(tonumber? // .)) })'",
      "for i in \"${!dict[@]}\"; do echo \"\\\"$i\\\"\"; echo \"${dict[$i]}\"; done | jq -n 'reduce inputs as $i ({}; . + { ($i): input })'",
      "for key in \"${!dict[@]}\"; do printf '%s\\0%s\\0' \"$key\" \"${dict[$key]}\"; done | jq -Rs '\n  split(\"\\u0000\")\n  | . as $a\n  | reduce range(0; length/2) as $i \n      ({}; . + {($a[2*$i]): ($a[2*$i + 1]|fromjson? // .)})'",
      "jq -n '[$ARGS.positional | _nwise(2) | {(.[0]): .[1]}] | add' --args \"${dict[@]@k}\"",
      "jq -nc '$ARGS.positional | [.[:$n], .[$n:]] | transpose | map({ (first): last }) | add' --argjson n ${#d[@]} --args \"${!d[@]}\" \"${d[@]}\""
    ],
    "data": [
      {
        "input": {
          "dict": {
            "foo": 1,
            "bar": 2,
            "baz": 3
          }
        },
        "output": {
          "foo": 1,
          "bar": 2,
          "baz": 3
        }
      },
      {
        "input": {
          "dict": {
            "foo\naha": "a\nb",
            "bar": 2,
            "baz": "{\"x\":0}"
          }
        },
        "output": {
          "foo\naha": "a\nb",
          "bar": 2,
          "baz": {
            "x": 0
          }
        }
      }
    ],
    "identifier": 44792241
  },
  {
    "context": [
      "Given this data I want to match the \"username\"s in the body with \"meta.input\" and if there is a match return/print related id.",
      "jq '.meta.input as $meta | .body[] | select(.username == $meta).id' input.json",
      "The output:",
      "\"4444\""
    ],
    "utterance": "Find and return the id of the object in body where username matches the value of meta.input.",
    "expressions": [
      ".meta.input as $meta | .body[] | select(.username == $meta).id"
    ],
    "data": [
      {
        "input": {
          "body": [
            {
              "username": "name1",
              "id": "4444"
            },
            {
              "username": "name2",
              "id": "5555"
            }
          ],
          "meta": {
            "input": "name1"
          }
        },
        "output": "4444"
      }
    ],
    "identifier": 44947370
  },
  {
    "context": [
      "I have this bash script that connects to a web service periodically to check this response. {\"status\":1,\"pin\":4}",
      "I am using jq and i was able to get the values that i need using ... echo ${foo} | jq '.status' ... echo ${foo} | jq '.pin'",
      "problem is when i try to pass the value to a variable and use them it doesn't work",
      "status = `${foo} | jq '.status'` ... pin = `${foo} | jq '.pin'` ... the error says ... status: command not found",
      "Here is an illustration of how you can achieve what you want using bash and jq:\n\n    foo='{\"status\": \"S\", \"pin\": \"P\"}'\n    status=$(jq .status <<< ${foo})\n    pin=$(jq .pin  <<< ${foo})",
      "IFS=$'\\t' read status pin < <(jq -r '[.status,.pin]|@tsv' <<< ${foo})"
    ],
    "utterance": "Extract the values of the fields 'status' and 'pin' from an object and assign them to bash variables.",
    "expressions": [
      "status=$(jq .status <<< ${foo})",
      "pin=$(jq .pin <<< ${foo})",
      "IFS=$'\\t' read status pin < <(jq -r '[.status,.pin]|@tsv' <<< ${foo})"
    ],
    "data": [
      {
        "input": {
          "status": 1,
          "pin": 4
        },
        "output": {
          "status": 1,
          "pin": 4
        }
      }
    ],
    "identifier": 44910010
  },
  {
    "context": [
      "let's say I want to extract `shifts` from say, first such a key. I am not interested in extracting by particular date as that would be easy as specifying that date as a key, but rather selecting from the whole set, one of them or range, by numeric index, once obtained those keys.",
      "when specific key by index needed, say 4th in row:",
      "jq '.[] | keys_unsorted[3] as $k | \"\\($k), \\(.[$k].shifts | length)\"'"
    ],
    "utterance": "Get the shifts for the fourth key in the object, where the key is a date of unknown value.",
    "expressions": [
      ".[] | keys_unsorted[3] as $k | .[$k].shifts",
      ".data | keys_unsorted[3] as $k | .[$k].shifts"
    ],
    "data": [
      {
        "input": {
          "data": {
            "2017-06-20": {
              "shifts": [
                {
                  "id": 24,
                  "shift_request_id": 24,
                  "created_at": "2017-06-27 15:10:50",
                  "updated_at": "2017-06-27 15:10:50"
                },
                {
                  "id": 38,
                  "shift_request_id": 38,
                  "created_at": "2017-06-27 15:10:50",
                  "updated_at": "2017-06-27 15:10:50"
                },
                {
                  "id": 85,
                  "shift_request_id": 85,
                  "created_at": "2017-06-27 15:10:51",
                  "updated_at": "2017-06-27 15:10:51"
                }
              ]
            },
            "2017-06-21": {
              "shifts": [
                {
                  "id": 26,
                  "shift_request_id": 26,
                  "created_at": "2017-06-27 15:10:50",
                  "updated_at": "2017-06-27 15:10:50"
                },
                {
                  "id": 28,
                  "shift_request_id": 28,
                  "created_at": "2017-06-27 15:10:50",
                  "updated_at": "2017-06-27 15:10:50"
                },
                {
                  "id": 88,
                  "shift_request_id": 88,
                  "created_at": "2017-06-27 15:10:51",
                  "updated_at": "2017-06-27 15:10:51"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 44903686
  },
  {
    "context": [
      "With the jq command i got a lot of duplicates (with the attached file i got around 3146 objects, expected objects are arround 250). I tried to Change the jq command to avoid the duplicates but had no 'luck' on that.",
      "The json files contains a variable amount of sails (10 in these case), while each sail has a variable amount of cabins (25 in this case). Any tips how i can realize that?",
      "This is probably what you're looking for:\r\n\r\n    [{nid, title, nights, company: .operator.shortTitle, zone: .zones[0].title} \r\n     + (.sails[] | ({ sails_nid: .nid, arrival, departure } +\r\n                    (.cabins[] | { cabinname: .cabinType.title,\r\n    \t\t                       cabintype: .cabinType.kindName,\r\n    \t\t\t                   cabinnid: .cabinType.nid,\r\n    \t\t\t                   catalogPrice,\r\n    \t\t\t                   discountPrice,\r\n    \t\t\t                   discountPercentage,\r\n    \t\t\t                   currency } ))) ]"
    ],
    "utterance": "Produce one flattened object for each cabin within each sail, including tour-level details, sail details, and cabin details, without duplication.",
    "expressions": [
      "[{nid, title, nights, company: .operator.shortTitle, zone: .zones[0].title} + (.sails[] | ({ sails_nid: .nid, arrival, departure } + (.cabins[] | { cabinname: .cabinType.title, cabintype: .cabinType.kindName, cabinnid: .cabinType.nid, catalogPrice, discountPrice, discountPercentage, currency })))]"
    ],
    "identifier": 44929627
  },
  {
    "context": [
      "I have more than 100 Auto Scaling Groups.",
      "I\u2019d like to be able to search my Auto Scaling groups based on a regex of the AutoScalingGroupName and return the AutoScalingGroupARN(s) (if exists).",
      "And am only interested in `AutoScalingGroupName` matching `/abc-app.+/`, I\u2019d want the output of:",
      "{\n    \"results\": [\n         {\n            \"AutoScalingGroupARN\": \"...\",\n            \"AutoScalingGroupName\": \"abc-app-dev-as-1IZQABPFDAV2A\"\n        },\n        {\n            \"AutoScalingGroupARN\": \"...\",\n            \"AutoScalingGroupName\": \"abc-app-prod-as-1IZQABPFDAV2A\"\n        }\n    ]\n}",
      "\"If you want both the Name and ARN, then just grab them both, e.g.:",
      ".AutoScalingGroups[]\n | select(.AutoScalingGroupName | test(\"group\"))\n | {AutoScalingGroupName, AutoScalingGroupARN}\""
    ],
    "utterance": "Find all Auto Scaling Groups where the name matches the pattern 'abc-app.+', returning both their names and ARNs.",
    "expressions": [
      ".AutoScalingGroups[] | select(.AutoScalingGroupName | test(\"abc-app.+\")) | {AutoScalingGroupName, AutoScalingGroupARN}",
      "{results: [.AutoScalingGroups[] | select(.AutoScalingGroupName | test(\"abc-app.+\")) | {AutoScalingGroupName, AutoScalingGroupARN}]}"
    ],
    "data": [
      {
        "input": {
          "AutoScalingGroups": [
            {
              "AutoScalingGroupARN": "arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:208e9fe9-3a9b-4f30-9b47-855f4a7ee671:autoScalingGroupName/abc-app-dev-as-1IZQABPFDAV2A",
              "AutoScalingGroupName": "abc-app-dev-as-1IZQABPFDAV2A",
              "...": "more output"
            },
            {
              "AutoScalingGroupARN": "arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:c6463f9a-7fa1-41de-a39b-7996d2b8cbb1:autoScalingGroupName/foo-app-dev-as-1IZQABPFDAV2A",
              "AutoScalingGroupName": "foo-app-dev-as-1IZQABPFDAV2A",
              "...": "more output"
            },
            {
              "AutoScalingGroupARN": "arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:6a659b27-1ea7-4d39-8a8b-790153033b39:autoScalingGroupName/abc-app-prod-as-1IZQABPFDAV2A",
              "AutoScalingGroupName": "abc-app-prod-as-1IZQABPFDAV2A",
              "...": "more output"
            },
            {
              "Lots more": "Like the above"
            }
          ]
        },
        "output": {
          "results": [
            {
              "AutoScalingGroupARN": "arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:208e9fe9-3a9b-4f30-9b47-855f4a7ee671:autoScalingGroupName/abc-app-dev-as-1IZQABPFDAV2A",
              "AutoScalingGroupName": "abc-app-dev-as-1IZQABPFDAV2A"
            },
            {
              "AutoScalingGroupARN": "arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:6a659b27-1ea7-4d39-8a8b-790153033b39:autoScalingGroupName/abc-app-prod-as-1IZQABPFDAV2A",
              "AutoScalingGroupName": "abc-app-prod-as-1IZQABPFDAV2A"
            }
          ]
        }
      }
    ],
    "identifier": 44888773
  },
  {
    "context": [
      "How would I get \"g\" as my output here? Or how do I cast that 1 to a \"1\" so it is handled correctly?",
      "You can also look up fields of an object using syntax like .[\"foo\"] (.foo above is a shorthand version of this, but only for identifier-like strings).",
      "You also need quotes and use `-r` if you want raw output :",
      "jq -r '.e[\"1\"].f' test.json"
    ],
    "utterance": "Extract the value associated with key 'f' from the object with key '1' inside object 'e'.",
    "expressions": [
      ".e[\"1\"].f",
      "-r '.e[\"1\"].f'"
    ],
    "data": [
      {
        "input": {
          "a": "b",
          "c": "d",
          "e": {
            "1": {
              "f": "g",
              "h": "i"
            }
          }
        },
        "output": "g"
      }
    ],
    "identifier": 44985737
  },
  {
    "context": [
      "I need to extract values of list_file and store it shell variable as an array.",
      "the array contains only the entries /var/a.txt and /dev/b.txt.",
      "x=($(jq -r '.[] | .list_file | @tsv' input.json))",
      "x=($(jq -r '.[] | .list_file[] | @sh' input.json))",
      "declare -a \"x=($(jq -r '.[] | .list_file[] | @sh' input.json))\""
    ],
    "utterance": "Extract all elements of the list_file arrays for each object in the top-level array and output them as separate plain string values.",
    "expressions": [
      ".[] | .list_file[]",
      ".[] | .list_file | @tsv",
      ".[] | .list_file[] | @sh"
    ],
    "data": [
      {
        "input": [
          {
            "id": 10,
            "list_file": [
              "/var/a.txt",
              "/dev/b.txt"
            ]
          }
        ],
        "output": [
          "/var/a.txt",
          "/dev/b.txt"
        ]
      }
    ],
    "identifier": 44981265
  },
  {
    "context": [
      "I am trying to slice an array in jq where the end index is passed as an argument from the shell (bash):",
      "cat obj.json | jq --arg eidx $end_index, '.arr[0:$eidx]'",
      "jq: error (at <stdin>:0): Start and end indices of an array slice must be numbers",
      "When you pass an argument via `--arg` it is treated as a string, not an int:",
      "so it would seem that you cannot use `--arg` to pass a value to be used in a slice.",
      "You can convert a string to a number using `tonumber`, as in:",
      "jq --arg eidx 1 '.arr[0:($eidx|tonumber)]'",
      "If your jq is sufficiently recent, you can use `--argjson` instead of `--arg`:",
      "jq --argjson eidx 1 '.arr[0:$eidx]'"
    ],
    "utterance": "Slice the array field 'arr' from index 0 up to a variable end index provided via shell argument.",
    "expressions": [
      ".arr[0:($eidx|tonumber)]",
      ".arr[0:$eidx]"
    ],
    "data": [
      {
        "input": {
          "arr": [
            10,
            20,
            30,
            40,
            50,
            60,
            70
          ]
        },
        "output": [
          10,
          20,
          30,
          40,
          50,
          60,
          70
        ]
      }
    ],
    "identifier": 44995626
  },
  {
    "context": [
      "I do have several similar JSON objects (e.g. in files):\r\n\r\n    file_1.json: {\"myArray\":[{a},{b}]}\r\n    ...\r\n    file_n.json: {\"myArray\":[{n},{m}]}\r\n\r\nI would like to transform all these files into one output with the following format, using jq and Linux or Windows command line tools:\r\n\r\n    result_file.json: [{a},{b},...,{n},{m}]\r\n\r\nSo, I just want one array having all the objects that can be found in the \"myArray\" arrays from the different inputs.",
      "You can \"slurp\" your inputs:",
      "`%jq -s '[.[].myArray[]]' 1.json 2.json`"
    ],
    "utterance": "Aggregate all elements from the \"myArray\" arrays in multiple files into a single array.",
    "expressions": [
      "[.[].myArray[]]"
    ],
    "data": [
      {
        "input": [
          {
            "myArray": [
              1,
              2,
              3
            ]
          },
          {
            "myArray": [
              3,
              4,
              5
            ]
          }
        ],
        "output": [
          1,
          2,
          3,
          3,
          4,
          5
        ]
      }
    ],
    "identifier": 44966762
  },
  {
    "context": [
      "$ echo '[\"a\",\"b\",\"c\",\"d\"]' | jq '.[] | select (. == [\"a\",\"b\"][] )'",
      "\"a\"",
      "\"b\"",
      "In the code above, all entries are selected that are in the '[\"a\",\"b\"]' array.",
      "echo '[\"a\",\"b\",\"c\",\"d\"]' | jq '.[] | (. == [\"a\",\"b\"][])'",
      "echo '[\"a\",\"b\",\"c\",\"d\"]' | jq '.[] | select(debug == [\"a\",\"b\"][])'"
    ],
    "utterance": "Filter all values from the input that are either \"a\" or \"b\".",
    "expressions": [
      ".[] | select(. == [\"a\",\"b\"][])"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c",
          "d"
        ],
        "output": [
          "a",
          "b"
        ]
      }
    ],
    "identifier": 44995429
  },
  {
    "context": [
      "I have three JSON files:",
      "I'd like to update the second json file, with the values from the first json, based on the third json.",
      "But no values may be placed in keyfile.json, only key names.",
      "I cannot modify input.json.",
      "If you can specify the algorithm, then rest assured, it can be done in jq.",
      "I would recommend considering adopting path specifications that can be used directly with the jq builtins getpath and setpath.",
      "For example, consider this format for keyfile.json: [ [<path in input.json>], [<path in vault.json> ], ... ]",
      "reduce $keyfile[] as $p (.; setpath(($p|.[0]); $vault|getpath($p|.[1])))"
    ],
    "utterance": "Replace specific values in input by mapping keys from vault according to path pairs specified in keyfile.",
    "expressions": [
      "reduce $keyfile[] as $p (.; setpath(($p|.[0]); $vault|getpath($p|.[1])))"
    ],
    "data": [
      {
        "input": {
          "input.json": {
            ".cloud_cpi_key": {
              "type": "wildcard_domain",
              "configurable": true,
              "credential": false,
              "value": "vault-supplied-value",
              "optional": false
            },
            ".cloud_cpi_secret": {
              "type": "wildcard_domain",
              "configurable": true,
              "credential": false,
              "value": "vault-supplied-value",
              "optional": false
            },
            ".properties.networking_point_of_entry": {
              "type": "selector",
              "configurable": true,
              "credential": false,
              "value": "external_ssl",
              "optional": false
            },
            ".properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate": {
              "type": "rsa_cert_credentials",
              "configurable": true,
              "credential": true,
              "value": {
                "private_key_pem": "vault-supplied-value",
                "cert_pem": "vault-supplied-value"
              },
              "optional": false
            }
          },
          "vault.json": {
            "aws": {
              "access_key_id": "My-Key-id",
              "secret_access_key": "My-Access-Key"
            },
            "ssl": {
              "crt": "My-Crt",
              "key": "My-Key",
              "req": "My-Req"
            }
          },
          "keyfile.json": [
            [
              [
                ".cloud_cpi_key",
                "value"
              ],
              [
                "aws",
                "access_key_id"
              ]
            ],
            [
              [
                ".cloud_cpi_secret",
                "value"
              ],
              [
                "aws",
                "secret_access_key"
              ]
            ],
            [
              [
                ".properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate",
                "value",
                "private_key_pem"
              ],
              [
                "ssl",
                "key"
              ]
            ],
            [
              [
                ".properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate",
                "value",
                "cert_pem"
              ],
              [
                "ssl",
                "crt"
              ]
            ]
          ]
        },
        "output": {
          ".cloud_cpi_key": {
            "type": "string",
            "configurable": true,
            "credential": true,
            "value": "My-Key-id",
            "optional": false
          },
          ".cloud_cpi_secret": {
            "type": "string",
            "configurable": true,
            "credential": true,
            "value": "My-Access-Key",
            "optional": false
          },
          ".properties.networking_point_of_entry": {
            "type": "selector",
            "configurable": true,
            "credential": false,
            "value": "external_ssl",
            "optional": false
          },
          ".properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate": {
            "type": "rsa_cert_credentials",
            "configurable": true,
            "credential": true,
            "value": {
              "private_key_pem": "My-Key",
              "cert_pem": "My-Crt"
            },
            "optional": false
          }
        }
      }
    ],
    "identifier": 44954791
  },
  {
    "context": [
      "Now I want to compare `title` from the first JSON line and the fourth JSON line, and if the  title is the same I want to omit one of the entries.",
      "I have only been able to convert it to JSON and remove duplicates by comparing all objects:",
      "    jq --slurp [.[]] | unique",
      "but this compares all objects inside whereas I want to compare only one object and remove the entire line.",
      "> find and remove duplicates [based on .title]",
      "INDEX(.title) | [.[]]",
      "(If your jq does not have `INDEX` then simply copy its definition from https://github.com/stedolan/jq/blob/master/src/builtin.jq )",
      "INDEX(.[]; .title) | [.[]]",
      "def INDEX(f): map( {(f|tostring): . } ) | add;"
    ],
    "utterance": "Remove duplicate entries, keeping only unique ones based on the value of the 'title' field.",
    "expressions": [
      "INDEX(.title) | [.[]]",
      "INDEX(.[]; .title) | [.[]]",
      "def INDEX(f): map( {(f|tostring): . } ) | add; INDEX(.title) | [.[]]"
    ],
    "data": [
      {
        "input": [
          {
            "headline": "sample headline 1",
            "title": "sample title 1",
            "href": "sample link 1",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag1"
          },
          {
            "headline": "sample headline 2",
            "title": "sample title 2",
            "href": "sample link 2",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag2"
          },
          {
            "headline": "sample headline 3",
            "title": "sample title 3",
            "href": "sample link ",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag3"
          },
          {
            "headline": "sample headline 4",
            "title": "sample title 1",
            "href": "sample link 4",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag4"
          }
        ],
        "output": [
          {
            "headline": "sample headline 4",
            "title": "sample title 1",
            "href": "sample link 4",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag4"
          },
          {
            "headline": "sample headline 2",
            "title": "sample title 2",
            "href": "sample link 2",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag2"
          },
          {
            "headline": "sample headline 3",
            "title": "sample title 3",
            "href": "sample link ",
            "day": " Fri, 7 Jul 2017 , 8:30PM ",
            "tags": "tag3"
          }
        ]
      }
    ],
    "identifier": 44948827
  },
  {
    "context": [
      "I\u2019d like to output the unique key name in \"other\" field",
      "The value of `.other` is a JSON string; you can use `fromjson` to change the string to a JSON object.",
      "Putting it all together:",
      "$ jq  '.other | fromjson | keys_unsorted | unique' input.json"
    ],
    "utterance": "Extract the unique keys found in the 'other' field, which contains a JSON string, across all objects.",
    "expressions": [
      ".other | fromjson | keys_unsorted | unique"
    ],
    "data": [
      {
        "input": [
          {
            "event_timestamp": "2016-03-16 13:19:53 UTC",
            "query": "Plagiarism",
            "search_session_id": "3605862756e95d26ac180",
            "version": "0.0.2",
            "other": "{\"client_timestamp\":1458134393.932,\"ios_page_index\":3}",
            "action": "HIT_BOUNCE"
          },
          {
            "event_timestamp": "2016-03-16 13:19:53 UTC",
            "query": "Plagiarism",
            "search_session_id": "3605862756e95d26ac180",
            "version": "0.0.2",
            "other": "{\"client_timestamp\":1458134393.932,\"ios_page_index\":3,\"ios_index_path_row\":1}",
            "action": "HIT_BOUNCE"
          }
        ],
        "output": [
          [
            "client_timestamp",
            "ios_page_index"
          ],
          [
            "client_timestamp",
            "ios_index_path_row",
            "ios_page_index"
          ]
        ]
      }
    ],
    "identifier": 45022178
  },
  {
    "context": [
      "jq '.scripts.start = \"webpack-dev-server\" | del(.scripts.test)' input.json > \"$tmp\" && mv \"$tmp\" input.json",
      "will produce the final `.json` file as\n\n    {\n      \"name\": \"test\",\n      \"version\": \"1.0.0\",\n      \"description\": \"\",\n      \"main\": \"index.js\",\n      \"scripts\": {\n        \"start\": \"webpack-dev-server\"\n      },\n      \"author\": \"\",\n      \"license\": \"ISC\",\n      \"dependencies\": {\n        \"nodemon\": \"^1.11.0\",\n        \"path\": \"^0.12.7\",\n        \"react\": \"^15.6.1\",\n        \"webpack\": \"^3.1.0\",\n        \"webpack-dev-server\": \"^2.5.1\"\n      }\n    }",
      "Another option using `jq` would be to simply overwrite the value of `.scripts`:\n\n    jq '.scripts = { start: \"webpack-dev-server\" }' file.json"
    ],
    "utterance": "Replace the scripts.test property with scripts.start set to \"webpack-dev-server\", removing the old test script entry.",
    "expressions": [
      ".scripts.start = \"webpack-dev-server\" | del(.scripts.test)",
      ".scripts = { start: \"webpack-dev-server\" }"
    ],
    "data": [
      {
        "input": {
          "name": "test",
          "version": "1.0.0",
          "description": "",
          "main": "index.js",
          "scripts": {
            "test": "echo \"Error: no test specified\" && exit 1"
          },
          "author": "",
          "license": "ISC",
          "dependencies": {
            "nodemon": "^1.11.0",
            "path": "^0.12.7",
            "react": "^15.6.1",
            "webpack": "^3.1.0",
            "webpack-dev-server": "^2.5.1"
          }
        },
        "output": {
          "name": "test",
          "version": "1.0.0",
          "description": "",
          "main": "index.js",
          "scripts": {
            "start": "webpack-dev-server"
          },
          "author": "",
          "license": "ISC",
          "dependencies": {
            "nodemon": "^1.11.0",
            "path": "^0.12.7",
            "react": "^15.6.1",
            "webpack": "^3.1.0",
            "webpack-dev-server": "^2.5.1"
          }
        }
      }
    ],
    "identifier": 45008223
  },
  {
    "context": [
      "I have a JSON string as seen below.",
      "{\r\n  \"wf.example.input1\": \"/path/to/file1\",\r\n  \"wf.example.input3\": [\r\n    \"/path/to/file3\",\r\n    \"/path/to/file4\"\r\n  ]\r\n}",
      "I need a `list` output in below format.",
      "name:\"wf.example.input1\", value:\"/path/to/file1\"\r\nname:\"wf.example.input3\", value:\"/path/to/file3\"\r\nname:\"wf.example.input3\", value:\"/path/to/file4\"",
      "Convert it to entries first, then you could build up your outputs for the keys and values.  For arrays of values, just go through all the values in the array, otherwise the value itself.",
      "$ jq -r 'to_entries[] | \"name:\\(.key|tojson), value:\\(.value|(arrays[]//.)|tojson)\"' input.json",
      "name:\"wf.example.input1\", value:\"/path/to/file1\"",
      "name:\"wf.example.input3\", value:\"/path/to/file3\"",
      "name:\"wf.example.input3\", value:\"/path/to/file4\""
    ],
    "utterance": "List all key-value mappings, with each array element as a separate entry, using the format name:KEY, value:VALUE.",
    "expressions": [
      "to_entries[] | \"name:\\(.key|tojson), value:\\(.value|(arrays[]//.)|tojson)\""
    ],
    "data": [
      {
        "input": {
          "wf.example.input1": "/path/to/file1",
          "wf.example.input3": [
            "/path/to/file3",
            "/path/to/file4"
          ]
        },
        "output": [
          "name:\"wf.example.input1\", value:\"/path/to/file1\"",
          "name:\"wf.example.input3\", value:\"/path/to/file3\"",
          "name:\"wf.example.input3\", value:\"/path/to/file4\""
        ]
      }
    ],
    "identifier": 45027469
  },
  {
    "context": [
      "Can anyone please assist? I would like to get **provider/color_code**",
      "Goal is below",
      "id     slug     provider color_code",
      "100442 spredfns    65c6bb",
      "With your input (corrected to make it valid JSON), the invocation:",
      "jq -r '[.id, .slug, .\"**provider**\".\"icons\".\"color_code\" ] | @csv'",
      "If your jq supports `@tsv`, then an alternative would be to use it instead of @csv; the output would then be:",
      "([\"id\", \"slug\", \"provider color_code\"],\n [.id, .slug, .\"**provider**\".\"icons\".\"color_code\" ])\n| @tsv",
      "If you are using a version of jq that does not support the `.\"foo\"` syntax, use the primary `.[\"foo\"]` syntax instead, remembering to create a pipeline:\n\n [.id, .slug, (.[\"**provider**\"] | .[\"icons\"] | .[\"color_code\"]) ]"
    ],
    "utterance": "Output the id, slug, and color_code from provider.icons as CSV or TSV columns, including a header row.",
    "expressions": [
      "[.id, .slug, .\"**provider**\".\"icons\".\"color_code\" ] | @csv",
      "([\"id\", \"slug\", \"provider color_code\"],\n [.id, .slug, .\"**provider**\".\"icons\".\"color_code\" ])\n| @tsv",
      "[.id, .slug, (.[\"**provider**\"] | .[\"icons\"] | .[\"color_code\"]) ]"
    ],
    "data": [
      {
        "input": {
          "requires_mfa_code": false,
          "key_vault": false,
          "id": 100442,
          "slug": "spredfns",
          "name": "Spredfns",
          "**provider**": {
            "icons": {
              "first_letter": "s",
              "color_code": "65c6bb",
              "large": "https://assetsedfast_lg.png",
              "small": "https://assets.dfast_sm.png"
            },
            "**capabilities**": {
              "has_ou": false,
              "has_import": false,
              "has_password_reset": false,
              "has_provision": false,
              "has_saml": false,
              "has_sync": false,
              "unsupported_browsers": [],
              "services": "authenticatab"
            }
          }
        },
        "output": [
          "100442,\"spredfns\",\"65c6bb\""
        ]
      }
    ],
    "identifier": 45004253
  },
  {
    "context": [
      "is there a way to fetch both key and value for the same and then store them as another JSON? For example, in JSON mentioned for this question, I need to get the output as another JSON containing all the matched paths. My output JSON should look something like below.\n\n     { \"binding\":\n       { \"wf.example.input1\": \"/path/to/file1\",\n         \"wf.example.input3\": [ \"/path/to/file3\", \"/path/to/file4\" ] \n       }\n     }",
      "The following jq filter will produce the desired output if given input that is very similar to the example",
      ". as $in\n| reduce paths(type == \"string\" and test(\"/\")) as $path ({};\n    ($in|getpath($path)) as $x\n    | if ($path[-1]|type) == \"string\"\n      then .[$path[-1]] = $x\n      else .[$path[-2]|tostring] += [$x]\n      end )\n| {binding: .}"
    ],
    "utterance": "Select all key-value pairs from the 'binding' object where the value contains a '/' character, preserving arrays and constructing a new object with only those pairs.",
    "expressions": [
      ". as $in\n| reduce paths(type == \"string\" and test(\"/\")) as $path ({};\n    ($in|getpath($path)) as $x\n    | if ($path[-1]|type) == \"string\"\n      then .[$path[-1]] = $x\n      else .[$path[-2]|tostring] += [$x]\n      end )\n| {binding: .}"
    ],
    "data": [
      {
        "input": {
          "dig": "sha256:d2aae00e4bc6424d8a6ae7639d41cfff8c5aa56fc6f573e64552a62f35b6293e",
          "name": "example",
          "binding": {
            "wf.example.input1": "/path/to/file1",
            "wf.example.input2": "hello",
            "wf.example.input3": [
              "/path/to/file3",
              "/path/to/file4"
            ],
            "wf.example.input4": 44
          }
        },
        "output": {
          "binding": {
            "wf.example.input1": "/path/to/file1",
            "wf.example.input3": [
              "/path/to/file3",
              "/path/to/file4"
            ]
          }
        }
      }
    ],
    "identifier": 45025624
  },
  {
    "context": [
      "How can I loop through each element in the json file in Bash which has as \"Generated\" value \"@logon\"?",
      "jq -rc '.[] | select(.Generated == \"@logon\")' file.json",
      "to print the keys of objects with .Generated == \"@logon\":",
      "$ jq -r 'to_entries[] | select(.value.Generated == \"@logon\") | .key' input.json",
      "version",
      "hostname"
    ],
    "utterance": "Get the top-level keys whose associated value has a Generated field equal to '@logon'.",
    "expressions": [
      "jq -r 'to_entries[] | select(.value.Generated == \"@logon\") | .key' input.json"
    ],
    "data": [
      {
        "input": {
          "version": {
            "Generated": "@logon",
            "Value": "Unknown",
            "LastRun": "Never"
          },
          "hostname": {
            "Generated": "@logon",
            "Value": "Unknown",
            "LastRun": "Never"
          },
          "updates": {
            "Generated": "@boot",
            "Value": "Unknown",
            "LastRun": "Never"
          }
        },
        "output": [
          "version",
          "hostname"
        ]
      }
    ],
    "identifier": 45039519
  },
  {
    "context": [
      "I need a flattened info from swagger spec above [ \"GET /pets\", \"POST /pets\", \"GET /pets/{petId}\" ]",
      "what I need is a way to combine keys at nested level to get above result i.e array of  \"METHOD /PATH\"",
      "The following filter produces the results you want, as shown below:",
      ".paths\n| to_entries\n| map( .key as $path\n       | ( .value | to_entries[]\n           | if .key == \"get\" then \"GET\"\n             elif .key == \"post\" then \"POST\" \n             else empty end ) as $verb\n       | $verb + \" \" + $path )",
      "Output:\n[\n  \"GET /pets\",\n  \"POST /pets\",\n  \"GET /pets/{petId}\"\n]"
    ],
    "utterance": "Produce an array of strings pairing each top-level HTTP method and its route in the format \"METHOD /path\", such as [\"GET /pets\", \"POST /pets\", \"GET /pets/{petId}\"] for specified verbs.",
    "expressions": [
      ".paths\n| to_entries\n| map(.key as $path\n      | (.value | to_entries[]\n         | if .key == \"get\" then \"GET\"\n           elif .key == \"post\" then \"POST\"\n           else empty end ) as $verb\n      | $verb + \" \" + $path)"
    ],
    "data": [
      {
        "input": {
          "paths": {
            "/pets": {
              "get": {
                "description": "get pets"
              },
              "post": {
                "description": "add a pet"
              }
            },
            "/pets/{petId}": {
              "get": {
                "description": "get pet by id"
              }
            }
          }
        },
        "output": [
          "GET /pets",
          "POST /pets",
          "GET /pets/{petId}"
        ]
      }
    ],
    "identifier": 45034898
  },
  {
    "context": [
      "SECRET_VALUE=$(echo \"$SECRET_VALUE_RESPONSE\" | jq --raw-output '.data.value')",
      "An example of $SECRET_VALUE_RESPONSE is: {\"request_id\":\"XXXX-YYYY..,\",\"lease_id\":\"\",\"renewable\":false,\"lease_duration\":nnnnnn,\"data\":{\"value\":\"secret-value\"},\"wrap_info\":null,\"warnings\":null,\"auth\":null}",
      "secret_value=$(get_secret_value | jq --raw-output '.data.value')"
    ],
    "utterance": "Extract the value of the nested key 'data.value' from the response object.",
    "expressions": [
      ".data.value"
    ],
    "data": [
      {
        "input": {
          "request_id": "XXXX-YYYY..,",
          "lease_id": "",
          "renewable": false,
          "lease_duration": "nnnnnn",
          "data": {
            "value": "secret-value"
          },
          "wrap_info": null,
          "warnings": null,
          "auth": null
        },
        "output": "secret-value"
      }
    ],
    "identifier": 45066954
  },
  {
    "context": [
      "I am trying to extract the value of `us-east-1` key.",
      "In the [jq playground][2], I was able to extract the value using the the following `filter`",
      ".Mappings.RegionMap.\"us-east-1\".AMI",
      "But when try to run this filter using [jq][1] on my windows machine using the `command prompt`",
      "jq '.Mappings.RegionMap.\"us-east-1\".AMI' <filename>",
      "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting",
      "One workaround is to put the jq command text into a file, and invoke jq with the -f option.",
      "If you want to avoid the -f option, try something like:",
      "jq \".Mappings.RegionMap.\\\"us-east-1\\\".AMI\"",
      "(For older versions of jq: jq \".Mappings.RegionMap | .[\\\"us-east-1\\\"].AMI\" )"
    ],
    "utterance": "Extract the AMI value for the us-east-1 region from the Mappings.RegionMap object.",
    "expressions": [
      ".Mappings.RegionMap[\"us-east-1\"].AMI",
      ".Mappings.RegionMap.\"us-east-1\".AMI"
    ],
    "data": [
      {
        "input": {
          "Mappings": {
            "RegionMap": {
              "us-east-1": {
                "AMI": "xxxxxx"
              },
              "us-east-2": {
                "AMI": ""
              },
              "us-west-1": {
                "AMI": ""
              },
              "us-west-2": {
                "AMI": ""
              },
              "ca-central-1": {
                "AMI": ""
              },
              "eu-central-1": {
                "AMI": ""
              },
              "eu-west-1": {
                "AMI": ""
              },
              "eu-west-2": {
                "AMI": ""
              },
              "ap-south-1": {
                "AMI": ""
              },
              "ap-southeast-1": {
                "AMI": ""
              },
              "ap-southeast-2": {
                "AMI": ""
              },
              "ap-northeast-1": {
                "AMI": ""
              },
              "ap-northeast-2": {
                "AMI": ""
              },
              "sa-east-1": {
                "AMI": ""
              }
            }
          }
        },
        "output": "xxxxxx"
      }
    ],
    "identifier": 45043970
  },
  {
    "context": [
      "My task is to update the value of the `AMI` key of `us-east-1` in the given json file and create the updated file as new file.",
      "After fixing that, you can easily update the needed property value:",
      "jq '.Mappings.RegionMap[\"us-east-1\"].AMI = \"abcd\"' oldfile > newfile"
    ],
    "utterance": "Set the AMI value of us-east-1 to abcd and write the updated content to a new file.",
    "expressions": [
      ".Mappings.RegionMap[\"us-east-1\"].AMI = \"abcd\""
    ],
    "data": [
      {
        "input": {
          "Name": "SA",
          "Password": "yyyyy",
          "Mappings": {
            "RegionMap": {
              "us-east-1": {
                "AMI": "xxxxxx"
              },
              "us-east-2": {
                "AMI": ""
              },
              "us-west-1": {
                "AMI": ""
              },
              "us-west-2": {
                "AMI": ""
              },
              "ca-central-1": {
                "AMI": ""
              },
              "eu-central-1": {
                "AMI": ""
              },
              "eu-west-1": {
                "AMI": ""
              },
              "eu-west-2": {
                "AMI": ""
              },
              "ap-south-1": {
                "AMI": ""
              },
              "ap-southeast-1": {
                "AMI": ""
              },
              "ap-southeast-2": {
                "AMI": ""
              },
              "ap-northeast-1": {
                "AMI": ""
              },
              "ap-northeast-2": {
                "AMI": ""
              },
              "sa-east-1": {
                "AMI": ""
              }
            }
          }
        },
        "output": {
          "Name": "SA",
          "Password": "yyyyy",
          "Mappings": {
            "RegionMap": {
              "us-east-1": {
                "AMI": "abcd"
              },
              "us-east-2": {
                "AMI": ""
              },
              "us-west-1": {
                "AMI": ""
              },
              "us-west-2": {
                "AMI": ""
              },
              "ca-central-1": {
                "AMI": ""
              },
              "eu-central-1": {
                "AMI": ""
              },
              "eu-west-1": {
                "AMI": ""
              },
              "eu-west-2": {
                "AMI": ""
              },
              "ap-south-1": {
                "AMI": ""
              },
              "ap-southeast-1": {
                "AMI": ""
              },
              "ap-southeast-2": {
                "AMI": ""
              },
              "ap-northeast-1": {
                "AMI": ""
              },
              "ap-northeast-2": {
                "AMI": ""
              },
              "sa-east-1": {
                "AMI": ""
              }
            }
          }
        }
      }
    ],
    "identifier": 45061585
  },
  {
    "context": [
      "You could take advantage of jq's regular formatted output, but you'll want to stringify it. You could simulate stringifying by slurping in as raw input, the formatted output. This will read in all of the input as a single string. And since the input was just a json object, it'll produce a string representation of that object.",
      "If you don't mind the extra jq calls, you could do this:",
      "$ var=$(jq '. ' input.json | jq -sR '.')",
      "$ echo \"$var\"",
      "\"{\\n  \\\"test\\\": {\\n    \\\"name\\\": \\\"test\\\",\\n    \\\"description\\\": \\\"blah\\\"\\n  },\\n  \\\"test2\\\": {\\n    \\\"name\\\": \\\"test2\\\",\\n    \\\"description\\\": \\\"blah2\\\"\\n  }\\n}\\n\""
    ],
    "utterance": "Produce a string representation that maintains pretty formatting with \\n line breaks and escaped quotes.",
    "expressions": [
      "jq '.' input.json | jq -sR '.'"
    ],
    "data": [
      {
        "input": {
          "test": {
            "name": "test",
            "description": "blah"
          },
          "test2": {
            "name": "test2",
            "description": "blah2"
          }
        },
        "output": "{\\n  \\\"test\\\": {\\n    \\\"name\\\": \\\"test\\\",\\n    \\\"description\\\": \\\"blah\\\"\\n  },\\n  \\\"test2\\\": {\\n    \\\"name\\\": \\\"test2\\\",\\n    \\\"description\\\": \\\"blah2\\\" \\n  }\\n}"
      }
    ],
    "identifier": 45069839
  },
  {
    "context": [
      "what I want to get is the data of the partitions.",
      "When I do **jq '.partitions'** I get Cannot index array with string \"partitions\"",
      "You can get \"partitions\" for the first element: $ jq '.[0].partitions' file",
      "Or for each elements: $ jq '[].partitions' file",
      "Or join all the partitions from each element into one list: $ jq 'map(.partitions) | add' file"
    ],
    "utterance": "Select the partitions field from each element in the top-level array.",
    "expressions": [
      ".[].partitions"
    ],
    "data": [
      {
        "input": [
          {
            "partitions": [
              "name@website"
            ]
          },
          {
            "partitions": [
              "more"
            ]
          }
        ],
        "output": [
          [
            "name@website"
          ],
          [
            "more"
          ]
        ]
      }
    ],
    "identifier": 45111742
  },
  {
    "context": [
      "what I need to do is add a `removable` and `appendable` attribute to each item inside every instance of `properties` and set them to true.",
      "Is there a way to automate this? as in write a script that automatically adds these fields right below each item in properties?",
      "Given that you want to apply the update to all objects that have a key named \"properties\", wherever they occur, I'd be inclined to use `walk/1`.",
      "def update(obj):\n  if type == \"object\" and has(\"properties\")\n  then .properties |= with_entries( .value += obj )\n  else .\n  end;",
      "walk( update({removable: true, appendable: true}) )",
      "It might be prudent to change the \"then\" line above to:\n    then .properties |= \n      with_entries( if .value | type == \"object\"\n                    then .value += obj\n                    else . end)"
    ],
    "utterance": "Add a removable: true and appendable: true attribute to each entry within every properties object, at all nesting levels.",
    "expressions": [
      "def update(obj): if type == \"object\" and has(\"properties\") then .properties |= with_entries(.value += obj) else . end; walk(update({removable: true, appendable: true}))",
      "def update(obj): if type == \"object\" and has(\"properties\") then .properties |= with_entries(if .value | type == \"object\" then .value += obj else . end) else . end; walk(update({removable: true, appendable: true}))"
    ],
    "data": [
      {
        "input": {
          "$schema": "someURL",
          "id": "someURL",
          "type": "object",
          "properties": {
            "copyright": {
              "id": "someURL",
              "type": "object",
              "description": "Setup for copyright link",
              "properties": {
                "translation": {
                  "id": "someURL",
                  "type": "string",
                  "description": "someString"
                },
                "url": {
                  "id": "someURL",
                  "type": "string",
                  "description": "someString"
                }
              }
            }
          }
        },
        "output": {
          "$schema": "someURL",
          "id": "someURL",
          "type": "object",
          "properties": {
            "copyright": {
              "removable": true,
              "appendable": true,
              "id": "someURL",
              "type": "object",
              "description": "Setup for copyright link",
              "properties": {
                "translation": {
                  "removable": true,
                  "appendable": true,
                  "id": "someURL",
                  "type": "string",
                  "description": "someString"
                },
                "url": {
                  "removable": true,
                  "appendable": true,
                  "id": "someURL",
                  "type": "string",
                  "description": "someString"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 45040597
  },
  {
    "context": [
      "I would love to get the following in my result\n\n    limit:10\n    offset:20\n    id:abcd, type:file, [users.total:2, users.profiles.first_name: [John, Sue], users.profiles.last_name: [Smith, Johnson]], \n    id:efgh, type:folder, [users.total:1, users.profiles.first_name: [Steve], users.profiles.last_name: [Gold]], \n",
      "You can use commas at the top-level to get those fields. Use parentheses to group the expression that gets everything from `.values`.\n\n    jq '.limit, .offset, (.values[] | .id, .type, .users.total, .users.profiles[].first_name, .users.profiles[].last_name)'"
    ],
    "utterance": "Output limit and offset at the top level, then for each element in values, output its id, type, users.total, each users.profiles.first_name, and each users.profiles.last_name.",
    "expressions": [
      ".limit, .offset, (.values[] | .id, .type, .users.total, .users.profiles[].first_name, .users.profiles[].last_name)"
    ],
    "data": [
      {
        "input": {
          "limit": 10,
          "offset": 20,
          "values": [
            {
              "id": "abcd",
              "type": "file",
              "users": {
                "total": 2,
                "profiles": [
                  {
                    "first_name": "John",
                    "last_name": "Smith"
                  },
                  {
                    "first_name": "Sue",
                    "last_name": "Johnson"
                  }
                ]
              }
            },
            {
              "id": "efgh",
              "type": "folder",
              "users": {
                "total": 1,
                "profiles": [
                  {
                    "first_name": "Steve",
                    "last_name": "Gold"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 45111137
  },
  {
    "context": [
      "So far I have managed to isolate the data with \r\n\r\n    cat basic.json | jq '.VCALENDAR[].VEVENT[] | select(.UID | contains(\"google.com\"))'",
      "How do I recreate the original structure including just the google.com or hebal.com data?",
      "Use *update-assignment* operator `|=`:",
      "jq '.VCALENDAR[0].VEVENT |= map(select(.UID | contains(\"google.com\")))' base.json"
    ],
    "utterance": "Return the full calendar structure but include only those events whose UID contains \"google.com\".",
    "expressions": [
      ".VCALENDAR[0].VEVENT |= map(select(.UID | contains(\"google.com\")))"
    ],
    "data": [
      {
        "input": {
          "VCALENDAR": [
            {
              "PRODID": "-//Google Inc//Google Calendar 70.9054//EN",
              "VERSION": "2.0",
              "CALSCALE": "GREGORIAN",
              "METHOD": "PUBLISH",
              "X-WR-CALNAME": "Events - TS Cinnaminson",
              "X-WR-TIMEZONE": "America/New_York",
              "VTIMEZONE": [
                {
                  "TZID": "America/New_York",
                  "X-LIC-LOCATION": "America/New_York",
                  "DAYLIGHT": [
                    {
                      "TZOFFSETFROM": "-0500",
                      "TZOFFSETTO": "-0400",
                      "TZNAME": "EDT",
                      "DTSTART": "19700308T020000",
                      "RRULE": "FREQ=YEARLY;BYMONTH=3;BYDAY=2SU"
                    }
                  ],
                  "STANDARD": [
                    {
                      "TZOFFSETFROM": "-0400",
                      "TZOFFSETTO": "-0500",
                      "TZNAME": "EST",
                      "DTSTART": "19701101T020000",
                      "RRULE": "FREQ=YEARLY;BYMONTH=11;BYDAY=1SU"
                    }
                  ]
                }
              ],
              "VEVENT": [
                {
                  "DTSTART;VALUE=DATE": "20170930",
                  "DTEND;VALUE=DATE": "20171001",
                  "DTSTAMP": "20170626T155902Z",
                  "UID": "hebcal-20170930-6d1036bc2e3a7c743225174c4feb5d1f",
                  "URL": "http://hebcal.com/h/yom-kippur",
                  "CLASS": "PUBLIC",
                  "CREATED": "20170603T024831Z",
                  "DESCRIPTION": "Day of Atonement\\n\\nhttp://hebcal.com/h/yom-kippur",
                  "LAST-MODIFIED": "20170626T153742Z",
                  "LOCATION": "",
                  "SEQUENCE": "0",
                  "STATUS": "CONFIRMED",
                  "SUMMARY": "Yom Kippur",
                  "TRANSP": "OPAQUE",
                  "X-MICROSOFT-CDO-BUSYSTATUS": "OOF"
                },
                {
                  "DTSTART": "20170731T233000Z",
                  "DTEND": "20170801T003000Z",
                  "DTSTAMP": "20170626T155902Z",
                  "UID": "va6vhj4qba2rll8epdmccnjs@google.com",
                  "CREATED": "20170523T010707Z",
                  "DESCRIPTION": "",
                  "LAST-MODIFIED": "20170523T010707Z",
                  "LOCATION": "",
                  "SEQUENCE": "0",
                  "STATUS": "CONFIRMED",
                  "SUMMARY": "Service",
                  "TRANSP": "OPAQUE"
                }
              ]
            }
          ]
        },
        "output": {
          "VCALENDAR": [
            {
              "PRODID": "-//Google Inc//Google Calendar 70.9054//EN",
              "VERSION": "2.0",
              "CALSCALE": "GREGORIAN",
              "METHOD": "PUBLISH",
              "X-WR-CALNAME": "Events - TS Cinnaminson",
              "X-WR-TIMEZONE": "America/New_York",
              "VTIMEZONE": [
                {
                  "TZID": "America/New_York",
                  "X-LIC-LOCATION": "America/New_York",
                  "DAYLIGHT": [
                    {
                      "TZOFFSETFROM": "-0500",
                      "TZOFFSETTO": "-0400",
                      "TZNAME": "EDT",
                      "DTSTART": "19700308T020000",
                      "RRULE": "FREQ=YEARLY;BYMONTH=3;BYDAY=2SU"
                    }
                  ],
                  "STANDARD": [
                    {
                      "TZOFFSETFROM": "-0400",
                      "TZOFFSETTO": "-0500",
                      "TZNAME": "EST",
                      "DTSTART": "19701101T020000",
                      "RRULE": "FREQ=YEARLY;BYMONTH=11;BYDAY=1SU"
                    }
                  ]
                }
              ],
              "VEVENT": [
                {
                  "DTSTART": "20170731T233000Z",
                  "DTEND": "20170801T003000Z",
                  "DTSTAMP": "20170626T155902Z",
                  "UID": "va6vhj4qba2rll8epdmccnjs@google.com",
                  "CREATED": "20170523T010707Z",
                  "DESCRIPTION": "",
                  "LAST-MODIFIED": "20170523T010707Z",
                  "LOCATION": "",
                  "SEQUENCE": "0",
                  "STATUS": "CONFIRMED",
                  "SUMMARY": "Service",
                  "TRANSP": "OPAQUE"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 44890243
  }
]