[
  {
    "context": [
      "In a very large nested json structure I&#39;m trying to find all of the paths that end in a key.",
      "would print something along the lines of:\r\n[\"A\",\"A1\",\"foo\"], [\"foo\"]",
      "jq -c 'paths | select(.[-1] == \"foo\")'",
      "[\"A\",\"A1\",\"foo\"]",
      "[\"foo\"]"
    ],
    "utterance": "List all paths in a nested structure that end with the key 'foo'.",
    "expressions": [
      "paths | select(.[-1] == \"foo\")",
      "-c 'paths | select(.[-1] == \"foo\")'"
    ],
    "data": [
      {
        "input": {
          "A": {
            "A1": {
              "foo": {
                "_": "_"
              }
            },
            "A2": {
              "_": "_"
            }
          },
          "B": {
            "B1": {}
          },
          "foo": {
            "_": "_"
          }
        },
        "output": [
          [
            "A",
            "A1",
            "foo"
          ],
          [
            "foo"
          ]
        ]
      }
    ],
    "identifier": 39800718
  },
  {
    "context": [
      "I want to remove from the array the objects that contain \"replication\". The result would be:\n\n    [  {\n        \"op\": \"remove\",\n        \"path\": \"/cache\"\n      },\n      {\n        \"op\": \"add\",\n        \"path\": \"/game_config\"\n      }\n    ]",
      "Negation can be achieved using `not`.  In your case, since you mentioned using regular expressions, you could use `test/1` as follows:\n\n    map( select(.path | test(\"replication\") | not))",
      ".[] | (select( .path | contains(\"value\") | not ))"
    ],
    "utterance": "Remove all objects from an array where the path field contains the substring 'replication'.",
    "expressions": [
      "map(select(.path | test(\"replication\") | not))",
      "map(select(.path | contains(\"replication\") | not))"
    ],
    "data": [
      {
        "input": [
          {
            "op": "remove",
            "path": "/cache"
          },
          {
            "op": "add",
            "path": "/game_config"
          },
          {
            "op": "remove",
            "path": "/use_replication"
          },
          {
            "op": "add",
            "path": "/copy_replication"
          }
        ],
        "output": [
          {
            "op": "remove",
            "path": "/cache"
          },
          {
            "op": "add",
            "path": "/game_config"
          }
        ]
      }
    ],
    "identifier": 39863036
  },
  {
    "context": [
      "Is there a way to instead output the path in the `jq` path selection format, i.e. `.foo[0].bar`?",
      "So you could use this:",
      "def to_expression($path): $path |\n    if length == 0\n        then \".\"\n        else map(\n            if type == \"string\"\n                then \".\\\"\\(.)\\\"\"\n            elif type == \"number\"\n                then \"[\\(.)]\"\n            else\n                error(\"unexpected path type: \\(type)\")\n            end\n        ) | add\n    end;"
    ],
    "utterance": "Output the location and value of all properties named \"bar\", with their paths formatted as .foo[0].bar",
    "expressions": [
      "tostream | select(.[0]|index(\"bar\")) | [to_expression(.[0]), .[1]]",
      "def to_expression($path): $path |\n    if length == 0\n        then \".\"\n        else map(\n            if type == \"string\"\n                then \".\\\"\\(.)\\\"\"\n            elif type == \"number\"\n                then \"[\\(.)]\"\n            else\n                error(\"unexpected path type: \\(type)\")\n            end\n        ) | add\n    end;\ntostream | select(.[0]|index(\"bar\")) | [to_expression(.[0]), .[1]]"
    ],
    "data": [
      {
        "input": {
          "foo": [
            {
              "bar": 2,
              "bor": 3
            }
          ]
        },
        "output": [
          [
            ".\"foo\"[0].\"bar\"",
            2
          ]
        ]
      }
    ],
    "identifier": 39826489
  },
  {
    "context": [
      "I have 2 json files with common key and I need to JOIN them with ***jq*** utility or alternative way from command line As follows:",
      "jsonFile1:",
      "{ \"id\":\"10\",\"data\":\"abc\" }",
      "{ \"id\":\"20\",\"data\":\"xyz\" }",
      "{ \"id\":\"30\",\"data\":\"qwe\" }",
      "{ \"id\":\"40\",\"data\":\"wsx\" }",
      "{ \"id\":\"50\",\"data\":\"zxc\" }",
      "jsonFile2:",
      "{ \"id\":\"60\",\"content\":\"ert\" }",
      "{ \"id\":\"40\",\"content\":\"tgb\" }",
      "{ \"id\":\"10\",\"content\":\"yui\" }",
      "{ \"id\":\"30\",\"content\":\"ujm\" }",
      "{ \"id\":\"70\",\"content\":\"rfv\" }",
      "output:",
      "{ \"id\":\"10\",\"data\":\"abc\",\"content\":\"yui\" }",
      "{ \"id\":\"30\",\"data\":\"qwe\",\"content\":\"ujm\" }",
      "{ \"id\":\"40\",\"data\":\"wsx\",\"content\":\"tgb\" }",
      "jq --slurpfile file2 file2.json '\n  INDEX($file2[]; .id) as $dict\n  | $dict[.id] as $x\n  | if $x then . + $x else empty end\n'  file1.json"
    ],
    "utterance": "Join two files by matching id and combine their objects such that only those with the same id in both files are output, merging their fields.",
    "expressions": [
      "jq --slurpfile file2 file2.json 'INDEX($file2[]; .id) as $dict | $dict[.id] as $x | if $x then . + $x else empty end' file1.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": "10",
            "data": "abc"
          },
          {
            "id": "20",
            "data": "xyz"
          },
          {
            "id": "30",
            "data": "qwe"
          },
          {
            "id": "40",
            "data": "wsx"
          },
          {
            "id": "50",
            "data": "zxc"
          }
        ],
        "output": [
          {
            "id": "10",
            "data": "abc",
            "content": "yui"
          },
          {
            "id": "30",
            "data": "qwe",
            "content": "ujm"
          },
          {
            "id": "40",
            "data": "wsx",
            "content": "tgb"
          }
        ]
      }
    ],
    "identifier": 39830426
  },
  {
    "context": [
      "I want to return ids that the last login date is > 90days so in this case it should only return 9376.",
      "This seems to work\n\n    .users[] | select ( .last_login | fromdateiso8601 > 1475625600) | .id",
      "jq: error (at <stdin>:0): strptime/1 requires string inputs and arguments",
      "how do I deal with the null,  ideally those would be included in the results.",
      "Just add the appropriate null checks.\n\n    .users[] | select (.last_login | . == null or fromdateiso8601 > 1475625600).id ",
      "One way to protect against null values of .last_login would be as follows:\n\n    .users[]\n    | select ( .last_login // empty | fromdateiso8601 > 1475625600)\n    | .id ",
      "Or more defensively still, use `?`:\n\n    .users[]\n    | select ( .last_login | fromdateiso8601? > 1475625600)\n    | .id ",
      "If you want to include items for which .last_login evaluates to `null`, then you could use the filter that Jeff suggested"
    ],
    "utterance": "Return ids for users whose last_login is null or is after 2016-10-05T00:00:00Z (epoch 1475625600).",
    "expressions": [
      ".users[] | select(.last_login | . == null or fromdateiso8601 > 1475625600).id",
      ".users[] | select((.last_login // empty) | fromdateiso8601 > 1475625600) | .id",
      ".users[] | select(.last_login | fromdateiso8601? > 1475625600) | .id"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "id": 8734,
              "last_login": "2016-10-04T06:59:40Z"
            },
            {
              "id": 9376,
              "last_login": "2016-05-04T20:37:32Z"
            },
            {
              "id": 9376,
              "last_login": null
            }
          ]
        },
        "output": [
          9376
        ]
      }
    ],
    "identifier": 39881728
  },
  {
    "context": [
      "For example the input \"Y000062\" should yield \"Aye\"",
      "Here are three solutions using jq.  If an individual is constrained to vote exactly once, then the results should be the same; otherwise, they may differ, e.g if an individual is recorded as voting both Aye and Nay.",
      "$ jq  --arg id Y000062 '.votes\n| if any( .Aye[]; select(.id == $id) ) then \"Aye\" \nelif any( .Nay[]; select(.id == $id) ) then \"Nay\"\nelse \"none\"\nend' votes.json",
      "$ jq  --arg id Y000062 '.votes\n| ((.Aye[] | select(.id == $id) | \"Aye\") // \n   (.Nay[] | select(.id == $id) | \"Nay\")) ' votes.json",
      "$ jq --arg id Y000062 '.votes\n| ((.Nay[] | [\"Nay\", .id]),\n   (.Aye[] | [\"Aye\", .id]))\n| select(.[1] == $id)\n| .[0]' votes.json",
      "Here is a jq solution using [tostream](https://stedolan.github.io/jq/manual/#tostream)\n\n  .votes\n| tostream\n| select(length==2) as [$p,$v]\n| select($v == $id)\n| $p[0]"
    ],
    "utterance": "Given an id value, find the corresponding vote cast (e.g., 'Aye', 'Nay') for that id in the data.",
    "expressions": [
      ".votes | if any( .Aye[]; select(.id == $id) ) then \"Aye\" elif any( .Nay[]; select(.id == $id) ) then \"Nay\" else \"none\" end",
      ".votes | ((.Aye[] | select(.id == $id) | \"Aye\") // (.Nay[] | select(.id == $id) | \"Nay\"))",
      ".votes | ((.Nay[] | [\"Nay\", .id]), (.Aye[] | [\"Aye\", .id])) | select(.[1] == $id) | .[0]",
      ".votes | tostream | select(length==2) as [$p,$v] | select($v == $id) | $p[0]"
    ],
    "data": [
      {
        "input": {
          "bill": {
            "congress": 114,
            "type": "hr"
          },
          "category": "passage",
          "votes": {
            "Aye": [
              {
                "display_name": "Abraham",
                "id": "A000374"
              },
              {
                "display_name": "Yarmuth",
                "id": "Y000062"
              }
            ],
            "Nay": [
              {
                "display_name": "Clyburn",
                "id": "C000537"
              }
            ]
          }
        },
        "output": "Aye"
      }
    ],
    "identifier": 39813641
  },
  {
    "context": [
      "It is supposed to read from `JSON.txt` and to output the value of `sm_api_content` (which is a string).",
      "I am currently running this command:\r\n\r\n    %jq% -f JSON.txt -r \".sm_api_content\"",
      "`-f` is for specifying a filename to read your \"filter\" from - the filter in this case being `.sm_api_content`",
      "It sounds as if you just want to run `jq` without `-f`, e.g.\r\n\r\n    jq -r .sm_api_content JSON.txt"
    ],
    "utterance": "Select the value of the key sm_api_content from an object in the file JSON.txt and output it as a string.",
    "expressions": [
      "jq -r .sm_api_content JSON.txt"
    ],
    "identifier": 39912584
  },
  {
    "context": [
      "But I'm getting this error message:",
      "jq: error (at <stdin>:0): array ([{\"email\":\"...) is not valid in a csv row",
      "I think it's because of I have multiple e-mail adresses, is it possible to place all of them in a CSV cell seperated by comma? How can I achieve that with `jq`?",
      "jq -r -c '.results[0] | .data[] | .row[]\n  | add\n  | keys_unsorted as $keys\n  | ($keys, [.[$keys[]]])\n  | @csv' input.json",
      "With your illustrative input, the output would be:",
      "\"email\",\"date_found\",\"last_name\",\"provider_id\",\"first_name\",\"number\",\"lon\",\"lat\",\"street_name\",\"hood\"",
      "\"gdggdd@gmail.com\",\"2011-11-29 12:51:14\",\"Doe\",2649,\"John\",\"133\",3.21114,22.8844,\"Govstreet\",\"Rotterdam\""
    ],
    "utterance": "Export all property values from each row as a CSV with column headers, flattening nested arrays or objects into a single row.",
    "expressions": [
      ".results[0] | .data[] | .row[]\n  | add\n  | keys_unsorted as $keys\n  | ($keys, [.[$keys[]]])\n  | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "columns": [
                "path"
              ],
              "data": [
                {
                  "row": [
                    [
                      {
                        "email": "gdggdd@gmail.com"
                      },
                      {},
                      {
                        "date_found": "2011-11-29 12:51:14",
                        "last_name": "Doe",
                        "provider_id": 2649,
                        "first_name": "John"
                      },
                      {},
                      {
                        "number": "133",
                        "lon": 3.21114,
                        "lat": 22.8844
                      },
                      {},
                      {
                        "street_name": "Govstreet"
                      },
                      {},
                      {
                        "hood": "Rotterdam"
                      }
                    ]
                  ],
                  "meta": [
                    [
                      {
                        "id": 71390,
                        "type": "node",
                        "deleted": false
                      },
                      {
                        "id": 226866,
                        "type": "relationship",
                        "deleted": false
                      },
                      {
                        "id": 63457,
                        "type": "node",
                        "deleted": false
                      },
                      {
                        "id": 227100,
                        "type": "relationship",
                        "deleted": false
                      },
                      {
                        "id": 65076,
                        "type": "node",
                        "deleted": false
                      },
                      {
                        "id": 214799,
                        "type": "relationship",
                        "deleted": false
                      },
                      {
                        "id": 63915,
                        "type": "node",
                        "deleted": false
                      },
                      {
                        "id": 226552,
                        "type": "relationship",
                        "deleted": false
                      },
                      {
                        "id": 71120,
                        "type": "node",
                        "deleted": false
                      }
                    ]
                  ]
                }
              ]
            }
          ],
          "errors": []
        },
        "output": "\"email\",\"date_found\",\"last_name\",\"provider_id\",\"first_name\",\"number\",\"lon\",\"lat\",\"street_name\",\"hood\"\n\"gdggdd@gmail.com\",\"2011-11-29 12:51:14\",\"Doe\",2649,\"John\",\"133\",3.21114,22.8844,\"Govstreet\",\"Rotterdam\""
      }
    ],
    "identifier": 39896605
  },
  {
    "context": [
      "For each instance, I would like to extract the PublicDnsName and the value of the \"budget_cluster\" tag key. How to do this either with `ec2 describe-instances` or with `jq` ?",
      "jq '.Reservations[]\n      | .Instances[]\n      | [.PublicDnsName, (.Tags|from_entries|.budget_cluster)]'",
      "jq1.4 '.Reservations[]\n| .Instances[]\n| [.PublicDnsName, (.Tags[]|select(.Key==\"budget_cluster\") | .Value)]'"
    ],
    "utterance": "Extract for each instance a pair containing the PublicDnsName and the value of the tag with Key equal to budget_cluster.",
    "expressions": [
      ".Reservations[] | .Instances[] | [.PublicDnsName, (.Tags|from_entries|.budget_cluster)]",
      ".Reservations[] | .Instances[] | [.PublicDnsName, (.Tags[] | select(.Key==\"budget_cluster\") | .Value)]"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "PublicDnsName": "ec2-xxxxx.amazonaws.com",
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "yyyyy"
                    },
                    {
                      "Key": "budget_cluster",
                      "Value": "zzzzz"
                    },
                    {
                      "Key": "poc",
                      "Value": "aaaaaaa"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "ec2-xxxxx.amazonaws.com",
          "zzzzz"
        ]
      }
    ],
    "identifier": 39902587
  },
  {
    "context": [
      "Specifically what I&#39;m looking for is a list of instances where VpcId is null, undefined, or non-existent. In other words I&#39;d like a list of my Classic instances and I need this through api so I can process the results.",
      "You can better write it by factoring `Reservations[].Instances`:",
      "aws ec2 describe-instances |\\\n  jq '.Reservations[].Instances[] | .PublicDnsName, .VpcId'",
      "and jq supports transformation into csv but it needs to take an array and to avoid issues with double-quotes, you can work with raw data:",
      "aws ec2 describe-instances |\\\n  jq -r '.Reservations[].Instances[]\n         | [.PublicDnsName, .VpcId]\n         | @csv'"
    ],
    "utterance": "List the PublicDnsName and VpcId for each instance, formatting them as CSV values.",
    "expressions": [
      ".Reservations[].Instances[] | [.PublicDnsName, .VpcId] | @csv"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "PublicDnsName": "ec2-1-2-3-4.compute-1.amazonaws.com",
                  "VpcId": null
                },
                {
                  "PublicDnsName": "ec2-5-6-7-8.compute-1.amazonaws.com",
                  "VpcId": "vpc-1234abcd"
                }
              ]
            }
          ]
        },
        "output": [
          "\"ec2-1-2-3-4.compute-1.amazonaws.com\",null",
          "\"ec2-5-6-7-8.compute-1.amazonaws.com\",\"vpc-1234abcd\""
        ]
      }
    ],
    "identifier": 39863816
  },
  {
    "context": [
      "jq --arg user $SOME_USER '.something.user|=\"$user Did a thing\"'",
      "it seems to pick up the variable but not replace it in the string in the JQ script.",
      "You have to explicitly request interpolation with \\(...).",
      "jq --arg user \"$SOME_USER\" '.something.user|=\"\\($user) did a thing\"'"
    ],
    "utterance": "Set the field something.user to a string that concatenates the value of user and the text ' did a thing'.",
    "expressions": [
      ".something.user |= ($user + \" did a thing\")",
      ".something.user |= \"\\($user) did a thing\""
    ],
    "identifier": 39983705
  },
  {
    "context": [
      "Now, how can i get multiple values with \"Finish\", \"Start\" along with the hash values?",
      "Try \n\n    jq '(.info.file.hashes[] |select(.name == (\"A\",\"B\",\"C\")).value), .Finish, .Start' b.json",
      "\"f34d5f2d4577ed6d9ceec516c1f5a744\"",
      "\"66031dad95dfe6ad10b35f06c4342faa\"",
      "\"9df25fa4e379837e42aaf6d05d92012018d4b659\"",
      "1475668827",
      "1475668826",
      "Note the brackets used for grouping the pipe separately from the Finish and Start values."
    ],
    "utterance": "Retrieve the values for keys 'Finish', 'Start', and the values of all array entries where name is 'A', 'B', or 'C' under .info.file.hashes.",
    "expressions": [
      "(.info.file.hashes[] | select(.name == (\"A\",\"B\",\"C\")).value), .Finish, .Start"
    ],
    "data": [
      {
        "input": {
          "Finish": 1475668827,
          "Start": 1475668826,
          "info": {
            "file": {
              "Score": 4,
              "file_subtype": "None",
              "file_type": "Image",
              "hashes": [
                {
                  "name": "A",
                  "value": "f34d5f2d4577ed6d9ceec516c1f5a744"
                },
                {
                  "name": "B",
                  "value": "66031dad95dfe6ad10b35f06c4342faa"
                },
                {
                  "name": "C",
                  "value": "9df25fa4e379837e42aaf6d05d92012018d4b659"
                },
                {
                  "name": "D",
                  "value": "4a51cc531082d216a3cf292f4c39869b462bf6aa"
                },
                {
                  "name": "E",
                  "value": "e445f412f92b25f3343d5f7adc3c94bdc950601521d5b91e7ce77c21a18259c9"
                }
              ],
              "size": 500
            }
          }
        },
        "output": [
          "f34d5f2d4577ed6d9ceec516c1f5a744",
          "66031dad95dfe6ad10b35f06c4342faa",
          "9df25fa4e379837e42aaf6d05d92012018d4b659",
          1475668827,
          1475668826
        ]
      }
    ],
    "identifier": 39913930
  },
  {
    "context": [
      "With the help of **jq** i would like to select all addresses of nodes that have at least one **required=true** in their attribute list. The result list should have unique items.",
      "I first tried with:\n\n    jq '.nodes[] | select(.attributes[].required == true) | .address'\n\nThis produces:\n\n    \"127.0.0.1\"\n    \"127.0.0.1\"\n\nSo it gets the address for every **required=true** field it finds in the attributes section. How to make the result list unique?",
      "Consider using `any` instead (or as well), as it more precisely captures the intention (\"at least one\"), as well as having \"short-circuit\" semantics (i.e., it stops searching once the condition is true):",
      "$ jq '.nodes[]\n| select( any(.attributes[]; .required == true))\n| .address' input.json"
    ],
    "utterance": "Select all addresses from nodes where at least one attribute has required equal to true, ensuring the addresses are unique.",
    "expressions": [
      ".nodes[] | select(any(.attributes[]; .required == true)) | .address",
      ".nodes[] | select(any(.attributes[]; .required == true)) | .address | unique"
    ],
    "data": [
      {
        "input": {
          "nodes": [
            {
              "address": "127.0.0.1",
              "attributes": [
                {
                  "id": "abc",
                  "required": true
                },
                {
                  "id": "def",
                  "required": true
                },
                {
                  "id": "ghi",
                  "required": false
                }
              ]
            },
            {
              "address": "127.0.0.2",
              "attributes": [
                {
                  "id": "abc",
                  "required": false
                },
                {
                  "id": "def",
                  "required": false
                }
              ]
            }
          ]
        },
        "output": [
          "127.0.0.1"
        ]
      }
    ],
    "identifier": 39914570
  },
  {
    "context": [
      "I am trying to count the posts made by userid 4",
      "it should just count the posts by userId and display the answer which is  10",
      "$ curl -s 'http://jsonplaceholder.typicode.com/posts' |\n    jq '[ .[] |select(.userId==4) ] | length'\n10\n\nThe outer '[ ]' converts the command result to an array you can apply the 'length' on.",
      "map(select(.userId==4))|length",
      "The filter you could then use would be:\n\n     count(.[]|select(.userId==4))",
      "jq 'reduce .[] as $i(0;if $i.userId==4 then .+1 else . end)' \\",
      "curl -s 'http://jsonplaceholder.typicode.com/posts' |  jq 'group_by(.userId)|.[]|{userId: .[0].userId, count: (.|length)}|select(.userId==4)'"
    ],
    "utterance": "Count the number of posts where userId equals 4.",
    "expressions": [
      "[ .[] | select(.userId == 4) ] | length",
      "map(select(.userId == 4)) | length",
      "reduce .[] as $i (0; if $i.userId == 4 then . + 1 else . end)",
      "count(.[] | select(.userId==4))",
      "group_by(.userId) | .[] | {userId: .[0].userId, count: (.|length)} | select(.userId==4) | .count"
    ],
    "data": [
      {
        "input": [
          {
            "userId": 1,
            "id": 1,
            "title": "sunt aut facere repellat provident occaecati excepturi optio reprehenderit",
            "body": "quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto"
          },
          {
            "userId": 1,
            "id": 2,
            "title": "qui est esse",
            "body": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla"
          },
          {
            "userId": 4,
            "id": 31,
            "title": "ullam ut quidem id aut vel consequuntur",
            "body": "debitis eius sed quibusdam non quis consectetur vitae\nimpedit ut qui consequatur sed aut in\nquidem sit nostrum et maiores adipisci atque\nquaerat voluptatem earum perferendis qui cumque"
          },
          {
            "userId": 4,
            "id": 32,
            "title": "doloremque illum aliquid sunt",
            "body": "deserunt eos nobis asperiores et hic\nest debitis repellendus enim molestiae quia ut eius\\net voluptatis voluptatem\noccaecati exercitationem occaecati qui voluptatum"
          }
        ],
        "output": 2
      }
    ],
    "identifier": 39960034
  },
  {
    "context": [
      "In this example I want to select all Subnets elements that have a child tag with key \"Name\" and value \"TheName\". ... i.e. `\"Key\": \"Name\", \"Value\": \"TheName\"`",
      "jq '.Subnets[] | select(.Tags[].Value==\"TheName\")' output",
      "How do I use jq to select only the subnets that have the name/value pair I am looking for?",
      "Assuming your jq has `any/2`, a simple and efficient solution would be:",
      ".Subnets[]\n| select( any (.Tags[]; .Key == \"Name\" and .Value == \"TheName\") )",
      "Here is a solution which uses [indices](https://stedolan.github.io/jq/manual/#indices\\(s\\))",
      ".Subnets[] | select(.Tags | indices({Key:\"Name\", Value:\"TheName\"}) != [])"
    ],
    "utterance": "Select all Subnets elements that contain a tag with Key equal to \"Name\" and Value equal to \"TheName\".",
    "expressions": [
      ".Subnets[] | select( any (.Tags[]; .Key == \"Name\" and .Value == \"TheName\") )",
      ".Subnets[] | select(.Tags | indices({Key:\"Name\", Value:\"TheName\"}) != [])"
    ],
    "data": [
      {
        "input": {
          "Subnets": [
            {
              "VpcId": "vpc-12345678",
              "SubnetId": "subnet-1234567a",
              "Tags": [
                {
                  "Key": "IgnoreThis",
                  "Value": "TheName"
                },
                {
                  "Key": "Name",
                  "Value": "NotTheName"
                }
              ]
            },
            {
              "VpcId": "vpc-12345678",
              "SubnetId": "subnet-1234567b",
              "Tags": [
                {
                  "Key": "IgnoreThis",
                  "Value": "ignore"
                },
                {
                  "Key": "Name",
                  "Value": "TheName"
                }
              ]
            }
          ]
        },
        "output": {
          "VpcId": "vpc-12345678",
          "SubnetId": "subnet-1234567b",
          "Tags": [
            {
              "Key": "IgnoreThis",
              "Value": "ignore"
            },
            {
              "Key": "Name",
              "Value": "TheName"
            }
          ]
        }
      }
    ],
    "identifier": 39971324
  },
  {
    "context": [
      "What I expect to output is:\r\n\r\n    {\r\n      \"department\": \"Admin\",\r\n      \"user_age\": {\r\n        \"user1\": \"51\",\r\n        \"user2\": \"52\",\r\n        \"user3\": \"53\",\r\n        \"user4\": \"54\"\r\n      },\r\n      \"year\": 2016\r\n    }",
      "reduce .data[] as $d ({}; .[$d.user] = $d.age)",
      "{department: .arg1, user_age: (reduce .data[] as $d ({}; .[$d.user] = $d.age)), year: 2016}",
      "cat tmp.json|jq '{department: .arg1, user_age: (.data|map({(.user): .age})|add), year: 2016}'",
      ".data | map({key:user, value:age|tostring}) | from_entries",
      "{\n  \"department\": .arg1,\n  \"user_age\": .data | map({key:.user, value:.age|tostring}) | from_entries,\n  \"year\": 2016\n}"
    ],
    "utterance": "Produce an object with keys 'department' set to 'arg1', 'user_age' mapping user names to their ages as strings, and 'year' set to 2016.",
    "expressions": [
      "{department: .arg1, user_age: (reduce .data[] as $d ({}; .[$d.user] = ($d.age|tostring))), year: 2016}",
      "{department: .arg1, user_age: (.data|map({(.user): (.age|tostring)})|add), year: 2016}",
      "{department: .arg1, user_age: .data|map({key:.user, value:(.age|tostring)})|from_entries, year: 2016}"
    ],
    "data": [
      {
        "input": {
          "arg1": "Admin",
          "arg2": 0,
          "data": [
            {
              "arg3": "11",
              "user": "user1",
              "age": 51,
              "arg4": "11"
            },
            {
              "arg3": "22",
              "user": "user2",
              "age": 52,
              "arg4": "22"
            },
            {
              "arg3": "33",
              "user": "user3",
              "age": 53,
              "arg4": "33"
            },
            {
              "arg3": "44",
              "user": "user4",
              "age": 54,
              "arg4": "44"
            }
          ]
        },
        "output": {
          "department": "Admin",
          "user_age": {
            "user1": "51",
            "user2": "52",
            "user3": "53",
            "user4": "54"
          },
          "year": 2016
        }
      }
    ],
    "identifier": 39935596
  },
  {
    "context": [
      "data.Sample[0].values.push([1028088000000,0]);",
      "The jq equivalent of the given expression:",
      ".Sample[0].values += [[1028088000000,0]]"
    ],
    "utterance": "Append [1028088000000, 0] as a new sub-array to the values array inside the first element of the Sample array.",
    "expressions": [
      ".Sample[0].values += [[1028088000000,0]]"
    ],
    "data": [
      {
        "input": {
          "Sample": [
            {
              "key": "KeyName",
              "values": [
                [
                  1025409600000,
                  10
                ],
                [
                  1028088000000,
                  -6.3382185140371
                ]
              ]
            }
          ]
        },
        "output": {
          "Sample": [
            {
              "key": "KeyName",
              "values": [
                [
                  1025409600000,
                  10
                ],
                [
                  1028088000000,
                  -6.3382185140371
                ],
                [
                  1028088000000,
                  0
                ]
              ]
            }
          ]
        }
      }
    ],
    "identifier": 40016256
  },
  {
    "context": [
      "What I have is an array of object. I want to have an array of object filtered by unique value 'myprop'",
      "The problem is that is returns just the list of values not list of object",
      "It was pretty easy actually",
      ".values | unique_by(.myProp)"
    ],
    "utterance": "Return an array containing only one object for each distinct value of myProp, removing duplicates.",
    "expressions": [
      "unique_by(.myProp)",
      ".values | unique_by(.myProp)"
    ],
    "data": [
      {
        "input": [
          {
            "myProp": "similarValue"
          },
          {
            "myProp": "similarValue"
          },
          {
            "myProp": "OtherValue"
          }
        ],
        "output": [
          {
            "myProp": "similarValue"
          },
          {
            "myProp": "OtherValue"
          }
        ]
      }
    ],
    "identifier": 40103370
  },
  {
    "context": [
      "My structure is like this:",
      "{\n    \"nsgs\": [\n        {\n            \"comments\": \"text1\",\n            \"properties\": {\n                \"securityRules\": [\n                    {\n                        \"name\": \"1\",\n                        \"properties\": {\n                            \"protocol\": \"TCP\",\n                            \"sourcePortRange\": \"*\"\n                        }\n                    },\n                    {\n                        \"name\": \"2\",\n                        \"properties\": {\n                            \"protocol\": \"UDP\",\n                            \"sourcePortRange\": \"*\"\n                        }\n                    }\n                ]\n            }\n        },\n        {\n            \"comments\": \"text2\",\n            \"properties\": {\n                \"securityRules\": [\n                    {\n                        \"name\": \"3\",\n                        \"properties\": {\n                            \"protocol\": \"TCP\",\n                            \"sourcePortRange\": \"*\"\n                        }\n                    },\n                    {\n                        \"name\": \"4\",\n                        \"properties\": {\n                            \"protocol\": \"UDP\",\n                            \"sourcePortRange\": \"*\"\n                        }\n                    }\n                ]\n            }\n        }\n    ]}",
      "And what I want to get is:",
      "[\n{ \"comments\": \"text1\",\n  \"name\": \"1\",\n  \"protocol\": \"TCP\",\n  \"sourcePortRange\": \"*\"\n},\n{ \"comments\": \"text1\",\n  \"name\": \"2\",\n  \"protocol\": \"UDP\",\n  \"sourcePortRange\": \"*\"\n},\n{ \"comments\": \"text2\",\n  \"name\": \"3\",\n  \"protocol\": \"TCP\",\n  \"sourcePortRange\": \"*\"\n},\n{ \"comments\": \"text2\",\n  \"name\": \"4\",\n  \"protocol\": \"UDP\",\n  \"sourcePortRange\": \"*\"\n}\n]",
      "The following filter, laid out here for easy reading, will aggregate the input as requested:",
      ".nsgs\n| map(.comments as $comments\n      | .properties.securityRules[]\n      | {comments: $comments,\n         name, \n         protocol: .properties.protocol,\n         sourcePortRange: .properties.sourcePortRange } )",
      "| {comments: $comments, name }\n  + (.properties | {protocol, sourcePortRange} ) )",
      "Here is another solution:",
      ".nsgs | map({comments} + (.properties.securityRules[] | {name}+.properties))"
    ],
    "utterance": "Transform an array of network security groups, each containing a comments field and nested securityRules, into a flat array of objects with comments, name, protocol, and sourcePortRange fields for each security rule.",
    "expressions": [
      ".nsgs | map(.comments as $comments | .properties.securityRules[] | {comments: $comments, name, protocol: .properties.protocol, sourcePortRange: .properties.sourcePortRange})",
      ".nsgs | map(.comments as $comments | .properties.securityRules[] | {comments: $comments, name} + (.properties | {protocol, sourcePortRange}))",
      ".nsgs | map({comments} + (.properties.securityRules[] | {name}+.properties))"
    ],
    "data": [
      {
        "input": {
          "nsgs": [
            {
              "comments": "text1",
              "properties": {
                "securityRules": [
                  {
                    "name": "1",
                    "properties": {
                      "protocol": "TCP",
                      "sourcePortRange": "*"
                    }
                  },
                  {
                    "name": "2",
                    "properties": {
                      "protocol": "UDP",
                      "sourcePortRange": "*"
                    }
                  }
                ]
              }
            },
            {
              "comments": "text2",
              "properties": {
                "securityRules": [
                  {
                    "name": "3",
                    "properties": {
                      "protocol": "TCP",
                      "sourcePortRange": "*"
                    }
                  },
                  {
                    "name": "4",
                    "properties": {
                      "protocol": "UDP",
                      "sourcePortRange": "*"
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "comments": "text1",
            "name": "1",
            "protocol": "TCP",
            "sourcePortRange": "*"
          },
          {
            "comments": "text1",
            "name": "2",
            "protocol": "UDP",
            "sourcePortRange": "*"
          },
          {
            "comments": "text2",
            "name": "3",
            "protocol": "TCP",
            "sourcePortRange": "*"
          },
          {
            "comments": "text2",
            "name": "4",
            "protocol": "UDP",
            "sourcePortRange": "*"
          }
        ]
      }
    ],
    "identifier": 39977784
  },
  {
    "context": [
      "How do I search for commits from specific authors?  For example, if I only want to return commits from \"dtolnay\" and \"stedolan\"?",
      "I can for example get commit messages from just 'stedolan'; however, I'd like to do something like `select(.author.login in(\"stedolan\", \"dtolnay\"))`"
    ],
    "utterance": "Return commit messages for commits authored by either 'dtolnay' or 'stedolan'.",
    "expressions": [
      ".[] | select(.author.login == \"stedolan\" or .author.login == \"dtolnay\") | .commit.message",
      ".[] | select([\"stedolan\", \"dtolnay\"] | index(.author.login)) | .commit.message"
    ],
    "identifier": 40117713
  },
  {
    "context": [
      "how in JQ switch number output format `3.5e-07` to `0.00000035` ?",
      "you can use `printf` to format a number in scientific notation as a decimal.",
      "$ printf '%.8f' $(curl -s https://bittrex.com/api/v1.1/public/getticker?market=btc-doge | jq \".result.Ask\")",
      "The `.8` in the printf command is specifying 8 places of precision."
    ],
    "utterance": "Convert scientific notation number 3.5e-07 to fixed-point decimal format 0.00000035 with 8 decimal places.",
    "expressions": [
      ".result.Ask | @sprintf(\"%.8f\")"
    ],
    "data": [
      {
        "input": 3.5e-07,
        "output": "0.00000035"
      }
    ],
    "identifier": 40125663
  },
  {
    "context": [
      "projectID=$(cat file.json | jq -r '.resource[] | select(.username==\"myemail@hotmail.com\") | .id')",
      "projectID=$(cat file.json | jq -r '.resource[] | select(.username==\"$EMAILID\") | .id')",
      "projectID=$(jq -r --arg EMAILID \"$EMAILID\" '\n     .resource[]\n     | select(.username==$EMAILID) \n     | .id' file.json)",
      "projectID=$(cat file.json | jq --arg EMAILID $EMAILID -r '.resource[] \n| select(.username==\"$EMAILID\") | .id')",
      "projectID=$(cat file.json | jq -r \".resource[] | select(.username==env.EMAILID) | .id\")"
    ],
    "utterance": "Select the id of the object in the resource array where username matches the value of the EMAILID shell variable.",
    "expressions": [
      ".resource[] | select(.username==\"$EMAILID\") | .id",
      "--arg EMAILID \"$EMAILID\" '.resource[] | select(.username==$EMAILID) | .id'",
      "--arg EMAILID $EMAILID '.resource[] | select(.username==\"$EMAILID\") | .id'",
      ".resource[] | select(.username==env.EMAILID) | .id"
    ],
    "data": [
      {
        "input": {
          "resource": [
            {
              "username": "foo@bar.com",
              "id": 1
            },
            {
              "username": "myemail@hotmail.com",
              "id": 42
            }
          ]
        },
        "output": 42
      }
    ],
    "identifier": 40027395
  },
  {
    "context": [
      "shell_exec('cd /home/scripts/scripts; ./total.sh | jq '.hits .hits [] .fields[\"termListData.terms\"] | .[]' | wc -l > /home/data/total.csv');",
      "$jq_args = '.hits .hits [] .fields[\"termListData.terms\"] | .[]';",
      "$cmd = 'cd /home/scripts/scripts; ./total.sh | jq '.escapeshellarg($jq_args).' | wc -l > /home/data/total.csv';"
    ],
    "utterance": "Select all elements from the termListData.terms field inside every hit within the hits array.",
    "expressions": [
      ".hits.hits[] .fields[\"termListData.terms\"] | .[]"
    ],
    "identifier": 40107941
  },
  {
    "context": [
      "The input looks like this:\r\n\r\n    [\r\n        { \"key\": \"1\", \"value\": \"value 1\"},\r\n        { \"key\": \"2\", \"value\": \"value 2\"},\r\n        { \"key\": \"1\", \"value\": \"value 3\"},\r\n    ]",
      "What I want to get is this:\r\n\r\n    {\r\n        \"1\": { \"values\": [\"value 1\", \"value 3\"] },\r\n        \"2\": { \"values\": [\"value 2\"] }\r\n    }\r\n\r\nor, for my use case:\r\n\r\n    {\r\n        \"1\": [ \"value 1\", \"value 3\" ],\r\n        \"2\": [ \"value 2\" ]\r\n    }\r\n\r\nwould also be OK.",
      "I want to accomplish is something like \"create a new key/value pair or add .value to an already existing one's 'values' array\".",
      "group_by(.key) | map({ \"key\": .[0].key, \"values\": map(.value) | unique })",
      "def meld:\r\n  reduce .[] as $o\r\n    ({}; reduce ($o|keys)[] as $key (.; .[$key] += [$o[$key]] ));",
      "data |  map([.] | from_entries) | meld"
    ],
    "utterance": "Aggregate objects with the same key by collecting their value fields into arrays under each key in the output object.",
    "expressions": [
      "group_by(.key) | map({ \"key\": .[0].key, \"values\": map(.value) | unique })",
      "def meld:\n  reduce .[] as $o\n    ({}; reduce ($o|keys)[] as $key (.; .[$key] += [$o[$key]] ));\n\nmap({ (.key): .value }) | add",
      "map({ (.key): .value }) | add",
      "map([.] | from_entries) | def meld:\n  reduce .[] as $o\n    ({}; reduce ($o|keys)[] as $key (.; .[$key] += [$o[$key]] ));\nmeld"
    ],
    "data": [
      {
        "input": [
          {
            "key": "1",
            "value": "value 1"
          },
          {
            "key": "2",
            "value": "value 2"
          },
          {
            "key": "1",
            "value": "value 3"
          }
        ],
        "output": {
          "1": [
            "value 1",
            "value 3"
          ],
          "2": [
            "value 2"
          ]
        }
      }
    ],
    "identifier": 39994652
  },
  {
    "context": [
      "How can we select only the hash values from desired 'name'. Example : If we want to select only hash values of string 'names' B,C,E in any JSON files using JQ ?",
      "jq -r '.info.file.hashes[] | select(.name == \"B\") | .value'",
      "jq -r '.info.file.hashes[] | select(.name | in({\"B\":1,\"C\":1})) | .value'",
      "jq -M -r --argjson names '[\"B\",\"C\",\"E\"]' -f filter.jq a.json b.json"
    ],
    "utterance": "Select all hash values whose name field is B, C, or E.",
    "expressions": [
      ".info.file.hashes[] | select(.name == \"B\" or .name == \"C\" or .name == \"E\") | .value",
      ".info.file.hashes[] | select(.name | in({\"B\":1,\"C\":1,\"E\":1})) | .value",
      ".info.file.hashes | map(select(.name == \"B\" or .name == \"C\" or .name == \"E\")).value[]",
      ".info.file.hashes | map(select(.name | IN([\"B\",\"C\",\"E\"]))).value[]"
    ],
    "data": [
      {
        "input": {
          "info": {
            "file": {
              "Score": 4.01207390507143,
              "file_subtype": "None",
              "file_type": "EXE",
              "hashes": [
                {
                  "name": "A",
                  "value": "7e5dcd8ffdfa8d726ecbdd3c69e18230"
                },
                {
                  "name": "B",
                  "value": "3c6781d16dc26baf6422bb24d1cd0f650e451b99"
                },
                {
                  "name": "C",
                  "value": "3c6781d16dc26baf6422bb24d1cd0f650e451b99"
                },
                {
                  "name": "D",
                  "value": "c25561f3246ef188467a47971821bab93934842a1e2a48910db9768a2f66e828"
                }
              ],
              "size": 1912
            }
          }
        },
        "output": [
          "3c6781d16dc26baf6422bb24d1cd0f650e451b99",
          "3c6781d16dc26baf6422bb24d1cd0f650e451b99"
        ]
      },
      {
        "input": {
          "info": {
            "file": {
              "Score": 4,
              "file_subtype": "None",
              "file_type": "Image",
              "hashes": [
                {
                  "name": "A",
                  "value": "f34d5f2d4577ed6d9ceec516c1f5a744"
                },
                {
                  "name": "B",
                  "value": "66031dad95dfe6ad10b35f06c4342faa"
                },
                {
                  "name": "C",
                  "value": "9df25fa4e379837e42aaf6d05d92012018d4b659"
                },
                {
                  "name": "D",
                  "value": "4a51cc531082d216a3cf292f4c39869b462bf6aa"
                },
                {
                  "name": "E",
                  "value": "e445f412f92b25f3343d5f7adc3c94bdc950601521d5b91e7ce77c21a18259c9"
                }
              ],
              "size": 500
            }
          }
        },
        "output": [
          "66031dad95dfe6ad10b35f06c4342faa",
          "9df25fa4e379837e42aaf6d05d92012018d4b659",
          "e445f412f92b25f3343d5f7adc3c94bdc950601521d5b91e7ce77c21a18259c9"
        ]
      }
    ],
    "identifier": 39902450
  },
  {
    "context": [
      "I would like to use JQ to tell me how many students achieved a score > x, for each test.",
      "Thus for the above input and x = 50, the output:\r\n\r\n    {testId: '1' numStudents:1}\r\n    {testId: '2' numStudents:2}\r\n    {testId: '3' numStudents:0}",
      "The following assumes the input consists of a stream of valid JSON objects.",
      "$ jq '{testId, numStudents: ([select(.studentId[].score > 50) | 1] | add // 0)}'",
      "{testId,\r\n numStudents: ([select(.studentId[].score > 50) ] | length)}",
      "def count(s): reduce s as $i (0; .+1);\r\n\r\n{testId, numStudents: count(select(.studentId[].score > 50))}"
    ],
    "utterance": "Count the number of students with a score greater than 50 for each test, outputting the testId and the count as numStudents.",
    "expressions": [
      "{testId, numStudents: ([select(.studentId[].score > 50) | 1] | add // 0)}",
      "{testId, numStudents: ([select(.studentId[].score > 50)] | length)}",
      "def count(s): reduce s as $i (0; .+1); {testId, numStudents: count(select(.studentId[].score > 50))}"
    ],
    "data": [
      {
        "input": {
          "testId": "1",
          "studentId": {
            "s1": {
              "score": 20
            },
            "s2": {
              "score": 80
            }
          }
        },
        "output": {
          "testId": "1",
          "numStudents": 1
        }
      },
      {
        "input": {
          "testId": "2",
          "studentId": {
            "s1": {
              "score": 60
            },
            "s2": {
              "score": 70
            }
          }
        },
        "output": {
          "testId": "2",
          "numStudents": 2
        }
      },
      {
        "input": {
          "testId": "3",
          "studentId": {
            "s5": {
              "score": 40
            },
            "s7": {
              "score": 30
            }
          }
        },
        "output": {
          "testId": "3",
          "numStudents": 0
        }
      }
    ],
    "identifier": 40120333
  },
  {
    "context": [
      "The problem is, I want to negate that and only show commits from authors besides 'stedolan' and 'dtolnay'; however, if I use != or not, I seem to get the same wrong result:",
      "One solution would simply be to use `index` with `not`:",
      "    .[] | .author.login | select( . as $i | $blacklist | index($i) | not)",
      "However, assuming your jq has `all/2`, there is something to be said for using it:",
      "    .[] | .author.login | select( . as $i | all($blacklist[]; $i != .))"
    ],
    "utterance": "Filter the authors so that only those whose login is not in the blacklist array (specifically, not 'stedolan' or 'dtolnay') are selected.",
    "expressions": [
      ".[] | .author.login | select( . as $i | $blacklist | index($i) | not)",
      ".[] | .author.login | select( . as $i | all($blacklist[]; $i != .))"
    ],
    "identifier": 40141310
  },
  {
    "context": [
      "I want to check if the attribute keys are in a list of possible keys.",
      "# attributes \"a\" and \"b\" contain quoted JSON",
      "with_entries(if is_json(.key) then .value = (.value|fromjson) else . end)",
      "def is_json($o): any( (\"a\",\"b\"); . == $o );",
      "with_entries(if is_json(.key) then .value |= fromjson else . end)",
      "reduce keys[] as $key\n  (.; if any((\"a\",\"b\"); . == $key) then .[$key] |= fromjson else . end)"
    ],
    "utterance": "Convert the values of keys 'a' and 'b' from their stringified forms to parsed objects while leaving other keys unchanged.",
    "expressions": [
      "def is_json($o): any((\"a\",\"b\"); . == $o); with_entries(if is_json(.key) then .value |= fromjson else . end)",
      "reduce keys[] as $key (.; if any((\"a\",\"b\"); . == $key) then .[$key] |= fromjson else . end)"
    ],
    "data": [
      {
        "input": {
          "a": "{\"x\":1}",
          "y": 2
        },
        "output": {
          "a": {
            "x": 1
          },
          "y": 2
        }
      }
    ],
    "identifier": 40135852
  },
  {
    "context": [
      "Unfortunately, cat does not expand variables into values.",
      "So, then I need to insert some variables into template using jq and create some new file with expanded variables.",
      "Unfortunatelly, it just inserts new strings with variables, but not expands variables in template:"
    ],
    "utterance": "Replace placeholder string values with provided variable values in specific fields (like ip_range and description) in a template, so the output contains the actual variable values.",
    "expressions": [
      ".ip_range = $snmp_ip1 | .description = $snmp_cred1 | .\"snmp.community\" = $snmp_cred1"
    ],
    "data": [
      {
        "input": {
          "ip_range": "$snmp_ip1",
          "types": [
            "snmp"
          ],
          "description": "$snmp_cred1",
          "snmp.version": "v2c",
          "snmp.port": 161,
          "snmp.community": "$snmp_cred1",
          "snmp.retries": 3,
          "snmp.timeout": 2
        },
        "output": {
          "ip_range": "10.82.112.21",
          "types": [
            "snmp"
          ],
          "description": "fortinet/fortigate/1.3.6.1.4.1.12356.101.1.37000_fortigate3700d/10.82.112.21@public",
          "snmp.version": "v2c",
          "snmp.port": 161,
          "snmp.community": "fortinet/fortigate/1.3.6.1.4.1.12356.101.1.37000_fortigate3700d/10.82.112.21@public",
          "snmp.retries": 3,
          "snmp.timeout": 2
        }
      }
    ],
    "identifier": 40129843
  },
  {
    "context": [
      "echo '{\"aggregations\":{\"sent\":{\"value\":25},\"bounced\":{\"value\":null},\"incoming_act\":{\"value\":12}}}' | jq '.aggregations | {\"num_sent\": .sent.value, \"num_incoming_act\": .incoming_act.value } | {diff:(.num_sent as $x | .num_incoming_act as $y | $y-$x as $d | $d)}'",
      "Will Produce:",
      "{\n  \"diff\": -13\n}",
      "In the examples where you get an error, write `($y-$x) as $d` rather than just `$y-$x as $d`.  The parentheses are sometimes necessary, and always advisable, when writing `(COMPOUND INFIX EXPRESSION) as $variable`."
    ],
    "utterance": "Create an object with a property diff containing the result of subtracting incoming_act.value from sent.value inside aggregations, e.g. diff: .incoming_act.value - .sent.value.",
    "expressions": [
      ".aggregations | {num_sent: .sent.value, num_incoming_act: .incoming_act.value} | {diff: (.num_incoming_act as $y | .num_sent as $x | ($y-$x)) }",
      ".aggregations | {num_sent: .sent.value, num_incoming_act: .incoming_act.value} | {diff: ((.num_incoming_act - .num_sent)) }"
    ],
    "data": [
      {
        "input": {
          "aggregations": {
            "sent": {
              "value": 25
            },
            "bounced": {
              "value": null
            },
            "incoming_act": {
              "value": 12
            }
          }
        },
        "output": {
          "diff": -13
        }
      }
    ],
    "identifier": 40130112
  },
  {
    "context": [
      "what I want to do is get every `id` in a loop,",
      "$ jq .id <<< \"$json\" | while read id ; do echo \"hello $id\"; done",
      "Output:",
      "hello 3397",
      "hello 3396"
    ],
    "utterance": "Extract all id values from each object in the array.",
    "expressions": [
      ".id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 3397,
            "title": "title_1"
          },
          {
            "id": 3396,
            "title": "title_2"
          }
        ],
        "output": [
          3397,
          3396
        ]
      }
    ],
    "identifier": 40242529
  },
  {
    "context": [
      "I need to get the application version from the above result.",
      "jq -r '.\"application.version\"'"
    ],
    "utterance": "Extract the value of the \"application.version\" key from the data.",
    "expressions": [
      ".\"application.version\"",
      ".[\"application.version\"]",
      "jq -r '.\"application.version\"'"
    ],
    "data": [
      {
        "input": {
          "application.name": "var-integration-xx",
          "application.version": "1.13.0-241",
          "os.name": "Linux"
        },
        "output": "1.13.0-241"
      }
    ],
    "identifier": 40357558
  },
  {
    "context": [
      "While extracting the message field in the below mentioned JSON file using jq, I'm getting newline characters and tab spaces. I want to remove the escape sequence characters and I have tried it using sed, but it did not work.",
      "$ jq -r '.content.message | gsub(\"[\\\\n\\\\t]\"; \"\")' file.json",
      "jq -rc \".content.message\" file.json",
      "$ jq 'walk(if type == \"string\" then gsub(\"\\\\p{Cc}\"; \"\") else . end)'"
    ],
    "utterance": "Remove all newline and tab escape characters from the 'message' field inside 'content'.",
    "expressions": [
      ".content.message | gsub(\"[\\n\\t]\"; \"\")",
      "walk(if type == \"string\" then gsub(\"\\p{Cc}\"; \"\") else . end)"
    ],
    "data": [
      {
        "input": {
          "HOSTNAME": "server1.example",
          "level": "WARN",
          "level_value": 30000,
          "logger_name": "server1.example.adapter",
          "content": {
            "message": "ERROR LALALLLA\nERROR INFO NANANAN\tSOME MORE ERROR INFO\nBABABABABABBA\n BABABABA\t ABABBABAA\n\n BABABABAB\n\n"
          }
        },
        "output": "ERROR LALALLLAERROR INFO NANANANSOME MORE ERROR INFOBABABABABABBA BABABABA ABABBABAA BABABABAB"
      }
    ],
    "identifier": 40321035
  },
  {
    "context": [
      "I need to sort this array based on the Timestamp to get the data in chronological order.",
      "If want to go with jq instead you'll use jq's [`sort_by`](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions) method as follow",
      "| jq -r '.Datapoints | sort_by(.Timestamp)[]'"
    ],
    "utterance": "Sort the Datapoints array by the Timestamp property in ascending chronological order.",
    "expressions": [
      ".Datapoints | sort_by(.Timestamp)[]"
    ],
    "data": [
      {
        "input": {
          "Datapoints": [
            {
              "Timestamp": "2016-10-18T12:11:00Z",
              "Average": 0.2588009963201394,
              "Minimum": 0.0007181167602539062,
              "Maximum": 3.203943729400635,
              "Unit": "Seconds"
            },
            {
              "Timestamp": "2016-10-18T12:10:00Z",
              "Average": 0.2519733751768076,
              "Minimum": 0.0006361007690429688,
              "Maximum": 2.839790821075439,
              "Unit": "Seconds"
            },
            {
              "Timestamp": "2016-10-18T12:19:00Z",
              "Average": 0.2287127116954388,
              "Minimum": 0.0006167888641357422,
              "Maximum": 1.416410446166992,
              "Unit": "Seconds"
            }
          ]
        },
        "output": [
          {
            "Timestamp": "2016-10-18T12:10:00Z",
            "Average": 0.2519733751768076,
            "Minimum": 0.0006361007690429688,
            "Maximum": 2.839790821075439,
            "Unit": "Seconds"
          },
          {
            "Timestamp": "2016-10-18T12:11:00Z",
            "Average": 0.2588009963201394,
            "Minimum": 0.0007181167602539062,
            "Maximum": 3.203943729400635,
            "Unit": "Seconds"
          },
          {
            "Timestamp": "2016-10-18T12:19:00Z",
            "Average": 0.2287127116954388,
            "Minimum": 0.0006167888641357422,
            "Maximum": 1.416410446166992,
            "Unit": "Seconds"
          }
        ]
      }
    ],
    "identifier": 40152622
  },
  {
    "context": [
      "It is possible to convert every line of raw input into a JSON string:\r\n\r\n    $ echo -e \"a\\nb\" | jq -Rc . \r\n    \"a\"\r\n    \"b\"",
      "In that example it makes no difference, when the dot expression is missing:\r\n\r\n    $ echo -e \"a\\nb\" | jq -Rc \r\n    \"a\"\r\n    \"b\"",
      "Next I can read the output from the first `jq` and slurp it into an array:\r\n\r\n    $ echo -e \"a\\nb\" | jq -Rc . | jq -sc .\r\n    [\"a\",\"b\"]",
      "Here it makes also no difference, when I omit the dot expression:\r\n\r\n    $ echo -e \"a\\nb\" | jq -Rc . | jq -sc  \r\n    [\"a\",\"b\"]"
    ],
    "utterance": "Output each input line as a string or collect them into an array, allowing the filter to be omitted.",
    "expressions": [
      ".",
      ""
    ],
    "data": [
      {
        "input": "a\nb",
        "output": [
          "\"a\"",
          "\"b\""
        ]
      },
      {
        "input": "a\nb",
        "output": [
          "[\"a\",\"b\"]"
        ]
      }
    ],
    "identifier": 40301450
  },
  {
    "context": [
      "I would like to delete all the resloved from a npm shrinwrap json file.",
      "How can I delete the resolved key from all the file",
      "I'm using the pattern : jq 'del(.resolved)' file.json",
      "In my opinion, the simplest approach to this kind of problem is to use `walk/1`:",
      "walk(if type == \"object\" and has(\"resolved\") then del(.resolved) else . end)"
    ],
    "utterance": "Remove every key named 'resolved', regardless of its level or position within the document.",
    "expressions": [
      "walk(if type == \"object\" and has(\"resolved\") then del(.resolved) else . end)"
    ],
    "data": [
      {
        "input": {
          "cssstyle": {
            "version": "0.2.37",
            "from": "cssstyle@>=0.2.29 <0.3.0",
            "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-0.2.37.tgz"
          },
          "dashdash": {
            "version": "1.14.0",
            "from": "dashdash@>=1.12.0 <2.0.0",
            "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.0.tgz",
            "dependencies": {
              "assert-plus": {
                "version": "1.0.0",
                "from": "assert-plus@>=1.0.0 <2.0.0",
                "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz"
              }
            }
          }
        },
        "output": {
          "cssstyle": {
            "version": "0.2.37",
            "from": "cssstyle@>=0.2.29 <0.3.0"
          },
          "dashdash": {
            "version": "1.14.0",
            "from": "dashdash@>=1.12.0 <2.0.0",
            "dependencies": {
              "assert-plus": {
                "version": "1.0.0",
                "from": "assert-plus@>=1.0.0 <2.0.0"
              }
            }
          }
        }
      }
    ],
    "identifier": 40361457
  },
  {
    "context": [
      "I have some json input data I would like to extract the variable values into something I can paste into my script",
      "**input sample:**",
      "{\n  \"menu\": {\n    \"props\": [{\n      \"name\": \"foo1\",\n      \"model\": \"bar1\"\n    }, {\n      \"name\": \"foo2\",\n      \"model\": \"bar2\"\n    }, {\n      \"name\": \"foo3\",\n      \"model\": \"bar3\"\n    }, {\n      \"name\": \"foo4\",\n      \"model\": \"bar4\"\n    }, {\n      \"name\": \"foo5\",\n      \"model\": \"bar5\"\n    }]\n  }\n}",
      "**desired output:**",
      "AddMenuItem(menu, \"bar1\", \"foo1\");\nAddMenuItem(menu, \"bar2\", \"foo2\");\nAddMenuItem(menu, \"bar3\", \"foo3\");\n...etc",
      "Something like this would work:",
      "$ jq -r '.menu.props[] | \"AddMenuItem(menu, \\\"\\(.model)\\\", \\\"\\(.name)\\\")\"' file.txt",
      "AddMenuItem(menu, \"bar1\", \"foo1\")",
      "One can also use `...props | map(\"AddMenu...\")[]` which might be more intuitive.",
      "`\\(...)` enables string interpolation between (` and `)."
    ],
    "utterance": "Print each entry as AddMenuItem(menu, model, name); using each object's model and name values inside the props array under menu",
    "expressions": [
      ".menu.props[] | \"AddMenuItem(menu, \\\"\\(.model)\\\", \\\"\\(.name)\\\");\"",
      ".menu.props | map(\"AddMenuItem(menu, \\\"\\(.model)\\\", \\\"\\(.name)\\\");\")[]"
    ],
    "data": [
      {
        "input": {
          "menu": {
            "props": [
              {
                "name": "foo1",
                "model": "bar1"
              },
              {
                "name": "foo2",
                "model": "bar2"
              },
              {
                "name": "foo3",
                "model": "bar3"
              },
              {
                "name": "foo4",
                "model": "bar4"
              },
              {
                "name": "foo5",
                "model": "bar5"
              }
            ]
          }
        },
        "output": [
          "AddMenuItem(menu, \"bar1\", \"foo1\");",
          "AddMenuItem(menu, \"bar2\", \"foo2\");",
          "AddMenuItem(menu, \"bar3\", \"foo3\");",
          "AddMenuItem(menu, \"bar4\", \"foo4\");",
          "AddMenuItem(menu, \"bar5\", \"foo5\");"
        ]
      }
    ],
    "identifier": 40359573
  },
  {
    "context": [
      "I have a JSON file with the following format:\r\n\r\n    [\r\n      {\r\n        \"id\": \"00001\",\r\n        \"attr\": {\r\n          \"a\": \"foo\",\r\n          \"b\": \"bar\",\r\n          ...\r\n        }\r\n      },\r\n      {\r\n        \"id\": \"00002\",\r\n        \"attr\": {\r\n          ...\r\n        },\r\n        ...\r\n      },\r\n    ...\r\n    ]\r\n\r\nand a text file with a list of ids, one per line. I'd like to use `jq` to filter only the records whose ids are mentioned in the text file. I.e. if the list contains \"00001\", only the first one should be printed.",
      "The trick is to convert ids.txt into a JSON array.  With the above assumption about quotation marks, this can be done by: \r\n\r\n    jq -R . ids.txt | jq -s .",
      "jq --argjson ids \"$(jq -R . ids.txt | jq -s .)\" '\r\n  map( select( .id as $id | $ids | index($id) ))' in.json",
      "def isin($a): . as $in | any($a[]; $in == .);\r\n\r\nThe required jq filter is then just: \r\n\r\n    map( select( .id | isin($ids) ) )",
      "jq --argjson ids \"$(jq -R . ids.txt | jq -s)\" -f select.jq in.json",
      "jq --slurpfile ids ids.txt 'map(select(.id as $id|any($ids[];$id==.)))' in.json"
    ],
    "utterance": "Filter only the objects where the id field matches any of the values listed in an external text file (one id per line).",
    "expressions": [
      "jq --argjson ids \"$(jq -R . ids.txt | jq -s .)\" 'map( select( .id as $id | $ids | index($id) ))' in.json",
      "def isin($a): . as $in | any($a[]; $in == .); map( select( .id | isin($ids) ) )",
      "jq --slurpfile ids ids.txt 'map(select(.id as $id|any($ids[];$id==.)))' in.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": "00001",
            "attr": {
              "a": "foo",
              "b": "bar"
            }
          },
          {
            "id": "00002",
            "attr": {
              "a": "baz"
            }
          }
        ],
        "output": [
          {
            "id": "00001",
            "attr": {
              "a": "foo",
              "b": "bar"
            }
          }
        ]
      }
    ],
    "identifier": 40354176
  },
  {
    "context": [
      "So say we have input:\r\n\r\n    [\r\n        {\r\n            \"name\": \"John\",\r\n            \"email\": \"john@company.com\"\r\n        },\r\n        {\r\n            \"name\": \"Brad\",\r\n            \"email\": \"brad@company.com\"\r\n        }\r\n    ]\r\n\r\nand desired output is:\r\n\r\n    {\r\n        \"name\": \"John\",\r\n        \"email\": \"john@company.com\"\r\n    }\r\n    {\r\n        \"name\": \"Brad\",\r\n        \"email\": \"brad@company.com\"\r\n    }",
      "You can use this :\r\n\r\n    jq '.[]' file\r\n",
      "If you use the `.[index]` syntax, but omit the index entirely, it will return all of the elements of an array."
    ],
    "utterance": "Output each object of an array as a separate object in the output stream.",
    "expressions": [
      ".[]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "email": "john@company.com"
          },
          {
            "name": "Brad",
            "email": "brad@company.com"
          }
        ],
        "output": [
          {
            "name": "John",
            "email": "john@company.com"
          },
          {
            "name": "Brad",
            "email": "brad@company.com"
          }
        ]
      }
    ],
    "identifier": 40381981
  },
  {
    "context": [
      "I wanna select \"created_at\" from \"2016-10-21\" to \"2016-10-22\";",
      "I wanna get result like this:\n\n    [{\n        \"id\": 3624,\n        \"created_at\": \"2016-10-21T20:51:16.000+08:00\",\n      },\n      {\n         \"id\": 3625,\n        \"created_at\": \"2016-10-22T08:09:16.000+08:00\",\n      }]",
      "jq --arg s '2016-10-21T20:51' --arg e '2016-10-22T08:09' '\n  map(select(.created_at | . >= $s and . <= $e + \"z\"))\n' <<<\"$json\"",
      "$ jq --arg s '2016-10-21' --arg e '2016-10-22' '\n[($s, $e) | strptime(\"%Y-%m-%d\")[0:3]] as $r\n  | map(select(\n        (.created_at[:19] | strptime(\"%Y-%m-%dT%H:%M:%S\")[0:3]) as $d\n          | $d >= $r[0] and $d <= $r[1]\n    ))\n' input.json"
    ],
    "utterance": "Select objects where the created_at date is between 2016-10-21 and 2016-10-22 inclusive.",
    "expressions": [
      "map(select(.created_at >= $s and .created_at <= $e + \"z\"))",
      "[($s, $e) | strptime(\"%Y-%m-%d\")[0:3]] as $r | map(select((.created_at[:19] | strptime(\"%Y-%m-%dT%H:%M:%S\")[0:3]) as $d | $d >= $r[0] and $d <= $r[1]))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 3624,
            "created_at": "2016-10-21T20:51:16.000+08:00"
          },
          {
            "id": 3625,
            "created_at": "2016-10-22T08:09:16.000+08:00"
          },
          {
            "id": 3626,
            "created_at": "2016-10-23T09:19:55.000+08:00"
          }
        ],
        "output": [
          {
            "id": 3624,
            "created_at": "2016-10-21T20:51:16.000+08:00"
          },
          {
            "id": 3625,
            "created_at": "2016-10-22T08:09:16.000+08:00"
          }
        ]
      }
    ],
    "identifier": 40210276
  },
  {
    "context": [
      "I have json input as follows:",
      "[{ \"a\": \"123\", \"b\": [ \"xyz\", \"uvw\" ] }, { \"a\": \"456\", \"b\": [ \"ghi\" ] }]",
      "and I'd like to produce a list where each object's \"a\" is combined with each element of \"b\" using a delimiter.",
      "123|xyz",
      "123|uvw",
      "456|ghi",
      "$ jq -r --arg delim '|' '.[] | \"\\(.a)\\($delim)\\(.b[])\"' input.json"
    ],
    "utterance": "For each object, produce a list of strings by joining the value of key 'a' with each value in the array 'b' using the '|' delimiter.",
    "expressions": [
      ".[] | \"\u001b[.a]\u001b[|]\u001b[.b[]]\"",
      ".[] | \"\\(.a)|\\(.b[])\""
    ],
    "data": [
      {
        "input": [
          {
            "a": "123",
            "b": [
              "xyz",
              "uvw"
            ]
          },
          {
            "a": "456",
            "b": [
              "ghi"
            ]
          }
        ],
        "output": [
          "123|xyz",
          "123|uvw",
          "456|ghi"
        ]
      }
    ],
    "identifier": 40392637
  },
  {
    "context": [
      "\"I'm curious how I can use the `sub(regex, tostring)` function to replace the underscores in my JSON with camelCase?\"",
      "\"The expected results would be: 'lineItems': [{ 'id': xxxx, 'name': 'xxxx', 'sku': 'xxxx', 'productId': xxxx, }]\"",
      "\"Here's a jq function that will convert 'a_bcd_ef' to 'aBcdEf', which seems to be what you want:\"",
      "\"To apply this function to ALL keys in an object, you could write: with_entries( .key |= camel )\"",
      "\"To change ALL keys in ALL objects within a JSON entity, you could use `walk/1`: walk(if type == 'object' then with_entries(.key |= camel) else . end)\"",
      "\"You can put this into a script called 'snake_to_camel.jq' ... map_keys(snake_to_camel)\""
    ],
    "utterance": "Transform all object keys containing underscores to camelCase format throughout the entire data, such that keys like 'product_id' become 'productId' and 'line_items' becomes 'lineItems'.",
    "expressions": [
      "def camel: gsub(\"_(?<a>[a-z])\"; .a|ascii_upcase); walk(if type == \"object\" then with_entries(.key |= camel) else . end)",
      "def head: .[0:1]; def tail: .[1:]; def capitalize: (head | ascii_upcase) + tail; def snake_to_camel: split(\"_\") | head + (tail | map(capitalize)) | join(\"\"); def map_keys(mapper): walk(if type == \"object\" then with_entries(.key |= mapper) else . end); map_keys(snake_to_camel)"
    ],
    "data": [
      {
        "input": {
          "line_items": [
            {
              "id": 1,
              "name": "Sample",
              "sku": "123",
              "product_id": 456
            }
          ]
        },
        "output": {
          "lineItems": [
            {
              "id": 1,
              "name": "Sample",
              "sku": "123",
              "productId": 456
            }
          ]
        }
      }
    ],
    "identifier": 40366520
  },
  {
    "context": [
      "But I need to parse each and every line but it's tough to identify which assignee is for which key as far as key group is concerned. Is this possible to make one bunch in one row using jq?",
      "Expected output:\n\n    { \"key\": \"SEA-739\", \"status\": \"Open\", \"assignee\": null }\n    { \"key\": \"SEA-738\", \"status\": \"Resolved\", \"assignee\": \"user2@mycompany.com\"}",
      "**`-c`** is what you likely need\n\nUsing the output you posted above, you can process it further:\n\n jq **-c** . input\n\nTo Give;\n\n    {\"key\":\"SEA-739\",\"status\":\"Open\",\"assignee\":null}\n    {\"key\":\"SEA-738\",\"status\":\"Resolved\",\"assignee\":\"user2@mycompany.com\"}",
      "Or you can just change your original command\n\n**FROM**\n\n jq **-r** '(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress})'\n\n**TO**\n\n jq **-c** '(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress})'"
    ],
    "utterance": "Output each object with key, status, and assignee on a single line so that it is easy to associate values to keys in each row.",
    "expressions": [
      "jq -c '(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress})'"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "SEA-739",
              "fields": {
                "status": {
                  "name": "Open"
                },
                "assignee": null
              }
            },
            {
              "key": "SEA-738",
              "fields": {
                "status": {
                  "name": "Resolved"
                },
                "assignee": {
                  "emailAddress": "user2@mycompany.com"
                }
              }
            }
          ]
        },
        "output": [
          "{\"key\":\"SEA-739\",\"status\":\"Open\",\"assignee\":null}",
          "{\"key\":\"SEA-738\",\"status\":\"Resolved\",\"assignee\":\"user2@mycompany.com\"}"
        ]
      }
    ],
    "identifier": 40396445
  },
  {
    "context": [
      "I get null output (after the curl progress bar)\nRunning without the final jq command gives the correct json.",
      "Please change the url **from:**  \n\n    curl 'https://demo.cachethq.io/API/v1/components?name=Blog' | tac | tac | jq '.'\n\n**To:**  \n\n    curl 'https://demo.cachethq.io/api/v1/components?name=Blog' | tac | tac | jq '.'\n",
      "**Output:**  \n\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\n                                 Dload  Upload   Total   Spent    Left  Speed\n    100   426    0   426    0     0    176      0 --:--:--  0:00:02 --:--:--   176\n    {\n      \"meta\": {\n        \"pagination\": {\n          \"total\": 1,\n          \"count\": 1,\n          \"per_page\": 20,\n          \"current_page\": 1,\n          \"total_pages\": 1,\n          \"links\": {\n            \"next_page\": null,\n            \"previous_page\": null\n          }\n        }\n      },\n      \"data\": [\n        {\n          \"id\": 4,\n          \"name\": \"Blog\",\n          \"description\": \"The Alt Three Blog.\",\n          \"link\": \"https://blog.alt-three.com\",\n          \"status\": 1,\n          \"order\": 0,\n          \"group_id\": 2,\n          \"created_at\": \"2016-11-03 01:30:01\",\n          \"updated_at\": \"2016-11-03 01:30:01\",\n          \"deleted_at\": null,\n          \"enabled\": true,\n          \"status_name\": \"Operational\",\n          \"tags\": {\n            \"\": \"\"\n          }\n        }\n      ]\n    }"
    ],
    "utterance": "Display the full content of the HTTP response.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": {
          "meta": {
            "pagination": {
              "total": 1,
              "count": 1,
              "per_page": 20,
              "current_page": 1,
              "total_pages": 1,
              "links": {
                "next_page": null,
                "previous_page": null
              }
            }
          },
          "data": [
            {
              "id": 4,
              "name": "Blog",
              "description": "The Alt Three Blog.",
              "link": "https://blog.alt-three.com",
              "status": 1,
              "order": 0,
              "group_id": 2,
              "created_at": "2016-11-03 01:30:01",
              "updated_at": "2016-11-03 01:30:01",
              "deleted_at": null,
              "enabled": true,
              "status_name": "Operational",
              "tags": {
                "": ""
              }
            }
          ]
        },
        "output": {
          "meta": {
            "pagination": {
              "total": 1,
              "count": 1,
              "per_page": 20,
              "current_page": 1,
              "total_pages": 1,
              "links": {
                "next_page": null,
                "previous_page": null
              }
            }
          },
          "data": [
            {
              "id": 4,
              "name": "Blog",
              "description": "The Alt Three Blog.",
              "link": "https://blog.alt-three.com",
              "status": 1,
              "order": 0,
              "group_id": 2,
              "created_at": "2016-11-03 01:30:01",
              "updated_at": "2016-11-03 01:30:01",
              "deleted_at": null,
              "enabled": true,
              "status_name": "Operational",
              "tags": {
                "": ""
              }
            }
          ]
        }
      }
    ],
    "identifier": 40390922
  },
  {
    "context": [
      "PROFILE=$(curl --user admin:admin -k -X GET https://192.168.1.1:8000/rest/call/profiles.json | jq '[.profiles[].id]')",
      "my results might look something like this (but i could have 1 to many lines returned):\n\n[\n  \"myprofile\",\n  \"myprofile1\",\n  \"myprofile2\",\n  \"myprofile3\"\n]",
      "set each id that is returned to a unique variable to be used later on in the script"
    ],
    "utterance": "Extract each value of the 'id' field from all elements in the 'profiles' array individually.",
    "expressions": [
      ".profiles[].id"
    ],
    "data": [
      {
        "input": {
          "profiles": [
            {
              "id": "myprofile"
            },
            {
              "id": "myprofile1"
            },
            {
              "id": "myprofile2"
            },
            {
              "id": "myprofile3"
            }
          ]
        },
        "output": [
          "myprofile",
          "myprofile1",
          "myprofile2",
          "myprofile3"
        ]
      }
    ],
    "identifier": 40423864
  },
  {
    "context": [
      "I have JSON like this that I'm parsing with jq:",
      "I'm trying to get \"string 1\" \"string 2\" and \"string 3\" into a Bash array, but I can't find a solution that ignores the whitespace in them.",
      "jq --raw-output '.data[].item.name' file.json",
      "readarray -t name_array < <(jq -r '.data[] | .[] | .name' <<<\"$s\")"
    ],
    "utterance": "Extract all values of the name field under item objects inside each entry of the data array, preserving whitespace, for use in a Bash array.",
    "expressions": [
      ".data[].item.name",
      ".data[] | .[] | .name"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "item": {
                "name": "string 1"
              }
            },
            {
              "item": {
                "name": "string 2"
              }
            },
            {
              "item": {
                "name": "string 3"
              }
            }
          ]
        },
        "output": [
          "string 1",
          "string 2",
          "string 3"
        ]
      }
    ],
    "identifier": 40451774
  },
  {
    "context": [
      "PROFILE=\"$(curl --user admin:admin -k -X GET https://xxx.xx.xx.xxx:8080/profiles.json | jq '.Profiles[].id')\"",
      "RETURNS - \n\t\"myprofile\"\n\t\"yourprofile\"",
      "Use `--raw-output` option to skip the JSON formatting. (In particular, string values are wrapped with double quotes by default.).",
      "curl --user admin:admin -k -X GET https://xxx.xx.xx.xxx:8080/profiles.json | \\\n  jq --monochrome-output --unbuffered --raw-output \\\n    '.Profiles[].id' | while read profile"
    ],
    "utterance": "Extract all id values from each object in the Profiles array.",
    "expressions": [
      ".Profiles[].id",
      ".Profiles[].id // select entries with id even if some objects might not have one"
    ],
    "data": [
      {
        "input": {
          "href": "http://localhost:8080//profiles",
          "Profiles": [
            {
              "href": "http://localhost:8080/profiles/myprofile",
              "id": "myprofile",
              "isRecording": false
            },
            {
              "href": "http://localhost:8080/profiles/yourprofile",
              "id": "yourprofile",
              "isRecording": false
            }
          ]
        },
        "output": [
          "myprofile",
          "yourprofile"
        ]
      }
    ],
    "identifier": 40434217
  },
  {
    "context": [
      "Suppose we have a JSON array of length 5 and we want to split the array into multiple arrays of length 2 and save the grouped items into different files, using linux command line tools.",
      "$ echo '[{\"key1\":\"value1\"},{\"key2\":\"value2\"},{\"key3\":\"value3\"},{\"key4\":\"value4\"},{\"key5\":\"value5\"}]' | jq -c -M '.[]' | split -l 2 -d -a 3 - meta2_ --filter=\"jq --slurp -c -M '.' >\\$FILE\"",
      "==> meta2_000 <==\n[{\"key1\":\"value1\"},{\"key2\":\"value2\"}]\n\n==> meta2_001 <==\n[{\"key3\":\"value3\"},{\"key4\":\"value4\"}]\n\n==> meta2_002 <==\n[{\"key5\":\"value5\"}]",
      "range(0; length; 2) as $i | .[$i:$i+2]",
      "produces:\n[{\"key1\":\"value1\"},{\"key2\":\"value2\"}]\n[{\"key3\":\"value3\"},{\"key4\":\"value4\"}]\n[{\"key5\":\"value5\"}]",
      "$ jq -cM --argjson sublen '2' 'range(0; length; $sublen) as $i | .[$i:$i+$sublen]' \\\n    input.json | split -l 1 -da 3 - meta2_"
    ],
    "utterance": "Split an array of 5 objects into separate arrays of up to 2 items each and save each group into its own file, so that each file contains a valid array.",
    "expressions": [
      "range(0; length; 2) as $i | .[$i:$i+2]",
      "range(0; length; $sublen) as $i | .[$i:$i+$sublen]"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1"
          },
          {
            "key2": "value2"
          },
          {
            "key3": "value3"
          },
          {
            "key4": "value4"
          },
          {
            "key5": "value5"
          }
        ],
        "output": [
          [
            {
              "key1": "value1"
            },
            {
              "key2": "value2"
            }
          ],
          [
            {
              "key3": "value3"
            },
            {
              "key4": "value4"
            }
          ],
          [
            {
              "key5": "value5"
            }
          ]
        ]
      }
    ],
    "identifier": 40385830
  },
  {
    "context": [
      "but if I want to get another value from the array **BlockDeviceMappings** I will have wrong result, which mean I can&#39;t get the value of different level array to display correctly, for example, **Tag value** and **VolumeId** and **DeviceName**, I will still get redundant of output.",
      "Here is the desired output (comma or any other delimiter are fine):\r\n\r\n    ec2-test1,vol-11111111,/dev/sda1\r\n    ec2-test1,vol-22222222,/dev/sdf\r\n    ec2-test1,vol-33333333,/dev/sdg\r\n    ec2-test2,vol-44444444,/dev/sda1\r\n    ec2-test2,vol-55555555,/dev/sdf\r\n    ec2-test2,vol-66666666,/dev/sdg\r\n",
      "Then if you want to add additional value from the Json like `DeviceName``\r\n\r\n    cat all-ec2-instance.json \\\r\n    | jq -r '.Reservations[].Instances[] | .Tags[].Value +\" \"+(.BlockDeviceMappings[] | .Ebs.VolumeId +\" \"+ .DeviceName)'\r\n\r\nyou get the following\r\n\r\n    \"ec2-test1 vol-11111111 /dev/sda1\"\r\n    \"ec2-test1 vol-22222222 /dev/sdf\"\r\n    \"ec2-test1 vol-33333333 /dev/sdg\"\r\n    \"ec2-test2 vol-44444444 /dev/sda1\"\r\n    \"ec2-test2 vol-55555555 /dev/sdf\"\r\n    \"ec2-test2 vol-66666666 /dev/sdg\""
    ],
    "utterance": "Output each instance's Name tag, EBS volume ID, and device name from all reservations, one line per device mapping, preserving their correct relationships.",
    "expressions": [
      ".Reservations[].Instances[] | .Tags[].Value + \",\" + (.BlockDeviceMappings[] | .Ebs.VolumeId + \",\" + .DeviceName)"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "OwnerId": "",
              "ReservationId": "",
              "Groups": [],
              "Instances": [
                {
                  "InstanceId": "i-11111111",
                  "Hypervisor": "xen",
                  "BlockDeviceMappings": [
                    {
                      "DeviceName": "/dev/sda1",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": false,
                        "VolumeId": "vol-11111111",
                        "AttachTime": "2016-04-19T15:53:53.000Z"
                      }
                    },
                    {
                      "DeviceName": "/dev/sdf",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": false,
                        "VolumeId": "vol-22222222",
                        "AttachTime": "2016-05-25T08:22:33.000Z"
                      }
                    },
                    {
                      "DeviceName": "/dev/sdg",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": false,
                        "VolumeId": "vol-33333333",
                        "AttachTime": "2016-02-28T04:22:07.000Z"
                      }
                    }
                  ],
                  "Tags": [
                    {
                      "Value": "ec2-test1",
                      "Key": "Name"
                    }
                  ]
                }
              ]
            },
            {
              "OwnerId": "",
              "ReservationId": "",
              "Groups": [],
              "Instances": [
                {
                  "InstanceId": "i-22222222",
                  "Hypervisor": "xen",
                  "BlockDeviceMappings": [
                    {
                      "DeviceName": "/dev/sda1",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": false,
                        "VolumeId": "vol-44444444",
                        "AttachTime": "2016-05-19T15:53:53.000Z"
                      }
                    },
                    {
                      "DeviceName": "/dev/sdf",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": false,
                        "VolumeId": "vol-55555555",
                        "AttachTime": "2015-08-25T08:22:33.000Z"
                      }
                    },
                    {
                      "DeviceName": "/dev/sdg",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": false,
                        "VolumeId": "vol-66666666",
                        "AttachTime": "2016-07-28T04:22:07.000Z"
                      }
                    }
                  ],
                  "Tags": [
                    {
                      "Value": "ec2-test2",
                      "Key": "Name"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "ec2-test1,vol-11111111,/dev/sda1",
          "ec2-test1,vol-22222222,/dev/sdf",
          "ec2-test1,vol-33333333,/dev/sdg",
          "ec2-test2,vol-44444444,/dev/sda1",
          "ec2-test2,vol-55555555,/dev/sdf",
          "ec2-test2,vol-66666666,/dev/sdg"
        ]
      }
    ],
    "identifier": 40043029
  },
  {
    "context": [
      "I want to extract the ***unique*** values (**`equip`**);",
      "From known locations with ***common*** names in the data set (**`site`**); **and**",
      "Have the values concatenated with a ***string*** delimiter that I can change;",
      "In order to get an output like this: (shown with a **`comma`** as my choice of delimiter):",
      "{\n  \"site\": [\n    {\n      \"uuid\": \"23451fae-a14f-49d1-a096-8f033f69dc80\",\n      \"testtype\": \"Scheduled\",\n      \"name\": \"JANE DOE HEAD OFFICE\",\n      \"equip\": \"\\\"Unique Item One\\\",\\\"Unique Item Two\\\",\\\"Unique Item Three\\\"\"\n    }\n  ]\n}",
      "You could group them up to determine what `equip` values need to be combined, then you could build up your string.",
      "$ jq -n --arg delim ',' '{\n    site: [inputs.site[]]\n        | group_by(.uuid)\n        | map({\n            uuid: .[0].uuid,\n            testtype: .[0].testtype,\n            name: .[0].name,\n            equip: (map(.equip | tojson) | unique | join($delim))\n        })\n}' input.json"
    ],
    "utterance": "Combine all unique 'equip' values for each site with the same uuid, joining them into a single string with a configurable delimiter.",
    "expressions": [
      "{ site: [inputs.site[]] | group_by(.uuid) | map({ uuid: .[0].uuid, testtype: .[0].testtype, name: .[0].name, equip: (map(.equip | tojson) | unique | join($delim)) }) }"
    ],
    "data": [
      {
        "input": [
          {
            "site": [
              {
                "uuid": "23451fae-a14f-49d1-a096-8f033f69dc80",
                "testtype": "Scheduled",
                "name": "JANE DOE HEAD OFFICE",
                "equip": "Unique Item One"
              }
            ]
          },
          {
            "site": [
              {
                "uuid": "23451fae-a14f-49d1-a096-8f033f69dc80",
                "testtype": "Scheduled",
                "name": "JANE DOE HEAD OFFICE",
                "equip": "Unique Item Two"
              }
            ]
          },
          {
            "site": [
              {
                "uuid": "23451fae-a14f-49d1-a096-8f033f69dc80",
                "testtype": "Scheduled",
                "name": "JANE DOE HEAD OFFICE",
                "equip": "Unique Item Three"
              }
            ]
          }
        ],
        "output": {
          "site": [
            {
              "uuid": "23451fae-a14f-49d1-a096-8f033f69dc80",
              "testtype": "Scheduled",
              "name": "JANE DOE HEAD OFFICE",
              "equip": "\"Unique Item One\",\"Unique Item Two\",\"Unique Item Three\""
            }
          ]
        }
      }
    ],
    "identifier": 40398344
  },
  {
    "context": [
      "I would like to get \"key\" (SEA-739), \"status\" (Open) and \"assignee\" (null or emailAddress). Also how can i get count of no. of issues retrieved ...",
      "I tried curl | jq '.issues[0].id' and it gives me valid id but I couldn't loop through both issues and get mentioned 3 values for both?",
      "How can I count issue using shell and get required output for all issues one by one?",
      "the following jq filter produces the information you seem to want:",
      "(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress}),",
      "(.issues|length)",
      "If you want a one-liner that will produce the values as a stream, without quotation marks, consider:",
      "$ jq -r '.issues | ((.[] | (.key, .fields.status.name, .fields.assignee.emailAddress)),length)'"
    ],
    "utterance": "For each issue, output the key, the name of the status, and the assignee's email address (or null), and then output the total number of issues.",
    "expressions": [
      "(.issues[] | {key, status: .fields.status.name, assignee: .fields.assignee.emailAddress}), (.issues|length)",
      ".issues | ((.[] | (.key, .fields.status.name, .fields.assignee.emailAddress)),length)"
    ],
    "data": [
      {
        "input": {
          "expand": "schema,names",
          "startAt": 0,
          "maxResults": 2,
          "total": 733,
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "292697",
              "self": "https://testserver.com/rest/api/2/issue/292697",
              "key": "SEA-739",
              "fields": {
                "assignee": null,
                "status": {
                  "self": "https://testserver.com/rest/api/2/status/1",
                  "description": "The issue is open and ready for the assignee to start work on it.",
                  "iconUrl": "https://testserver.com/images/icons/statuses/open.png",
                  "name": "Open",
                  "id": "1",
                  "statusCategory": {
                    "self": "https://testserver.com/rest/api/2/statuscategory/2",
                    "id": 2,
                    "key": "new",
                    "colorName": "blue-gray",
                    "name": "To Do"
                  }
                }
              }
            },
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "273625",
              "self": "https://testserver.com/rest/api/2/issue/273625",
              "key": "SEA-738",
              "fields": {
                "assignee": {
                  "self": "https://testserver.com/rest/api/2/user?username=user2",
                  "name": "user2",
                  "key": "user2",
                  "emailAddress": "user2@mycompany.com"
                },
                "status": {
                  "self": "https://testserver.com/rest/api/2/status/5",
                  "description": "A resolution has been taken and is awaiting verification by reporter. From here issues are either reopened or are closed.",
                  "iconUrl": "https://testserver.com/images/icons/statuses/resolved.png",
                  "name": "Resolved",
                  "id": "5",
                  "statusCategory": {
                    "self": "https://testserver.com/rest/api/2/statuscategory/3",
                    "id": 3,
                    "key": "done",
                    "colorName": "green",
                    "name": "Done"
                  }
                }
              }
            }
          ]
        },
        "output": [
          {
            "key": "SEA-739",
            "status": "Open",
            "assignee": null
          },
          {
            "key": "SEA-738",
            "status": "Resolved",
            "assignee": "user2@mycompany.com"
          },
          2
        ]
      }
    ],
    "identifier": 40327037
  },
  {
    "context": [
      "abc@uswest1aprod 13:53:09 ~\r\n   $ cat test | jq .[\"bus_v320161103-12-00-44\"]\r\nerror: bus_v320161103 is not defined\r\n.[bus_v320161103-12-00-44]  1 compile error",
      "You need to quote your filter so it isn&#39;t interpreted by the shell...",
      "$ jq &#39;.&quot;bus_v320161103-12-00-44&quot;&#39; test",
      "Without it, it&#39;s effectively being passed in like this:\r\n\r\n    .bus_v320161103-12-00-44"
    ],
    "utterance": "Select the object with the key 'bus_v320161103-12-00-44'.",
    "expressions": [
      ".\"bus_v320161103-12-00-44\""
    ],
    "data": [
      {
        "input": {
          "bus_v320161103-12-00-44": {
            "aliases": {
              "bus_v3": {}
            },
            "mappings": {
              "business": {
                "dynamic": "strict",
                "_all": {
                  "enabled": false
                }
              }
            }
          }
        },
        "output": {
          "aliases": {
            "bus_v3": {}
          },
          "mappings": {
            "business": {
              "dynamic": "strict",
              "_all": {
                "enabled": false
              }
            }
          }
        }
      }
    ],
    "identifier": 40455737
  },
  {
    "context": [
      "However, the following incorrectly indicates an error status (as far as my needs go):\n\n    % jq -re .key <<<'{\"key\":false}'\n    false\n    % echo $?\n    1\n    %\n\nThe problem with the above is that the -e option will give a return status of 1 if the last output value was either `false` or `null`. However, if values of false and null are present in the JSON input, then this return status gives the wrong impression that some failure occurred.",
      "Remember that it's only dependent on the last result of the filter. So it might be easier to add the check as part of your filter at the end.  You just have to remember to ignore the last result.\n\n    $ jq -re --arg key 'key' '.[$key], has($key)' <<< '{\"key\":false}'\n    false\n    true\n    $ echo $?\n    0",
      "Let me point out firstly that in jq, expressions such as `{} | .a` are not regarded as erroneous. If you want an error condition to be raised when an attempt to access the value of a non-existent key is made,\nyou could write something like: \n\n    if has(\"a\") then .a else error(\"no such key\") end\n\nAnother way to distinguish between the case when an input object has a key and the case when it does not have the key\nis to write something like:\n\n    if has(\"a\") then .a else empty end\n\nor more compactly:\n\n    select(has(\"a\")) | .a"
    ],
    "utterance": "Ensure that accessing a given object key is only considered a failure if the key does not exist, even when the key's value is false or null.",
    "expressions": [
      ".[$key], has($key)",
      "if has(\"a\") then .a else error(\"no such key\") end",
      "if has(\"a\") then .a else empty end",
      "select(has(\"a\")) | .a"
    ],
    "data": [
      {
        "input": {
          "key": false
        },
        "output": [
          false,
          true
        ]
      },
      {
        "input": {},
        "output": [
          null,
          false
        ]
      }
    ],
    "identifier": 40513044
  },
  {
    "context": [
      "jq  -r \".notifiestext | map(select(.read==false))\" temp_notif |",
      "jq --arg foo \"$max\" \"map(select(.id<$foo))\"",
      "jq: error: syntax error, unexpected ')' (Unix shell quoting issues?) at <top-level>, line 1: map(select(.id<))",
      "jq -r '.notifiestext | map(select(.read==false))' temp_notif |",
      "jq --arg foo \"$max\" 'map(select(.id<$foo))'"
    ],
    "utterance": "Select objects with read equal to false and id less than a variable max value.",
    "expressions": [
      ".notifiestext | map(select(.read==false))",
      "map(select(.id<$foo))"
    ],
    "identifier": 40514605
  },
  {
    "context": [
      "I would like a query that would give me the results of the record that has the id 2000 (for example), these to be exact:\r\n\r\n    {\r\n       \"read\": false,\r\n       \"mex\": \"message 2\",\r\n       \"id\": 2000\r\n     }",
      "The types don't match which is why it's not selecting.  The `id` fields are all numbers but you're comparing to a string.  `--arg` reads the parameter as a string.  You'll want to treat it as a number or the id as a string.  It'll just be easier to read the parameter as json using `--argjson`:\r\n\r\n    $ jq -r --argjson id 2000 'map(select((.read | not) and .id == $id))' file.json",
      "Here's a simple filter to select the object with .id 2000.\r\n\r\n      .[]\r\n    | if .id == 2000 then . else empty end"
    ],
    "utterance": "Return the object where id equals 2000.",
    "expressions": [
      "map(select(.id == 2000))",
      "map(select(.id == $id))",
      ".[] | if .id == 2000 then . else empty end",
      "map(select((.read | not) and .id == $id))"
    ],
    "data": [
      {
        "input": [
          {
            "read": false,
            "mex": "message 1",
            "id": 1000
          },
          {
            "read": false,
            "mex": "message 2",
            "id": 2000
          },
          {
            "read": false,
            "mex": "message 3",
            "id": 3000
          }
        ],
        "output": [
          {
            "read": false,
            "mex": "message 2",
            "id": 2000
          }
        ]
      }
    ],
    "identifier": 40517324
  },
  {
    "context": [
      "I have this:\r\n\r\n    cat file | jq -r '.Instances[] | {ip: .PrivateIpAddress, name: .Tags[]}\r\n                                   | select(.name.Key == \"Name\")'\r\n\r\nAnd I need to also include the `.name.Key == \"Type\"`",
      "Desired output:\r\n\r\n    {\r\n      \"ip\": \"1.1.1.1\",\r\n      \"name\": \"System\",\r\n      \"type\": \"PROD\"\r\n    }",
      "Convert the tags to an object for easy access to the properties.\r\n\r\n    $ jq '.Instances[]\r\n        | .Tags |= from_entries\r\n        | {\r\n            ip:   .PrivateIpAddress,\r\n            name: .Tags.Name,\r\n            type: .Tags.Type\r\n          }' file"
    ],
    "utterance": "For each instance, extract the private IP address, the value of the tag with Key equal to \"Name\" as \"name\", and the value of the tag with Key equal to \"Type\" as \"type\".",
    "expressions": [
      ".Instances[]\n| .Tags |= from_entries\n| {\n    ip: .PrivateIpAddress,\n    name: .Tags.Name,\n    type: .Tags.Type\n  }"
    ],
    "data": [
      {
        "input": {
          "Instances": [
            {
              "PrivateIpAddress": "1.1.1.1",
              "Tags": [
                {
                  "Value": "Daily",
                  "Key": "Backup"
                },
                {
                  "Value": "System",
                  "Key": "Name"
                },
                {
                  "Value": "YES",
                  "Key": "Is_in_Domain"
                },
                {
                  "Value": "PROD",
                  "Key": "Type"
                }
              ]
            }
          ]
        },
        "output": {
          "ip": "1.1.1.1",
          "name": "System",
          "type": "PROD"
        }
      }
    ],
    "identifier": 40614513
  },
  {
    "context": [
      "I would use `jq` to pipe each record as a single line, then read that output with a `while` loop to pass to `curl`.",
      "jq -c '.json_records[]' | while IFS= read -r rec; do",
      "curl -X POST -d\"$rec\" \"$URL\"",
      "done"
    ],
    "utterance": "Extract each object within the top-level array 'json_records' as compact, newline-delimited objects for iteration.",
    "expressions": [
      ".json_records[]",
      "-c '.json_records[]'"
    ],
    "data": [
      {
        "input": {
          "json_records": [
            {
              "name": "name_1",
              "mark": "mark_1"
            },
            {
              "name": "name_2",
              "mark": "mark_2"
            }
          ]
        },
        "output": [
          {
            "name": "name_1",
            "mark": "mark_1"
          },
          {
            "name": "name_2",
            "mark": "mark_2"
          }
        ]
      }
    ],
    "identifier": 40577767
  },
  {
    "context": [
      "I am trying to extract the value of the \"value\" field from each line. `jq -r '.result[].value' <jsonfile>` works perfectly but it does not take into account the JSON lines where there is no \"value\" field. I would like it to print an empty line for them. Is this possible with jq?",
      "This would work:\r\n\r\n    jq -r '.result | if length > 0 then .[0].value else \"\" end'",
      "You can use this:\r\n\r\n    jq -r '.result[].value // \"\" ' a.json",
      "To achieve the stated goal as I understand it, you could use the following filter:\r\n\r\n    .result[] | if has(\"value\") then .value else \"\" end"
    ],
    "utterance": "Output the value field from each line; if the field does not exist, output an empty line instead.",
    "expressions": [
      ".result | if length > 0 then .[0].value else \"\" end",
      ".result[].value // \"\"",
      ".result[] | if has(\"value\") then .value else \"\" end"
    ],
    "data": [
      {
        "input": [
          {
            "jsonrpc": "2.0",
            "result": [],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [
              {
                "hostmacroid": "2392",
                "hostid": "10953",
                "macro": "{$GATEWAY}",
                "value": "10.25.230.1"
              }
            ],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [
              {
                "hostmacroid": "1893",
                "hostid": "12093",
                "macro": "{$GATEWAY}",
                "value": "10.38.118.1"
              }
            ],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [
              {
                "hostmacroid": "2400",
                "hostid": "14471",
                "macro": "{$GATEWAY}",
                "value": "10.25.230.1"
              }
            ],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [
              {
                "hostmacroid": "799",
                "hostid": "10798",
                "macro": "{$GATEWAY}",
                "value": "10.36.136.1"
              }
            ],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [
              {
                "hostmacroid": "1433",
                "hostid": "10857",
                "macro": "{$GATEWAY}",
                "value": "10.38.24.129"
              }
            ],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [
              {
                "hostmacroid": "842",
                "hostid": "13159",
                "macro": "{$GATEWAY}",
                "value": "10.38.113.1"
              }
            ],
            "id": 1
          },
          {
            "jsonrpc": "2.0",
            "result": [],
            "id": 1
          }
        ],
        "output": [
          "",
          "10.25.230.1",
          "10.38.118.1",
          "10.25.230.1",
          "10.36.136.1",
          "",
          "10.38.24.129",
          "10.38.113.1",
          ""
        ]
      }
    ],
    "identifier": 40590263
  },
  {
    "context": [
      "Is there an elegant way to replicate an object for each array item within?",
      "Here's a programmatic way to expand all array-valued keys of an arbitrary JSON object:",
      "def blowup(a): \n  def b(f): {(f): (.[f] | if type == \"array\" then .[] else . end)};\n\n  if a|length == 0 then {} else b(a[0]) + blowup(a[1:]) end;\n\nblowup(keys)",
      "Input: {a:0, b: [1,2], c: [3,4]}",
      "Output: \n\n    {\"a\":0,\"b\":1,\"c\":3}\n    {\"a\":0,\"b\":2,\"c\":3}\n    {\"a\":0,\"b\":1,\"c\":4}\n    {\"a\":0,\"b\":2,\"c\":4}"
    ],
    "utterance": "Replicate an object for each combination of array values in its properties, expanding array-valued keys to their Cartesian product.",
    "expressions": [
      "def blowup(a):\n  def b(f): {(f): (.[f] | if type == \"array\" then .[] else . end)};\n  if a|length == 0 then {} else b(a[0]) + blowup(a[1:]) end;\nblowup(keys)"
    ],
    "data": [
      {
        "input": {
          "a": 0,
          "b": [
            1,
            2
          ],
          "c": [
            3,
            4
          ]
        },
        "output": [
          {
            "a": 0,
            "b": 1,
            "c": 3
          },
          {
            "a": 0,
            "b": 2,
            "c": 3
          },
          {
            "a": 0,
            "b": 1,
            "c": 4
          },
          {
            "a": 0,
            "b": 2,
            "c": 4
          }
        ]
      }
    ],
    "identifier": 40746437
  },
  {
    "context": [
      "If `array = [\"darwin\",\"intel\"]`it returns objects containing both darwin \"and\" intel.",
      "How can I make it return objects containing darwin \"and/or\" intel?",
      "The filter to use is then simply:\n\n    .[] | select( intersectq(.hosts; $array)) | .hostName"
    ],
    "utterance": "Select objects where the hosts array contains at least one of \"darwin\" or \"intel\".",
    "expressions": [
      "def intersectq(a;b): any(a[]; . as $x | any( b[]; . == $x) );\n.[] | select(intersetq(.hosts; $array)) | .hostName"
    ],
    "identifier": 40794182
  },
  {
    "context": [
      "\"I want to do following: .items[] | if .metadata.name==\\\"127.0.0.1\\\" then {cpu: .status.capacity.cpu} else <<I want to skip>> end\"",
      "\"Required Output: {\\\"cpu\\\":3}\"",
      "\"Use map(select(...)): jq '.items|map(select(.metadata.name == \\\"127.0.0.1\\\"))|.[].status.capacity' items\"",
      "\"You could write: .items[] | if .metadata.name==\\\"127.0.0.1\\\" then {cpu: .status.capacity.cpu} else empty end\"",
      "\"or more succinctly: .items[] | select(.metadata.name==\\\"127.0.0.1\\\") | { cpu: .status.capacity.cpu }\""
    ],
    "utterance": "Extract the cpu value as an object for the item whose metadata.name is \"127.0.0.1\".",
    "expressions": [
      ".items | map(select(.metadata.name == \"127.0.0.1\")) | .[].status.capacity",
      ".items[] | if .metadata.name==\"127.0.0.1\" then {cpu: .status.capacity.cpu} else empty end",
      ".items[] | select(.metadata.name==\"127.0.0.1\") | { cpu: .status.capacity.cpu }"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "127.0.0.1"
              },
              "status": {
                "capacity": {
                  "cpu": 3
                }
              }
            },
            {
              "metadata": {
                "name": "127.0.0.2"
              },
              "status": {
                "capacity": {
                  "cpu": 8
                }
              }
            }
          ]
        },
        "output": {
          "cpu": 3
        }
      }
    ],
    "identifier": 40762235
  },
  {
    "context": [
      "How can I use jq to convert the following lines to a JSON format?",
      "The following is more general than @chepner's solution (it uses `add` and therefore is not restricted to three key-value pairs) and perhaps slightly simpler:\r\n\r\n    $ jq -Rn '[ inputs | match(\"\\\\[(.*)\\\\] (.*)\")\r\n              | .captures | {(.[0].string): (.[1].string)}]\r\n            | {payment_test: { service1: { api: add }}} ' tmp.txt",
      "An improvement would be to use named capture variables. jq provides a filter, `capture`, for creating an object from the capture variables; it can be used in conjunction with `from_entries` like so:\r\n\r\n    [inputs | capture(\"\\\\[(?<key>.*)\\\\] (?<value>.*)\")]\r\n    | from_entries\r\n    | {payment_test: { service1: { api: . }}}",
      "Assuming there are only three segments where only the first may contain underscores, you could do this:\r\n\r\n    $ jq -Rn 'reduce (inputs\r\n            | [match(\"(\\\\S+)_([^_]+)_([^_]+)\\\\[([^\\\\]]+)\\\\] (\\\\S+)\").captures[].string]\r\n        ) as $p\r\n        ({}; setpath($p[:-1]; $p[-1]))' input.txt"
    ],
    "utterance": "Convert lines in the form 'payment_test_service1_api[host] HOST1' into a nested object structure with 'payment_test', 'service1', 'api', and keys/values under 'api', matching the example output.",
    "expressions": [
      "[inputs | capture(\"\\[(?<key>.*)\\] (?<value>.*)\")] | from_entries | {payment_test: { service1: { api: . }}}",
      "[ inputs | match(\"\\[(.*)\\] (.*)\") | .captures | {(.[0].string): (.[1].string)} ] | {payment_test: { service1: { api: add }}}",
      "reduce (inputs | [match(\"(\\S+)_([^_]+)_([^_]+)\\[([^\\]]+)\\] (\\S+)\").captures[].string]) as $p ({}; setpath($p[:-1]; $p[-1]))"
    ],
    "data": [
      {
        "input": [
          "payment_test_service1_api[host] HOST1",
          "payment_test_service1_api[username] USERNAME1",
          "payment_test_service1_api[password] PASSWORD1"
        ],
        "output": {
          "payment_test": {
            "service1": {
              "api": {
                "host": "HOST1",
                "username": "USERNAME1",
                "password": "PASSWORD1"
              }
            }
          }
        }
      }
    ],
    "identifier": 40722754
  },
  {
    "context": [
      "echo \"{\\\"meta\\\": {\\\"link\\\": {\\\"upload\\\": { \\\"href\\\": \\\"http://${ip}${target}\\\"}}}, \\\"status\\\": \\\"empty\\\"}\" | jq .",
      "My expected output is as below.\r\n\r\n    {\r\n      \"meta\": {\r\n      \"link\": {\r\n      \"upload\": { \"href\": \"http://fileserver.example.com/upload/content/{id}\" }\r\n      }\r\n    },\"status\": \"empty\"\r\n    }"
    ],
    "utterance": "Pretty-print an object with meta.link.upload.href and status set to specific values",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": {
          "meta": {
            "link": {
              "upload": {
                "href": "http://fileserver.example.com/upload/content/{id}"
              }
            }
          },
          "status": "empty"
        },
        "output": {
          "meta": {
            "link": {
              "upload": {
                "href": "http://fileserver.example.com/upload/content/{id}"
              }
            }
          },
          "status": "empty"
        }
      }
    ],
    "identifier": 40799242
  },
  {
    "context": [
      "I have the following JSON:\r\n\r\n    [\r\n      {\r\n        \"name\": \"InstanceA\",\r\n        \"tags\": [\r\n          {\r\n            \"key\": \"environment\",\r\n            \"value\": \"production\"\r\n          },\r\n          {\r\n            \"key\": \"group\",\r\n            \"value\": \"group1\"\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        \"name\": \"InstanceB\",\r\n        \"tags\": [\r\n          {\r\n            \"key\": \"group\",\r\n            \"value\": \"group2\"\r\n          },\r\n          {\r\n            \"key\": \"environment\",\r\n            \"value\": \"staging\"\r\n          }\r\n        ]\r\n      }\r\n    ]",
      "I'm trying to get a flat output of `value` based on the condition `key == 'environment'`.",
      "I cannot get the desired output, like:\r\n\"InstanceA, production\"\r\n\"InstanceB, staging\"",
      "jq '.[] | .name + \", \" + (.tags[] | select(.key == \"environment\").value)' f.json",
      "$ jq '.[] | \"\\(.name), \\(.tags | from_entries | .environment)\"' input.json",
      "Here is a solution using **join**\r\n\n  .[]\n| [.name, (.tags[] | if .key == \"environment\" then .value else empty end)]\n| join(\", \")"
    ],
    "utterance": "List all items with their name and the value from their tags where key equals \"environment\", separated by a comma.",
    "expressions": [
      ".[] | .name + \", \" + (.tags[] | select(.key == \"environment\").value)",
      ".[] | \"\u001b[.name], \u001b[.tags | from_entries | .environment]\"",
      ".[] | [.name, (.tags[] | if .key == \"environment\" then .value else empty end)] | join(\", \")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "InstanceA",
            "tags": [
              {
                "key": "environment",
                "value": "production"
              },
              {
                "key": "group",
                "value": "group1"
              }
            ]
          },
          {
            "name": "InstanceB",
            "tags": [
              {
                "key": "group",
                "value": "group2"
              },
              {
                "key": "environment",
                "value": "staging"
              }
            ]
          }
        ],
        "output": [
          "InstanceA, production",
          "InstanceB, staging"
        ]
      }
    ],
    "identifier": 40732976
  },
  {
    "context": [
      "json_result=\"$(curl --silent -H 'Authorization:Basic XXXX' 'https://XXXXX.com/api/databrowser/malware_presence/query/sha1/'$sha1_checksum'?format=json&extended=true'| jq -r '.rl.malware_presence.name,.rl.malware_presence.level' | awk -vORS=, '{print $1}' |sed 's/,$/\\n/')\"",
      "jq -r '.rl.malware_presence.name,.rl.malware_presence.level'"
    ],
    "utterance": "Extract the values of the fields 'name' and 'level' from the 'malware_presence' object within the 'rl' property, outputting them as raw text.",
    "expressions": [
      ".rl.malware_presence.name, .rl.malware_presence.level"
    ],
    "identifier": 40801525
  },
  {
    "context": [
      "I would like to get only the last object of the JSON file as I need to check that in every case, the last object is `error.content`.",
      "Objects with duplicate keys can be handled in jq using the --stream option, e.g.:",
      "$ jq -s --stream '[length-2] | { (.[0][0]): (.[1]) }' input.json",
      "For large files, the following would probably be better as it avoids \"slurping\" the input file:",
      "$ jq 'first(tostream) | {(.[0][0]): .[1]}' input.json"
    ],
    "utterance": "Get the last key-value pair from an object, even when there are duplicate keys, where the last is expected to have the key error.content.",
    "expressions": [
      "-s --stream '.[length-2] | { (.[0][0]): (.[1]) }'",
      "first(tostream) | {(.[0][0]): .[1]}"
    ],
    "data": [
      {
        "input": {
          "system.timestamp": "{system.timestamp}",
          "error.state": "{error.state}",
          "error.content": "{custom.error.content}"
        },
        "output": {
          "error.content": "{custom.error.content}"
        }
      }
    ],
    "identifier": 40810498
  },
  {
    "context": [
      "Given this JSON snippet, I'm trying to figure out to extract the name of the key corresponding to a specific \"instance-id\" using jq.",
      "jq '.machines | keys as $x | if .[].\"instance-id\"==\"wdc7ae\" then <some-code-to-get-the-key>  else empty end'",
      "Here's the command that 'Goldfish' shared and working like a charm for me:",
      ".machines | to_entries[] | select(.value.\"instance-id\" == \"wdc7ae\").key"
    ],
    "utterance": "Find the machine key whose instance-id is \"wdc7ae\".",
    "expressions": [
      ".machines | to_entries[] | select(.value.\"instance-id\" == \"wdc7ae\").key"
    ],
    "data": [
      {
        "input": {
          "model": {
            "name": "maas2",
            "controller": "ctr-xenial",
            "cloud": "maas",
            "version": "2.0.1"
          },
          "machines": {
            "1": {
              "dns-name": "10.4.0.181",
              "instance-id": "wdc7ae",
              "series": "xenial"
            },
            "2": {
              "dns-name": "10.4.0.182",
              "instance-id": "7mx74d",
              "series": "xenial"
            },
            "3": {
              "dns-name": "10.4.0.183",
              "instance-id": "rgn3ca",
              "series": "xenial"
            },
            "4": {
              "dns-name": "10.4.0.184",
              "instance-id": "kmy4bh",
              "series": "xenial"
            },
            "5": {
              "dns-name": "10.4.0.185",
              "instance-id": "eb38c7",
              "series": "xenial"
            }
          }
        },
        "output": "1"
      }
    ],
    "identifier": 40817623
  },
  {
    "context": [
      "Given the json `filter.json`:\r\n\r\n    {\r\n        \"123\": {\r\n            \"name\": \"Horst\"\r\n        },\r\n        \"789\": {\r\n            \"name\": \"Bob\"\r\n        }\r\n    }",
      "I want to filter for each key and the name, wanting an output like:\r\n\r\n    \"123\": \"Horst\"\r\n    \"789\": \"Bob\"",
      "$ jq 'to_entries[]| {(.key): .value.name}' < /tmp/filter.json\r\n    {\r\n      \"123\": \"Horst\"\r\n    }\r\n    {\r\n      \"789\": \"Bob\"\r\n    }",
      "$ jq -r 'keys[] as $key | \"\\\"\\($key)\\\" : \\\"\\(.[$key].name)\\\"\"'\r\nproduces:\r\n\r\n    \"123\": \"Horst\"\r\n    \"789\": \"Bob\""
    ],
    "utterance": "For each top-level key, output the key and its corresponding sub-object's 'name' property as key-value pairs.",
    "expressions": [
      "to_entries[] | {(.key): .value.name}",
      "keys[] as $key | \"\\\"\\($key)\\\" : \\\"\\(.[$key].name)\\\"\""
    ],
    "data": [
      {
        "input": {
          "123": {
            "name": "Horst"
          },
          "789": {
            "name": "Bob"
          }
        },
        "output": [
          {
            "123": "Horst"
          },
          {
            "789": "Bob"
          }
        ]
      }
    ],
    "identifier": 40845789
  },
  {
    "context": [
      "Using jq I would like to inverse a json object so that the property becomes the value and the value becomes the key.",
      "Source:\r\n\r\n    { \r\n        &quot;123&quot;: &quot;Foobar&quot;\r\n        &quot;567&quot;: &quot;Poit&quot;\r\n    } \r\n\r\nGoal:\r\n\r\n    { \r\n        &quot;Foobar&quot;: &quot;123&quot;\r\n        &quot;Poit&quot;: &quot;567&quot;\r\n    }",
      "to_entries | map( {(.value) : .key } ) | add",
      "with_entries( .key as $k | .key = (.value|tostring) | .value = $k )",
      "to_entries | map({key: .value|tostring, value: .key}) | from_entries"
    ],
    "utterance": "Invert an object so each property name becomes the value and each value becomes the property name.",
    "expressions": [
      "to_entries | map({(.value): .key}) | add",
      "with_entries(.key as $k | .key = (.value|tostring) | .value = $k)",
      "to_entries | map({key: .value|tostring, value: .key}) | from_entries"
    ],
    "data": [
      {
        "input": {
          "123": "Foobar",
          "567": "Poit"
        },
        "output": {
          "Foobar": "123",
          "Poit": "567"
        }
      }
    ],
    "identifier": 40847936
  },
  {
    "context": [
      "I want to remove any duplicate events by using unique_by() on the incident_key. However, I want the first occurrence of the incident_key, and unique_by() is removing all but the last.",
      "What I'm trying to do is use unique_by() to get the first occurrence of reference_key, based on the id. So in this case, I'd want the output to be",
      "If you don't have access to a sufficiently recent version of jq, then consider the following, which has been tested with jq 1.3, 1.4 and 1.5:",
      "bucketize(.reference_key) | .[][0]",
      "Or much more economically:",
      "reduce .[] as $x ({};\n  $x.reference_key as $key \n  | if .[$key] then . else .[$key] = $x end)\n| .[]"
    ],
    "utterance": "Return only the first occurrence of each reference_key in the array.",
    "expressions": [
      "unique_by(.reference_key)",
      "bucketize(.reference_key) | .[][0]",
      "reduce .[] as $x ({}; $x.reference_key as $key | if .[$key] then . else .[$key] = $x end) | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "reference_key": "200",
            "id": "1"
          },
          {
            "reference_key": "200",
            "id": "2"
          },
          {
            "reference_key": "200",
            "id": "3"
          },
          {
            "reference_key": "201",
            "id": "4"
          },
          {
            "reference_key": "201",
            "id": "5"
          },
          {
            "reference_key": "201",
            "id": "6"
          }
        ],
        "output": [
          {
            "reference_key": "200",
            "id": "1"
          },
          {
            "reference_key": "201",
            "id": "4"
          }
        ]
      }
    ],
    "identifier": 40877513
  },
  {
    "context": [
      "Below is the command which I am executing.",
      "curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq .data[] | select(.name==\\\"TestAccount\\\").id",
      "You need to quote the JQ expression, e.g.:",
      "curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq '.data[] | select(.name==\"TestAccount\").id'",
      "when on Windows you'll need to use double quotes and escaped double quotes as in:",
      "curl --basic -u admin:admin http://XX.XX.XX.XX:8080/mmc-console-3.7.3/api/deployments | jq \".data[] | select(.name==\\\"TestAccount\\\").id\""
    ],
    "utterance": "Return the id of the object in the data array whose name is TestAccount.",
    "expressions": [
      ".data[] | select(.name==\"TestAccount\").id"
    ],
    "identifier": 40912672
  },
  {
    "context": [
      "Is that because the jq output is not split at every json object? if yes how do I do that with jq?",
      "you are missing the '.[]' array operation operator on the returned json list",
      "Please Note the `-c` to print each output without indent.",
      "jq -c '{title: .heading[0], description: .text, languageKey: \"ja\"}'"
    ],
    "utterance": "Output each matching object on a single line so that each can be processed separately in a shell loop or by downstream tools.",
    "expressions": [
      ".[]",
      "-c"
    ],
    "identifier": 40992970
  },
  {
    "context": [
      "I\u2019ve been googling and experimenting for a few hours trying to filter the object to select only the activity entries that have a stop_time_utc value, and use something like a \"select(.stop_time_utc | fromdateiso8601 > now)\" to only pick activities that have expired. For example, I\u2019d like to use filters to create an array from the sample object with only the one relevant entry:\n\n    [\n      \"-KSndgjqvmQkWVKHCpLh\"\n    ]",
      ".activities\n| with_entries( select( (.value.stop_time_utc? | fromdateiso8601?) < now ) )\n| keys"
    ],
    "utterance": "List the keys of activities where stop_time_utc exists and is a date in the past.",
    "expressions": [
      ".activities | with_entries( select( (.value.stop_time_utc? | fromdateiso8601?) < now ) ) | keys"
    ],
    "data": [
      {
        "input": {
          "activities": {
            "-KSndgjqvmQkWVKHCpLh": {
              "create_device": "...",
              "stop_time_utc": "2016-11-01T23:08:08Z"
            },
            "-KSoBSrBh6PZcjRocGD7": {
              "create_device": "..."
            },
            "-KSptboGjo8g4bieUbGM": {
              "create_device": "...",
              "stop_time_utc": "2017-01-17T23:08:08Z"
            }
          }
        },
        "output": [
          "-KSndgjqvmQkWVKHCpLh"
        ]
      }
    ],
    "identifier": 40923539
  },
  {
    "context": [
      "I can't figure out how to go about in incrementing the '**id**' value since when I merge it there will be duplicating id values.",
      "So if your goal is to reseed the ids, you could do this:\n\n    $ jq -n '[ foreach inputs[] as $i (0; .+1; $i*{id:(.-1)}) ]' file_?.json",
      "First slurp, then concatenate (`add`), and finally adjust the \"id\" values:\n\n    $ jq -s 'add | reduce range(0;length) as $n (.; .[$n].id = $n)' file_?.json"
    ],
    "utterance": "Merge two files containing objects with numeric id fields, and reset all id values to unique incrementing integers starting from 0.",
    "expressions": [
      "[ foreach inputs[] as $i (0; .+1; $i*{id:(.-1)}) ]",
      "add | reduce range(0;length) as $n (.; .[$n].id = $n)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 0,
              "fruit_name": "Apple",
              "fruit_category": "category 1",
              "fruit_count": 1
            },
            {
              "id": 1,
              "fruit_name": "Apricot",
              "fruit_category": "category 2",
              "fruit_count": 1
            },
            {
              "id": 2,
              "fruit_name": "Avocado",
              "fruit_category": "category 3",
              "fruit_count": 2
            }
          ],
          [
            {
              "id": 0,
              "fruit_name": "Banana",
              "fruit_category": "category 4",
              "fruit_count": 1
            },
            {
              "id": 1,
              "fruit_name": "Bilberry",
              "fruit_category": "category 5",
              "fruit_count": 1
            },
            {
              "id": 2,
              "fruit_name": "Blackberry",
              "fruit_category": "category 6",
              "fruit_count": 2
            }
          ]
        ],
        "output": [
          {
            "id": 0,
            "fruit_name": "Apple",
            "fruit_category": "category 1",
            "fruit_count": 1
          },
          {
            "id": 1,
            "fruit_name": "Apricot",
            "fruit_category": "category 2",
            "fruit_count": 1
          },
          {
            "id": 2,
            "fruit_name": "Avocado",
            "fruit_category": "category 3",
            "fruit_count": 2
          },
          {
            "id": 3,
            "fruit_name": "Banana",
            "fruit_category": "category 4",
            "fruit_count": 1
          },
          {
            "id": 4,
            "fruit_name": "Bilberry",
            "fruit_category": "category 5",
            "fruit_count": 1
          },
          {
            "id": 5,
            "fruit_name": "Blackberry",
            "fruit_category": "category 6",
            "fruit_count": 2
          }
        ]
      }
    ],
    "identifier": 40871001
  },
  {
    "context": [
      "Can I paste version.number from logg.json into version.number 1.json using jq? I need something like that (it&#39;s absolutely wrong):",
      "$ jq --argfile logg logg.json &#39;.version.number = $logg.version.number + 1&#39; 1.json",
      "jq --argfile logg logg.json \".version.number = $logg.version.number + 1\" 1.json"
    ],
    "utterance": "Update the field version.number in the first file to be one more than version.number from the second file.",
    "expressions": [
      "jq --argfile logg logg.json '.version.number = $logg.version.number + 1' 1.json"
    ],
    "data": [
      {
        "input": {
          "1.json": {
            "id": "107709375",
            "type": "page",
            "title": "SomeTitle",
            "space": {
              "key": "BUSINT"
            },
            "version": {
              "number": 62
            }
          },
          "logg.json": {
            "id": "228204270",
            "type": "page",
            "status": "current",
            "title": "test-test",
            "version": {
              "when": "2016-11-23T16:54:18.313+07:00",
              "number": 17,
              "minorEdit": false
            },
            "extensions": {
              "position": "none"
            }
          }
        },
        "output": {
          "id": "107709375",
          "type": "page",
          "title": "SomeTitle",
          "space": {
            "key": "BUSINT"
          },
          "version": {
            "number": 18
          }
        }
      }
    ],
    "identifier": 40989786
  },
  {
    "context": [
      "whenever there's invalid json content we get parse error message on the cmd line . So Question is how do we suppress that parse error message from the screen .",
      "If you want jq to ignore errors, then consider handling the error programmatically within jq, e.g.",
      "$ jq -n 'try inputs catch \"The end\"' <<< 'silly'",
      "\"The end\""
    ],
    "utterance": "Suppress error messages when parsing invalid input so that no parse errors appear on the command line.",
    "expressions": [
      "jq -n 'try inputs catch \"The end\"'"
    ],
    "data": [
      {
        "input": "silly",
        "output": "The end"
      }
    ],
    "identifier": 41035458
  },
  {
    "context": [
      "I would like to transform the JSON of the Node.js pm2 process listing ... Input JSON: ... Expected Output: ... So I want to convert each array element ... to a JSON map element as follows:",
      "The attribute value with the key \"name\" gets promoted to the key of that map element.",
      "The attributes under the \"monit\" subtree are consolidated under the key of that map (this part works already).",
      "I cannot get the desired output if the array contains more than one element.",
      "reduce .[] as $item ({}; .[$item.name] = {\"cpu\" : $item.monit.cpu, \"memory\" : $item.monit.memory, \"pid\" : $item.pid})",
      "map( { (.name): (.monit + {pid} ) } ) | add"
    ],
    "utterance": "Transform an array of process objects so that each object's 'name' property becomes a key, and its value is an object containing the 'pid' and all properties from the 'monit' object.",
    "expressions": [
      "reduce .[] as $item ({}; .[$item.name] = {\"cpu\": $item.monit.cpu, \"memory\": $item.monit.memory, \"pid\": $item.pid})",
      "map({ (.name): (.monit + {pid}) }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "pid": 1419,
            "name": "myapp",
            "pm_id": 0,
            "monit": {
              "memory": 13795328,
              "cpu": 0
            }
          },
          {
            "pid": 1425,
            "name": "calendar-viewer",
            "pm_id": 1,
            "monit": {
              "memory": 22761472,
              "cpu": 0
            }
          }
        ],
        "output": {
          "myapp": {
            "cpu": 0,
            "memory": 13795328,
            "pid": 1419
          },
          "calendar-viewer": {
            "cpu": 0,
            "memory": 22761472,
            "pid": 1425
          }
        }
      }
    ],
    "identifier": 41029693
  },
  {
    "context": [
      "How do I get the total number of `home->pageid` items?",
      "[.home[] | select(has(\"pageid\")) ] | length",
      "[.home[] | .pageid//empty ] | length",
      "def count(s): reduce s as $i(0; .+1);\ncount(.home[] | select(has(\"pageid\")))",
      "reduce (.home[].pageid?//empty) as $x (0; .+1)",
      "[.home[].pageid | select(type == \"string\")] | length",
      "[.home[] | if has(\"pageid\") then 1 else 0 end] | add"
    ],
    "utterance": "Count the number of objects in the 'home' array that have a 'pageid' property.",
    "expressions": [
      "[.home[] | select(has(\"pageid\")) ] | length",
      "[.home[] | .pageid//empty ] | length",
      "def count(s): reduce s as $i(0; .+1); count(.home[] | select(has(\"pageid\")))",
      "reduce (.home[].pageid?//empty) as $x (0; .+1)",
      "[.home[].pageid | select(type == \"string\")] | length",
      "[.home[] | if has(\"pageid\") then 1 else 0 end] | add"
    ],
    "data": [
      {
        "input": {
          "home": [
            {
              "pageid": "about yft",
              "pageData": "0908782"
            },
            {
              "pageData": "09897"
            }
          ]
        },
        "output": 1
      }
    ],
    "identifier": 41036841
  },
  {
    "context": [
      "I\u2019m able to (separately) extract the two arrays I\u2019m looking to combine:",
      "$ cat noaa.json | jq .time.startPeriodName",
      "[ \"Today\", \"Tonight\", \"Friday\", ... ]",
      "$ cat noaa.json | jq .data.weather",
      "[ \"Mostly Sunny\", \"Mostly Cloudy\", \"Mostly Sunny\", ... ]",
      "I\u2019d like to combine the two arrays together into a single object like this:",
      "{ \"Today\": \"Mostly Sunny\", \"Tonight\": \"Mostly Cloudy\", ..., \"Wednesday\": \"Mostly Sunny\" }",
      "The key here is to use it with `transpose/0`, which can be used as though it were a \"zip\" function:",
      "[.time.startPeriodName, .data.weather] | transpose | map( {(.[0]): .[1]})",
      "So, to produce a single JSON object, simply add the `add` filter to the pipeline."
    ],
    "utterance": "Combine time.startPeriodName and data.weather arrays so each period name maps to its corresponding weather description in a single object.",
    "expressions": [
      "[.time.startPeriodName, .data.weather] | transpose | map({(.[0]): .[1]}) | add"
    ],
    "data": [
      {
        "input": {
          "time": {
            "startPeriodName": [
              "Today",
              "Tonight",
              "Friday",
              "Friday Night",
              "Saturday",
              "Saturday Night",
              "Sunday",
              "Sunday Night",
              "Monday",
              "Monday Night",
              "Tuesday",
              "Tuesday Night",
              "Wednesday"
            ]
          },
          "data": {
            "weather": [
              "Mostly Sunny",
              "Mostly Cloudy",
              "Mostly Sunny",
              "Partly Cloudy",
              "Slight Chance Showers",
              "Slight Chance Snow Showers",
              "Slight Chance Snow Showers then Mostly Sunny",
              "Mostly Clear",
              "Mostly Sunny",
              "Partly Cloudy",
              "Mostly Sunny",
              "Partly Cloudy",
              "Mostly Sunny"
            ]
          }
        },
        "output": {
          "Today": "Mostly Sunny",
          "Tonight": "Mostly Cloudy",
          "Friday": "Mostly Sunny",
          "Friday Night": "Partly Cloudy",
          "Saturday": "Slight Chance Showers",
          "Saturday Night": "Slight Chance Snow Showers",
          "Sunday": "Slight Chance Snow Showers then Mostly Sunny",
          "Sunday Night": "Mostly Clear",
          "Monday": "Mostly Sunny",
          "Monday Night": "Partly Cloudy",
          "Tuesday": "Mostly Sunny",
          "Tuesday Night": "Partly Cloudy",
          "Wednesday": "Mostly Sunny"
        }
      }
    ],
    "identifier": 41045659
  },
  {
    "context": [
      "I am looking to merge all of the manifest files to generate a single manifest file, thus allowing me to perform a single Redshift copy.",
      "I am looking for an output like:- \n\n    {\n        \"entries\": [\n             {\n                \"url\": \"DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz\"\n             },\n             {\n                \"url\": \"DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz\"\n             }\n        ]\n    }",
      "$ jq 'reduce inputs as $i (.; .entries += $i.entries)' manifest_file{1,2}.json",
      "$ jq -n '{entries: [inputs.entries[]]}' manifest_file_{1,2}.json",
      "$ jq -s '{entries: [.[].entries[]]}' manifest_file_{1,2}.json"
    ],
    "utterance": "Merge several manifest files so their entries arrays are combined into a single entries array in one manifest output.",
    "expressions": [
      "reduce inputs as $i (.; .entries += $i.entries)",
      "-n '{entries: [inputs.entries[]]}'",
      "-s '{entries: [.[].entries[]]}'"
    ],
    "data": [
      {
        "input": [
          {
            "entries": [
              {
                "url": "DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz"
              }
            ]
          },
          {
            "entries": [
              {
                "url": "DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz"
              }
            ]
          }
        ],
        "output": {
          "entries": [
            {
              "url": "DFA/20161001/394007-OMD-Coles/dcm_account394007_activity_20160930_20161001_050403_294198927.csv.gz"
            },
            {
              "url": "DFA/20161002/394007-OMD-Coles/dcm_account394007_activity_20161001_20161002_054043_294865863.csv.gz"
            }
          ]
        }
      }
    ],
    "identifier": 41092891
  },
  {
    "context": [
      "With jq:\r\n\r\n    $ jq -nR '[inputs | split(\" \") | {\"From\": .[0], \"To\": .[1]}]' <<EOF\r\n    foo bar\r\n    what ever\r\n    EOF\r\n    \r\n    [\r\n      {\r\n        \"From\": \"foo\",\r\n        \"To\": \"bar\"\r\n      },\r\n      {\r\n        \"From\": \"what\",\r\n        \"To\": \"ever\"\r\n      }\r\n    ]",
      "Here&#39;s an all-jq solution that assumes the \"From\" and \"To\" values are presented exactly as in your example:\r\n\r\n    jq -R -n '[inputs | split(\" \") | {From: .[0], To: .[1]}]'"
    ],
    "utterance": "Convert lines containing two space-separated values into an array of objects with keys 'From' and 'To', where each object maps the first value to 'From' and the second to 'To'.",
    "expressions": [
      "jq -nR '[inputs | split(\" \") | {\"From\": .[0], \"To\": .[1]}]'",
      "jq -R -n '[inputs | split(\" \") | {From: .[0], To: .[1]}]'",
      "jq -R -s 'split(\"\\n\") | map(select(length>1) | split(\" \") | {From: .[0], To: .[1]})'"
    ],
    "data": [
      {
        "input": "foo bar\nwhat ever",
        "output": [
          {
            "From": "foo",
            "To": "bar"
          },
          {
            "From": "what",
            "To": "ever"
          }
        ]
      }
    ],
    "identifier": 41082241
  },
  {
    "context": [
      "I am trying to write a batch script to change the value of \"tags\" key for below 2 jsons named example1.json and example2.json.",
      "Expected Output is two jsons with same name but the tags value is now changed.",
      "Example1.json : \n\n input tags value - example1 (which is json file name)\n\n output tags value - tags1   (as per requirement)",
      "So if I understand correctly, you want to replace tags that have the file's name and replace it with a tag of your choosing.",
      "$ jq --arg newtag 'tag1' '(input_filename | sub(\"\\.json$\"; \"\")) as $oldtag\n    | .paths[][].tags |= map(if . == $oldtag then $newtag else . end)' example1.json",
      "$ jq --arg oldtag 'example1' --arg newtag 'tag1' \\\n    '.paths[][].tags |= map(if . == $oldtag then $newtag else . end)' example1.json",
      "$ jq --argjson tagmap '{\"example1\":\"tag1\",\"example2\":\"tag2\"}' \\\n    '.paths[][].tags |= map($tagmap[.] // .)' example1.json"
    ],
    "utterance": "Replace every occurrence of a tag in the tags arrays under all paths and HTTP methods when it matches a specific name (such as the input file's name) with a new value of your choosing.",
    "expressions": [
      "(input_filename | sub(\"\\.json$\"; \"\")) as $oldtag | .paths[][].tags |= map(if . == $oldtag then $newtag else . end)",
      ".paths[][].tags |= map(if . == $oldtag then $newtag else . end)",
      ".paths[][].tags |= map($tagmap[.] // .)"
    ],
    "data": [
      {
        "input": {
          "info": {
            "title": "My example swagger 1",
            "version": "1.0"
          },
          "paths": {
            "/v1/resource1": {
              "get": {
                "description": "This is the example1",
                "tags": [
                  "example1"
                ],
                "consumes": [
                  "*/*"
                ]
              }
            },
            "/v1/resource2": {
              "get": {
                "tags": [
                  "example1"
                ],
                "consumes": [
                  "*/*"
                ]
              }
            }
          }
        },
        "output": {
          "info": {
            "title": "My example swagger 1",
            "version": "1.0"
          },
          "paths": {
            "/v1/resource1": {
              "get": {
                "description": "This is the example1",
                "tags": [
                  "tag1"
                ],
                "consumes": [
                  "*/*"
                ]
              }
            },
            "/v1/resource2": {
              "get": {
                "tags": [
                  "tag1"
                ],
                "consumes": [
                  "*/*"
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 40814863
  },
  {
    "context": [
      "I want to find the list of keys whose array value have the entry `svc`",
      "the following filter yields the output as shown:",
      "to_entries[] | select( .value | index(\"svc\") ) | .key",
      "with_entries(select(any(.value[]; . == $key)))"
    ],
    "utterance": "List the keys whose array values contain the exact element 'svc'.",
    "expressions": [
      "to_entries[] | select(.value | index(\"svc\")) | .key",
      "with_entries(select(any(.value[]; . == \"svc\")))"
    ],
    "data": [
      {
        "input": {
          "ContentKey--4-0-47--Vovb1BQ": [
            "infra",
            "qa",
            "qa-ContentKey-4-0-47-Vovb1BQ",
            "internal-qa-Conten-WebServi-19E4PUWHRGD44-460820639.us-east-1.elb.amazonaws.com",
            "plan--default"
          ],
          "ContentKey--4-0-47--zjOkiQ": [
            "svc",
            "dev",
            "dev-ContentKey-4-0-47-zjOkiQ",
            "dev-Conte-WebServi-KXJXZBDY113W-2116785917.us-east-1.elb.amazonaws.com",
            "plan--default"
          ],
          "IdGenService--2001-4-22--CJUFaMQ": [
            "svc",
            "dev",
            "dev-IdGenService-2001-4-22-CJUFaMQ",
            "dev-IdGen-WebServi-R7RVXSYAV92W-304073075.us-east-1.elb.amazonaws.com"
          ],
          "IdGenService--2001-4-22--Uhf9CTQ": [
            "svc",
            "qa",
            "qa-IdGenService-2001-4-22-Uhf9CTQ",
            "internal-qa-IdGenS-WebServi-RT5BI5EEVZP3-665537643.us-east-1.elb.amazonaws.com"
          ]
        },
        "output": [
          "ContentKey--4-0-47--zjOkiQ",
          "IdGenService--2001-4-22--CJUFaMQ",
          "IdGenService--2001-4-22--Uhf9CTQ"
        ]
      }
    ],
    "identifier": 41111477
  },
  {
    "context": [
      "However I need to use the Message field as a payload for a JSON data structure. How do I quickly get a piece of JSON inserted so the final JSON looks like: https://s.natalian.org/2016-12-15/sns-event-stringified-message.json",
      "file.json to be inserted has the contents:\n\n    [\n      {\n        \"From\": \"foo\",\n        \"To\": \"bar\"\n      }\n    ]",
      "$ jq --argfile file file.json '.Records[0].Sns.Message = ($file | tojson)' input.json",
      "setall( \"Message\"; $file|tojson )"
    ],
    "utterance": "Replace the Message field in the data with the stringified contents of file.json, where file.json contains a JSON array of From/To pairs like [{\"From\": \"foo\", \"To\": \"bar\"}].",
    "expressions": [
      ".Records[0].Sns.Message = ($file | tojson)",
      "setall( \"Message\"; $file|tojson )"
    ],
    "data": [
      {
        "input": {
          "Records": [
            {
              "Sns": {
                "Message": "original"
              }
            }
          ]
        },
        "output": {
          "Records": [
            {
              "Sns": {
                "Message": "[{\"From\":\"foo\",\"To\":\"bar\"}]"
              }
            }
          ]
        }
      }
    ],
    "identifier": 41156118
  },
  {
    "context": [
      "I want to extract the names of all *innermost* nodes, i.e., the name of all nodes that do not have children.",
      "Is there a way to return only nodes that do not have children, no matter how deep they are nested?",
      "$ jq -r '.blockdevices[] | .. | objects | select(has(\"children\")|not)| .name' tmp.json",
      "It recursively outputs each value found in the JSON, filtering out first anything that is not an object, then any object that has a `children` key. Finally, you can select the `name` value from each remaining object."
    ],
    "utterance": "Extract the name keys of all nodes that do not have a children key, at any depth.",
    "expressions": [
      ".blockdevices[] | .. | objects | select(has(\"children\")|not) | .name"
    ],
    "data": [
      {
        "input": {
          "blockdevices": [
            {
              "name": "sda",
              "mountpoint": null,
              "children": [
                {
                  "name": "sda1",
                  "mountpoint": "/sda1/mountpoint"
                },
                {
                  "name": "sda2",
                  "mountpoint": null,
                  "children": [
                    {
                      "name": "sda2_mapper",
                      "mountpoint": "/sda2/mountpoint"
                    }
                  ]
                },
                {
                  "name": "sda3",
                  "mountpoint": null
                },
                {
                  "name": "sda4",
                  "mountpoint": null
                }
              ]
            },
            {
              "name": "sdb",
              "mountpoint": null,
              "children": [
                {
                  "name": "sdb1",
                  "mountpoint": "/sdb1/mountpoint"
                },
                {
                  "name": "sdb2",
                  "mountpoint": null
                }
              ]
            },
            {
              "name": "sdc",
              "mountpoint": null
            }
          ]
        },
        "output": [
          "sda1",
          "sda2_mapper",
          "sda3",
          "sda4",
          "sdb1",
          "sdb2",
          "sdc"
        ]
      }
    ],
    "identifier": 41150539
  },
  {
    "context": [
      "I'm looking for a filter to say \"return all objects where `show_id` does not equal `1641788`\"",
      "with_entries( select(.value.show_id != 1641788 ))",
      "del( .[] | select( .show_id == 1641788 ) )"
    ],
    "utterance": "Return all top-level objects excluding those whose show_id is 1641788.",
    "expressions": [
      "with_entries( select(.value.show_id != 1641788 ))",
      "del( .[] | select( .show_id == 1641788 ) )"
    ],
    "data": [
      {
        "input": {
          "10000703": {
            "show_id": 1641788
          },
          "10000838": {
            "show_id": 1517903
          },
          "10001325": {
            "show_id": 1641788
          }
        },
        "output": {
          "10000838": {
            "show_id": 1517903
          }
        }
      }
    ],
    "identifier": 41195915
  },
  {
    "context": [
      "Given a JSON file, empty out all 'paragraphs.result.msg' fields.",
      "To set the .result.msg values to \"\"\n    .paragraphs[].result.msg = \"\""
    ],
    "utterance": "Set every 'result.msg' field inside each element of the 'paragraphs' array to an empty string.",
    "expressions": [
      ".paragraphs[].result.msg = \"\""
    ],
    "data": [
      {
        "input": {
          "paragraphs": [
            {
              "result": {
                "msg": "msg1"
              }
            },
            {
              "result": {
                "msg": "msg2"
              }
            }
          ]
        },
        "output": {
          "paragraphs": [
            {
              "result": {
                "msg": ""
              }
            },
            {
              "result": {
                "msg": ""
              }
            }
          ]
        }
      }
    ],
    "identifier": 41229477
  },
  {
    "context": [
      "I want to keep the json as is but change the Timestamp to human readable date like \"2016-12-19T09:21:35Z\"",
      "I know I can do it using 'todate' jq feature but I lose all other data",
      "Use |= rather than just |"
    ],
    "utterance": "Convert the value of the Timestamp field in each object to a human-readable date format, while preserving all other fields.",
    "expressions": [
      ".SampledRequests[] |= (.Timestamp |= todate)"
    ],
    "data": [
      {
        "input": {
          "SampledRequests": [
            {
              "Action": "ALLOW",
              "Timestamp": 1482139256.274,
              "Request": {
                "Country": "US",
                "URI": "/version/moot/beta.json",
                "Headers": [
                  {
                    "Name": "Host",
                    "Value": "static.tiza.com"
                  }
                ],
                "ClientIP": "107.22.17.51",
                "Method": "GET",
                "HTTPVersion": "HTTP/1.1"
              },
              "Weight": 1
            }
          ]
        },
        "output": {
          "SampledRequests": [
            {
              "Action": "ALLOW",
              "Timestamp": "2016-12-19T09:20:56Z",
              "Request": {
                "Country": "US",
                "URI": "/version/moot/beta.json",
                "Headers": [
                  {
                    "Name": "Host",
                    "Value": "static.tiza.com"
                  }
                ],
                "ClientIP": "107.22.17.51",
                "Method": "GET",
                "HTTPVersion": "HTTP/1.1"
              },
              "Weight": 1
            }
          ]
        }
      }
    ],
    "identifier": 41222293
  },
  {
    "context": [
      "I want to know if a given filter succeeds in pulling data from a JSON data structure.",
      "If the filter does not pull data from the JSON data structure, I need to know this. I would prefer the filter to return a non-zero return code.",
      "You can use the `-e / --exit-status` flag from the [`jq Manual`](https://stedolan.github.io/jq/manual/), which says",
      ">Sets the exit status of jq to 0 if the last output values was neither false nor null, 1 if the last output value was either false or null, or 4 if no valid result was ever produced. ...",
      "The idea is use `jq -e \"$Filter\"` as a first-pass check. Then for the return code of 1, do a `jq \"path($Filter)\"` check. The latter will only succeed if, in fact, there is a path into the JSON data.",
      "Result=\"$(jq -e --arg Name \"$Name\" \"$Filter\" <<<$Input)\";",
      "case $Status in",
      "1) jq --arg Name \"$Name\" \"path($Filter)\" <<<$Input >/dev/null 2>&1",
      "\".[]|select(.user == $Name)|.value\""
    ],
    "utterance": "Determine if selecting the .value for a user by name actually retrieves a value (including false, null, or empty string) or fails for a name not present.",
    "expressions": [
      "jq -e --arg Name \"$Name\" '.[]|select(.user == $Name)|.value'",
      "jq --arg Name \"$Name\" 'path(.[]|select(.user == $Name)|.value)'"
    ],
    "data": [
      {
        "input": [
          {
            "user": "steve",
            "value": false
          },
          {
            "user": "tom",
            "value": true
          },
          {
            "user": "pat",
            "value": null
          },
          {
            "user": "jane",
            "value": ""
          }
        ],
        "output": [
          "steve -> false",
          "tom -> true",
          "pat -> null",
          "jane -> \"\"",
          "mary -> (indicate failure/exit code nonzero)"
        ]
      }
    ],
    "identifier": 41124355
  },
  {
    "context": [
      "1. How can I extract only fields common to both these ASG?",
      "2. How can I extract only fields unique to both these ASG?",
      "To find items common between two arrays, just perform a set intersection between the two.",
      "def intersect($a; $b): [($a | unique)[], ($b | unique)[]] | [group_by(.)[] | select(length > 1)[0]];",
      "intersect(.tag_aws_autoscaling_groupName_asg_test; .tag_aws_autoscaling_groupName_asg_unknown)",
      "To find items unique to an array, just perform the set difference.",
      "def difference($a; $b): ($a | unique) - ($b | unique);",
      "difference(.tag_aws_autoscaling_groupName_asg_test; .tag_aws_autoscaling_groupName_asg_unknown)",
      "def difference($a; $b): ($a | unique) - $b;",
      "def sdiff($a; $b): (($a-$b) + ($b-$a)) | unique;",
      "def intersect(x;y): ( (x|unique) + (y|unique) | sort) as $sorted | reduce range(1; $sorted|length) as $i ([]; if $sorted[$i] == $sorted[$i-1] then . + [$sorted[$i]] else . end) ;"
    ],
    "utterance": "Extract the elements that are common to both the arrays tag_aws_autoscaling_groupName_asg_test and tag_aws_autoscaling_groupName_asg_unknown, and the elements unique to each array.",
    "expressions": [
      "def intersect($a; $b): [($a | unique)[], ($b | unique)[]] | [group_by(.)[] | select(length > 1)[0]]; intersect(.tag_aws_autoscaling_groupName_asg_test; .tag_aws_autoscaling_groupName_asg_unknown)",
      "def difference($a; $b): ($a | unique) - ($b | unique); difference(.tag_aws_autoscaling_groupName_asg_test; .tag_aws_autoscaling_groupName_asg_unknown)",
      "def difference($a; $b): ($a | unique) - $b;",
      "def sdiff($a; $b): (($a-$b) + ($b-$a)) | unique;",
      "def intersect(x;y): ( (x|unique) + (y|unique) | sort) as $sorted | reduce range(1; $sorted|length) as $i ([]; if $sorted[$i] == $sorted[$i-1] then . + [$sorted[$i]] else . end) ;"
    ],
    "data": [
      {
        "input": {
          "tag_aws_autoscaling_groupName_asg_test": [
            "aa.b.bb.55",
            "1b.b.c.d"
          ],
          "tag_aws_autoscaling_groupName_asg_unknown": [
            "aa.b.bb.55",
            "1b.b.c.e"
          ]
        },
        "output": {
          "common": [
            "aa.b.bb.55"
          ],
          "unique_to_test": [
            "1b.b.c.d"
          ],
          "unique_to_unknown": [
            "1b.b.c.e"
          ]
        }
      }
    ],
    "identifier": 41185194
  },
  {
    "context": [
      "create empty FINAL array",
      "c. ***add this JSON array to FINAL array***",
      "CURL Response 1 (ex: $curl1):",
      "CURL Response 2 (ex : $curl2):",
      "NEEDED OUTPUT ($final):",
      "`jq` can deal with multiple input arrays. You can pipe the whole output of the loop to it:",
      "for service in \"$services\" ; do",
      "    curl \"$service/path\"",
      "done | jq -r '.[]|[.id,.startDate,.calls]|@csv'",
      "$ for service in \"$services\" ; do",
      "    curl \"$service/path\"",
      "  done | jq -sr 'add[] | [.[]] | @csv'"
    ],
    "utterance": "Combine the responses from multiple curl calls, each returning an array of objects, into a single array of objects.",
    "expressions": [
      "jq -s add",
      "jq -sr 'add[]'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "123",
              "startDate": "2016-12-09T00:00:00Z",
              "calls": 4
            },
            {
              "id": "456",
              "startDate": "2016-12-09T00:00:00Z",
              "calls": 22
            }
          ],
          [
            {
              "id": "789",
              "startDate": "2016-12-09T00:00:00Z",
              "calls": 8
            },
            {
              "id": "147",
              "startDate": "2016-12-09T00:00:00Z",
              "calls": 10
            }
          ]
        ],
        "output": [
          {
            "id": "123",
            "startDate": "2016-12-09T00:00:00Z",
            "calls": 4
          },
          {
            "id": "456",
            "startDate": "2016-12-09T00:00:00Z",
            "calls": 22
          },
          {
            "id": "789",
            "startDate": "2016-12-09T00:00:00Z",
            "calls": 8
          },
          {
            "id": "147",
            "startDate": "2016-12-09T00:00:00Z",
            "calls": 10
          }
        ]
      }
    ],
    "identifier": 41216894
  },
  {
    "context": [
      "The specific processing I want to do is to sort \"array1\" entries by a \"name\" field which is doable by:\n\n    jq '.array1 | sort_by(.name)' test.json\n\nbut I also want this output as \"array1\" as well as all the other data to be preserved.",
      "Whenever you use the assignment operators (`=`, `|=`, `+=`, etc.), the context of the expression is kept unchanged.  So as long as your top-level filter(s) are assignments, in the end, you'll get the rest of the data (with your changes applied).",
      "In this case, you're just sorting the `array1` array so you could just update the array.\n\n    .array1 |= sort_by(.name)"
    ],
    "utterance": "Sort the elements of the top-level key array1 by their name property while leaving the rest of the data unchanged.",
    "expressions": [
      ".array1 |= sort_by(.name)"
    ],
    "data": [
      {
        "input": {
          "field1": "value1",
          "array1": [
            {
              "name": "B",
              "otherdata": "Bstuff"
            },
            {
              "name": "A",
              "otherdata": "Astuff"
            }
          ],
          "array2": [
            "array2 stuff"
          ],
          "array3": [
            "array3 stuff"
          ]
        },
        "output": {
          "field1": "value1",
          "array1": [
            {
              "name": "A",
              "otherdata": "Astuff"
            },
            {
              "name": "B",
              "otherdata": "Bstuff"
            }
          ],
          "array2": [
            "array2 stuff"
          ],
          "array3": [
            "array3 stuff"
          ]
        }
      }
    ],
    "identifier": 41252971
  },
  {
    "context": [
      "How can I update all the name fields to \"something\", maintaining the rest of the JSON file the same?",
      "If it is acceptable to change the \"name\" field wherever it occurs, you could use `walk/1`:",
      "walk(if type == \"object\" and has(\"name\") then .name = \"something\" else . end)",
      "If you only want to modify the \"name\" field in the \"z\" context, then consider:",
      ".z |= with_entries(if .value.name? then .value.name = \"something\" else . end)",
      "Assuming every value within `z` has a name property, you could do this:",
      "$ jq --arg newname 'something' '.z[].name = $newname' input.json",
      "here's another way it could be achieved using a structure similar to the first approach, assuming we only want to update objects that already have a `name` property:",
      "$ jq --arg newname 'something' '(.z[] | select(has(\"name\")).name) = $newname' input.json"
    ],
    "utterance": "Update all fields named 'name' to 'something' wherever they occur in the data, preserving the rest of the structure.",
    "expressions": [
      "walk(if type == \"object\" and has(\"name\") then .name = \"something\" else . end)"
    ],
    "data": [
      {
        "input": {
          "u": "stuff",
          "x": [
            1,
            2,
            3
          ],
          "y": {
            "field": "value"
          },
          "z": {
            "zz": {
              "name": "change me",
              "more": "stuff"
            },
            "randomKey": {
              "name": "change me",
              "random": "more stuff"
            }
          }
        },
        "output": {
          "u": "stuff",
          "x": [
            1,
            2,
            3
          ],
          "y": {
            "field": "value"
          },
          "z": {
            "zz": {
              "name": "something",
              "more": "stuff"
            },
            "randomKey": {
              "name": "something",
              "random": "more stuff"
            }
          }
        }
      }
    ],
    "identifier": 41350839
  },
  {
    "context": [
      "I want to output the following:\r\n\r\n    \"hello\", 1, \"k1\", \"v1\"\r\n    \"hello\", 2, \"k2\", \"v2\"\r\n    \"hello\", 3, \"k3\", \"v3\"\r\n\r\nI am using jq to tranform this and the answer should also be with a jq transformation.",
      "How can I also get the index to show of the array element being parsed?",
      "You could convert the array to entries to access the index and the value.  Then you can build out the CSV rows.\r\n\r\n    $ jq -r '[.foo] + (.bar | to_entries[] | [.key+1,.value.key,.value.val]) | @csv' input.json\r\n    \"hello\",1,\"k1\",\"v1\"\r\n    \"hello\",2,\"k2\",\"v2\"\r\n    \"hello\",3,\"k3\",\"v3\"\r\n",
      "Assuming you have access to jq 1.5 and that the key/val keys are presented in that order:\r\n\r\n    jq -r '.foo as $foo \r\n      | foreach .bar[] as $i (0; .+1; [$foo, .] + [$i[]])\r\n      | @csv'\r\n\r\nwould produce:\r\n\r\n    \"hello\",1,\"k1\",\"v1\"\r\n    \"hello\",2,\"k2\",\"v2\"\r\n    \"hello\",3,\"k3\",\"v3\"\r\n"
    ],
    "utterance": "Output each element from 'bar' as a CSV line containing 'foo', the 1-based index, the element's key, and the element's val.",
    "expressions": [
      "[.foo] + (.bar | to_entries[] | [.key+1,.value.key,.value.val]) | @csv",
      ".foo as $foo | foreach .bar[] as $i (0; .+1; [$foo, .] + [$i[]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "foo": "hello",
          "bar": [
            {
              "key": "k1",
              "val": "v1"
            },
            {
              "key": "k2",
              "val": "v2"
            },
            {
              "key": "k3",
              "val": "v3"
            }
          ]
        },
        "output": [
          "\"hello\",1,\"k1\",\"v1\"",
          "\"hello\",2,\"k2\",\"v2\"",
          "\"hello\",3,\"k3\",\"v3\""
        ]
      }
    ],
    "identifier": 41233816
  },
  {
    "context": [
      "the filter\n\n    .users[]\n\nwill give you just the user data to load and the filter\n\n    .scroll_param\n\nwill return just the scroll parameter.",
      "you could simply use the `,` operator to return one value after another.  e.g.\n\n      .scroll_param\n    , .users[]",
      "If you use that filter along with the `-c` option jq will generate output like\n\n    \"24ba0fac-b8f9-46b2-944a-9bb523dcd1b1\"\n    {\"type\":\"user\",\"id\":\"581c13632f25960e6e3dc89a\",\"user_id\":\"ieo2e6dtsqhiyhtr\",...\n    {\"type\":\"user\",\"id\":\"581c22a19a1dc02c460541df\",\"user_id\":\"1o3helrdv58cxm7jf\",..."
    ],
    "utterance": "Output the scroll_param value followed by each user object, each as a compact newline-delimited entry, with no extra text.",
    "expressions": [
      ".scroll_param, .users[]"
    ],
    "data": [
      {
        "input": {
          "type": "user.list",
          "users": [
            {
              "type": "user",
              "id": "581c13632f25960e6e3dc89a",
              "user_id": "ieo2e6dtsqhiyhtr",
              "anonymous": false,
              "email": "test@gmail.com",
              "name": "Joe Martinez",
              "pseudonym": null,
              "avatar": {
                "type": "avatar",
                "image_url": null
              },
              "app_id": "b5vkxvop",
              "companies": {
                "type": "company.list",
                "companies": []
              },
              "location_data": {
                "type": "location_data",
                "city_name": "Houston",
                "continent_code": "NA",
                "country_name": "United States",
                "latitude": 29.7633,
                "longitude": -95.3633,
                "postal_code": "77002",
                "region_name": "Texas",
                "timezone": "America/Chicago",
                "country_code": "USA"
              },
              "last_request_at": 1478235114,
              "last_seen_ip": "66.87.120.30",
              "created_at": 1478234979,
              "remote_created_at": 1478234944,
              "signed_up_at": 1478234944,
              "updated_at": 1478235145,
              "session_count": 1,
              "social_profiles": {
                "type": "social_profile.list",
                "social_profiles": []
              },
              "unsubscribed_from_emails": false,
              "user_agent_data": "Mozilla/5.0 (Linux; Android 6.0.1; SM-G920P Build/MMB29K) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.68 Mobile Safari/537.36",
              "tags": {
                "type": "tag.list",
                "tags": []
              },
              "segments": {
                "type": "segment.list",
                "segments": [
                  {
                    "type": "segment",
                    "id": "57d2ea275bfcebabd516d963"
                  },
                  {
                    "type": "segment",
                    "id": "57d2ea265bfcebabd516d962"
                  }
                ]
              },
              "custom_attributes": {
                "claimCount": "1",
                "memberType": "claimant"
              }
            },
            {
              "type": "user",
              "id": "581c22a19a1dc02c460541df",
              "user_id": "1o3helrdv58cxm7jf",
              "anonymous": false,
              "email": "test@mail.com",
              "name": "Joe Coleman",
              "pseudonym": null,
              "avatar": {
                "type": "avatar",
                "image_url": null
              },
              "app_id": "b5vkxvop",
              "companies": {
                "type": "company.list",
                "companies": []
              },
              "location_data": {
                "type": "location_data",
                "city_name": "San Jose",
                "continent_code": "NA",
                "country_name": "United States",
                "latitude": 37.3394,
                "longitude": -121.895,
                "postal_code": "95141",
                "region_name": "California",
                "timezone": "America/Los_Angeles",
                "country_code": "USA"
              },
              "last_request_at": 1478239113,
              "last_seen_ip": "216.151.183.47",
              "created_at": 1478238881,
              "remote_created_at": 1478238744,
              "signed_up_at": 1478238744,
              "updated_at": 1478239113,
              "session_count": 1,
              "social_profiles": {
                "type": "social_profile.list",
                "social_profiles": []
              },
              "unsubscribed_from_emails": false,
              "user_agent_data": "Mozilla/5.0 (Windows NT 6.3; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0",
              "tags": {
                "type": "tag.list",
                "tags": []
              },
              "segments": {
                "type": "segment.list",
                "segments": [
                  {
                    "type": "segment",
                    "id": "57d2ea275bfcebabd516d963"
                  },
                  {
                    "type": "segment",
                    "id": "57d2ea265bfcebabd516d962"
                  }
                ]
              },
              "custom_attributes": {
                "claimCount": "2",
                "memberType": "claimant"
              }
            }
          ],
          "scroll_param": "24ba0fac-b8f9-46b2-944a-9bb523dcd1b1"
        },
        "output": [
          "24ba0fac-b8f9-46b2-944a-9bb523dcd1b1",
          {
            "type": "user",
            "id": "581c13632f25960e6e3dc89a",
            "user_id": "ieo2e6dtsqhiyhtr",
            "anonymous": false,
            "email": "test@gmail.com",
            "name": "Joe Martinez",
            "pseudonym": null,
            "avatar": {
              "type": "avatar",
              "image_url": null
            },
            "app_id": "b5vkxvop",
            "companies": {
              "type": "company.list",
              "companies": []
            },
            "location_data": {
              "type": "location_data",
              "city_name": "Houston",
              "continent_code": "NA",
              "country_name": "United States",
              "latitude": 29.7633,
              "longitude": -95.3633,
              "postal_code": "77002",
              "region_name": "Texas",
              "timezone": "America/Chicago",
              "country_code": "USA"
            },
            "last_request_at": 1478235114,
            "last_seen_ip": "66.87.120.30",
            "created_at": 1478234979,
            "remote_created_at": 1478234944,
            "signed_up_at": 1478234944,
            "updated_at": 1478235145,
            "session_count": 1,
            "social_profiles": {
              "type": "social_profile.list",
              "social_profiles": []
            },
            "unsubscribed_from_emails": false,
            "user_agent_data": "Mozilla/5.0 (Linux; Android 6.0.1; SM-G920P Build/MMB29K) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.68 Mobile Safari/537.36",
            "tags": {
              "type": "tag.list",
              "tags": []
            },
            "segments": {
              "type": "segment.list",
              "segments": [
                {
                  "type": "segment",
                  "id": "57d2ea275bfcebabd516d963"
                },
                {
                  "type": "segment",
                  "id": "57d2ea265bfcebabd516d962"
                }
              ]
            },
            "custom_attributes": {
              "claimCount": "1",
              "memberType": "claimant"
            }
          },
          {
            "type": "user",
            "id": "581c22a19a1dc02c460541df",
            "user_id": "1o3helrdv58cxm7jf",
            "anonymous": false,
            "email": "test@mail.com",
            "name": "Joe Coleman",
            "pseudonym": null,
            "avatar": {
              "type": "avatar",
              "image_url": null
            },
            "app_id": "b5vkxvop",
            "companies": {
              "type": "company.list",
              "companies": []
            },
            "location_data": {
              "type": "location_data",
              "city_name": "San Jose",
              "continent_code": "NA",
              "country_name": "United States",
              "latitude": 37.3394,
              "longitude": -121.895,
              "postal_code": "95141",
              "region_name": "California",
              "timezone": "America/Los_Angeles",
              "country_code": "USA"
            },
            "last_request_at": 1478239113,
            "last_seen_ip": "216.151.183.47",
            "created_at": 1478238881,
            "remote_created_at": 1478238744,
            "signed_up_at": 1478238744,
            "updated_at": 1478239113,
            "session_count": 1,
            "social_profiles": {
              "type": "social_profile.list",
              "social_profiles": []
            },
            "unsubscribed_from_emails": false,
            "user_agent_data": "Mozilla/5.0 (Windows NT 6.3; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0",
            "tags": {
              "type": "tag.list",
              "tags": []
            },
            "segments": {
              "type": "segment.list",
              "segments": [
                {
                  "type": "segment",
                  "id": "57d2ea275bfcebabd516d963"
                },
                {
                  "type": "segment",
                  "id": "57d2ea265bfcebabd516d962"
                }
              ]
            },
            "custom_attributes": {
              "claimCount": "2",
              "memberType": "claimant"
            }
          }
        ]
      }
    ],
    "identifier": 40661704
  },
  {
    "context": [
      "I have this output:\r\n\r\n    [Info] Searching artifacts...\r\n    [Info] Found 3 artifacts.\r\n    [\r\n      {\r\n        \"path\": \"foo/01_Develop/01_CI/HPCC-Package-47.zip\"\r\n      },\r\n      {\r\n        \"path\": \"foo/01_Develop/01_CI/HPCC-Package-48.zip\"\r\n      },\r\n      {\r\n        \"path\": \"foo/01_Develop/01_CI/HPCC-Package-72.zip\"\r\n      }\r\n    ]",
      "I want to get the last path in json array with this command as suggested [here][1]:\r\n\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip | jq .[-1].path",
      "Your Artifactory output isn't pure json... you need to remove those non-json parts.  Assuming we will only need to skip the first two lines, we could just use tail to skip em.\r\n\r\n    /usr/bin/jfrog rt s foo/01_Develop/01_CI/HPCC-Package-*.zip | tail -n +3 | jq '.[-1].path'",
      "For the record, here's a jq-only solution that assumes there are exactly two lines of non-JSON prolog: \r\n\r\n    ... | jq -n -R -r '[inputs][2:] | join(\"\") | fromjson[-1]'"
    ],
    "utterance": "Extract the path field of the last element from an array in the tool's output, ignoring the initial non-JSON lines.",
    "expressions": [
      "tail -n +3 | jq '.[-1].path'",
      "jq -n -R -r '[inputs][2:] | join(\"\") | fromjson[-1].path'"
    ],
    "data": [
      {
        "input": "[Info] Searching artifacts...\n[Info] Found 3 artifacts.\n[\n  {\n    \"path\": \"foo/01_Develop/01_CI/HPCC-Package-47.zip\"\n  },\n  {\n    \"path\": \"foo/01_Develop/01_CI/HPCC-Package-48.zip\"\n  },\n  {\n    \"path\": \"foo/01_Develop/01_CI/HPCC-Package-72.zip\"\n  }\n]\n",
        "output": "\"foo/01_Develop/01_CI/HPCC-Package-72.zip\""
      }
    ],
    "identifier": 41366699
  },
  {
    "context": [
      "Is there not some way of combining this in returning pairs? (what I am really trying to do is find the key name of the first root level array, if any).",
      "jq 'first(path(.[] | select(type == \"array\"))[0])' < data.json",
      "So the result of the command is key name of the first top-level array item.",
      "Sample Output",
      "\"dataset\""
    ],
    "utterance": "Find the key name of the first top-level property whose value is an array.",
    "expressions": [
      "first(path(.[] | select(type == \"array\"))[0])"
    ],
    "data": [
      {
        "input": {
          "@context": "some string",
          "@id": "some string",
          "@type": "some string",
          "conformsTo": "some string",
          "describedBy": "some string",
          "dataset": []
        },
        "output": "dataset"
      }
    ],
    "identifier": 41301988
  },
  {
    "context": [
      "But for some reason when I run this in the command line:\n\n    curl https://api.example.com/users/scroll -u ... | jq -c '.users[]'\n\n[It spits out a result that is totally not formmated how it is suppose to come out, despite using the exact same filter][4]:\n\n    {\"custom_attributes\":...,\"segments\":..., ...}\n\nWhich as you can tell, is nothing like how it turns out in the jqplayground feature.",
      "jq 1.3 does not always respect the ordering of keys within JSON objects.  Assuming you are using jq 1.3 (or earlier), the solution would be to upgrade to a later version (1.4, 1.5, or the \"master\" version). "
    ],
    "utterance": "Output objects with properties in the original key order when extracting each user from the users array.",
    "expressions": [
      ".users[]"
    ],
    "data": [
      {
        "input": {
          "type": "user.list",
          "users": [
            {
              "type": "user",
              "id": "57db1b1b9jdjd84f99b977785ba",
              "user_id": "janwjf3sqdditwn7c7",
              "anonymous": false,
              "email": "test@diversifiedventures.net",
              "phone": null,
              "name": "Joe Smith",
              "pseudonym": null,
              "avatar": {
                "type": "avatar",
                "image_url": null
              },
              "app_id": "b5vkddxvop",
              "companies": {
                "type": "company.list",
                "companies": []
              },
              "location_data": {
                "type": "location_data",
                "city_name": "Murfreesboro",
                "continent_code": "NA",
                "country_name": "United States",
                "latitude": 35.8896,
                "longitude": -86.3166,
                "postal_code": "37130",
                "region_name": "Tennessee",
                "timezone": "America/Chicago",
                "country_code": "USA"
              },
              "last_request_at": 1478624249,
              "last_seen_ip": "69.139.122.123",
              "created_at": 1473977115,
              "remote_created_at": 1466313380,
              "signed_up_at": 1466313380,
              "updated_at": 1480970142,
              "session_count": 1,
              "social_profiles": {
                "type": "social_profile.list",
                "social_profiles": []
              },
              "unsubscribed_from_emails": false,
              "user_agent_data": "Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko",
              "tags": {
                "type": "tag.list",
                "tags": [
                  {
                    "type": "tag",
                    "id": "587061",
                    "name": "Mixpanel Import - 2016-09-15 21:25:08 UTC"
                  }
                ]
              },
              "segments": {
                "type": "segment.list",
                "segments": [
                  {
                    "type": "segment",
                    "id": "581a048c4ad88d6b458198d7"
                  },
                  {
                    "type": "segment",
                    "id": "5845cd57c91b1fe3e440032b"
                  },
                  {
                    "type": "segment",
                    "id": "5845cab9d951b43e7d33d2f7"
                  }
                ]
              },
              "custom_attributes": {
                "mixpanel_id": "1556710d919339-0beb72f2966b408-69581467-cff8c-1556710d91a54b",
                "claimCount": "2",
                "memberType": "claimant"
              }
            }
          ],
          "scroll_param": "56386a4d-743b-470a-ae9f-848b991e0ccc"
        },
        "output": {
          "type": "user",
          "id": "57db1b1b9jdjd84f99b977785ba",
          "user_id": "janwjf3sqdditwn7c7",
          "anonymous": false,
          "email": "test@diversifiedventures.net",
          "phone": null,
          "name": "Joe Smith",
          "pseudonym": null,
          "avatar": {
            "type": "avatar",
            "image_url": null
          },
          "app_id": "b5vkddxvop",
          "companies": {
            "type": "company.list",
            "companies": []
          },
          "location_data": {
            "type": "location_data",
            "city_name": "Murfreesboro",
            "continent_code": "NA",
            "country_name": "United States",
            "latitude": 35.8896,
            "longitude": -86.3166,
            "postal_code": "37130",
            "region_name": "Tennessee",
            "timezone": "America/Chicago",
            "country_code": "USA"
          },
          "last_request_at": 1478624249,
          "last_seen_ip": "69.139.122.123",
          "created_at": 1473977115,
          "remote_created_at": 1466313380,
          "signed_up_at": 1466313380,
          "updated_at": 1480970142,
          "session_count": 1,
          "social_profiles": {
            "type": "social_profile.list",
            "social_profiles": []
          },
          "unsubscribed_from_emails": false,
          "user_agent_data": "Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko",
          "tags": {
            "type": "tag.list",
            "tags": [
              {
                "type": "tag",
                "id": "587061",
                "name": "Mixpanel Import - 2016-09-15 21:25:08 UTC"
              }
            ]
          },
          "segments": {
            "type": "segment.list",
            "segments": [
              {
                "type": "segment",
                "id": "581a048c4ad88d6b458198d7"
              },
              {
                "type": "segment",
                "id": "5845cd57c91b1fe3e440032b"
              },
              {
                "type": "segment",
                "id": "5845cab9d951b43e7d33d2f7"
              }
            ]
          },
          "custom_attributes": {
            "mixpanel_id": "1556710d919339-0beb72f2966b408-69581467-cff8c-1556710d91a54b",
            "claimCount": "2",
            "memberType": "claimant"
          }
        }
      }
    ],
    "identifier": 41051322
  },
  {
    "context": [
      "csvOutput=`echo $output | jq --raw-output '.result .items[]|[.name,.key,.created,.updated]|@csv'`",
      "echo $csvOutput >> out.csv",
      "echo \"$csvOutput\" >> out.csv",
      "The double quotes will preserve newlines, see [this post][1]"
    ],
    "utterance": "Extract the name, key, created, and updated fields from each item in result.items and output as CSV records.",
    "expressions": [
      ".result .items[] | [.name, .key, .created, .updated] | @csv"
    ],
    "data": [
      {
        "input": {
          "result": {
            "total_items": 22,
            "total_pages": 1,
            "items_per_page": 1000,
            "current_page": 1,
            "items": [
              {
                "key": "1",
                "name": "Name 1",
                "created": "2016-12-20T08:51:13Z",
                "updated": "2016-12-20T09:29:08Z"
              },
              {
                "key": "2",
                "name": "Name 2",
                "created": "2016-12-20T08:51:13Z",
                "updated": "2016-12-20T09:29:08Z"
              },
              {
                "key": "3",
                "name": "Name 3",
                "created": "2016-12-20T08:51:13Z",
                "updated": "2016-12-20T09:29:08Z"
              }
            ]
          },
          "id": 1
        },
        "output": [
          "\"Name 1\",\"1\",\"2016-12-20T08:51:13Z\",\"2016-12-20T09:29:08Z\"",
          "\"Name 2\",\"2\",\"2016-12-20T08:51:13Z\",\"2016-12-20T09:29:08Z\"",
          "\"Name 3\",\"3\",\"2016-12-20T08:51:13Z\",\"2016-12-20T09:29:08Z\""
        ]
      }
    ],
    "identifier": 41345239
  },
  {
    "context": [
      "I want to update `hbase.hregion.max.filesize`",
      "Manage to do it \r\n\r\n    jq '.items[0].properties.\"hfile.block.cache.size\"=\"0.2\"' initial.json > 1.json",
      "The original question asks how to alter more than one of the \"properties\".  The key to doing so without being repetitive is `|=`.  Here's an illustration:",
      ".items[0].properties |=\n  ( .[\"hfile.block.cache.size\"] = \"newvalue1\"\n  | .[\"hbase.hregion.max.filesize\"] = \"newvalue2\" )"
    ],
    "utterance": "Update both the 'hfile.block.cache.size' and 'hbase.hregion.max.filesize' properties to new values under items[0].properties.",
    "expressions": [
      ".items[0].properties |= ( .[\"hfile.block.cache.size\"] = \"newvalue1\" | .[\"hbase.hregion.max.filesize\"] = \"newvalue2\" )"
    ],
    "data": [
      {
        "input": {
          "href": "http://localhost:8080/api/v1/clusters/ambarihbase/configurations?type=hbase-site&tag=TOPOLOGY_RESOLVED",
          "items": [
            {
              "href": "http://localhost:8080/api/v1/clusters/ambarihbase/configurations?type=hbase-site&tag=TOPOLOGY_RESOLVED",
              "tag": "TOPOLOGY_RESOLVED",
              "type": "hbase-site",
              "version": 2,
              "Config": {
                "cluster_name": "ambarihbase",
                "stack_id": "HDP-2.5"
              },
              "properties": {
                "hfile.block.cache.size": "0.40",
                "hbase.hregion.max.filesize": "3221225472",
                "other.key": "othervalue"
              }
            }
          ]
        },
        "output": {
          "href": "http://localhost:8080/api/v1/clusters/ambarihbase/configurations?type=hbase-site&tag=TOPOLOGY_RESOLVED",
          "items": [
            {
              "href": "http://localhost:8080/api/v1/clusters/ambarihbase/configurations?type=hbase-site&tag=TOPOLOGY_RESOLVED",
              "tag": "TOPOLOGY_RESOLVED",
              "type": "hbase-site",
              "version": 2,
              "Config": {
                "cluster_name": "ambarihbase",
                "stack_id": "HDP-2.5"
              },
              "properties": {
                "hfile.block.cache.size": "newvalue1",
                "hbase.hregion.max.filesize": "newvalue2",
                "other.key": "othervalue"
              }
            }
          ]
        }
      }
    ],
    "identifier": 41166330
  }
]